diff --git a/components/all-data/all-data.vue b/components/all-data/all-data.vue index 7984bef..07b6a17 100644 --- a/components/all-data/all-data.vue +++ b/components/all-data/all-data.vue @@ -237,7 +237,7 @@ diff --git a/manifest.json b/manifest.json index 78d8143..578b5ab 100644 --- a/manifest.json +++ b/manifest.json @@ -126,7 +126,7 @@ "disableHostCheck" : true, // 开启可以用自己的域名 "proxy" : { "/watch" : { - "target" : "https://test.sc2.agrimedia.cn", + "target" : "https://ai.agrimedia.cn", "changeOrigin" : true, "secure" : false } diff --git a/unpackage/dist/dev/app-plus/app-service.js b/unpackage/dist/dev/app-plus/app-service.js index 1cd5d5a..5cd2703 100644 --- a/unpackage/dist/dev/app-plus/app-service.js +++ b/unpackage/dist/dev/app-plus/app-service.js @@ -970,7 +970,7 @@ var render = function () { "view", [ _c("tm-nav-bar", { - attrs: { "left-icon": "arrow-left", title: "睡眠", _i: 1 }, + attrs: { "left-icon": "arrow-left", title: "睡眠", rbgs: false, _i: 1 }, on: { clickLeft: _vm.back }, }), _c( @@ -2831,7 +2831,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _App /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _typeof = __webpack_require__(/*! @babel/runtime/helpers/typeof */ 4);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 48));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 50));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\nvar _vuex = __webpack_require__(/*! vuex */ 65);\nvar echarts = _interopRequireWildcard(__webpack_require__(/*! @/uni_modules/lime-echart/static/echarts.min */ 67));\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar _default = {\n name: 'sleep-info',\n data: function data() {\n return {\n sleepData: {\n shen: 0,\n qian: 0,\n kuai: 0\n },\n isOption: false,\n isInit: false,\n exitSleepTime: [],\n fallAsleepTime: [],\n option: {\n tooltip: {\n show: false\n },\n legend: {\n top: '5%',\n left: 'center'\n },\n series: [{\n data: [],\n type: 'pie',\n radius: ['70%', '90%'],\n avoidLabelOverlap: false,\n labelLine: {\n show: false\n }\n }]\n },\n cavasConfig: {\n canvasWidth: 250,\n canvasHeight: 250,\n lineWidth: 20,\n radius: 68,\n // 内圆的半径\n startAngle: -90,\n // 起始角度,-90度,即垂直方向的3点钟位置\n bigRadius: 90,\n // 外圆的半径\n cxt: null,\n colorBg: '#f7c1f5',\n bigColorBg: '#d1ccf4',\n color: '#e933dd',\n bigColor: '#6452da',\n bigAngle: 0,\n angle: 0,\n startSmallAngle: 0,\n bigStartAngle: 0,\n stop: 0,\n bigStop: 0,\n maxTime: 480\n },\n sleepList: [],\n time: new Date().toISOString().substring(0, 10),\n sleep: {\n shen: '0 分',\n qian: '0 分'\n }\n };\n },\n watch: {\n isInit: function isInit(newVal, oldVal) {\n if (this.isOption == true) {\n this.doDrawPie();\n }\n },\n isOption: function isOption(newVal, oldVal) {\n if (this.isInit == true) {\n this.doDrawPie();\n }\n }\n },\n mounted: function mounted() {\n this.getDataList();\n this.cavasConfig.ctx = uni.createCanvasContext('circleCanvas', this);\n this.drawCircle('bottom', 360, this.cavasConfig.bigRadius, this.cavasConfig.bigColorBg);\n this.drawCircle('bottom', 360, this.cavasConfig.radius, this.cavasConfig.colorBg);\n },\n computed: _objectSpread({}, (0, _vuex.mapGetters)({\n getActiceDevice: \"api/getActiceDevice\"\n })),\n methods: {\n init: function init() {\n this.isInit = true;\n __f__(\"log\", 'iiiiiiiiiiiiint', \" at components/sleep-info/sleep-info.vue:248\");\n },\n doDrawPie: function doDrawPie() {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var chart;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return _this.$refs.chartRef.init(echarts);\n case 2:\n chart = _context.sent;\n chart.setOption(_this.option);\n case 4:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }))();\n },\n countOccurrences: function countOccurrences(array, value) {\n return array.reduce(function (count, current) {\n return current === value ? count + 1 : count;\n }, 0);\n },\n back: function back() {\n this.$emit('back', 1);\n },\n getDataList: function getDataList() {\n var _this2 = this;\n var type = 'SleepDatas';\n var res = this.$store.dispatch('api/getDeviceListDays', {\n type: type,\n // type: (this.type),\n device_real_time: this.time,\n device_id: this.getActiceDevice.device_id\n }).then(function (res) {\n if (res.data.length > 0) {\n _this2.sleep.shen = _this2.min2Hour(res.data[0].data_msg[0].sleepTotalTime);\n _this2.sleep.qian = _this2.min2Hour(res.data[0].data_msg[0].deepSleepTime);\n _this2.cavasConfig.angle = _this2.getAngle(res.data[0].data_msg[0].deepSleepTime);\n _this2.cavasConfig.bigAngle = _this2.getAngle(res.data[0].data_msg[0].sleepTotalTime);\n _this2.sleepList = res.data[0].data_msg[0].sleepCurve;\n _this2.option.series[0].data = [{\n value: _this2.countOccurrences(_this2.sleepList, 0),\n itemStyle: {\n color: '#e933dd'\n }\n }, {\n value: _this2.countOccurrences(_this2.sleepList, 1),\n itemStyle: {\n color: '#6452da'\n }\n }, {\n value: _this2.countOccurrences(_this2.sleepList, 2),\n itemStyle: {\n color: '#4faffc'\n }\n }];\n var len = _this2.sleepList.length;\n _this2.sleepData.shen = _this2.getPercent(_this2.sleepList, 0);\n _this2.sleepData.qian = _this2.getPercent(_this2.sleepList, 1);\n _this2.sleepData.kuai = _this2.getPercent(_this2.sleepList, 2);\n _this2.exitSleepTime = res.data[0].data_msg[0].exitSleepTime.split('-');\n _this2.fallAsleepTime = res.data[0].data_msg[0].fallAsleepTime.split('-');\n _this2.isOption = true;\n }\n _this2.doAnimation(0);\n _this2.doAnimation(1);\n });\n },\n getPercent: function getPercent(data, find) {\n var len = data.length;\n return (this.countOccurrences(data, find) / len * 100).toFixed(1);\n },\n getAngle: function getAngle(min) {\n return min / this.cavasConfig.maxTime * 360;\n },\n min2Hour: function min2Hour(min) {\n var hour = Math.floor(min / 60);\n var minute = min % 60;\n return hour ? hour + ' 小时 ' + minute + ' 分' : minute + ' 分';\n },\n doAnimation: function doAnimation(type) {\n var _this3 = this;\n if (type == 0) {\n if (this.cavasConfig.bigStop === 1) {\n return;\n }\n if (this.cavasConfig.bigStartAngle >= this.cavasConfig.bigAngle) {\n this.cavasConfig.bigStartAngle = this.cavasConfig.bigAngle;\n this.cavasConfig.bigStop = 1;\n } else {\n this.cavasConfig.bigStartAngle += this.cavasConfig.bigAngle / 50;\n }\n this.drawCircle('round', this.cavasConfig.bigStartAngle, this.cavasConfig.bigRadius, this.cavasConfig.bigColor);\n } else {\n if (this.cavasConfig.stop == 1) {\n return;\n }\n if (this.cavasConfig.startSmallAngle >= this.cavasConfig.angle) {\n this.cavasConfig.startSmallAngle = this.cavasConfig.angle;\n this.cavasConfig.stop = 1;\n } else {\n this.cavasConfig.startSmallAngle += this.cavasConfig.angle / 50;\n }\n this.drawCircle('round', this.cavasConfig.startSmallAngle, this.cavasConfig.radius, this.cavasConfig.color);\n }\n // window.requestAnimationFrame(() => {\n setTimeout(function () {\n _this3.doAnimation(type);\n }, 17);\n\n // })\n },\n // lineCap线条类型 edangle绘制角度 radius 直径 color 线条颜色\n drawCircle: function drawCircle(lineCap, edangle, radius, color) {\n this.cavasConfig.ctx.save();\n var cx = this.cavasConfig.canvasWidth / 2;\n var cy = this.cavasConfig.canvasHeight / 2;\n this.cavasConfig.ctx.translate(cx, cy);\n this.cavasConfig.ctx.scale(1, 1);\n this.cavasConfig.ctx.lineCap = lineCap;\n var start = this.cavasConfig.startAngle * Math.PI / 180;\n var end = (edangle + this.cavasConfig.startAngle) * Math.PI / 180;\n this.cavasConfig.ctx.beginPath();\n this.cavasConfig.ctx.arc(0, 0, radius, start, end);\n this.cavasConfig.ctx.lineWidth = this.cavasConfig.lineWidth; // 设置线宽\n this.cavasConfig.ctx.strokeStyle = color; // 设置绘制样式为蓝色\n this.cavasConfig.ctx.stroke(); // 绘制路径\n this.cavasConfig.ctx.closePath();\n this.cavasConfig.ctx.restore();\n this.cavasConfig.ctx.draw(true);\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/sleep-info/sleep-info.vue"],"names":["name","data","sleepData","shen","qian","kuai","isOption","isInit","exitSleepTime","fallAsleepTime","option","tooltip","show","legend","top","left","series","type","radius","avoidLabelOverlap","labelLine","cavasConfig","canvasWidth","canvasHeight","lineWidth","startAngle","bigRadius","cxt","colorBg","bigColorBg","color","bigColor","bigAngle","angle","startSmallAngle","bigStartAngle","stop","bigStop","maxTime","sleepList","time","sleep","watch","mounted","computed","getActiceDevice","methods","init","doDrawPie","chart","countOccurrences","back","getDataList","device_real_time","device_id","value","itemStyle","getPercent","getAngle","min2Hour","doAnimation","setTimeout","drawCircle"],"mappings":";;;;;;;;;;;AA4JA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA,eACA;EACAA;EACAC;IACA;MACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MACAC;QACAC;UACAC;QACA;QACAC;UACAC;UACAC;QACA;QACAC,SACA;UACAf;UACAgB;UACAC;UACAC;UACAC;YACAR;UACA;QACA;MAEA;MACAS;QACAC;QACAC;QACAC;QACAN;QAAA;QACAO;QAAA;QACAC;QAAA;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;QACAtC;QACAC;MACA;IACA;EACA;EACAsC;IACAnC;MACA;QACA;MACA;IACA;IACAD;MACA;QACA;MACA;IACA;EACA;EACAqC;IACA;IAEA;IACA;IACA;EAEA;EACAC,4BACA;IACAC;EACA,GACA;EACAC;IACAC;MACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBAAAC;gBACAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACAC;MACA;QACA;MACA;IACA;IAEAC;MACA;IACA;IAEAC;MAAA;MACA;MACA;QACAnC;QACA;QACAoC;QACAC;MACA;QAEA;UACA;UACA;UACA;UACA;UACA;UACA,gCACA;YACAC;YACAC;cACA1B;YACA;UACA,GACA;YACAyB;YACAC;cACA1B;YACA;UACA,GACA;YACAyB;YACAC;cACA1B;YACA;UACA,EACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;QACA;QACA;QACA;MACA;IAGA;IACA2B;MACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MAAA;MACA;QACA;UACA;QACA;QACA;UACA;UACA;QACA;UACA;QACA;QACA;MACA;QACA;UACA;QACA;QACA;UACA;UACA;QACA;UACA;QACA;QACA;MACA;MACA;MACAC;QACA;MACA;;MAEA;IACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"64.js","sourcesContent":["<template>\n\t<view>\n\t\t<tm-nav-bar left-icon=\"arrow-left\" title=\"睡眠\" @clickLeft=\"back\" />\n\t\t<view class=\"flx jcsb ac\" style=\"height: 40rpx;background-color: #fff;padding: 20rpx;\">\n\t\t\t<view class=\"\" style=\"font-size: 40rpx;font-weight: bold;\">\n\t\t\t\t\n\t\t\t</view>\n\t\t\t<view class=\"\" style=\"color: #b8b8b8;font-size: 24rpx;\">\n\t\t\t\t{{time}}\n\t\t\t</view>\n\t\t</view>\n\t\t\n\t\t<view class=\"flx\">\n\t\t\t<view class=\"w-5\">\n\t\t\t\t<view class=\"canvas_box\">\n\t\t\t\t\t<canvas canvas-id=\"circleCanvas\" style=\"width: 250px; height: 250px;margin: 0  auto;\"></canvas>\n\t\t\t\t\t<view class=\"\" style=\"height: 40rpx;\"></view>\n\t\t\t\t\t<view class=\"flx flx_sb\">\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<!-- color:'#e933dd',\n\t\t\t\t\t\t\tbigColor:'#6452da', -->\n\t\t\t\t\t\t\t<view class=\"circle\" style=\"background-color:#6452da ;\" >\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"sleep_info\">\n\t\t\t\t\t\t\t\t<view class=\"info_title\">\n\t\t\t\t\t\t\t\t\t睡眠时长\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"info_val\">\n\t\t\t\t\t\t\t\t\t{{sleep.shen}}\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"sleep_info\">\n\t\t\t\t\t\t\t\t<view class=\"info_title\" style=\"text-align: right;\">\n\t\t\t\t\t\t\t\t\t深度睡眠\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"info_val\">\n\t\t\t\t\t\t\t\t\t{{sleep.qian}}\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"circle\" style=\"background-color:#e933dd ;\">\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view class=\"w-5\">\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;margin-top: 40rpx\t;\">\n\t\t\t\t\t<view class=\"flx flx_sb title_box\">\n\t\t\t\t\t\t<view class=\"title\">\n\t\t\t\t\t\t\t{{sleep.shen}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t\t<sleep-list-data :canvas-id=\"'sleep-canvas-id'\" :dataList=\"sleepList\"></sleep-list-data>\n\t\t\t\t\t<view class=\"flx flx_sb flx_ac\" style=\"margin-top: 20rpx;\">\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t<image src=\"../../static/icon/sleep.png\" style=\"width: 30rpx;margin-right: 5rpx;\" mode=\"widthFix\"></image>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-if=\"fallAsleepTime.length > 0\">\n\t\t\t\t\t\t\t\t{{ fallAsleepTime[2] }}:{{ fallAsleepTime[3] }} , {{ fallAsleepTime[0] }}/{{ fallAsleepTime[1] }}\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-else>\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"small-title\"  v-if=\"exitSleepTime.length > 0\">\n\t\t\t\t\t\t\t\t{{ exitSleepTime[2] }}:{{ exitSleepTime[3] }} , {{ exitSleepTime[0] }}/{{ exitSleepTime[1] }}\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-else>\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t<image src=\"../../static/image/richu.png\" style=\"width: 50rpx;\" mode=\"widthFix\"></image>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;padding-bottom: 20rpx;margin-top: 40rpx;\" v-if=\"option.series[0].data.length > 0\">\n\t\t\t\t\t<view class=\"\" style=\"font-size: 26rpx;margin-bottom: 30rpx;\"> \n\t\t\t\t\t\t睡眠阶段\n\t\t\t\t\t</view>\n\t\t\t\t\t<view class=\"flx flx_sb\">\n\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t<view style=\"width: 200rpx; height:200rpx;background-color: #fff;\"><l-echart ref=\"chartRef\" @finished=\"init\"></l-echart></view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_sb\" style=\"width: 100%;margin-left: 40rpx;flex-direction: column;padding: 20rpx 0;padding-right: 40rpx;\">\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian0 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t深睡\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c0\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.shen }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian1 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t浅睡\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c1\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.qian }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian2 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t快速动眼\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c2\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.kuai }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;padding-bottom: 20rpx;margin-top: 40rpx;\">\n\t\t\t\t\t<view class=\"flx flx_sb title_box flx_ac\">\n\t\t\t\t\t\t<view class=\"title\" >\n\t\t\t\t\t\t\t目标\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"more\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t8 小时\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t</view>\n\t\t\n\t\t<view class=\"\" style=\"height: 40rpx\"></view>\n\t</view>\n</template>\n\n\n<script>\n\timport { mapGetters } from \"vuex\";\n\timport * as echarts from '@/uni_modules/lime-echart/static/echarts.min'\n\texport default {\n\t\tname: 'sleep-info',\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tsleepData:{\n\t\t\t\t\tshen:0,\n\t\t\t\t\tqian:0,\n\t\t\t\t\tkuai:0\n\t\t\t\t},\n\t\t\t\tisOption:false,\n\t\t\t\tisInit:false,\n\t\t\t\texitSleepTime:[],\n\t\t\t\tfallAsleepTime:[],\n\t\t\t\toption:{\n\t\t\t\t  tooltip: {\n\t\t\t\t\tshow:false\n\t\t\t\t  },\n\t\t\t\t  legend: {\n\t\t\t\t\ttop: '5%',\n\t\t\t\t\tleft: 'center'\n\t\t\t\t  },\n\t\t\t\t  series: [\n\t\t\t\t\t{\n\t\t\t\t\t  data:[],\n\t\t\t\t\t  type: 'pie',\n\t\t\t\t\t  radius: ['70%', '90%'],\n\t\t\t\t\t  avoidLabelOverlap: false,\n\t\t\t\t\t  labelLine: {\n\t\t\t\t\t\tshow: false\n\t\t\t\t\t  },\n\t\t\t\t\t}\n\t\t\t\t  ]\n\t\t\t\t},\n\t\t\t\tcavasConfig:{\n\t\t\t\t\tcanvasWidth: 250,\n\t\t\t\t\tcanvasHeight: 250,\n\t\t\t\t\tlineWidth:20,\n\t\t\t\t\tradius: 68, // 内圆的半径\n\t\t\t\t\tstartAngle: -90, // 起始角度，-90度，即垂直方向的3点钟位置\n\t\t\t\t\tbigRadius:90,// 外圆的半径\n\t\t\t\t\tcxt:null,\n\t\t\t\t\tcolorBg:'#f7c1f5',\n\t\t\t\t\tbigColorBg:'#d1ccf4',\n\t\t\t\t\tcolor:'#e933dd',\n\t\t\t\t\tbigColor:'#6452da',\n\t\t\t\t\tbigAngle:0,\n\t\t\t\t\tangle:0,\n\t\t\t\t\tstartSmallAngle:0,\n\t\t\t\t\tbigStartAngle:0,\n\t\t\t\t\tstop:0,\n\t\t\t\t\tbigStop:0,\n\t\t\t\t\tmaxTime:480\n\t\t\t\t},\n\t\t\t\tsleepList:[],\n\t\t\t\ttime: new Date().toISOString().substring(0, 10),\n\t\t\t\tsleep:{\n\t\t\t\t\tshen:'0 分',\n\t\t\t\t\tqian:'0 分'\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\twatch:{\n\t\t\tisInit(newVal,oldVal){\n\t\t\t\tif(this.isOption == true){\n\t\t\t\t\tthis.doDrawPie()\n\t\t\t\t}\n\t\t\t},\n\t\t\tisOption(newVal,oldVal){\n\t\t\t\tif(this.isInit == true){\n\t\t\t\t\tthis.doDrawPie()\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\tmounted() {\n\t\t\tthis.getDataList()\n\t\t\t\n\t\t\tthis.cavasConfig.ctx = uni.createCanvasContext('circleCanvas', this);\n\t\t\tthis.drawCircle('bottom',360,this.cavasConfig.bigRadius,this.cavasConfig.bigColorBg);\n\t\t\tthis.drawCircle('bottom',360,this.cavasConfig.radius,this.cavasConfig.colorBg);\n\t\t\t\n\t\t},\n\t\tcomputed: {\n\t\t\t...mapGetters({\n\t\t\t\tgetActiceDevice: \"api/getActiceDevice\"\n\t\t\t})\n\t\t},\n\t\tmethods: {\n\t\t\tinit() {\n\t\t\t\tthis.isInit = true\n\t\t\t\tconsole.log('iiiiiiiiiiiiint')\n\t\t\t},\n\t\t\tasync doDrawPie(){\n\t\t\t\tconst chart = await this.$refs.chartRef.init(echarts);\n\t\t\t\tchart.setOption(this.option)\n\t\t\t},\n\t\t\tcountOccurrences(array, value) {\n\t\t\t  return array.reduce((count, current) => {\n\t\t\t    return current === value ? count + 1 : count;\n\t\t\t  }, 0);\n\t\t\t},\n\t\t\t\n\t\t\tback() {\n\t\t\t\tthis.$emit('back', 1)\n\t\t\t},\n\t\t\t\n\t\t\tgetDataList(){\n\t\t\t\tlet type = 'SleepDatas'\n\t\t\t\tlet res = this.$store.dispatch('api/getDeviceListDays', {\n\t\t\t\t\ttype: type,\n\t\t\t\t\t// type: (this.type),\n\t\t\t\t\tdevice_real_time: this.time,\n\t\t\t\t\tdevice_id:this.getActiceDevice.device_id\n\t\t\t\t}).then(res => {\n\t\t\t\t\t\n\t\t\t\t\tif(res.data.length > 0){\n\t\t\t\t\t\tthis.sleep.shen = this.min2Hour(res.data[0].data_msg[0].sleepTotalTime)\n\t\t\t\t\t\tthis.sleep.qian = this.min2Hour(res.data[0].data_msg[0].deepSleepTime)\n\t\t\t\t\t\tthis.cavasConfig.angle = this.getAngle(res.data[0].data_msg[0].deepSleepTime)\n\t\t\t\t\t\tthis.cavasConfig.bigAngle = this.getAngle(res.data[0].data_msg[0].sleepTotalTime)\n\t\t\t\t\t\tthis.sleepList = res.data[0].data_msg[0].sleepCurve\n\t\t\t\t\t\tthis.option.series[0].data = [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,0),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#e933dd'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,1),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#6452da'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,2),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#4faffc'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t];\n\t\t\t\t\t\tlet len = this.sleepList.length\n\t\t\t\t\t\tthis.sleepData.shen = this.getPercent(this.sleepList,0) \n\t\t\t\t\t\tthis.sleepData.qian = this.getPercent(this.sleepList,1) \n\t\t\t\t\t\tthis.sleepData.kuai = this.getPercent(this.sleepList,2) \n\t\t\t\t\t\tthis.exitSleepTime = res.data[0].data_msg[0].exitSleepTime.split('-')\n\t\t\t\t\t\tthis.fallAsleepTime = res.data[0].data_msg[0].fallAsleepTime.split('-')\n\t\t\t\t\t\tthis.isOption = true\n\t\t\t\t\t}\n\t\t\t\t\tthis.doAnimation(0)\n\t\t\t\t\tthis.doAnimation(1)\n\t\t\t\t})\n\t\t\t\t\n\t\t\t\t\n\t\t\t},\n\t\t\tgetPercent(data,find){\n\t\t\t\tlet len = data.length\n\t\t\t\treturn (this.countOccurrences(data,find) / len * 100).toFixed(1)\n\t\t\t},\n\t\t\tgetAngle(min){\n\t\t\t\treturn min/this.cavasConfig.maxTime * 360\n\t\t\t},\n\t\t\tmin2Hour(min){\n\t\t\t\tlet hour = (Math.floor(min / 60))\n\t\t\t\tlet minute = (min % 60)\n\t\t\t\treturn (hour?hour + ' 小时 ' + minute+ ' 分':minute+ ' 分')\n\t\t\t},\n\t\t\tdoAnimation(type){\n\t\t\t\t  if(type == 0){\n\t\t\t\t\t  if(this.cavasConfig.bigStop === 1){\n\t\t\t\t\t\t  return\n\t\t\t\t\t  }\n\t\t\t\t\t  if(this.cavasConfig.bigStartAngle >= this.cavasConfig.bigAngle){\n\t\t\t\t\t\t  this.cavasConfig.bigStartAngle = this.cavasConfig.bigAngle\n\t\t\t\t\t\t  this.cavasConfig.bigStop = 1;\n\t\t\t\t\t  }else{\n\t\t\t\t\t\t  this.cavasConfig.bigStartAngle += this.cavasConfig.bigAngle/50\n\t\t\t\t\t  }\n\t\t\t\t\t  this.drawCircle('round',this.cavasConfig.bigStartAngle,this.cavasConfig.bigRadius,this.cavasConfig.bigColor);\n\t\t\t\t  }else{\n\t\t\t\t\t  if(this.cavasConfig.stop == 1){\n\t\t\t\t\t\t  return \n\t\t\t\t\t  }\n\t\t\t\t\t  if(this.cavasConfig.startSmallAngle >= this.cavasConfig.angle){\n\t\t\t\t\t\t  this.cavasConfig.startSmallAngle = this.cavasConfig.angle\n\t\t\t\t\t\t  this.cavasConfig.stop = 1;\n\t\t\t\t\t  }else{\n\t\t\t\t\t\t  this.cavasConfig.startSmallAngle += this.cavasConfig.angle/50\n\t\t\t\t\t  }\n\t\t\t\t\t  this.drawCircle('round',this.cavasConfig.startSmallAngle,this.cavasConfig.radius,this.cavasConfig.color);\n\t\t\t\t  }\n\t\t\t\t// window.requestAnimationFrame(() => {\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis.doAnimation(type)\n\t\t\t\t\t},(17))\n\t\t\t\t\t\n\t\t\t\t// })\n\t\t\t  },\n\t\t\t  // lineCap线条类型  edangle绘制角度  radius 直径 color 线条颜色\n\t\t\tdrawCircle(lineCap,edangle,radius,color) {\n\t\t\t\tthis.cavasConfig.ctx.save()\n\t\t\t\tconst cx = this.cavasConfig.canvasWidth / 2\n\t\t\t\tconst cy = this.cavasConfig.canvasHeight / 2\n\t\t\t\tthis.cavasConfig.ctx.translate(cx,cy)\n\t\t\t\tthis.cavasConfig.ctx.scale(1, 1);\n\t\t\t\tthis.cavasConfig.ctx.lineCap = lineCap\n\t\t\t\tlet start = this.cavasConfig.startAngle*Math.PI/180\n\t\t\t\tlet end = (edangle+this.cavasConfig.startAngle)*Math.PI/180\n\t\t\t\tthis.cavasConfig.ctx.beginPath()\n\t\t\t\tthis.cavasConfig.ctx.arc(0,0, radius , start, end);\n\t\t\t\tthis.cavasConfig.ctx.lineWidth = this.cavasConfig.lineWidth; // 设置线宽\n\t\t\t\tthis.cavasConfig.ctx.strokeStyle = color; // 设置绘制样式为蓝色\n\t\t\t\tthis.cavasConfig.ctx.stroke(); // 绘制路径\n\t\t\t\tthis.cavasConfig.ctx.closePath()\n\t\t\t\tthis.cavasConfig.ctx.restore()\n\t\t\t\tthis.cavasConfig.ctx.draw(true)\n\t\t\t}\n\t\t}\n\t}\n</script>\n\n<style  lang=\"scss\" scoped>\n.dian0{\n\tbackground-color: #e933dd;\n}\n.dian1{\n\tbackground-color: #6452da;\n}\n.dian2{\n\tbackground-color: #4faffc;\n}\n.c0{\n\tcolor: #e933dd;\n\tfont-size: 26rpx;\n}\n.c1{\n\tcolor: #6452da;\n\tfont-size: 26rpx;\n}\n.c2{\n\tcolor: #4faffc;\n\tfont-size: 26rpx;\n}\n.yuan{\n\twidth: 16rpx;\n\theight: 16rpx;\n\tborder-radius: 50%;\n}\n.small-title{\n\tfont-size: 24rpx;\n\tcolor: #999;\n}\n.canvas_box{\n\tbackground-color: #fff;\n\tpadding: 20rpx;\n\t.circle {\r\n\t\twidth: 40rpx;\r\n\t\theight: 40rpx;\r\n\t\t\r\n\t\tmargin: 0 auto;\r\n\t\tborder-radius: 50%;\r\n\t\tmargin: 0 10rpx;\r\n\t}\n\t.sleep_info{\n\t\t\n\t\t.info_title{\n\t\t\tfont-size: 24rpx;\n\t\t\tcolor: #999;\n\t\t}\n\t\t.info_val{\n\t\t\t\n\t\t}\n\t}\r\n\t\n}\n.title_box{\n\tmargin-bottom: 20rpx;\n\t.title{\n\t\tfont-size: 28rpx;\n\t}\n\t.more{\n\t\tcolor: #999;\n\t}\n}\n\n\n.video {\n\twidth: 80%;\n\tpadding: 0rpx 20rpx;\n}\n\n/* 隐藏所有默认控件 */\nvideo::-webkit-media-controls {\n  display: none !important;\n}\n \nvideo::-moz-media-controls {\n  display: none !important;\n}\n \nvideo::-ms-media-controls {\n  display: none !important;\n}\n \n/* 针对不同浏览器的隐藏控件的方式 */\nvideo::part(media-controls) {\n  display: none !important;\n}\n</style>\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///64\n"); +eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nvar _typeof = __webpack_require__(/*! @babel/runtime/helpers/typeof */ 4);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _regenerator = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/regenerator */ 48));\nvar _asyncToGenerator2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ 50));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\nvar _vuex = __webpack_require__(/*! vuex */ 65);\nvar echarts = _interopRequireWildcard(__webpack_require__(/*! @/uni_modules/lime-echart/static/echarts.min */ 67));\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar _default = {\n name: 'sleep-info',\n data: function data() {\n return {\n sleepData: {\n shen: 0,\n qian: 0,\n kuai: 0\n },\n isOption: false,\n isInit: false,\n exitSleepTime: [],\n fallAsleepTime: [],\n option: {\n tooltip: {\n show: false\n },\n legend: {\n top: '5%',\n left: 'center'\n },\n series: [{\n data: [],\n type: 'pie',\n radius: ['70%', '90%'],\n avoidLabelOverlap: false,\n labelLine: {\n show: false\n }\n }]\n },\n cavasConfig: {\n canvasWidth: 250,\n canvasHeight: 250,\n lineWidth: 20,\n radius: 68,\n // 内圆的半径\n startAngle: -90,\n // 起始角度,-90度,即垂直方向的3点钟位置\n bigRadius: 90,\n // 外圆的半径\n cxt: null,\n colorBg: '#f7c1f5',\n bigColorBg: '#d1ccf4',\n color: '#e933dd',\n bigColor: '#6452da',\n bigAngle: 0,\n angle: 0,\n startSmallAngle: 0,\n bigStartAngle: 0,\n stop: 0,\n bigStop: 0,\n maxTime: 480\n },\n sleepList: [],\n time: new Date().toISOString().substring(0, 10),\n sleep: {\n shen: '0 分',\n qian: '0 分'\n }\n };\n },\n watch: {\n isInit: function isInit(newVal, oldVal) {\n if (this.isOption == true) {\n this.doDrawPie();\n }\n },\n isOption: function isOption(newVal, oldVal) {\n if (this.isInit == true) {\n this.doDrawPie();\n }\n }\n },\n mounted: function mounted() {\n this.getDataList();\n this.cavasConfig.ctx = uni.createCanvasContext('circleCanvas', this);\n this.drawCircle('bottom', 360, this.cavasConfig.bigRadius, this.cavasConfig.bigColorBg);\n this.drawCircle('bottom', 360, this.cavasConfig.radius, this.cavasConfig.colorBg);\n },\n computed: _objectSpread({}, (0, _vuex.mapGetters)({\n getActiceDevice: \"api/getActiceDevice\"\n })),\n methods: {\n init: function init() {\n this.isInit = true;\n __f__(\"log\", 'iiiiiiiiiiiiint', \" at components/sleep-info/sleep-info.vue:248\");\n },\n doDrawPie: function doDrawPie() {\n var _this = this;\n return (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {\n var chart;\n return _regenerator.default.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return _this.$refs.chartRef.init(echarts);\n case 2:\n chart = _context.sent;\n chart.setOption(_this.option);\n case 4:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }))();\n },\n countOccurrences: function countOccurrences(array, value) {\n return array.reduce(function (count, current) {\n return current === value ? count + 1 : count;\n }, 0);\n },\n back: function back() {\n this.$emit('back', 1);\n },\n getDataList: function getDataList() {\n var _this2 = this;\n var type = 'SleepDatas';\n var res = this.$store.dispatch('api/getDeviceListDays', {\n type: type,\n // type: (this.type),\n device_real_time: this.time,\n device_id: this.getActiceDevice.device_id\n }).then(function (res) {\n if (res.data.length > 0) {\n _this2.sleep.shen = _this2.min2Hour(res.data[0].data_msg[0].sleepTotalTime);\n _this2.sleep.qian = _this2.min2Hour(res.data[0].data_msg[0].deepSleepTime);\n _this2.cavasConfig.angle = _this2.getAngle(res.data[0].data_msg[0].deepSleepTime);\n _this2.cavasConfig.bigAngle = _this2.getAngle(res.data[0].data_msg[0].sleepTotalTime);\n _this2.sleepList = res.data[0].data_msg[0].sleepCurve;\n _this2.option.series[0].data = [{\n value: _this2.countOccurrences(_this2.sleepList, 0),\n itemStyle: {\n color: '#e933dd'\n }\n }, {\n value: _this2.countOccurrences(_this2.sleepList, 1),\n itemStyle: {\n color: '#6452da'\n }\n }, {\n value: _this2.countOccurrences(_this2.sleepList, 2),\n itemStyle: {\n color: '#4faffc'\n }\n }];\n var len = _this2.sleepList.length;\n _this2.sleepData.shen = _this2.getPercent(_this2.sleepList, 0);\n _this2.sleepData.qian = _this2.getPercent(_this2.sleepList, 1);\n _this2.sleepData.kuai = _this2.getPercent(_this2.sleepList, 2);\n _this2.exitSleepTime = res.data[0].data_msg[0].exitSleepTime.split('-');\n _this2.fallAsleepTime = res.data[0].data_msg[0].fallAsleepTime.split('-');\n _this2.isOption = true;\n }\n _this2.doAnimation(0);\n _this2.doAnimation(1);\n });\n },\n getPercent: function getPercent(data, find) {\n var len = data.length;\n return (this.countOccurrences(data, find) / len * 100).toFixed(1);\n },\n getAngle: function getAngle(min) {\n return min / this.cavasConfig.maxTime * 360;\n },\n min2Hour: function min2Hour(min) {\n var hour = Math.floor(min / 60);\n var minute = min % 60;\n return hour ? hour + ' 小时 ' + minute + ' 分' : minute + ' 分';\n },\n doAnimation: function doAnimation(type) {\n var _this3 = this;\n if (type == 0) {\n if (this.cavasConfig.bigStop === 1) {\n return;\n }\n if (this.cavasConfig.bigStartAngle >= this.cavasConfig.bigAngle) {\n this.cavasConfig.bigStartAngle = this.cavasConfig.bigAngle;\n this.cavasConfig.bigStop = 1;\n } else {\n this.cavasConfig.bigStartAngle += this.cavasConfig.bigAngle / 50;\n }\n this.drawCircle('round', this.cavasConfig.bigStartAngle, this.cavasConfig.bigRadius, this.cavasConfig.bigColor);\n } else {\n if (this.cavasConfig.stop == 1) {\n return;\n }\n if (this.cavasConfig.startSmallAngle >= this.cavasConfig.angle) {\n this.cavasConfig.startSmallAngle = this.cavasConfig.angle;\n this.cavasConfig.stop = 1;\n } else {\n this.cavasConfig.startSmallAngle += this.cavasConfig.angle / 50;\n }\n this.drawCircle('round', this.cavasConfig.startSmallAngle, this.cavasConfig.radius, this.cavasConfig.color);\n }\n // window.requestAnimationFrame(() => {\n setTimeout(function () {\n _this3.doAnimation(type);\n }, 17);\n\n // })\n },\n // lineCap线条类型 edangle绘制角度 radius 直径 color 线条颜色\n drawCircle: function drawCircle(lineCap, edangle, radius, color) {\n this.cavasConfig.ctx.save();\n var cx = this.cavasConfig.canvasWidth / 2;\n var cy = this.cavasConfig.canvasHeight / 2;\n this.cavasConfig.ctx.translate(cx, cy);\n this.cavasConfig.ctx.scale(1, 1);\n this.cavasConfig.ctx.lineCap = lineCap;\n var start = this.cavasConfig.startAngle * Math.PI / 180;\n var end = (edangle + this.cavasConfig.startAngle) * Math.PI / 180;\n this.cavasConfig.ctx.beginPath();\n this.cavasConfig.ctx.arc(0, 0, radius, start, end);\n this.cavasConfig.ctx.lineWidth = this.cavasConfig.lineWidth; // 设置线宽\n this.cavasConfig.ctx.strokeStyle = color; // 设置绘制样式为蓝色\n this.cavasConfig.ctx.stroke(); // 绘制路径\n this.cavasConfig.ctx.closePath();\n this.cavasConfig.ctx.restore();\n this.cavasConfig.ctx.draw(true);\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/sleep-info/sleep-info.vue"],"names":["name","data","sleepData","shen","qian","kuai","isOption","isInit","exitSleepTime","fallAsleepTime","option","tooltip","show","legend","top","left","series","type","radius","avoidLabelOverlap","labelLine","cavasConfig","canvasWidth","canvasHeight","lineWidth","startAngle","bigRadius","cxt","colorBg","bigColorBg","color","bigColor","bigAngle","angle","startSmallAngle","bigStartAngle","stop","bigStop","maxTime","sleepList","time","sleep","watch","mounted","computed","getActiceDevice","methods","init","doDrawPie","chart","countOccurrences","back","getDataList","device_real_time","device_id","value","itemStyle","getPercent","getAngle","min2Hour","doAnimation","setTimeout","drawCircle"],"mappings":";;;;;;;;;;;AA4JA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA,eACA;EACAA;EACAC;IACA;MACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MACAC;QACAC;UACAC;QACA;QACAC;UACAC;UACAC;QACA;QACAC,SACA;UACAf;UACAgB;UACAC;UACAC;UACAC;YACAR;UACA;QACA;MAEA;MACAS;QACAC;QACAC;QACAC;QACAN;QAAA;QACAO;QAAA;QACAC;QAAA;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;QACAtC;QACAC;MACA;IACA;EACA;EACAsC;IACAnC;MACA;QACA;MACA;IACA;IACAD;MACA;QACA;MACA;IACA;EACA;EACAqC;IACA;IAEA;IACA;IACA;EAEA;EACAC,4BACA;IACAC;EACA,GACA;EACAC;IACAC;MACA;MACA;IACA;IACAC;MAAA;MAAA;QAAA;QAAA;UAAA;YAAA;cAAA;gBAAA;gBAAA,OACA;cAAA;gBAAAC;gBACAA;cAAA;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA;IACA;IACAC;MACA;QACA;MACA;IACA;IAEAC;MACA;IACA;IAEAC;MAAA;MACA;MACA;QACAnC;QACA;QACAoC;QACAC;MACA;QAEA;UACA;UACA;UACA;UACA;UACA;UACA,gCACA;YACAC;YACAC;cACA1B;YACA;UACA,GACA;YACAyB;YACAC;cACA1B;YACA;UACA,GACA;YACAyB;YACAC;cACA1B;YACA;UACA,EACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;QACA;QACA;QACA;MACA;IAGA;IACA2B;MACA;MACA;IACA;IACAC;MACA;IACA;IACAC;MACA;MACA;MACA;IACA;IACAC;MAAA;MACA;QACA;UACA;QACA;QACA;UACA;UACA;QACA;UACA;QACA;QACA;MACA;QACA;UACA;QACA;QACA;UACA;UACA;QACA;UACA;QACA;QACA;MACA;MACA;MACAC;QACA;MACA;;MAEA;IACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"64.js","sourcesContent":["<template>\n\t<view>\n\t\t<tm-nav-bar left-icon=\"arrow-left\" title=\"睡眠\" @clickLeft=\"back\" :rbgs=\"false\"/>\n\t\t<view class=\"flx jcsb ac\" style=\"height: 40rpx;background-color: #fff;padding: 20rpx;\">\n\t\t\t<view class=\"\" style=\"font-size: 40rpx;font-weight: bold;\">\n\t\t\t\t\n\t\t\t</view>\n\t\t\t<view class=\"\" style=\"color: #b8b8b8;font-size: 24rpx;\">\n\t\t\t\t{{time}}\n\t\t\t</view>\n\t\t</view>\n\t\t\n\t\t<view class=\"flx\">\n\t\t\t<view class=\"w-5\">\n\t\t\t\t<view class=\"canvas_box\">\n\t\t\t\t\t<canvas canvas-id=\"circleCanvas\" style=\"width: 250px; height: 250px;margin: 0  auto;\"></canvas>\n\t\t\t\t\t<view class=\"\" style=\"height: 40rpx;\"></view>\n\t\t\t\t\t<view class=\"flx flx_sb\">\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<!-- color:'#e933dd',\n\t\t\t\t\t\t\tbigColor:'#6452da', -->\n\t\t\t\t\t\t\t<view class=\"circle\" style=\"background-color:#6452da ;\" >\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"sleep_info\">\n\t\t\t\t\t\t\t\t<view class=\"info_title\">\n\t\t\t\t\t\t\t\t\t睡眠时长\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"info_val\">\n\t\t\t\t\t\t\t\t\t{{sleep.shen}}\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"sleep_info\">\n\t\t\t\t\t\t\t\t<view class=\"info_title\" style=\"text-align: right;\">\n\t\t\t\t\t\t\t\t\t深度睡眠\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"info_val\">\n\t\t\t\t\t\t\t\t\t{{sleep.qian}}\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"circle\" style=\"background-color:#e933dd ;\">\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view class=\"w-5\">\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;margin-top: 40rpx\t;\">\n\t\t\t\t\t<view class=\"flx flx_sb title_box\">\n\t\t\t\t\t\t<view class=\"title\">\n\t\t\t\t\t\t\t{{sleep.shen}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t\t<sleep-list-data :canvas-id=\"'sleep-canvas-id'\" :dataList=\"sleepList\"></sleep-list-data>\n\t\t\t\t\t<view class=\"flx flx_sb flx_ac\" style=\"margin-top: 20rpx;\">\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t<image src=\"../../static/icon/sleep.png\" style=\"width: 30rpx;margin-right: 5rpx;\" mode=\"widthFix\"></image>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-if=\"fallAsleepTime.length > 0\">\n\t\t\t\t\t\t\t\t{{ fallAsleepTime[2] }}:{{ fallAsleepTime[3] }} , {{ fallAsleepTime[0] }}/{{ fallAsleepTime[1] }}\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-else>\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t<view class=\"small-title\"  v-if=\"exitSleepTime.length > 0\">\n\t\t\t\t\t\t\t\t{{ exitSleepTime[2] }}:{{ exitSleepTime[3] }} , {{ exitSleepTime[0] }}/{{ exitSleepTime[1] }}\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"small-title\" v-else>\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t<image src=\"../../static/image/richu.png\" style=\"width: 50rpx;\" mode=\"widthFix\"></image>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;padding-bottom: 20rpx;margin-top: 40rpx;\" v-if=\"option.series[0].data.length > 0\">\n\t\t\t\t\t<view class=\"\" style=\"font-size: 26rpx;margin-bottom: 30rpx;\"> \n\t\t\t\t\t\t睡眠阶段\n\t\t\t\t\t</view>\n\t\t\t\t\t<view class=\"flx flx_sb\">\n\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t<view style=\"width: 200rpx; height:200rpx;background-color: #fff;\"><l-echart ref=\"chartRef\" @finished=\"init\"></l-echart></view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"flx flx_sb\" style=\"width: 100%;margin-left: 40rpx;flex-direction: column;padding: 20rpx 0;padding-right: 40rpx;\">\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian0 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t深睡\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c0\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.shen }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian1 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t浅睡\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c1\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.qian }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx  flx_sb line\">\n\t\t\t\t\t\t\t\t<view class=\"flx small-title flx_ac\">\n\t\t\t\t\t\t\t\t\t<view class=\"dian2 yuan\" style=\"margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t快速动眼\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<view class=\"c2\">\n\t\t\t\t\t\t\t\t\t\t{{ sleepData.kuai }}%\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"radius_box\" style=\"margin: 20rpx;padding-bottom: 20rpx;margin-top: 40rpx;\">\n\t\t\t\t\t<view class=\"flx flx_sb title_box flx_ac\">\n\t\t\t\t\t\t<view class=\"title\" >\n\t\t\t\t\t\t\t目标\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"more\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t8 小时\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t</view>\n\t\t\n\t\t<view class=\"\" style=\"height: 40rpx\"></view>\n\t</view>\n</template>\n\n\n<script>\n\timport { mapGetters } from \"vuex\";\n\timport * as echarts from '@/uni_modules/lime-echart/static/echarts.min'\n\texport default {\n\t\tname: 'sleep-info',\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tsleepData:{\n\t\t\t\t\tshen:0,\n\t\t\t\t\tqian:0,\n\t\t\t\t\tkuai:0\n\t\t\t\t},\n\t\t\t\tisOption:false,\n\t\t\t\tisInit:false,\n\t\t\t\texitSleepTime:[],\n\t\t\t\tfallAsleepTime:[],\n\t\t\t\toption:{\n\t\t\t\t  tooltip: {\n\t\t\t\t\tshow:false\n\t\t\t\t  },\n\t\t\t\t  legend: {\n\t\t\t\t\ttop: '5%',\n\t\t\t\t\tleft: 'center'\n\t\t\t\t  },\n\t\t\t\t  series: [\n\t\t\t\t\t{\n\t\t\t\t\t  data:[],\n\t\t\t\t\t  type: 'pie',\n\t\t\t\t\t  radius: ['70%', '90%'],\n\t\t\t\t\t  avoidLabelOverlap: false,\n\t\t\t\t\t  labelLine: {\n\t\t\t\t\t\tshow: false\n\t\t\t\t\t  },\n\t\t\t\t\t}\n\t\t\t\t  ]\n\t\t\t\t},\n\t\t\t\tcavasConfig:{\n\t\t\t\t\tcanvasWidth: 250,\n\t\t\t\t\tcanvasHeight: 250,\n\t\t\t\t\tlineWidth:20,\n\t\t\t\t\tradius: 68, // 内圆的半径\n\t\t\t\t\tstartAngle: -90, // 起始角度，-90度，即垂直方向的3点钟位置\n\t\t\t\t\tbigRadius:90,// 外圆的半径\n\t\t\t\t\tcxt:null,\n\t\t\t\t\tcolorBg:'#f7c1f5',\n\t\t\t\t\tbigColorBg:'#d1ccf4',\n\t\t\t\t\tcolor:'#e933dd',\n\t\t\t\t\tbigColor:'#6452da',\n\t\t\t\t\tbigAngle:0,\n\t\t\t\t\tangle:0,\n\t\t\t\t\tstartSmallAngle:0,\n\t\t\t\t\tbigStartAngle:0,\n\t\t\t\t\tstop:0,\n\t\t\t\t\tbigStop:0,\n\t\t\t\t\tmaxTime:480\n\t\t\t\t},\n\t\t\t\tsleepList:[],\n\t\t\t\ttime: new Date().toISOString().substring(0, 10),\n\t\t\t\tsleep:{\n\t\t\t\t\tshen:'0 分',\n\t\t\t\t\tqian:'0 分'\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\twatch:{\n\t\t\tisInit(newVal,oldVal){\n\t\t\t\tif(this.isOption == true){\n\t\t\t\t\tthis.doDrawPie()\n\t\t\t\t}\n\t\t\t},\n\t\t\tisOption(newVal,oldVal){\n\t\t\t\tif(this.isInit == true){\n\t\t\t\t\tthis.doDrawPie()\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\tmounted() {\n\t\t\tthis.getDataList()\n\t\t\t\n\t\t\tthis.cavasConfig.ctx = uni.createCanvasContext('circleCanvas', this);\n\t\t\tthis.drawCircle('bottom',360,this.cavasConfig.bigRadius,this.cavasConfig.bigColorBg);\n\t\t\tthis.drawCircle('bottom',360,this.cavasConfig.radius,this.cavasConfig.colorBg);\n\t\t\t\n\t\t},\n\t\tcomputed: {\n\t\t\t...mapGetters({\n\t\t\t\tgetActiceDevice: \"api/getActiceDevice\"\n\t\t\t})\n\t\t},\n\t\tmethods: {\n\t\t\tinit() {\n\t\t\t\tthis.isInit = true\n\t\t\t\tconsole.log('iiiiiiiiiiiiint')\n\t\t\t},\n\t\t\tasync doDrawPie(){\n\t\t\t\tconst chart = await this.$refs.chartRef.init(echarts);\n\t\t\t\tchart.setOption(this.option)\n\t\t\t},\n\t\t\tcountOccurrences(array, value) {\n\t\t\t  return array.reduce((count, current) => {\n\t\t\t    return current === value ? count + 1 : count;\n\t\t\t  }, 0);\n\t\t\t},\n\t\t\t\n\t\t\tback() {\n\t\t\t\tthis.$emit('back', 1)\n\t\t\t},\n\t\t\t\n\t\t\tgetDataList(){\n\t\t\t\tlet type = 'SleepDatas'\n\t\t\t\tlet res = this.$store.dispatch('api/getDeviceListDays', {\n\t\t\t\t\ttype: type,\n\t\t\t\t\t// type: (this.type),\n\t\t\t\t\tdevice_real_time: this.time,\n\t\t\t\t\tdevice_id:this.getActiceDevice.device_id\n\t\t\t\t}).then(res => {\n\t\t\t\t\t\n\t\t\t\t\tif(res.data.length > 0){\n\t\t\t\t\t\tthis.sleep.shen = this.min2Hour(res.data[0].data_msg[0].sleepTotalTime)\n\t\t\t\t\t\tthis.sleep.qian = this.min2Hour(res.data[0].data_msg[0].deepSleepTime)\n\t\t\t\t\t\tthis.cavasConfig.angle = this.getAngle(res.data[0].data_msg[0].deepSleepTime)\n\t\t\t\t\t\tthis.cavasConfig.bigAngle = this.getAngle(res.data[0].data_msg[0].sleepTotalTime)\n\t\t\t\t\t\tthis.sleepList = res.data[0].data_msg[0].sleepCurve\n\t\t\t\t\t\tthis.option.series[0].data = [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,0),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#e933dd'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,1),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#6452da'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue:this.countOccurrences(this.sleepList,2),\n\t\t\t\t\t\t\t\titemStyle:{\n\t\t\t\t\t\t\t\t\tcolor:'#4faffc'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t];\n\t\t\t\t\t\tlet len = this.sleepList.length\n\t\t\t\t\t\tthis.sleepData.shen = this.getPercent(this.sleepList,0) \n\t\t\t\t\t\tthis.sleepData.qian = this.getPercent(this.sleepList,1) \n\t\t\t\t\t\tthis.sleepData.kuai = this.getPercent(this.sleepList,2) \n\t\t\t\t\t\tthis.exitSleepTime = res.data[0].data_msg[0].exitSleepTime.split('-')\n\t\t\t\t\t\tthis.fallAsleepTime = res.data[0].data_msg[0].fallAsleepTime.split('-')\n\t\t\t\t\t\tthis.isOption = true\n\t\t\t\t\t}\n\t\t\t\t\tthis.doAnimation(0)\n\t\t\t\t\tthis.doAnimation(1)\n\t\t\t\t})\n\t\t\t\t\n\t\t\t\t\n\t\t\t},\n\t\t\tgetPercent(data,find){\n\t\t\t\tlet len = data.length\n\t\t\t\treturn (this.countOccurrences(data,find) / len * 100).toFixed(1)\n\t\t\t},\n\t\t\tgetAngle(min){\n\t\t\t\treturn min/this.cavasConfig.maxTime * 360\n\t\t\t},\n\t\t\tmin2Hour(min){\n\t\t\t\tlet hour = (Math.floor(min / 60))\n\t\t\t\tlet minute = (min % 60)\n\t\t\t\treturn (hour?hour + ' 小时 ' + minute+ ' 分':minute+ ' 分')\n\t\t\t},\n\t\t\tdoAnimation(type){\n\t\t\t\t  if(type == 0){\n\t\t\t\t\t  if(this.cavasConfig.bigStop === 1){\n\t\t\t\t\t\t  return\n\t\t\t\t\t  }\n\t\t\t\t\t  if(this.cavasConfig.bigStartAngle >= this.cavasConfig.bigAngle){\n\t\t\t\t\t\t  this.cavasConfig.bigStartAngle = this.cavasConfig.bigAngle\n\t\t\t\t\t\t  this.cavasConfig.bigStop = 1;\n\t\t\t\t\t  }else{\n\t\t\t\t\t\t  this.cavasConfig.bigStartAngle += this.cavasConfig.bigAngle/50\n\t\t\t\t\t  }\n\t\t\t\t\t  this.drawCircle('round',this.cavasConfig.bigStartAngle,this.cavasConfig.bigRadius,this.cavasConfig.bigColor);\n\t\t\t\t  }else{\n\t\t\t\t\t  if(this.cavasConfig.stop == 1){\n\t\t\t\t\t\t  return \n\t\t\t\t\t  }\n\t\t\t\t\t  if(this.cavasConfig.startSmallAngle >= this.cavasConfig.angle){\n\t\t\t\t\t\t  this.cavasConfig.startSmallAngle = this.cavasConfig.angle\n\t\t\t\t\t\t  this.cavasConfig.stop = 1;\n\t\t\t\t\t  }else{\n\t\t\t\t\t\t  this.cavasConfig.startSmallAngle += this.cavasConfig.angle/50\n\t\t\t\t\t  }\n\t\t\t\t\t  this.drawCircle('round',this.cavasConfig.startSmallAngle,this.cavasConfig.radius,this.cavasConfig.color);\n\t\t\t\t  }\n\t\t\t\t// window.requestAnimationFrame(() => {\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis.doAnimation(type)\n\t\t\t\t\t},(17))\n\t\t\t\t\t\n\t\t\t\t// })\n\t\t\t  },\n\t\t\t  // lineCap线条类型  edangle绘制角度  radius 直径 color 线条颜色\n\t\t\tdrawCircle(lineCap,edangle,radius,color) {\n\t\t\t\tthis.cavasConfig.ctx.save()\n\t\t\t\tconst cx = this.cavasConfig.canvasWidth / 2\n\t\t\t\tconst cy = this.cavasConfig.canvasHeight / 2\n\t\t\t\tthis.cavasConfig.ctx.translate(cx,cy)\n\t\t\t\tthis.cavasConfig.ctx.scale(1, 1);\n\t\t\t\tthis.cavasConfig.ctx.lineCap = lineCap\n\t\t\t\tlet start = this.cavasConfig.startAngle*Math.PI/180\n\t\t\t\tlet end = (edangle+this.cavasConfig.startAngle)*Math.PI/180\n\t\t\t\tthis.cavasConfig.ctx.beginPath()\n\t\t\t\tthis.cavasConfig.ctx.arc(0,0, radius , start, end);\n\t\t\t\tthis.cavasConfig.ctx.lineWidth = this.cavasConfig.lineWidth; // 设置线宽\n\t\t\t\tthis.cavasConfig.ctx.strokeStyle = color; // 设置绘制样式为蓝色\n\t\t\t\tthis.cavasConfig.ctx.stroke(); // 绘制路径\n\t\t\t\tthis.cavasConfig.ctx.closePath()\n\t\t\t\tthis.cavasConfig.ctx.restore()\n\t\t\t\tthis.cavasConfig.ctx.draw(true)\n\t\t\t}\n\t\t}\n\t}\n</script>\n\n<style  lang=\"scss\" scoped>\n.dian0{\n\tbackground-color: #e933dd;\n}\n.dian1{\n\tbackground-color: #6452da;\n}\n.dian2{\n\tbackground-color: #4faffc;\n}\n.c0{\n\tcolor: #e933dd;\n\tfont-size: 26rpx;\n}\n.c1{\n\tcolor: #6452da;\n\tfont-size: 26rpx;\n}\n.c2{\n\tcolor: #4faffc;\n\tfont-size: 26rpx;\n}\n.yuan{\n\twidth: 16rpx;\n\theight: 16rpx;\n\tborder-radius: 50%;\n}\n.small-title{\n\tfont-size: 24rpx;\n\tcolor: #999;\n}\n.canvas_box{\n\tbackground-color: #fff;\n\tpadding: 20rpx;\n\t.circle {\r\n\t\twidth: 40rpx;\r\n\t\theight: 40rpx;\r\n\t\t\r\n\t\tmargin: 0 auto;\r\n\t\tborder-radius: 50%;\r\n\t\tmargin: 0 10rpx;\r\n\t}\n\t.sleep_info{\n\t\t\n\t\t.info_title{\n\t\t\tfont-size: 24rpx;\n\t\t\tcolor: #999;\n\t\t}\n\t\t.info_val{\n\t\t\t\n\t\t}\n\t}\r\n\t\n}\n.title_box{\n\tmargin-bottom: 20rpx;\n\t.title{\n\t\tfont-size: 28rpx;\n\t}\n\t.more{\n\t\tcolor: #999;\n\t}\n}\n\n\n.video {\n\twidth: 80%;\n\tpadding: 0rpx 20rpx;\n}\n\n/* 隐藏所有默认控件 */\nvideo::-webkit-media-controls {\n  display: none !important;\n}\n \nvideo::-moz-media-controls {\n  display: none !important;\n}\n \nvideo::-ms-media-controls {\n  display: none !important;\n}\n \n/* 针对不同浏览器的隐藏控件的方式 */\nvideo::part(media-controls) {\n  display: none !important;\n}\n</style>\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///64\n"); /***/ }), /* 65 */ @@ -13418,840 +13418,947 @@ var render = function () { attrs: { type: "bottom", "border-radius": "10px 10px 0 0", _i: 1 }, }, [ - _vm._$s(2, "i", _vm.typeIndex == 1) - ? _c( - "view", - { staticClass: _vm._$s(2, "sc", "pop-main"), attrs: { _i: 2 } }, - [ - _c("view", [ - _c("view", { - staticClass: _vm._$s(4, "sc", "pop-close"), - attrs: { _i: 4 }, - on: { - click: function ($event) { - return _vm.close() - }, - }, - }), - _c( - "view", - { - staticClass: _vm._$s(5, "sc", "dxxl"), - attrs: { _i: 5 }, - }, - [ - _c( - "scroll-view", - { - staticClass: _vm._$s(6, "sc", "myScoll"), - attrs: { _i: 6 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(7, "sc", "box1"), - attrs: { _i: 7 }, - }, - [_c("canvas", {})] - ), - _c( - "view", - { - staticClass: _vm._$s(9, "sc", "box2"), - style: _vm._$s(9, "s", { - left: _vm.pLeft + "px", - }), - attrs: { _i: 9 }, - }, - [_c("canvas", {})] - ), - ] - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(11, "sc", "list"), - attrs: { _i: 11 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(12, "sc", "flx flx_ac "), - attrs: { _i: 12 }, - }, - [ - _c("view", [ - _c("image", { - attrs: { - src: _vm._$s( - 14, - "a-src", - __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) - ), - _i: 14, - }, - }), - ]), - _c("view"), - ] - ), - _c( - "view", - { - staticClass: _vm._$s( - 16, - "sc", - "flx flx_sb sl_box flx_wp" - ), - attrs: { _i: 16 }, - }, - [ - _vm._l( - _vm._$s(17, "f", { forItems: _vm.xinlv.jisuan }), - function (item, index, $20, $30) { - return _c( - "view", - { - key: _vm._$s(17, "f", { - forIndex: $20, - key: 17 + "-" + $30, - }), - staticClass: _vm._$s( - "17-" + $30, - "sc", - "all" - ), - attrs: { _i: "17-" + $30 }, - }, - [ - _c("view", [ - _c( - "span", - { - staticClass: _vm._$s( - "19-" + $30, - "sc", - "sl_box_wz" - ), - attrs: { _i: "19-" + $30 }, - }, - [ - _vm._v( - _vm._$s( - "19-" + $30, - "t0-0", - _vm._s( - item.times ? item.times : 0 - ) - ) - ), - ] - ), - _c( - "span", - { - staticClass: _vm._$s( - "20-" + $30, - "sc", - "sl_box_unit" - ), - attrs: { _i: "20-" + $30 }, - }, - [ - _vm._v( - _vm._$s( - "20-" + $30, - "t0-0", - _vm._s(item.unit) - ) - ), - ] - ), - ]), - _c( - "view", - { - staticClass: _vm._$s( - "21-" + $30, - "sc", - "sl_box_desc" - ), - attrs: { _i: "21-" + $30 }, - }, - [ - _vm._v( - _vm._$s( - "21-" + $30, - "t0-0", - _vm._s(item.desc) - ) - ), - ] - ), - _vm._$s("22-" + $30, "i", item.cankao) - ? _c( - "view", - { - staticClass: _vm._$s( - "22-" + $30, - "sc", - "sl_box_cankao" - ), - attrs: { _i: "22-" + $30 }, - }, - [ - _vm._v( - _vm._$s( - "22-" + $30, - "t0-0", - _vm._s(item.cankao) - ) - ), - ] - ) - : _vm._e(), - ] - ) - } - ), - _vm._l( - _vm._$s(23, "f", { forItems: _vm.xinlv.cankao }), - function (item, index, $21, $31) { - return _c( - "view", - { - key: _vm._$s(23, "f", { - forIndex: $21, - key: 23 + "-" + $31, - }), - staticClass: _vm._$s( - "23-" + $31, - "sc", - "all" - ), - attrs: { _i: "23-" + $31 }, - }, - [ - _c("view", [ - _c( - "span", - { - staticClass: _vm._$s( - "25-" + $31, - "sc", - "sl_box_wz" - ), - attrs: { _i: "25-" + $31 }, - }, - [ - _vm._v( - _vm._$s( - "25-" + $31, - "t0-0", - _vm._s(item.times.toFixed(2)) - ) - ), - ] - ), - _c( - "span", - { - staticClass: _vm._$s( - "26-" + $31, - "sc", - "sl_box_unit" - ), - attrs: { _i: "26-" + $31 }, - }, - [ - _vm._v( - _vm._$s( - "26-" + $31, - "t0-0", - _vm._s(item.unit) - ) - ), - ] - ), - ]), - _c( - "view", - { - staticClass: _vm._$s( - "27-" + $31, - "sc", - "sl_box_desc" - ), - attrs: { _i: "27-" + $31 }, - }, - [ - _vm._v( - _vm._$s( - "27-" + $31, - "t0-0", - _vm._s(item.desc) - ) - ), - ] - ), - _vm._$s("28-" + $31, "i", item.cankao) - ? _c( - "view", - { - staticClass: _vm._$s( - "28-" + $31, - "sc", - "sl_box_cankao" - ), - attrs: { _i: "28-" + $31 }, - }, - [ - _vm._v( - _vm._$s( - "28-" + $31, - "t0-0", - _vm._s(item.cankao) - ) - ), - ] - ) - : _vm._e(), - ] - ) - } - ), - ], - 2 - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(29, "sc", "list"), - attrs: { _i: 29 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(30, "sc", "flx flx_ac "), - attrs: { _i: 30 }, - }, - [ - _c("view", [ - _c("image", { - attrs: { - src: _vm._$s( - 32, - "a-src", - __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) - ), - _i: 32, - }, - }), - ]), - _c("view"), - ] - ), - _c( - "view", - [ - _c("xdt", { - attrs: { datas: _vm.ybx.hrv, _i: 35 }, - }), - _c("xdt", { - attrs: { datas: _vm.ybx.sdnn, _i: 36 }, - }), - _c("xdt", { - attrs: { datas: _vm.ybx.rmssd, _i: 37 }, - }), - ], - 1 - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(38, "sc", "list"), - attrs: { _i: 38 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(39, "sc", "flx flx_ac "), - attrs: { _i: 39 }, - }, - [ - _c("view", [ - _c("image", { - attrs: { - src: _vm._$s( - 41, - "a-src", - __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) - ), - _i: 41, - }, - }), - ]), - _c("view"), - ] - ), - _c( - "view", - [ - _c("xdt", { - attrs: { datas: _vm.xdt.pwv, _i: 44 }, - }), - _c("xdt", { - attrs: { datas: _vm.xdt.qtc, _i: 45 }, - }), - _c("xdt", { - attrs: { datas: _vm.xdt.qsrf, _i: 46 }, - }), - _c("xdt", { - attrs: { datas: _vm.xdt.qsrx, _i: 47 }, - }), - _c("xdt", { - attrs: { datas: _vm.xdt.qsrfx, _i: 48 }, - }), - _c("xdt", { attrs: { datas: _vm.xdt.st, _i: 49 } }), - ], - 1 - ), - ] - ), - _c("view"), - ]), - ] - ) - : _vm._e(), - _vm._$s(51, "i", _vm.typeIndex == 2) - ? _c( - "view", - { - staticClass: _vm._$s(51, "sc", "pop-main"), - attrs: { _i: 51 }, - }, - [ - _c("view", [ - _c("view", { - staticClass: _vm._$s(53, "sc", "pop-close"), - attrs: { _i: 53 }, - on: { - click: function ($event) { - return _vm.close() - }, - }, - }), - _c("view", [ + _c( + "view", + { staticClass: _vm._$s(2, "sc", "main"), attrs: { _i: 2 } }, + [ + _vm._$s(3, "i", _vm.typeIndex == 1) + ? _c( + "view", + { + staticClass: _vm._$s(3, "sc", "pop-main"), + attrs: { _i: 3 }, + }, + [ _c( "view", { - staticClass: _vm._$s(55, "sc", "flx flx_ac"), - attrs: { _i: 55 }, + staticClass: _vm._$s(4, "sc", "pops"), + attrs: { _i: 4 }, }, [ - _c("view", [ - _c("text", { - staticClass: _vm._$s( - 57, - "sc", - "iconfont icon-wode" + _c("view", { + staticClass: _vm._$s(5, "sc", "pop-close"), + attrs: { _i: 5 }, + on: { + click: function ($event) { + return _vm.close() + }, + }, + }), + _c( + "view", + { + staticClass: _vm._$s(6, "sc", "dxxl"), + attrs: { _i: 6 }, + }, + [ + _c( + "scroll-view", + { + staticClass: _vm._$s(7, "sc", "myScoll"), + attrs: { _i: 7 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s(8, "sc", "box1"), + attrs: { _i: 8 }, + }, + [_c("canvas", {})] + ), + _c( + "view", + { + staticClass: _vm._$s(10, "sc", "box2"), + style: _vm._$s(10, "s", { + left: _vm.pLeft + "px", + }), + attrs: { _i: 10 }, + }, + [_c("canvas", {})] + ), + ] ), - style: _vm._$s( - 57, - "s", - "font-size: 50rpx;margin-right:10rpx;color:" + - _vm.bodyDesc.color + ] + ), + _c( + "view", + { + staticClass: _vm._$s(12, "sc", "list"), + attrs: { _i: 12 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s(13, "sc", "flx flx_ac "), + attrs: { _i: 13 }, + }, + [ + _c("view", [ + _c("image", { + attrs: { + src: _vm._$s( + 15, + "a-src", + __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) + ), + _i: 15, + }, + }), + ]), + _c("view"), + ] ), - attrs: { _i: 57 }, - }), - ]), - _c("view", [ - _c("text", [ - _vm._v( - _vm._$s(59, "t0-0", _vm._s(_vm.bodyDesc.name)) + _c( + "view", + { + staticClass: _vm._$s( + 17, + "sc", + "flx flx_sb sl_box flx_wp" + ), + attrs: { _i: 17 }, + }, + [ + _vm._l( + _vm._$s(18, "f", { + forItems: _vm.xinlv.jisuan, + }), + function (item, index, $20, $30) { + return _c( + "view", + { + key: _vm._$s(18, "f", { + forIndex: $20, + key: 18 + "-" + $30, + }), + staticClass: _vm._$s( + "18-" + $30, + "sc", + "all" + ), + attrs: { _i: "18-" + $30 }, + }, + [ + _c("view", [ + _c( + "span", + { + staticClass: _vm._$s( + "20-" + $30, + "sc", + "sl_box_wz" + ), + attrs: { _i: "20-" + $30 }, + }, + [ + _vm._v( + _vm._$s( + "20-" + $30, + "t0-0", + _vm._s( + item.times + ? item.times + : 0 + ) + ) + ), + ] + ), + _c( + "span", + { + staticClass: _vm._$s( + "21-" + $30, + "sc", + "sl_box_unit" + ), + attrs: { _i: "21-" + $30 }, + }, + [ + _vm._v( + _vm._$s( + "21-" + $30, + "t0-0", + _vm._s(item.unit) + ) + ), + ] + ), + ]), + _c( + "view", + { + staticClass: _vm._$s( + "22-" + $30, + "sc", + "sl_box_desc" + ), + attrs: { _i: "22-" + $30 }, + }, + [ + _vm._v( + _vm._$s( + "22-" + $30, + "t0-0", + _vm._s(item.desc) + ) + ), + ] + ), + _vm._$s("23-" + $30, "i", item.cankao) + ? _c( + "view", + { + staticClass: _vm._$s( + "23-" + $30, + "sc", + "sl_box_cankao" + ), + attrs: { _i: "23-" + $30 }, + }, + [ + _vm._v( + _vm._$s( + "23-" + $30, + "t0-0", + _vm._s(item.cankao) + ) + ), + ] + ) + : _vm._e(), + ] + ) + } + ), + _vm._l( + _vm._$s(24, "f", { + forItems: _vm.xinlv.cankao, + }), + function (item, index, $21, $31) { + return _c( + "view", + { + key: _vm._$s(24, "f", { + forIndex: $21, + key: 24 + "-" + $31, + }), + staticClass: _vm._$s( + "24-" + $31, + "sc", + "all" + ), + attrs: { _i: "24-" + $31 }, + }, + [ + _c("view", [ + _c( + "span", + { + staticClass: _vm._$s( + "26-" + $31, + "sc", + "sl_box_wz" + ), + attrs: { _i: "26-" + $31 }, + }, + [ + _vm._v( + _vm._$s( + "26-" + $31, + "t0-0", + _vm._s( + item.times.toFixed(2) + ) + ) + ), + ] + ), + _c( + "span", + { + staticClass: _vm._$s( + "27-" + $31, + "sc", + "sl_box_unit" + ), + attrs: { _i: "27-" + $31 }, + }, + [ + _vm._v( + _vm._$s( + "27-" + $31, + "t0-0", + _vm._s(item.unit) + ) + ), + ] + ), + ]), + _c( + "view", + { + staticClass: _vm._$s( + "28-" + $31, + "sc", + "sl_box_desc" + ), + attrs: { _i: "28-" + $31 }, + }, + [ + _vm._v( + _vm._$s( + "28-" + $31, + "t0-0", + _vm._s(item.desc) + ) + ), + ] + ), + _vm._$s("29-" + $31, "i", item.cankao) + ? _c( + "view", + { + staticClass: _vm._$s( + "29-" + $31, + "sc", + "sl_box_cankao" + ), + attrs: { _i: "29-" + $31 }, + }, + [ + _vm._v( + _vm._$s( + "29-" + $31, + "t0-0", + _vm._s(item.cankao) + ) + ), + ] + ) + : _vm._e(), + ] + ) + } + ), + ], + 2 ), - ]), - ]), + ] + ), + _c( + "view", + { + staticClass: _vm._$s(30, "sc", "list"), + attrs: { _i: 30 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s(31, "sc", "flx flx_ac "), + attrs: { _i: 31 }, + }, + [ + _c("view", [ + _c("image", { + attrs: { + src: _vm._$s( + 33, + "a-src", + __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) + ), + _i: 33, + }, + }), + ]), + _c("view"), + ] + ), + _c( + "view", + [ + _c("xdt", { + attrs: { datas: _vm.ybx.hrv, _i: 36 }, + }), + _c("xdt", { + attrs: { datas: _vm.ybx.sdnn, _i: 37 }, + }), + _c("xdt", { + attrs: { datas: _vm.ybx.rmssd, _i: 38 }, + }), + ], + 1 + ), + ] + ), + _c( + "view", + { + staticClass: _vm._$s(39, "sc", "list"), + attrs: { _i: 39 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s(40, "sc", "flx flx_ac "), + attrs: { _i: 40 }, + }, + [ + _c("view", [ + _c("image", { + attrs: { + src: _vm._$s( + 42, + "a-src", + __webpack_require__(/*! ../../static/icon/xinlv-small.png */ 212) + ), + _i: 42, + }, + }), + ]), + _c("view"), + ] + ), + _c( + "view", + [ + _c("xdt", { + attrs: { datas: _vm.xdt.pwv, _i: 45 }, + }), + _c("xdt", { + attrs: { datas: _vm.xdt.qtc, _i: 46 }, + }), + _c("xdt", { + attrs: { datas: _vm.xdt.qsrf, _i: 47 }, + }), + _c("xdt", { + attrs: { datas: _vm.xdt.qsrx, _i: 48 }, + }), + _c("xdt", { + attrs: { datas: _vm.xdt.qsrfx, _i: 49 }, + }), + _c("xdt", { + attrs: { datas: _vm.xdt.st, _i: 50 }, + }), + ], + 1 + ), + ] + ), + _c("view"), ] ), - _c("view", [ - _c("image", { - attrs: { - src: _vm._$s( - 61, - "a-src", - __webpack_require__(/*! ../../static/image/body.png */ 213) - ), - _i: 61, - }, - }), - _c( - "view", - { - staticClass: _vm._$s( - 62, - "sc", - "left_position postion " - ), - attrs: { _i: 62 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(63, "sc", "desc_box"), - attrs: { _i: 63 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s( - 64, - "sc", - "flx flx_ac" - ), - attrs: { _i: 64 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(65, "sc", "tt"), - attrs: { _i: 65 }, - }, - [ - _vm._v( - _vm._$s( - 65, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg - .basalMetabolicRate - ) - ) - ), - ] - ), - _c("view", { - staticClass: _vm._$s(66, "sc", "unit"), - attrs: { _i: 66 }, - }), - ] - ), - _c("view", { - staticClass: _vm._$s(67, "sc", "name"), - attrs: { _i: 67 }, - }), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(68, "sc", "desc_box"), - attrs: { _i: 68 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s( - 69, - "sc", - "flx flx_ac" - ), - attrs: { _i: 69 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(70, "sc", "tt"), - attrs: { _i: 70 }, - }, - [ - _vm._v( - _vm._$s( - 70, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg.boneMass - ) - ) - ), - ] - ), - _c("view", { - staticClass: _vm._$s(71, "sc", "unit"), - attrs: { _i: 71 }, - }), - ] - ), - _c("view", { - staticClass: _vm._$s(72, "sc", "name"), - attrs: { _i: 72 }, - }), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(73, "sc", "desc_box"), - attrs: { _i: 73 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s( - 74, - "sc", - "flx flx_ac" - ), - attrs: { _i: 74 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(75, "sc", "tt"), - attrs: { _i: 75 }, - }, - [ - _vm._v( - _vm._$s( - 75, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg.waterContent - ) - ) - ), - ] - ), - _c("view", { - staticClass: _vm._$s(76, "sc", "unit"), - attrs: { _i: 76 }, - }), - ] - ), - _c("view", { - staticClass: _vm._$s(77, "sc", "name"), - attrs: { _i: 77 }, - }), - ] - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s( - 78, - "sc", - "right_position postion" - ), - attrs: { _i: 78 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(79, "sc", "desc_box"), - attrs: { _i: 79 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s( - 80, - "sc", - "flx flx_ac" - ), - attrs: { _i: 80 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(81, "sc", "tt"), - attrs: { _i: 81 }, - }, - [ - _vm._v( - _vm._$s( - 81, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg.fatMass - ) - ) - ), - ] - ), - _c("view", { - staticClass: _vm._$s(82, "sc", "unit"), - attrs: { _i: 82 }, - }), - ] - ), - _c("view", { - staticClass: _vm._$s(83, "sc", "name"), - attrs: { _i: 83 }, - }), - ] - ), - _c( - "view", - { - staticClass: _vm._$s(84, "sc", "desc_box"), - attrs: { _i: 84 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s( - 85, - "sc", - "flx flx_ac" - ), - attrs: { _i: 85 }, - }, - [ - _c( - "view", - { - staticClass: _vm._$s(86, "sc", "tt"), - attrs: { _i: 86 }, - }, - [ - _vm._v( - _vm._$s( - 86, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg - .proteinAmount - ) - ) - ), - ] - ), - _c("view", { - staticClass: _vm._$s(87, "sc", "unit"), - attrs: { _i: 87 }, - }), - ] - ), - _c("view", { - staticClass: _vm._$s(88, "sc", "name"), - attrs: { _i: 88 }, - }), - ] - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s( - 89, - "sc", - "postion center_posion" - ), - attrs: { _i: 89 }, - }, - [ - _vm._v( - _vm._$s( - 89, - "t0-0", - _vm._s( - _vm.dataInfo.data_msg.userInfo.gender == "2" - ? "女" - : "男" - ) - ) + - _vm._$s( - 89, - "t0-1", - _vm._s(_vm.dataInfo.data_msg.userInfo.weight) - ) - ), - ] - ), - _c( - "view", - { - staticClass: _vm._$s( - 90, - "sc", - "postion right_center" - ), - attrs: { _i: 90 }, - }, - [ - _vm._v( - _vm._$s( - 90, - "t0-0", - _vm._s(_vm.dataInfo.data_msg.userInfo.height) - ) - ), - ] - ), - ]), + ] + ) + : _vm._e(), + _vm._$s(52, "i", _vm.typeIndex == 2) + ? _c( + "view", + { + staticClass: _vm._$s(52, "sc", "pop-main"), + attrs: { _i: 52 }, + }, + [ _c( "view", { - staticClass: _vm._$s(91, "sc", "radius_box"), - attrs: { _i: 91 }, + staticClass: _vm._$s(53, "sc", "pops"), + attrs: { _i: 53 }, }, - _vm._l( - _vm._$s(92, "f", { forItems: _vm.arr }), - function (v, i, $22, $32) { - return _c( + [ + _c("view", { + staticClass: _vm._$s(54, "sc", "pop-close"), + attrs: { _i: 54 }, + on: { + click: function ($event) { + return _vm.close() + }, + }, + }), + _c("view", [ + _c( "view", { - key: _vm._$s(92, "f", { - forIndex: $22, - key: i, - }), + staticClass: _vm._$s(56, "sc", "flx flx_ac"), + attrs: { _i: 56 }, }, [ - _c("body_info_components", { - attrs: { - key_name: v, - value: parseFloat(_vm.dataInfo.data_msg[v]), - _i: "93-" + $32, - }, - }), - ], - 1 - ) - } - ), - 0 + _c("view", [ + _c("text", { + staticClass: _vm._$s( + 58, + "sc", + "iconfont icon-wode" + ), + style: _vm._$s( + 58, + "s", + "font-size: 50rpx;margin-right:10rpx;color:" + + _vm.bodyDesc.color + ), + attrs: { _i: 58 }, + }), + ]), + _c("view", [ + _c("text", [ + _vm._v( + _vm._$s( + 60, + "t0-0", + _vm._s(_vm.bodyDesc.name) + ) + ), + ]), + ]), + ] + ), + _c("view", [ + _c("image", { + attrs: { + src: _vm._$s( + 62, + "a-src", + __webpack_require__(/*! ../../static/image/body.png */ 213) + ), + _i: 62, + }, + }), + _c( + "view", + { + staticClass: _vm._$s( + 63, + "sc", + "left_position postion " + ), + attrs: { _i: 63 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 64, + "sc", + "desc_box" + ), + attrs: { _i: 64 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 65, + "sc", + "flx flx_ac" + ), + attrs: { _i: 65 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 66, + "sc", + "tt" + ), + attrs: { _i: 66 }, + }, + [ + _vm._v( + _vm._$s( + 66, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg + .basalMetabolicRate + ) + ) + ), + ] + ), + _c("view", { + staticClass: _vm._$s( + 67, + "sc", + "unit" + ), + attrs: { _i: 67 }, + }), + ] + ), + _c("view", { + staticClass: _vm._$s(68, "sc", "name"), + attrs: { _i: 68 }, + }), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 69, + "sc", + "desc_box" + ), + attrs: { _i: 69 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 70, + "sc", + "flx flx_ac" + ), + attrs: { _i: 70 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 71, + "sc", + "tt" + ), + attrs: { _i: 71 }, + }, + [ + _vm._v( + _vm._$s( + 71, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg + .boneMass + ) + ) + ), + ] + ), + _c("view", { + staticClass: _vm._$s( + 72, + "sc", + "unit" + ), + attrs: { _i: 72 }, + }), + ] + ), + _c("view", { + staticClass: _vm._$s(73, "sc", "name"), + attrs: { _i: 73 }, + }), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 74, + "sc", + "desc_box" + ), + attrs: { _i: 74 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 75, + "sc", + "flx flx_ac" + ), + attrs: { _i: 75 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 76, + "sc", + "tt" + ), + attrs: { _i: 76 }, + }, + [ + _vm._v( + _vm._$s( + 76, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg + .waterContent + ) + ) + ), + ] + ), + _c("view", { + staticClass: _vm._$s( + 77, + "sc", + "unit" + ), + attrs: { _i: 77 }, + }), + ] + ), + _c("view", { + staticClass: _vm._$s(78, "sc", "name"), + attrs: { _i: 78 }, + }), + ] + ), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 79, + "sc", + "right_position postion" + ), + attrs: { _i: 79 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 80, + "sc", + "desc_box" + ), + attrs: { _i: 80 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 81, + "sc", + "flx flx_ac" + ), + attrs: { _i: 81 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 82, + "sc", + "tt" + ), + attrs: { _i: 82 }, + }, + [ + _vm._v( + _vm._$s( + 82, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg + .fatMass + ) + ) + ), + ] + ), + _c("view", { + staticClass: _vm._$s( + 83, + "sc", + "unit" + ), + attrs: { _i: 83 }, + }), + ] + ), + _c("view", { + staticClass: _vm._$s(84, "sc", "name"), + attrs: { _i: 84 }, + }), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 85, + "sc", + "desc_box" + ), + attrs: { _i: 85 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 86, + "sc", + "flx flx_ac" + ), + attrs: { _i: 86 }, + }, + [ + _c( + "view", + { + staticClass: _vm._$s( + 87, + "sc", + "tt" + ), + attrs: { _i: 87 }, + }, + [ + _vm._v( + _vm._$s( + 87, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg + .proteinAmount + ) + ) + ), + ] + ), + _c("view", { + staticClass: _vm._$s( + 88, + "sc", + "unit" + ), + attrs: { _i: 88 }, + }), + ] + ), + _c("view", { + staticClass: _vm._$s(89, "sc", "name"), + attrs: { _i: 89 }, + }), + ] + ), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 90, + "sc", + "postion center_posion" + ), + attrs: { _i: 90 }, + }, + [ + _vm._v( + _vm._$s( + 90, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg.userInfo.gender == + "2" + ? "女" + : "男" + ) + ) + + _vm._$s( + 90, + "t0-1", + _vm._s( + _vm.dataInfo.data_msg.userInfo.weight + ) + ) + ), + ] + ), + _c( + "view", + { + staticClass: _vm._$s( + 91, + "sc", + "postion right_center" + ), + attrs: { _i: 91 }, + }, + [ + _vm._v( + _vm._$s( + 91, + "t0-0", + _vm._s( + _vm.dataInfo.data_msg.userInfo.height + ) + ) + ), + ] + ), + ]), + _c( + "view", + { + staticClass: _vm._$s(92, "sc", "radius_box"), + attrs: { _i: 92 }, + }, + _vm._l( + _vm._$s(93, "f", { forItems: _vm.arr }), + function (v, i, $22, $32) { + return _c( + "view", + { + key: _vm._$s(93, "f", { + forIndex: $22, + key: i, + }), + }, + [ + _c("body_info_components", { + attrs: { + key_name: v, + value: parseFloat( + _vm.dataInfo.data_msg[v] + ), + _i: "94-" + $32, + }, + }), + ], + 1 + ) + } + ), + 0 + ), + _c("view"), + ]), + _c("view"), + ] ), - _c("view"), - ]), - _c("view"), - ]), - ] - ) - : _vm._e(), + ] + ) + : _vm._e(), + ] + ), ] ), ], @@ -15031,7 +15138,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _App /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 52));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n name: \"pop-info\",\n data: function data() {\n var _ref;\n return _ref = {\n typeIndex: 1,\n dataInfo: {},\n bodyDesc: {},\n arr: ['BMI', 'bodyFatPercentage', 'leanBodyMass', 'muscleRate', 'muscleMass', 'subcutaneousFat', 'bodyMoisture', 'skeletalMuscleRate', 'boneMass', 'proteinAmount', 'basalMetabolicRate'],\n title: '',\n list: [],\n height: 300,\n width: 3000,\n centerY: 200,\n pLeft: '0'\n }, (0, _defineProperty2.default)(_ref, \"dataInfo\", {}), (0, _defineProperty2.default)(_ref, \"xinlv\", {\n jisuan: [{\n times: 0,\n unit: '次/分',\n desc: '平均心率',\n cankao: ''\n }, {\n times: 0,\n unit: '次/分',\n desc: '最高心率',\n cankao: ''\n }, {\n times: 0,\n unit: '次/分',\n desc: '最低心率',\n cankao: ''\n }],\n cankao: [{\n times: 0,\n unit: '%',\n desc: '正常',\n cankao: '(60~100次/分)'\n }, {\n times: 0,\n unit: '%',\n desc: '心率偏快',\n cankao: '>100次/分)'\n }, {\n times: 0,\n unit: '%',\n desc: '心率偏慢',\n cankao: '(<60次/分)'\n }]\n }), (0, _defineProperty2.default)(_ref, \"ybx\", {\n hrv: {\n name: 'HRV',\n max: 210,\n unit: '毫秒',\n min: 0,\n val: 0\n },\n sdnn: {\n name: 'SDNN',\n max: 180,\n unit: '毫秒',\n min: 102,\n val: 0\n },\n rmssd: {\n name: 'RMSSD',\n max: 39,\n unit: '毫秒',\n min: 15,\n val: 0\n }\n }), (0, _defineProperty2.default)(_ref, \"xdt\", {\n pwv: {\n name: 'PWV',\n max: 15,\n unit: 'm/s',\n min: 6,\n val: 0\n },\n qtc: {\n name: 'QTc',\n max: 400,\n unit: '毫秒',\n min: 260,\n val: 0\n },\n qsrf: {\n name: 'QRS 波振幅',\n max: 1.5,\n unit: 'mV',\n min: 0.05,\n val: 0\n },\n qsrx: {\n name: 'QRS 波时限',\n max: 120,\n unit: '毫秒',\n min: 80,\n val: 0\n },\n qsrfx: {\n name: 'QRS 主波方向',\n max: 0,\n unit: '向上,向下',\n min: 0,\n val: 0\n },\n st: {\n name: 'ST 段振幅',\n max: 0.1,\n unit: 'mV',\n min: -0.05,\n val: 0\n }\n }), _ref;\n },\n methods: {\n close: function close() {\n this.$refs.popup.close();\n },\n open: function open(val) {\n var _this = this;\n val == 1 ? this.typeIndex = 1 : this.typeIndex = 2;\n // 通过组件定义的ref调用uni-popup方法 ,如果传入参数 ,type 属性将失效 ,仅支持 ['top','left','bottom','right','center']\n this.$refs.popup.open('bottom');\n if (val == 1) {\n var dataKey = 'infoData'; // 同上面设置的key\n var get = uni.getStorageSync(dataKey);\n if (!get) {\n uni.showToast({\n title: \"读取数据失败\"\n });\n setTimeout(function () {\n uni.navigateBack({\n delta: -1\n });\n }, 2000);\n return;\n }\n var data = JSON.parse(get);\n __f__(\"log\", data, \" at components/ecg-info/ecg-info.vue:375\");\n this.dataInfo = data;\n this.changeData(this.dataInfo);\n this.list = this.dataInfo.data_msg.list;\n\n // 绘制\n setTimeout(function () {\n _this.list = _this.list.filter(function (val) {\n return val !== 0;\n });\n var ctx = uni.createCanvasContext('ecg', _this);\n ctx.setStrokeStyle('#d5d5d5'); //\n ctx.setLineWidth(1); // 线条宽度\n for (var x = 0.5; x < 3000; x += 15) {\n ctx.moveTo(x, 0);\n // 结束点\n ctx.lineTo(x, 3000);\n // 描边,不调用stroke则看不到画的内容\n ctx.stroke();\n }\n for (var y = 0.5; y < 3000; y += 15) {\n ctx.moveTo(0, y);\n // 结束点\n ctx.lineTo(3000, y);\n // 描边,不调用stroke则看不到画的内容\n ctx.stroke();\n }\n // ctx.fill();\n ctx.draw();\n _this.drawCurve();\n }, 1000);\n } else {\n var _dataKey = 'bodyData'; // 同上面设置的key\n var _get = uni.getStorageSync(_dataKey);\n if (!_get) {\n uni.showToast({\n title: \"读取数据失败\"\n });\n setTimeout(function () {\n uni.navigateBack({\n delta: -1\n });\n }, 2000);\n return;\n }\n var _data = JSON.parse(_get);\n this.dataInfo = _data;\n __f__(\"log\", this.dataInfo, \" at components/ecg-info/ecg-info.vue:421\");\n // this.getUserInfo()\n this.bodyDesc = this.$utils.getBodyKeyInfo(this.dataInfo.data_msg.BMI, 'BMI');\n // uni.removeStorageSync(dataKey);\n }\n },\n drawCurve: function drawCurve() {\n var ctx = uni.createCanvasContext('myCanvas', this);\n var list = this.list;\n var centerY = this.centerY;\n var width = this.width;\n var xScale = width / (list.length - 1); // 计算每个数据点占据的宽度\n var yScale = centerY / (Math.max.apply(Math, (0, _toConsumableArray2.default)(list)) - Math.min.apply(Math, (0, _toConsumableArray2.default)(list)));\n // yScale *= 3\n var x = 0;\n var y = centerY / 2 - list[0] * yScale;\n ctx.beginPath(); // 开始绘制\n ctx.moveTo(x, y);\n ctx.setStrokeStyle('#c96d79'); // 设置线条颜色\n ctx.setLineWidth(2); // 设置线条宽度\n for (var i = 1; i < list.length; i++) {\n var _x = i * xScale;\n var _y = centerY / 2 - list[i] / 2 * yScale; // 负数在中心下方,正数在中心上方\n ctx.lineTo(_x, _y);\n }\n ctx.stroke(); // 绘制线条\n // ctx.fill();\n ctx.draw(false);\n\n // 绘制到canvas上,不需要等待上一步绘制完成\n },\n changeData: function changeData(data) {\n var HRV = [];\n var QT = [];\n var heart = [];\n var pwv = [];\n var resRate = [];\n this.xinlv.jisuan[0].times = data.data_msg.meanHeartRate == undefined ? data.data_msg.heartRate : data.data_msg.meanHeartRate;\n if (data.data_msg.wavefrom == undefined) {\n return;\n }\n data.data_msg.wavefrom.map(function (v, i) {\n if (!(v instanceof Array)) {\n if (v.HRV != 0) {\n HRV.push(v.HRV);\n }\n if (v.QT != 0) {\n QT.push(v.QT);\n }\n if (v.heart != 0 && v.heart != null) {\n heart.push(v.heart);\n }\n if (v.pwv != 0) {\n pwv.push(v.pwv);\n }\n if (v.resRate != 0) {\n resRate.push(v.resRate);\n }\n }\n });\n this.xinlv.jisuan[1].times = Math.max.apply(Math, heart);\n this.xinlv.jisuan[2].times = Math.min.apply(Math, heart);\n // 获取心率每个区间的数据数量\n var heart_zc = heart.filter(function (value) {\n return value >= 60 && value <= 100;\n }).length;\n var heart_fast = heart.filter(function (value) {\n return value > 100;\n }).length;\n var heart_slow = heart.filter(function (value) {\n return value < 60;\n }).length;\n var heart_length = heart.length;\n this.xinlv.cankao[0].times = (heart_zc / heart_length).toFixed(2) * 100;\n this.xinlv.cankao[1].times = (heart_fast / heart_length).toFixed(2) * 100;\n this.xinlv.cankao[2].times = (heart_slow / heart_length).toFixed(2) * 100;\n if (this.xinlv.cankao[0].times > 50) {\n this.title = '窦性心率';\n } else if (this.xinlv.cankao[1].times >= 50) {\n this.title = '心率偏快';\n } else if (this.xinlv.cankao[2].times >= 50) {\n this.title = '心率偏慢';\n } else {\n this.title = '窦性心率不齐';\n }\n if (data.diseaseRisk != undefined && data.diseaseRisk >= 30 && this.xinlv.cankao[0].times > 50) {\n this.title = '窦性心率不齐';\n }\n if (data.data_msg.hrv != undefined) {\n this.ybx.hrv.val = data.data_msg.hrv;\n this.ybx.sdnn.val = data.data_msg.diseaseSdnn;\n this.ybx.rmssd.val = data.data_msg.diseaseRmssd;\n this.xdt.pwv.val = (data.data_msg.pwvMeanVal / 10).toFixed(2);\n this.xdt.qtc.val = data.data_msg.QTC;\n this.xdt.qsrf.val = (data.data_msg.qrsAmp / 100).toFixed(2);\n this.xdt.qsrx.val = data.data_msg.qrsTime;\n this.xdt.qsrfx.val = data.data_msg.leadOffType == 0 ? '向上' : '向下';\n this.xdt.st.val = (data.data_msg.stMeanVal / 100).toFixed(2);\n } else {\n __f__(\"log\", 'is undefined', \" at components/ecg-info/ecg-info.vue:520\");\n this.ybx.hrv.val = data.data_msg.averageHRV;\n this.xdt.qtc.val = data.data_msg.averageTimeInterval;\n }\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/ecg-info/ecg-info.vue"],"names":["name","data","typeIndex","dataInfo","bodyDesc","arr","title","list","height","width","centerY","pLeft","jisuan","times","unit","desc","cankao","hrv","max","min","val","sdnn","rmssd","pwv","qtc","qsrf","qsrx","qsrfx","st","methods","close","open","uni","setTimeout","delta","ctx","drawCurve","changeData","data_msg","HRV","QT","heart","resRate"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eA+MA;EACAA;EACAC;IAAA;IACA;MACAC;MACAC;MACAC;MACAC,MACA,OACA,qBACA,gBACA,cACA,cACA,mBACA,gBACA,sBACA,YACA,iBACA,qBACA;MAGAC;MACAC;MAEAC;MACAC;MACAC;MACAC;IAAA,mDACA,kDACA;MACAC;QACAC;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,EACA;MACAA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA;IAGA,+CAEA;MACAC;QACAjB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAC;QACArB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAE;QACAtB;QACAkB;QACAJ;QACAK;QACAC;MACA;IACA,+CACA;MACAG;QACAvB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAI;QACAxB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAK;QACAzB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAM;QACA1B;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAO;QACA3B;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAQ;QACA5B;QACAkB;QACAJ;QACAK;QACAC;MACA;IACA;EAEA;EAEAS;IACAC;MACA;IACA;IACAC;MAAA;MACAX;MACA;MACA;MAEA;QACA;QACA;QAEA;UACAY;YACA1B;UACA;UACA2B;YACAD;cACAE;YACA;UACA;UACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACAD;UACA;YAAA;UAAA;UACA;UACAE;UACAA;UACA;YACAA;YACA;YACAA;YACA;YACAA;UACA;UACA;YACAA;YACA;YACAA;YACA;YACAA;UACA;UACA;UACAA;UACA;QACA;MACA;QACA;QACA;QAEA;UACAH;YACA1B;UACA;UACA2B;YACAD;cACAE;YACA;UACA;UACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;MACA;IACA;IAEAE;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACAD;MACAA;MACAA;MACAA;MACA;QACA;QACA;QACAA;MAEA;MACAA;MACA;MACAA;;MAEA;IACA;IAEAE;MACA;MACA;MACA;MACA;MACA;MACA,uGACAC;MACA;QACA;MACA;MACArC;QAEA;UACA;YACAsC;UACA;UACA;YACAC;UACA;UACA;YACAC;UACA;UACA;YACAlB;UACA;UACA;YACAmB;UACA;QACA;MAEA;MACA;MACA;MACA;MACA;QAAA;MAAA;MACA;QAAA;MAAA;MACA;QAAA;MAAA;MACA;MACA;MACA;MACA;MACA;QACA;MACA;QACA;MACA;QACA;MACA;QACA;MACA;MACA;QACA;MACA;MACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;MACA;QACA;QACA;QACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"215.js","sourcesContent":["<template>\r\n\t<view class=\"content\" style=\"width: 60%;\">\r\n\t\t<uni-popup ref=\"popup\" type=\"bottom\" border-radius=\"10px 10px 0 0\">\r\n\t\t\t<view class=\"pop-main\" v-if=\"typeIndex == 1\">\r\n\t\t\t\t<view>\r\n\t\t\t\t\t<view class=\"pop-close\" @click=\"close()\">\r\n\t\t\t\t\t\t×\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"dxxl\">\r\n\t\t\t\t\t\t<scroll-view class=\"myScoll\" scroll-x :show-scrollbar=\"true\">\r\n\t\t\t\t\t\t\t<view class=\"box1\">\r\n\t\t\t\t\t\t\t\t<canvas canvas-id=\"ecg\" style=\"width: 3000px; height: 300px;\"></canvas>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"box2\" :style=\"{'left': pLeft + 'px'}\">\r\n\t\t\t\t\t\t\t\t<canvas canvas-id=\"myCanvas\" style=\"width: 3000px; height: 300px;\"></canvas>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</scroll-view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"list\">\r\n\t\t\t\t\t\t<view class=\"flx flx_ac \">\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\r\n\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\r\n\t\t\t\t\t\t\t\t</image>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\r\n\t\t\t\t\t\t\t\t心率\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"flx flx_sb sl_box flx_wp\">\r\n\t\t\t\t\t\t\t<view class=\"all\" v-for=\"(item,index) in xinlv.jisuan\">\r\n\t\t\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t\t\t<span class=\"sl_box_wz\">{{item.times?item.times:0}}</span>\r\n\t\t\t\t\t\t\t\t\t<span class=\"sl_box_unit\">{{item.unit}}</span>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"sl_box_desc\">\r\n\t\t\t\t\t\t\t\t\t{{item.desc}}\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"sl_box_cankao\" v-if=\"item.cankao\">\r\n\t\t\t\t\t\t\t\t\t{{item.cankao}}\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"all\" v-for=\"(item,index) in xinlv.cankao\">\r\n\t\t\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t\t\t<span class=\"sl_box_wz\">{{item.times.toFixed(2)}}</span>\r\n\t\t\t\t\t\t\t\t\t<span class=\"sl_box_unit\">{{item.unit}}</span>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"sl_box_desc\">\r\n\t\t\t\t\t\t\t\t\t{{item.desc}}\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"sl_box_cankao\" v-if=\"item.cankao\">\r\n\t\t\t\t\t\t\t\t\t{{item.cankao}}\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"list\">\r\n\t\t\t\t\t\t<view class=\"flx flx_ac \">\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\r\n\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\r\n\t\t\t\t\t\t\t\t</image>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\r\n\t\t\t\t\t\t\t\t心率变异性\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t<xdt :datas=\"ybx.hrv\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"ybx.sdnn\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"ybx.rmssd\"></xdt>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"list\">\r\n\t\t\t\t\t\t<view class=\"flx flx_ac \">\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\r\n\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\r\n\t\t\t\t\t\t\t\t</image>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\r\n\t\t\t\t\t\t\t\t心电图\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.pwv\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.qtc\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrf\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrx\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrfx\"></xdt>\r\n\t\t\t\t\t\t\t<xdt :datas=\"xdt.st\"></xdt>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view class=\"\" style=\"height: 20rpx;\"></view>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\r\n\t\t\t<view class=\"pop-main\" v-if=\"typeIndex == 2\">\r\n\t\t\t\t<view>\r\n\t\t\t\t\t<view class=\"pop-close\" @click=\"close()\">\r\n\t\t\t\t\t\t×\r\n\t\t\t\t\t</view>\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<view class=\"flx flx_ac\" style=\"background-color: #fff;padding: 30rpx 0 0 30rpx;\">\r\n\t\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t\t<text class=\"iconfont icon-wode\"\r\n\t\t\t\t\t\t\t\t\t:style=\"'font-size: 50rpx;margin-right:10rpx;color:' + bodyDesc.color \"></text>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"\">\r\n\t\t\t\t\t\t\t\t<text>{{bodyDesc.name}}</text>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"\" style=\"position: relative;\">\r\n\t\t\t\t\t\t\t<image src=\"../../static/image/body.png\" style=\"width: 100%;\" mode=\"widthFix\"></image>\r\n\t\t\t\t\t\t\t<view class=\"left_position postion \">\r\n\t\t\t\t\t\t\t\t<view class=\"desc_box\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\r\n\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.basalMetabolicRate }}\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\r\n\t\t\t\t\t\t\t\t\t\t\t千卡\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"name\">\r\n\t\t\t\t\t\t\t\t\t\t基础代谢\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"desc_box\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\r\n\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.boneMass }}\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\r\n\t\t\t\t\t\t\t\t\t\t\t千克\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"name\">\r\n\t\t\t\t\t\t\t\t\t\t骨重\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"desc_box\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\r\n\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.waterContent }}\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\r\n\t\t\t\t\t\t\t\t\t\t\t千克\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"name\">\r\n\t\t\t\t\t\t\t\t\t\t水分\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"right_position postion\">\r\n\t\t\t\t\t\t\t\t<view class=\"desc_box\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\r\n\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.fatMass }}\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\r\n\t\t\t\t\t\t\t\t\t\t\t千克\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"name\">\r\n\t\t\t\t\t\t\t\t\t\t脂肪\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<view class=\"desc_box\" style=\"margin-bottom: 0;margin-top: 174rpx;\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\r\n\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.proteinAmount }}\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\r\n\t\t\t\t\t\t\t\t\t\t\t千克\r\n\t\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"name\">\r\n\t\t\t\t\t\t\t\t\t\t蛋白质\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"postion center_posion\">\r\n\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.userInfo.gender == '2'?'女':'男' }}性，{{ dataInfo.data_msg.userInfo.weight  }}千克\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<view class=\"postion right_center\">\r\n\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.userInfo.height  }}厘米\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"radius_box\" style=\"padding: 0;margin: 30rpx;\">\r\n\t\t\t\t\t\t\t<view class=\"\" v-for=\"(v,i) in arr\" :key=\"i\">\r\n\t\t\t\t\t\t\t\t<body_info_components :key_name=\"v\" :value=\"parseFloat(dataInfo.data_msg[v])\">\r\n\t\t\t\t\t\t\t\t</body_info_components>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t<view class=\"\" style=\"height: 40rpx;\">\r\n\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\r\n\t\t\t\t\t<view class=\"\" style=\"height: 20rpx;\"></view>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</uni-popup>\r\n\t</view>\r\n</template>\r\n\r\n<script>\r\n\texport default {\r\n\t\tname: \"pop-info\",\r\n\t\tdata() {\r\n\t\t\treturn {\r\n\t\t\t\ttypeIndex: 1,\r\n\t\t\t\tdataInfo: {},\r\n\t\t\t\tbodyDesc: {},\r\n\t\t\t\tarr: [\r\n\t\t\t\t\t'BMI',\r\n\t\t\t\t\t'bodyFatPercentage',\r\n\t\t\t\t\t'leanBodyMass',\r\n\t\t\t\t\t'muscleRate',\r\n\t\t\t\t\t'muscleMass',\r\n\t\t\t\t\t'subcutaneousFat',\r\n\t\t\t\t\t'bodyMoisture',\r\n\t\t\t\t\t'skeletalMuscleRate',\r\n\t\t\t\t\t'boneMass',\r\n\t\t\t\t\t'proteinAmount',\r\n\t\t\t\t\t'basalMetabolicRate',\r\n\t\t\t\t],\r\n\r\n\r\n\t\t\t\ttitle: '',\r\n\t\t\t\tlist: [],\r\n\r\n\t\t\t\theight: 300,\r\n\t\t\t\twidth: 3000,\r\n\t\t\t\tcenterY: 200,\r\n\t\t\t\tpLeft: '0',\r\n\t\t\t\tdataInfo: {},\r\n\t\t\t\txinlv: {\r\n\t\t\t\t\tjisuan: [{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '平均心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '最高心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '最低心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\t\t\tcankao: [{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '正常',\r\n\t\t\t\t\t\t\tcankao: '(60~100次/分)'\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '心率偏快',\r\n\t\t\t\t\t\t\tcankao: '>100次/分)'\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '心率偏慢',\r\n\t\t\t\t\t\t\tcankao: '(<60次/分)'\r\n\t\t\t\t\t\t},\r\n\r\n\t\t\t\t\t],\r\n\t\t\t\t},\r\n\t\t\t\t// 心率异变性\r\n\t\t\t\tybx: {\r\n\t\t\t\t\thrv: {\r\n\t\t\t\t\t\tname: 'HRV',\r\n\t\t\t\t\t\tmax: 210,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 0,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsdnn: {\r\n\t\t\t\t\t\tname: 'SDNN',\r\n\t\t\t\t\t\tmax: 180,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 102,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\trmssd: {\r\n\t\t\t\t\t\tname: 'RMSSD',\r\n\t\t\t\t\t\tmax: 39,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 15,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\txdt: {\r\n\t\t\t\t\tpwv: {\r\n\t\t\t\t\t\tname: 'PWV',\r\n\t\t\t\t\t\tmax: 15,\r\n\t\t\t\t\t\tunit: 'm/s',\r\n\t\t\t\t\t\tmin: 6,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqtc: {\r\n\t\t\t\t\t\tname: 'QTc',\r\n\t\t\t\t\t\tmax: 400,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 260,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrf: {\r\n\t\t\t\t\t\tname: 'QRS 波振幅',\r\n\t\t\t\t\t\tmax: 1.5,\r\n\t\t\t\t\t\tunit: 'mV',\r\n\t\t\t\t\t\tmin: 0.05,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrx: {\r\n\t\t\t\t\t\tname: 'QRS 波时限',\r\n\t\t\t\t\t\tmax: 120,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 80,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrfx: {\r\n\t\t\t\t\t\tname: 'QRS 主波方向',\r\n\t\t\t\t\t\tmax: 0,\r\n\t\t\t\t\t\tunit: '向上，向下',\r\n\t\t\t\t\t\tmin: 0,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tst: {\r\n\t\t\t\t\t\tname: 'ST 段振幅',\r\n\t\t\t\t\t\tmax: 0.1,\r\n\t\t\t\t\t\tunit: 'mV',\r\n\t\t\t\t\t\tmin: -0.05,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t},\r\n\r\n\t\tmethods: {\r\n\t\t\tclose() {\r\n\t\t\t\tthis.$refs.popup.close()\r\n\t\t\t},\r\n\t\t\topen(val) {\r\n\t\t\t\tval == 1 ? this.typeIndex = 1 : this.typeIndex = 2;\r\n\t\t\t\t// 通过组件定义的ref调用uni-popup方法 ,如果传入参数 ，type 属性将失效 ，仅支持 ['top','left','bottom','right','center']\r\n\t\t\t\tthis.$refs.popup.open('bottom')\r\n\r\n\t\t\t\tif (val == 1) {\r\n\t\t\t\t\tconst dataKey = 'infoData'; // 同上面设置的key\r\n\t\t\t\t\tlet get = uni.getStorageSync(dataKey)\r\n\r\n\t\t\t\t\tif (!get) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"读取数据失败\"\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tuni.navigateBack({\r\n\t\t\t\t\t\t\t\tdelta: -1\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}, 2000)\r\n\t\t\t\t\t\treturn\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst data = JSON.parse(get);\r\n\t\t\t\t\tconsole.log(data)\r\n\t\t\t\t\tthis.dataInfo = data;\r\n\t\t\t\t\tthis.changeData(this.dataInfo)\r\n\t\t\t\t\tthis.list = this.dataInfo.data_msg.list;\r\n\r\n\t\t\t\t\t// 绘制\r\n\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\tthis.list = this.list.filter(val => val !== 0)\r\n\t\t\t\t\t\tconst ctx = uni.createCanvasContext('ecg', this);\r\n\t\t\t\t\t\tctx.setStrokeStyle('#d5d5d5') //\r\n\t\t\t\t\t\tctx.setLineWidth(1) // 线条宽度\r\n\t\t\t\t\t\tfor (var x = 0.5; x < 3000; x += 15) {\r\n\t\t\t\t\t\t\tctx.moveTo(x, 0)\r\n\t\t\t\t\t\t\t// 结束点\r\n\t\t\t\t\t\t\tctx.lineTo(x, 3000)\r\n\t\t\t\t\t\t\t// 描边，不调用stroke则看不到画的内容\r\n\t\t\t\t\t\t\tctx.stroke()\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tfor (var y = 0.5; y < 3000; y += 15) {\r\n\t\t\t\t\t\t\tctx.moveTo(0, y)\r\n\t\t\t\t\t\t\t// 结束点\r\n\t\t\t\t\t\t\tctx.lineTo(3000, y)\r\n\t\t\t\t\t\t\t// 描边，不调用stroke则看不到画的内容\r\n\t\t\t\t\t\t\tctx.stroke()\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t// ctx.fill();\r\n\t\t\t\t\t\tctx.draw()\r\n\t\t\t\t\t\tthis.drawCurve()\r\n\t\t\t\t\t}, 1000)\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst dataKey = 'bodyData'; // 同上面设置的key\r\n\t\t\t\t\tlet get = uni.getStorageSync(dataKey)\r\n\r\n\t\t\t\t\tif (!get) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"读取数据失败\"\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tuni.navigateBack({\r\n\t\t\t\t\t\t\t\tdelta: -1\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}, 2000)\r\n\t\t\t\t\t\treturn\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst data = JSON.parse(get);\r\n\t\t\t\t\tthis.dataInfo = data;\r\n\t\t\t\t\tconsole.log(this.dataInfo)\r\n\t\t\t\t\t// this.getUserInfo()\r\n\t\t\t\t\tthis.bodyDesc = this.$utils.getBodyKeyInfo(this.dataInfo.data_msg.BMI, 'BMI')\r\n\t\t\t\t\t// uni.removeStorageSync(dataKey);\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tdrawCurve() {\r\n\t\t\t\tlet ctx = uni.createCanvasContext('myCanvas', this)\r\n\t\t\t\tlet list = this.list;\r\n\t\t\t\tlet centerY = this.centerY;\r\n\t\t\t\tlet width = this.width;\r\n\t\t\t\tlet xScale = width / (list.length - 1); // 计算每个数据点占据的宽度\r\n\t\t\t\tlet yScale = centerY / (Math.max(...list) - Math.min(...list))\r\n\t\t\t\t// yScale *= 3\r\n\t\t\t\tlet x = 0;\r\n\t\t\t\tlet y = centerY / 2 - (list[0] * yScale)\r\n\t\t\t\tctx.beginPath(); // 开始绘制\r\n\t\t\t\tctx.moveTo(x, y);\r\n\t\t\t\tctx.setStrokeStyle('#c96d79'); // 设置线条颜色\r\n\t\t\t\tctx.setLineWidth(2); // 设置线条宽度\r\n\t\t\t\tfor (let i = 1; i < list.length; i++) {\r\n\t\t\t\t\tlet x = i * xScale;\r\n\t\t\t\t\tlet y = centerY / 2 - ((list[i] / 2) * yScale); // 负数在中心下方，正数在中心上方\r\n\t\t\t\t\tctx.lineTo(x, y);\r\n\r\n\t\t\t\t}\r\n\t\t\t\tctx.stroke() // 绘制线条\r\n\t\t\t\t// ctx.fill();\r\n\t\t\t\tctx.draw(false);\r\n\r\n\t\t\t\t// 绘制到canvas上，不需要等待上一步绘制完成\r\n\t\t\t},\r\n\r\n\t\t\tchangeData(data) {\r\n\t\t\t\tlet HRV = []\r\n\t\t\t\tlet QT = []\r\n\t\t\t\tlet heart = []\r\n\t\t\t\tlet pwv = []\r\n\t\t\t\tlet resRate = []\r\n\t\t\t\tthis.xinlv.jisuan[0].times = data.data_msg.meanHeartRate == undefined ? data.data_msg.heartRate : data\r\n\t\t\t\t\t.data_msg.meanHeartRate\r\n\t\t\t\tif (data.data_msg.wavefrom == undefined) {\r\n\t\t\t\t\treturn\r\n\t\t\t\t}\r\n\t\t\t\tdata.data_msg.wavefrom.map((v, i) => {\r\n\r\n\t\t\t\t\tif (!(v instanceof Array)) {\r\n\t\t\t\t\t\tif (v.HRV != 0) {\r\n\t\t\t\t\t\t\tHRV.push(v.HRV)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.QT != 0) {\r\n\t\t\t\t\t\t\tQT.push(v.QT)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.heart != 0 && v.heart != null) {\r\n\t\t\t\t\t\t\theart.push(v.heart)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.pwv != 0) {\r\n\t\t\t\t\t\t\tpwv.push(v.pwv)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.resRate != 0) {\r\n\t\t\t\t\t\t\tresRate.push(v.resRate)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t})\r\n\t\t\t\tthis.xinlv.jisuan[1].times = Math.max(...heart)\r\n\t\t\t\tthis.xinlv.jisuan[2].times = Math.min(...heart)\r\n\t\t\t\t// 获取心率每个区间的数据数量\r\n\t\t\t\tlet heart_zc = heart.filter(value => (value >= 60 && value <= 100)).length;\r\n\t\t\t\tlet heart_fast = heart.filter(value => value > 100).length;\r\n\t\t\t\tlet heart_slow = heart.filter(value => value < 60).length;\r\n\t\t\t\tlet heart_length = heart.length\r\n\t\t\t\tthis.xinlv.cankao[0].times = (heart_zc / heart_length).toFixed(2) * 100\r\n\t\t\t\tthis.xinlv.cankao[1].times = (heart_fast / heart_length).toFixed(2) * 100\r\n\t\t\t\tthis.xinlv.cankao[2].times = (heart_slow / heart_length).toFixed(2) * 100\r\n\t\t\t\tif (this.xinlv.cankao[0].times > 50) {\r\n\t\t\t\t\tthis.title = '窦性心率';\r\n\t\t\t\t} else if (this.xinlv.cankao[1].times >= 50) {\r\n\t\t\t\t\tthis.title = '心率偏快';\r\n\t\t\t\t} else if (this.xinlv.cankao[2].times >= 50) {\r\n\t\t\t\t\tthis.title = '心率偏慢';\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.title = '窦性心率不齐';\r\n\t\t\t\t}\r\n\t\t\t\tif (data.diseaseRisk != undefined && data.diseaseRisk >= 30 && this.xinlv.cankao[0].times > 50) {\r\n\t\t\t\t\tthis.title = '窦性心率不齐';\r\n\t\t\t\t}\r\n\t\t\t\tif (data.data_msg.hrv != undefined) {\r\n\t\t\t\t\tthis.ybx.hrv.val = data.data_msg.hrv\r\n\t\t\t\t\tthis.ybx.sdnn.val = data.data_msg.diseaseSdnn\r\n\t\t\t\t\tthis.ybx.rmssd.val = data.data_msg.diseaseRmssd\r\n\t\t\t\t\tthis.xdt.pwv.val = (data.data_msg.pwvMeanVal / 10).toFixed(2)\r\n\t\t\t\t\tthis.xdt.qtc.val = data.data_msg.QTC\r\n\t\t\t\t\tthis.xdt.qsrf.val = (data.data_msg.qrsAmp / 100).toFixed(2)\r\n\t\t\t\t\tthis.xdt.qsrx.val = data.data_msg.qrsTime\r\n\t\t\t\t\tthis.xdt.qsrfx.val = data.data_msg.leadOffType == 0 ? '向上' : '向下'\r\n\t\t\t\t\tthis.xdt.st.val = (data.data_msg.stMeanVal / 100).toFixed(2)\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconsole.log('is undefined')\r\n\t\t\t\t\tthis.ybx.hrv.val = data.data_msg.averageHRV\r\n\t\t\t\t\tthis.xdt.qtc.val = data.data_msg.averageTimeInterval\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n\t.pop-close {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: row-reverse;\r\n\t\tfont-size: 100rpx;\r\n\t\tpadding-right: 50rpx;\r\n\t}\r\n\r\n\t.pop-main {\r\n\t\twidth: 100%;\r\n\t\theight: 100vh;\r\n\t\tbackground-color: #fff;\r\n\t\toverflow-y: scroll;\r\n\t}\r\n\r\n\t.box1 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.box2 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.myScoll {\r\n\t\twidth: 100%;\r\n\t\theight: 396rpx;\r\n\t\twhite-space: nowrap;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.list {\r\n\t\tbackground-color: #fff;\r\n\t\toverflow: hidden;\r\n\t\tpadding: 30rpx;\r\n\t\tmargin: 30rpx 30rpx;\r\n\t\tborder-radius: 30rpx;\r\n\t}\r\n\r\n\t.dxxl {\r\n\t\tbackground-color: #fff;\r\n\t\tpadding: 20rpx;\r\n\t\tpadding-top: 40rpx;\r\n\t}\r\n\r\n\t.sl_box {\r\n\t\ttext-align: center;\r\n\r\n\t\t.all {\r\n\t\t\twidth: calc(100% / 3);\r\n\t\t\tmargin-top: 40rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_cankao,\r\n\t\t.sl_box_desc {\r\n\t\t\tfont-size: 24rpx;\r\n\t\t\tcolor: #999;\r\n\t\t}\r\n\r\n\t\t.sl_box_unit {\r\n\t\t\tfont-size: 26rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_wz {\r\n\t\t\tmargin-right: 10rpx;\r\n\t\t\tfont-size: 30rpx;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n</style>\r\n\r\n\r\n<style lang=\"scss\" scoped>\r\n\t.pop-close {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: row-reverse;\r\n\t\tfont-size: 100rpx;\r\n\t\tpadding-right: 50rpx;\r\n\t}\r\n\r\n\t.pop-main {\r\n\t\twidth: 60%;\r\n\t\theight: 100vh;\r\n\t\tbackground-color: #fff;\r\n\t\toverflow-y: scroll;\r\n\t}\r\n\r\n\t.box1 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.box2 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.myScoll {\r\n\t\twidth: 100%;\r\n\t\theight: 396rpx;\r\n\t\twhite-space: nowrap;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.list {\r\n\t\tbackground-color: #fff;\r\n\t\toverflow: hidden;\r\n\t\tpadding: 30rpx;\r\n\t\tmargin: 30rpx 30rpx;\r\n\t\tborder-radius: 30rpx;\r\n\t}\r\n\r\n\t.dxxl {\r\n\t\tbackground-color: #fff;\r\n\t\tpadding: 20rpx;\r\n\t\tpadding-top: 40rpx;\r\n\t}\r\n\r\n\t.sl_box {\r\n\t\ttext-align: center;\r\n\r\n\t\t.all {\r\n\t\t\twidth: calc(100% / 3);\r\n\t\t\tmargin-top: 40rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_cankao,\r\n\t\t.sl_box_desc {\r\n\t\t\tfont-size: 24rpx;\r\n\t\t\tcolor: #999;\r\n\t\t}\r\n\r\n\t\t.sl_box_unit {\r\n\t\t\tfont-size: 26rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_wz {\r\n\t\t\tmargin-right: 10rpx;\r\n\t\t\tfont-size: 30rpx;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n</style>\n\n\n<style lang=\"scss\" scoped>\n.postion{\n\tposition: absolute;\n}\n.left_position{\n\tleft: 40rpx;\n\ttop:12%\n}\n.right_position{\n\tright: 40rpx;\n\ttop:15%\n}\n.right_center{\n\tright: 160rpx;\n\ttop:42%;\n\tfont-size: 26rpx;\n}\n.center_posion{\n\twidth: 100%;\n\ttext-align: center;\n\tbottom: 20rpx;\n}\n.desc_box{\n\tmargin-bottom: 64rpx;\n\t.tt{\n\t\tfont-size: 30rpx;\n\t\tfont-weight: bold;\n\t\tmargin-right: 10rpx;\n\t}\n\t.unit{\n\t\tfont-size: 24rpx;\n\t\tcolor: #666;\n\t}\n\t.name{\n\t\tfont-size: 24rpx;\n\t\tcolor: #999;\n\t}\n}\n</style>\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///215\n"); +eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 52));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\nvar _default = {\n name: \"pop-info\",\n data: function data() {\n var _ref;\n return _ref = {\n typeIndex: 1,\n dataInfo: {},\n bodyDesc: {},\n arr: ['BMI', 'bodyFatPercentage', 'leanBodyMass', 'muscleRate', 'muscleMass', 'subcutaneousFat', 'bodyMoisture', 'skeletalMuscleRate', 'boneMass', 'proteinAmount', 'basalMetabolicRate'],\n title: '',\n list: [],\n height: 300,\n width: 3000,\n centerY: 200,\n pLeft: '0'\n }, (0, _defineProperty2.default)(_ref, \"dataInfo\", {}), (0, _defineProperty2.default)(_ref, \"xinlv\", {\n jisuan: [{\n times: 0,\n unit: '次/分',\n desc: '平均心率',\n cankao: ''\n }, {\n times: 0,\n unit: '次/分',\n desc: '最高心率',\n cankao: ''\n }, {\n times: 0,\n unit: '次/分',\n desc: '最低心率',\n cankao: ''\n }],\n cankao: [{\n times: 0,\n unit: '%',\n desc: '正常',\n cankao: '(60~100次/分)'\n }, {\n times: 0,\n unit: '%',\n desc: '心率偏快',\n cankao: '>100次/分)'\n }, {\n times: 0,\n unit: '%',\n desc: '心率偏慢',\n cankao: '(<60次/分)'\n }]\n }), (0, _defineProperty2.default)(_ref, \"ybx\", {\n hrv: {\n name: 'HRV',\n max: 210,\n unit: '毫秒',\n min: 0,\n val: 0\n },\n sdnn: {\n name: 'SDNN',\n max: 180,\n unit: '毫秒',\n min: 102,\n val: 0\n },\n rmssd: {\n name: 'RMSSD',\n max: 39,\n unit: '毫秒',\n min: 15,\n val: 0\n }\n }), (0, _defineProperty2.default)(_ref, \"xdt\", {\n pwv: {\n name: 'PWV',\n max: 15,\n unit: 'm/s',\n min: 6,\n val: 0\n },\n qtc: {\n name: 'QTc',\n max: 400,\n unit: '毫秒',\n min: 260,\n val: 0\n },\n qsrf: {\n name: 'QRS 波振幅',\n max: 1.5,\n unit: 'mV',\n min: 0.05,\n val: 0\n },\n qsrx: {\n name: 'QRS 波时限',\n max: 120,\n unit: '毫秒',\n min: 80,\n val: 0\n },\n qsrfx: {\n name: 'QRS 主波方向',\n max: 0,\n unit: '向上,向下',\n min: 0,\n val: 0\n },\n st: {\n name: 'ST 段振幅',\n max: 0.1,\n unit: 'mV',\n min: -0.05,\n val: 0\n }\n }), _ref;\n },\n methods: {\n close: function close() {\n this.$refs.popup.close();\n },\n open: function open(val) {\n var _this = this;\n val == 1 ? this.typeIndex = 1 : this.typeIndex = 2;\n // 通过组件定义的ref调用uni-popup方法 ,如果传入参数 ,type 属性将失效 ,仅支持 ['top','left','bottom','right','center']\n this.$refs.popup.open('bottom');\n if (val == 1) {\n var dataKey = 'infoData'; // 同上面设置的key\n var get = uni.getStorageSync(dataKey);\n if (!get) {\n uni.showToast({\n title: \"读取数据失败\"\n });\n setTimeout(function () {\n uni.navigateBack({\n delta: -1\n });\n }, 2000);\n return;\n }\n var data = JSON.parse(get);\n __f__(\"log\", data, \" at components/ecg-info/ecg-info.vue:377\");\n this.dataInfo = data;\n this.changeData(this.dataInfo);\n this.list = this.dataInfo.data_msg.list;\n\n // 绘制\n setTimeout(function () {\n _this.list = _this.list.filter(function (val) {\n return val !== 0;\n });\n var ctx = uni.createCanvasContext('ecg', _this);\n ctx.setStrokeStyle('#d5d5d5'); //\n ctx.setLineWidth(1); // 线条宽度\n for (var x = 0.5; x < 3000; x += 15) {\n ctx.moveTo(x, 0);\n // 结束点\n ctx.lineTo(x, 3000);\n // 描边,不调用stroke则看不到画的内容\n ctx.stroke();\n }\n for (var y = 0.5; y < 3000; y += 15) {\n ctx.moveTo(0, y);\n // 结束点\n ctx.lineTo(3000, y);\n // 描边,不调用stroke则看不到画的内容\n ctx.stroke();\n }\n // ctx.fill();\n ctx.draw();\n _this.drawCurve();\n }, 1000);\n } else {\n var _dataKey = 'bodyData'; // 同上面设置的key\n var _get = uni.getStorageSync(_dataKey);\n if (!_get) {\n uni.showToast({\n title: \"读取数据失败\"\n });\n setTimeout(function () {\n uni.navigateBack({\n delta: -1\n });\n }, 2000);\n return;\n }\n var _data = JSON.parse(_get);\n this.dataInfo = _data;\n __f__(\"log\", this.dataInfo, \" at components/ecg-info/ecg-info.vue:423\");\n // this.getUserInfo()\n this.bodyDesc = this.$utils.getBodyKeyInfo(this.dataInfo.data_msg.BMI, 'BMI');\n // uni.removeStorageSync(dataKey);\n }\n },\n drawCurve: function drawCurve() {\n var ctx = uni.createCanvasContext('myCanvas', this);\n var list = this.list;\n var centerY = this.centerY;\n var width = this.width;\n var xScale = width / (list.length - 1); // 计算每个数据点占据的宽度\n var yScale = centerY / (Math.max.apply(Math, (0, _toConsumableArray2.default)(list)) - Math.min.apply(Math, (0, _toConsumableArray2.default)(list)));\n // yScale *= 3\n var x = 0;\n var y = centerY / 2 - list[0] * yScale;\n ctx.beginPath(); // 开始绘制\n ctx.moveTo(x, y);\n ctx.setStrokeStyle('#c96d79'); // 设置线条颜色\n ctx.setLineWidth(2); // 设置线条宽度\n for (var i = 1; i < list.length; i++) {\n var _x = i * xScale;\n var _y = centerY / 2 - list[i] / 2 * yScale; // 负数在中心下方,正数在中心上方\n ctx.lineTo(_x, _y);\n }\n ctx.stroke(); // 绘制线条\n // ctx.fill();\n ctx.draw(false);\n\n // 绘制到canvas上,不需要等待上一步绘制完成\n },\n changeData: function changeData(data) {\n var HRV = [];\n var QT = [];\n var heart = [];\n var pwv = [];\n var resRate = [];\n this.xinlv.jisuan[0].times = data.data_msg.meanHeartRate == undefined ? data.data_msg.heartRate : data.data_msg.meanHeartRate;\n if (data.data_msg.wavefrom == undefined) {\n return;\n }\n data.data_msg.wavefrom.map(function (v, i) {\n if (!(v instanceof Array)) {\n if (v.HRV != 0) {\n HRV.push(v.HRV);\n }\n if (v.QT != 0) {\n QT.push(v.QT);\n }\n if (v.heart != 0 && v.heart != null) {\n heart.push(v.heart);\n }\n if (v.pwv != 0) {\n pwv.push(v.pwv);\n }\n if (v.resRate != 0) {\n resRate.push(v.resRate);\n }\n }\n });\n this.xinlv.jisuan[1].times = Math.max.apply(Math, heart);\n this.xinlv.jisuan[2].times = Math.min.apply(Math, heart);\n // 获取心率每个区间的数据数量\n var heart_zc = heart.filter(function (value) {\n return value >= 60 && value <= 100;\n }).length;\n var heart_fast = heart.filter(function (value) {\n return value > 100;\n }).length;\n var heart_slow = heart.filter(function (value) {\n return value < 60;\n }).length;\n var heart_length = heart.length;\n this.xinlv.cankao[0].times = (heart_zc / heart_length).toFixed(2) * 100;\n this.xinlv.cankao[1].times = (heart_fast / heart_length).toFixed(2) * 100;\n this.xinlv.cankao[2].times = (heart_slow / heart_length).toFixed(2) * 100;\n if (this.xinlv.cankao[0].times > 50) {\n this.title = '窦性心率';\n } else if (this.xinlv.cankao[1].times >= 50) {\n this.title = '心率偏快';\n } else if (this.xinlv.cankao[2].times >= 50) {\n this.title = '心率偏慢';\n } else {\n this.title = '窦性心率不齐';\n }\n if (data.diseaseRisk != undefined && data.diseaseRisk >= 30 && this.xinlv.cankao[0].times > 50) {\n this.title = '窦性心率不齐';\n }\n if (data.data_msg.hrv != undefined) {\n this.ybx.hrv.val = data.data_msg.hrv;\n this.ybx.sdnn.val = data.data_msg.diseaseSdnn;\n this.ybx.rmssd.val = data.data_msg.diseaseRmssd;\n this.xdt.pwv.val = (data.data_msg.pwvMeanVal / 10).toFixed(2);\n this.xdt.qtc.val = data.data_msg.QTC;\n this.xdt.qsrf.val = (data.data_msg.qrsAmp / 100).toFixed(2);\n this.xdt.qsrx.val = data.data_msg.qrsTime;\n this.xdt.qsrfx.val = data.data_msg.leadOffType == 0 ? '向上' : '向下';\n this.xdt.st.val = (data.data_msg.stMeanVal / 100).toFixed(2);\n } else {\n __f__(\"log\", 'is undefined', \" at components/ecg-info/ecg-info.vue:522\");\n this.ybx.hrv.val = data.data_msg.averageHRV;\n this.xdt.qtc.val = data.data_msg.averageTimeInterval;\n }\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/ecg-info/ecg-info.vue"],"names":["name","data","typeIndex","dataInfo","bodyDesc","arr","title","list","height","width","centerY","pLeft","jisuan","times","unit","desc","cankao","hrv","max","min","val","sdnn","rmssd","pwv","qtc","qsrf","qsrx","qsrfx","st","methods","close","open","uni","setTimeout","delta","ctx","drawCurve","changeData","data_msg","HRV","QT","heart","resRate"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAiNA;EACAA;EACAC;IAAA;IACA;MACAC;MACAC;MACAC;MACAC,MACA,OACA,qBACA,gBACA,cACA,cACA,mBACA,gBACA,sBACA,YACA,iBACA,qBACA;MAGAC;MACAC;MAEAC;MACAC;MACAC;MACAC;IAAA,mDACA,kDACA;MACAC;QACAC;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,EACA;MACAA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA,GACA;QACAH;QACAC;QACAC;QACAC;MACA;IAGA,+CAEA;MACAC;QACAjB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAC;QACArB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAE;QACAtB;QACAkB;QACAJ;QACAK;QACAC;MACA;IACA,+CACA;MACAG;QACAvB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAI;QACAxB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAK;QACAzB;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAM;QACA1B;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAO;QACA3B;QACAkB;QACAJ;QACAK;QACAC;MACA;MACAQ;QACA5B;QACAkB;QACAJ;QACAK;QACAC;MACA;IACA;EAEA;EAEAS;IACAC;MACA;IACA;IACAC;MAAA;MACAX;MACA;MACA;MAEA;QACA;QACA;QAEA;UACAY;YACA1B;UACA;UACA2B;YACAD;cACAE;YACA;UACA;UACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACAD;UACA;YAAA;UAAA;UACA;UACAE;UACAA;UACA;YACAA;YACA;YACAA;YACA;YACAA;UACA;UACA;YACAA;YACA;YACAA;YACA;YACAA;UACA;UACA;UACAA;UACA;QACA;MACA;QACA;QACA;QAEA;UACAH;YACA1B;UACA;UACA2B;YACAD;cACAE;YACA;UACA;UACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;MACA;IACA;IAEAE;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACAD;MACAA;MACAA;MACAA;MACA;QACA;QACA;QACAA;MAEA;MACAA;MACA;MACAA;;MAEA;IACA;IAEAE;MACA;MACA;MACA;MACA;MACA;MACA,uGACAC;MACA;QACA;MACA;MACArC;QAEA;UACA;YACAsC;UACA;UACA;YACAC;UACA;UACA;YACAC;UACA;UACA;YACAlB;UACA;UACA;YACAmB;UACA;QACA;MAEA;MACA;MACA;MACA;MACA;QAAA;MAAA;MACA;QAAA;MAAA;MACA;QAAA;MAAA;MACA;MACA;MACA;MACA;MACA;QACA;MACA;QACA;MACA;QACA;MACA;QACA;MACA;MACA;QACA;MACA;MACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;MACA;QACA;QACA;QACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"215.js","sourcesContent":["<template>\r\n\t<view class=\"content\" style=\"width: 60%;\">\r\n\t\t<uni-popup ref=\"popup\" type=\"bottom\" border-radius=\"10px 10px 0 0\">\r\n\t\t\t<view class=\"main\">\n\t\t\t\t<view class=\"pop-main\" v-if=\"typeIndex == 1\">\n\t\t\t\t\t<view class=\"pops\">\n\t\t\t\t\t\t<view class=\"pop-close\" @click=\"close()\">\n\t\t\t\t\t\t\t×\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"dxxl\">\n\t\t\t\t\t\t\t<scroll-view class=\"myScoll\" scroll-x :show-scrollbar=\"true\">\n\t\t\t\t\t\t\t\t<view class=\"box1\">\n\t\t\t\t\t\t\t\t\t<canvas canvas-id=\"ecg\" style=\"width: 3000px; height: 300px;\"></canvas>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"box2\" :style=\"{'left': pLeft + 'px'}\">\n\t\t\t\t\t\t\t\t\t<canvas canvas-id=\"myCanvas\" style=\"width: 3000px; height: 300px;\"></canvas>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</scroll-view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"list\">\n\t\t\t\t\t\t\t<view class=\"flx flx_ac \">\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\n\t\t\t\t\t\t\t\t\t</image>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\n\t\t\t\t\t\t\t\t\t心率\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"flx flx_sb sl_box flx_wp\">\n\t\t\t\t\t\t\t\t<view class=\"all\" v-for=\"(item,index) in xinlv.jisuan\">\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t<span class=\"sl_box_wz\">{{item.times?item.times:0}}</span>\n\t\t\t\t\t\t\t\t\t\t<span class=\"sl_box_unit\">{{item.unit}}</span>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"sl_box_desc\">\n\t\t\t\t\t\t\t\t\t\t{{item.desc}}\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"sl_box_cankao\" v-if=\"item.cankao\">\n\t\t\t\t\t\t\t\t\t\t{{item.cankao}}\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"all\" v-for=\"(item,index) in xinlv.cankao\">\n\t\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t\t<span class=\"sl_box_wz\">{{item.times.toFixed(2)}}</span>\n\t\t\t\t\t\t\t\t\t\t<span class=\"sl_box_unit\">{{item.unit}}</span>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"sl_box_desc\">\n\t\t\t\t\t\t\t\t\t\t{{item.desc}}\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"sl_box_cankao\" v-if=\"item.cankao\">\n\t\t\t\t\t\t\t\t\t\t{{item.cankao}}\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"list\">\n\t\t\t\t\t\t\t<view class=\"flx flx_ac \">\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\n\t\t\t\t\t\t\t\t\t</image>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\n\t\t\t\t\t\t\t\t\t心率变异性\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t<xdt :datas=\"ybx.hrv\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"ybx.sdnn\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"ybx.rmssd\"></xdt>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"list\">\n\t\t\t\t\t\t\t<view class=\"flx flx_ac \">\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"margin-top: 10rpx;margin-right: 10rpx;\">\n\t\t\t\t\t\t\t\t\t<image src=\"../../static/icon/xinlv-small.png\" style=\"width: 40rpx;\" mode=\"widthFix\">\n\t\t\t\t\t\t\t\t\t</image>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\" style=\"color: red;\">\n\t\t\t\t\t\t\t\t\t心电图\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.pwv\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.qtc\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrf\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrx\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.qsrfx\"></xdt>\n\t\t\t\t\t\t\t\t<xdt :datas=\"xdt.st\"></xdt>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view class=\"\" style=\"height: 20rpx;\"></view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t\n\t\t\t\t<view class=\"pop-main\" v-if=\"typeIndex == 2\">\n\t\t\t\t\t<view class=\"pops\">\n\t\t\t\t\t\t<view class=\"pop-close\" @click=\"close()\">\n\t\t\t\t\t\t\t×\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view>\n\t\t\t\t\t\t\t<view class=\"flx flx_ac\" style=\"background-color: #fff;padding: 30rpx 0 0 30rpx;\">\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<text class=\"iconfont icon-wode\"\n\t\t\t\t\t\t\t\t\t\t:style=\"'font-size: 50rpx;margin-right:10rpx;color:' + bodyDesc.color \"></text>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"\">\n\t\t\t\t\t\t\t\t\t<text>{{bodyDesc.name}}</text>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"\" style=\"position: relative;\">\n\t\t\t\t\t\t\t\t<image src=\"../../static/image/body.png\" style=\"width: 100%;\" mode=\"widthFix\"></image>\n\t\t\t\t\t\t\t\t<view class=\"left_position postion \">\n\t\t\t\t\t\t\t\t\t<view class=\"desc_box\">\n\t\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\n\t\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.basalMetabolicRate }}\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\n\t\t\t\t\t\t\t\t\t\t\t\t千卡\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t\t\t\t\t\t基础代谢\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"desc_box\">\n\t\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\n\t\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.boneMass }}\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\n\t\t\t\t\t\t\t\t\t\t\t\t千克\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t\t\t\t\t\t骨重\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"desc_box\">\n\t\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\n\t\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.waterContent }}\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\n\t\t\t\t\t\t\t\t\t\t\t\t千克\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t\t\t\t\t\t水分\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"right_position postion\">\n\t\t\t\t\t\t\t\t\t<view class=\"desc_box\">\n\t\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\n\t\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.fatMass }}\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\n\t\t\t\t\t\t\t\t\t\t\t\t千克\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t\t\t\t\t\t脂肪\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t<view class=\"desc_box\" style=\"margin-bottom: 0;margin-top: 174rpx;\">\n\t\t\t\t\t\t\t\t\t\t<view class=\"flx flx_ac\">\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"tt\">\n\t\t\t\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.proteinAmount }}\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t\t<view class=\"unit\">\n\t\t\t\t\t\t\t\t\t\t\t\t千克\n\t\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t\t\t\t\t\t蛋白质\n\t\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"postion center_posion\">\n\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.userInfo.gender == '2'?'女':'男' }}性，{{ dataInfo.data_msg.userInfo.weight  }}千克\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t\t<view class=\"postion right_center\">\n\t\t\t\t\t\t\t\t\t{{ dataInfo.data_msg.userInfo.height  }}厘米\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"radius_box\" style=\"padding: 0;margin: 30rpx;\">\n\t\t\t\t\t\t\t\t<view class=\"\" v-for=\"(v,i) in arr\" :key=\"i\">\n\t\t\t\t\t\t\t\t\t<body_info_components :key_name=\"v\" :value=\"parseFloat(dataInfo.data_msg[v])\">\n\t\t\t\t\t\t\t\t\t</body_info_components>\n\t\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t\t<view class=\"\" style=\"height: 40rpx;\">\n\t\t\t\t\n\t\t\t\t\t\t\t</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\n\t\t\t\t\t\t<view class=\"\" style=\"height: 20rpx;\"></view>\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\r\n\t\t</uni-popup>\r\n\t</view>\r\n</template>\r\n\r\n<script>\r\n\texport default {\r\n\t\tname: \"pop-info\",\r\n\t\tdata() {\r\n\t\t\treturn {\r\n\t\t\t\ttypeIndex: 1,\r\n\t\t\t\tdataInfo: {},\r\n\t\t\t\tbodyDesc: {},\r\n\t\t\t\tarr: [\r\n\t\t\t\t\t'BMI',\r\n\t\t\t\t\t'bodyFatPercentage',\r\n\t\t\t\t\t'leanBodyMass',\r\n\t\t\t\t\t'muscleRate',\r\n\t\t\t\t\t'muscleMass',\r\n\t\t\t\t\t'subcutaneousFat',\r\n\t\t\t\t\t'bodyMoisture',\r\n\t\t\t\t\t'skeletalMuscleRate',\r\n\t\t\t\t\t'boneMass',\r\n\t\t\t\t\t'proteinAmount',\r\n\t\t\t\t\t'basalMetabolicRate',\r\n\t\t\t\t],\r\n\r\n\r\n\t\t\t\ttitle: '',\r\n\t\t\t\tlist: [],\r\n\r\n\t\t\t\theight: 300,\r\n\t\t\t\twidth: 3000,\r\n\t\t\t\tcenterY: 200,\r\n\t\t\t\tpLeft: '0',\r\n\t\t\t\tdataInfo: {},\r\n\t\t\t\txinlv: {\r\n\t\t\t\t\tjisuan: [{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '平均心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '最高心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '次/分',\r\n\t\t\t\t\t\t\tdesc: '最低心率',\r\n\t\t\t\t\t\t\tcankao: ''\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\t\t\tcankao: [{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '正常',\r\n\t\t\t\t\t\t\tcankao: '(60~100次/分)'\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '心率偏快',\r\n\t\t\t\t\t\t\tcankao: '>100次/分)'\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\ttimes: 0,\r\n\t\t\t\t\t\t\tunit: '%',\r\n\t\t\t\t\t\t\tdesc: '心率偏慢',\r\n\t\t\t\t\t\t\tcankao: '(<60次/分)'\r\n\t\t\t\t\t\t},\r\n\r\n\t\t\t\t\t],\r\n\t\t\t\t},\r\n\t\t\t\t// 心率异变性\r\n\t\t\t\tybx: {\r\n\t\t\t\t\thrv: {\r\n\t\t\t\t\t\tname: 'HRV',\r\n\t\t\t\t\t\tmax: 210,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 0,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tsdnn: {\r\n\t\t\t\t\t\tname: 'SDNN',\r\n\t\t\t\t\t\tmax: 180,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 102,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\trmssd: {\r\n\t\t\t\t\t\tname: 'RMSSD',\r\n\t\t\t\t\t\tmax: 39,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 15,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\txdt: {\r\n\t\t\t\t\tpwv: {\r\n\t\t\t\t\t\tname: 'PWV',\r\n\t\t\t\t\t\tmax: 15,\r\n\t\t\t\t\t\tunit: 'm/s',\r\n\t\t\t\t\t\tmin: 6,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqtc: {\r\n\t\t\t\t\t\tname: 'QTc',\r\n\t\t\t\t\t\tmax: 400,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 260,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrf: {\r\n\t\t\t\t\t\tname: 'QRS 波振幅',\r\n\t\t\t\t\t\tmax: 1.5,\r\n\t\t\t\t\t\tunit: 'mV',\r\n\t\t\t\t\t\tmin: 0.05,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrx: {\r\n\t\t\t\t\t\tname: 'QRS 波时限',\r\n\t\t\t\t\t\tmax: 120,\r\n\t\t\t\t\t\tunit: '毫秒',\r\n\t\t\t\t\t\tmin: 80,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tqsrfx: {\r\n\t\t\t\t\t\tname: 'QRS 主波方向',\r\n\t\t\t\t\t\tmax: 0,\r\n\t\t\t\t\t\tunit: '向上，向下',\r\n\t\t\t\t\t\tmin: 0,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t},\r\n\t\t\t\t\tst: {\r\n\t\t\t\t\t\tname: 'ST 段振幅',\r\n\t\t\t\t\t\tmax: 0.1,\r\n\t\t\t\t\t\tunit: 'mV',\r\n\t\t\t\t\t\tmin: -0.05,\r\n\t\t\t\t\t\tval: 0\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t},\r\n\r\n\t\tmethods: {\r\n\t\t\tclose() {\r\n\t\t\t\tthis.$refs.popup.close()\r\n\t\t\t},\r\n\t\t\topen(val) {\r\n\t\t\t\tval == 1 ? this.typeIndex = 1 : this.typeIndex = 2;\r\n\t\t\t\t// 通过组件定义的ref调用uni-popup方法 ,如果传入参数 ，type 属性将失效 ，仅支持 ['top','left','bottom','right','center']\r\n\t\t\t\tthis.$refs.popup.open('bottom')\r\n\r\n\t\t\t\tif (val == 1) {\r\n\t\t\t\t\tconst dataKey = 'infoData'; // 同上面设置的key\r\n\t\t\t\t\tlet get = uni.getStorageSync(dataKey)\r\n\r\n\t\t\t\t\tif (!get) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"读取数据失败\"\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tuni.navigateBack({\r\n\t\t\t\t\t\t\t\tdelta: -1\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}, 2000)\r\n\t\t\t\t\t\treturn\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst data = JSON.parse(get);\r\n\t\t\t\t\tconsole.log(data)\r\n\t\t\t\t\tthis.dataInfo = data;\r\n\t\t\t\t\tthis.changeData(this.dataInfo)\r\n\t\t\t\t\tthis.list = this.dataInfo.data_msg.list;\r\n\r\n\t\t\t\t\t// 绘制\r\n\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\tthis.list = this.list.filter(val => val !== 0)\r\n\t\t\t\t\t\tconst ctx = uni.createCanvasContext('ecg', this);\r\n\t\t\t\t\t\tctx.setStrokeStyle('#d5d5d5') //\r\n\t\t\t\t\t\tctx.setLineWidth(1) // 线条宽度\r\n\t\t\t\t\t\tfor (var x = 0.5; x < 3000; x += 15) {\r\n\t\t\t\t\t\t\tctx.moveTo(x, 0)\r\n\t\t\t\t\t\t\t// 结束点\r\n\t\t\t\t\t\t\tctx.lineTo(x, 3000)\r\n\t\t\t\t\t\t\t// 描边，不调用stroke则看不到画的内容\r\n\t\t\t\t\t\t\tctx.stroke()\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tfor (var y = 0.5; y < 3000; y += 15) {\r\n\t\t\t\t\t\t\tctx.moveTo(0, y)\r\n\t\t\t\t\t\t\t// 结束点\r\n\t\t\t\t\t\t\tctx.lineTo(3000, y)\r\n\t\t\t\t\t\t\t// 描边，不调用stroke则看不到画的内容\r\n\t\t\t\t\t\t\tctx.stroke()\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t// ctx.fill();\r\n\t\t\t\t\t\tctx.draw()\r\n\t\t\t\t\t\tthis.drawCurve()\r\n\t\t\t\t\t}, 1000)\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconst dataKey = 'bodyData'; // 同上面设置的key\r\n\t\t\t\t\tlet get = uni.getStorageSync(dataKey)\r\n\r\n\t\t\t\t\tif (!get) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: \"读取数据失败\"\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tuni.navigateBack({\r\n\t\t\t\t\t\t\t\tdelta: -1\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}, 2000)\r\n\t\t\t\t\t\treturn\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst data = JSON.parse(get);\r\n\t\t\t\t\tthis.dataInfo = data;\r\n\t\t\t\t\tconsole.log(this.dataInfo)\r\n\t\t\t\t\t// this.getUserInfo()\r\n\t\t\t\t\tthis.bodyDesc = this.$utils.getBodyKeyInfo(this.dataInfo.data_msg.BMI, 'BMI')\r\n\t\t\t\t\t// uni.removeStorageSync(dataKey);\r\n\t\t\t\t}\r\n\t\t\t},\r\n\r\n\t\t\tdrawCurve() {\r\n\t\t\t\tlet ctx = uni.createCanvasContext('myCanvas', this)\r\n\t\t\t\tlet list = this.list;\r\n\t\t\t\tlet centerY = this.centerY;\r\n\t\t\t\tlet width = this.width;\r\n\t\t\t\tlet xScale = width / (list.length - 1); // 计算每个数据点占据的宽度\r\n\t\t\t\tlet yScale = centerY / (Math.max(...list) - Math.min(...list))\r\n\t\t\t\t// yScale *= 3\r\n\t\t\t\tlet x = 0;\r\n\t\t\t\tlet y = centerY / 2 - (list[0] * yScale)\r\n\t\t\t\tctx.beginPath(); // 开始绘制\r\n\t\t\t\tctx.moveTo(x, y);\r\n\t\t\t\tctx.setStrokeStyle('#c96d79'); // 设置线条颜色\r\n\t\t\t\tctx.setLineWidth(2); // 设置线条宽度\r\n\t\t\t\tfor (let i = 1; i < list.length; i++) {\r\n\t\t\t\t\tlet x = i * xScale;\r\n\t\t\t\t\tlet y = centerY / 2 - ((list[i] / 2) * yScale); // 负数在中心下方，正数在中心上方\r\n\t\t\t\t\tctx.lineTo(x, y);\r\n\r\n\t\t\t\t}\r\n\t\t\t\tctx.stroke() // 绘制线条\r\n\t\t\t\t// ctx.fill();\r\n\t\t\t\tctx.draw(false);\r\n\r\n\t\t\t\t// 绘制到canvas上，不需要等待上一步绘制完成\r\n\t\t\t},\r\n\r\n\t\t\tchangeData(data) {\r\n\t\t\t\tlet HRV = []\r\n\t\t\t\tlet QT = []\r\n\t\t\t\tlet heart = []\r\n\t\t\t\tlet pwv = []\r\n\t\t\t\tlet resRate = []\r\n\t\t\t\tthis.xinlv.jisuan[0].times = data.data_msg.meanHeartRate == undefined ? data.data_msg.heartRate : data\r\n\t\t\t\t\t.data_msg.meanHeartRate\r\n\t\t\t\tif (data.data_msg.wavefrom == undefined) {\r\n\t\t\t\t\treturn\r\n\t\t\t\t}\r\n\t\t\t\tdata.data_msg.wavefrom.map((v, i) => {\r\n\r\n\t\t\t\t\tif (!(v instanceof Array)) {\r\n\t\t\t\t\t\tif (v.HRV != 0) {\r\n\t\t\t\t\t\t\tHRV.push(v.HRV)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.QT != 0) {\r\n\t\t\t\t\t\t\tQT.push(v.QT)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.heart != 0 && v.heart != null) {\r\n\t\t\t\t\t\t\theart.push(v.heart)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.pwv != 0) {\r\n\t\t\t\t\t\t\tpwv.push(v.pwv)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (v.resRate != 0) {\r\n\t\t\t\t\t\t\tresRate.push(v.resRate)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t})\r\n\t\t\t\tthis.xinlv.jisuan[1].times = Math.max(...heart)\r\n\t\t\t\tthis.xinlv.jisuan[2].times = Math.min(...heart)\r\n\t\t\t\t// 获取心率每个区间的数据数量\r\n\t\t\t\tlet heart_zc = heart.filter(value => (value >= 60 && value <= 100)).length;\r\n\t\t\t\tlet heart_fast = heart.filter(value => value > 100).length;\r\n\t\t\t\tlet heart_slow = heart.filter(value => value < 60).length;\r\n\t\t\t\tlet heart_length = heart.length\r\n\t\t\t\tthis.xinlv.cankao[0].times = (heart_zc / heart_length).toFixed(2) * 100\r\n\t\t\t\tthis.xinlv.cankao[1].times = (heart_fast / heart_length).toFixed(2) * 100\r\n\t\t\t\tthis.xinlv.cankao[2].times = (heart_slow / heart_length).toFixed(2) * 100\r\n\t\t\t\tif (this.xinlv.cankao[0].times > 50) {\r\n\t\t\t\t\tthis.title = '窦性心率';\r\n\t\t\t\t} else if (this.xinlv.cankao[1].times >= 50) {\r\n\t\t\t\t\tthis.title = '心率偏快';\r\n\t\t\t\t} else if (this.xinlv.cankao[2].times >= 50) {\r\n\t\t\t\t\tthis.title = '心率偏慢';\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.title = '窦性心率不齐';\r\n\t\t\t\t}\r\n\t\t\t\tif (data.diseaseRisk != undefined && data.diseaseRisk >= 30 && this.xinlv.cankao[0].times > 50) {\r\n\t\t\t\t\tthis.title = '窦性心率不齐';\r\n\t\t\t\t}\r\n\t\t\t\tif (data.data_msg.hrv != undefined) {\r\n\t\t\t\t\tthis.ybx.hrv.val = data.data_msg.hrv\r\n\t\t\t\t\tthis.ybx.sdnn.val = data.data_msg.diseaseSdnn\r\n\t\t\t\t\tthis.ybx.rmssd.val = data.data_msg.diseaseRmssd\r\n\t\t\t\t\tthis.xdt.pwv.val = (data.data_msg.pwvMeanVal / 10).toFixed(2)\r\n\t\t\t\t\tthis.xdt.qtc.val = data.data_msg.QTC\r\n\t\t\t\t\tthis.xdt.qsrf.val = (data.data_msg.qrsAmp / 100).toFixed(2)\r\n\t\t\t\t\tthis.xdt.qsrx.val = data.data_msg.qrsTime\r\n\t\t\t\t\tthis.xdt.qsrfx.val = data.data_msg.leadOffType == 0 ? '向上' : '向下'\r\n\t\t\t\t\tthis.xdt.st.val = (data.data_msg.stMeanVal / 100).toFixed(2)\r\n\t\t\t\t} else {\r\n\t\t\t\t\tconsole.log('is undefined')\r\n\t\t\t\t\tthis.ybx.hrv.val = data.data_msg.averageHRV\r\n\t\t\t\t\tthis.xdt.qtc.val = data.data_msg.averageTimeInterval\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n</script>\r\n\r\n<style lang=\"scss\" scoped>\r\n\t.pop-close {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: row-reverse;\r\n\t\tfont-size: 100rpx;\r\n\t\tpadding-right: 50rpx;\r\n\t}\n\t\r\n\t.pop-main {\r\n\t\twidth: 100%;\r\n\t\theight: 100vh;\r\n\t\tbackground-color: #fff;\r\n\t\toverflow-y: scroll;\n\t\tpadding: 50rpx;\n\t}\n\t\n\t.pops {\n\t\tborder: 1rpx solid gray;\n\t\tborder-radius: 20rpx;\n\t\tmargin: 50rpx;\n\t\tmargin-top: 100rpx;\n\t}\r\n\r\n\t.box1 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.box2 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.myScoll {\r\n\t\twidth: 100%;\r\n\t\theight: 396rpx;\r\n\t\twhite-space: nowrap;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.list {\r\n\t\tbackground-color: #fff;\r\n\t\toverflow: hidden;\r\n\t\tpadding: 30rpx;\r\n\t\tmargin: 30rpx 30rpx;\r\n\t\tborder-radius: 30rpx;\r\n\t}\r\n\r\n\t.dxxl {\r\n\t\tbackground-color: #fff;\r\n\t\tpadding: 20rpx;\r\n\t\tpadding-top: 40rpx;\r\n\t}\r\n\r\n\t.sl_box {\r\n\t\ttext-align: center;\r\n\r\n\t\t.all {\r\n\t\t\twidth: calc(100% / 3);\r\n\t\t\tmargin-top: 40rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_cankao,\r\n\t\t.sl_box_desc {\r\n\t\t\tfont-size: 24rpx;\r\n\t\t\tcolor: #999;\r\n\t\t}\r\n\r\n\t\t.sl_box_unit {\r\n\t\t\tfont-size: 26rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_wz {\r\n\t\t\tmargin-right: 10rpx;\r\n\t\t\tfont-size: 30rpx;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n</style>\r\n\r\n\r\n<style lang=\"scss\" scoped>\r\n\t.pop-close {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: row-reverse;\r\n\t\tfont-size: 100rpx;\r\n\t\tpadding-right: 50rpx;\n\t\tmargin-top: 50rpx;\r\n\t}\r\n\r\n\t.pop-main {\r\n\t\twidth: 60%;\r\n\t\theight: 100vh;\r\n\t\tbackground-color: #fff;\r\n\t\toverflow-y: scroll;\r\n\t}\r\n\r\n\t.box1 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.box2 {\r\n\t\tposition: absolute;\r\n\t\tleft: 0px;\r\n\t\twidth: 3000rpx;\r\n\t}\r\n\r\n\t.myScoll {\r\n\t\twidth: 100%;\r\n\t\theight: 396rpx;\r\n\t\twhite-space: nowrap;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.list {\r\n\t\tbackground-color: #fff;\r\n\t\toverflow: hidden;\r\n\t\tpadding: 30rpx;\r\n\t\tmargin: 30rpx 30rpx;\r\n\t\tborder-radius: 30rpx;\r\n\t}\r\n\r\n\t.dxxl {\r\n\t\tbackground-color: #fff;\r\n\t\tpadding: 20rpx;\r\n\t\tpadding-top: 40rpx;\r\n\t}\r\n\r\n\t.sl_box {\r\n\t\ttext-align: center;\r\n\r\n\t\t.all {\r\n\t\t\twidth: calc(100% / 3);\r\n\t\t\tmargin-top: 40rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_cankao,\r\n\t\t.sl_box_desc {\r\n\t\t\tfont-size: 24rpx;\r\n\t\t\tcolor: #999;\r\n\t\t}\r\n\r\n\t\t.sl_box_unit {\r\n\t\t\tfont-size: 26rpx;\r\n\t\t}\r\n\r\n\t\t.sl_box_wz {\r\n\t\t\tmargin-right: 10rpx;\r\n\t\t\tfont-size: 30rpx;\r\n\t\t\tfont-weight: bold;\r\n\t\t}\r\n\t}\r\n</style>\n\n\n<style lang=\"scss\" scoped>\n.postion{\n\tposition: absolute;\n}\n.left_position{\n\tleft: 40rpx;\n\ttop:12%\n}\n.right_position{\n\tright: 40rpx;\n\ttop:15%\n}\n.right_center{\n\tright: 160rpx;\n\ttop:42%;\n\tfont-size: 26rpx;\n}\n.center_posion{\n\twidth: 100%;\n\ttext-align: center;\n\tbottom: 20rpx;\n}\n.desc_box{\n\tmargin-bottom: 64rpx;\n\t.tt{\n\t\tfont-size: 30rpx;\n\t\tfont-weight: bold;\n\t\tmargin-right: 10rpx;\n\t}\n\t.unit{\n\t\tfont-size: 24rpx;\n\t\tcolor: #666;\n\t}\n\t.name{\n\t\tfont-size: 24rpx;\n\t\tcolor: #999;\n\t}\n}\n</style>\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///215\n"); /***/ }), /* 216 */ @@ -15053,7 +15160,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _App /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 52));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\nvar _utils = __webpack_require__(/*! @/utils/utils.js */ 146);\nvar _vuex = __webpack_require__(/*! vuex */ 65);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar _default = {\n props: {\n activeType: {\n type: String,\n default: ''\n }\n },\n data: function data() {\n return {\n customType: [\n // 'bodyData',\n // 'bloodLiquid',\n // 'bloodLiquidAll',\n // 'ECGData'\n ],\n blData: [{\n name: '总胆固醇',\n color: '#46b4ff'\n }, {\n name: '甘油三酯',\n color: '#29cf6c'\n }, {\n name: '高密度脂蛋白',\n color: '#fcc05d'\n }, {\n name: '低密度脂蛋白',\n color: '#fa4e33'\n }],\n desc: '',\n dataList: [],\n keyNameMap: {\n bloodGlucose: \"血糖\",\n bloodOxygen: \"血氧\",\n bloodPressure: '血压',\n pulseReat: '心率',\n bloodLiquid: \"尿酸\",\n meiTuo: '梅脱',\n updataDate: '更新时间',\n bodyTemperature: '体温',\n ECGData: '心电图',\n stepIndex: '步数',\n bodyData: '身体成分',\n bloodLiquidAll: '血脂'\n },\n time: new Date().toISOString().substring(0, 10),\n flag: true,\n successList: ['1676995200000'],\n errorList: ['1676908800000'],\n showPopup: false,\n ecgData: [],\n bodyData: []\n };\n },\n mounted: function mounted() {\n var _this = this;\n // 初始化\n this.$refs.calendar.initCalendar();\n this.queryList();\n // 模拟异步赋值\n var timer = setTimeout(function () {\n _this.addTimer();\n }, 2000);\n },\n // onShow(e) {\n // \tlet routes = getCurrentPages(); // 获取当前打开过的页面路由数组\n // \tlet curRoute = routes[routes.length - 1].route //获取当前页面路由\n // \tlet curParam = routes[routes.length - 1].options; //获取路由参数\n // \t// 拼接参数\n // \tlet param = ''\n // \tfor (let key in curParam) {\n // \t param += '&' + key + '=' + curParam[key]\n // \t}\n\n computed: _objectSpread({}, (0, _vuex.mapGetters)({\n getActiceDevice: \"api/getActiceDevice\"\n })),\n methods: {\n goInfo: function goInfo(idx) {\n if (this.activeType == 'ECGData') {\n uni.setStorageSync('infoData', JSON.stringify(this.dataList[idx]));\n this.$refs.popShow.open(1);\n }\n if (this.activeType == 'bodyData') {\n uni.setStorageSync('bodyData', JSON.stringify(this.dataList[idx]));\n this.$refs.popShow.open(2);\n }\n },\n getArrMaxValue: _utils.getArrMaxValue,\n queryList: function queryList() {\n var _this2 = this;\n var type = '';\n if (this.activeType == 'step') {\n type = 'step_split';\n } else {\n type = this.activeType;\n }\n ;\n if (this.activeType == 'bloodLiquidAll') {\n type = 'bloodLiquid';\n } else {\n type = this.activeType;\n }\n ;\n this.$store.dispatch('api/getDeviceListDays', {\n type: type,\n device_real_time: this.time,\n device_id: this.getActiceDevice.device_id\n }).then(function (res) {\n _this2.dataList = res.data;\n __f__(\"log\", _this2.dataList, \" at components/all-data/all-data.vue:209\");\n });\n },\n getNameByKey: function getNameByKey(key) {\n return this.keyNameMap[key] || \"Key not found\";\n },\n addTimer: function addTimer() {\n this.successList = [].concat((0, _toConsumableArray2.default)(this.successList), ['1681920000000']);\n },\n // 点击某一天\n chooseDay: function chooseDay(val) {\n this.time = val.year + '-' + val.month + '-' + val.day;\n this.queryList();\n },\n back: function back() {\n if (this.activeType == 'ECGData' || this.activeType == 'bodyData') {\n this.$emit('back', 1);\n } else {\n this.$emit('back', 2);\n }\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/all-data/all-data.vue"],"names":["props","activeType","type","default","data","customType","blData","name","color","desc","dataList","keyNameMap","bloodGlucose","bloodOxygen","bloodPressure","pulseReat","bloodLiquid","meiTuo","updataDate","bodyTemperature","ECGData","stepIndex","bodyData","bloodLiquidAll","time","flag","successList","errorList","showPopup","ecgData","mounted","computed","getActiceDevice","methods","goInfo","uni","getArrMaxValue","queryList","device_real_time","device_id","getNameByKey","addTimer","chooseDay","back"],"mappings":";;;;;;;;;AAuFA;AACA;AAAA;AAAA;AAAA,eACA;EACAA;IACAC;MACAC;MACAC;IACA;EACA;EACAC;IACA;MACAC;QACA;QACA;QACA;QACA;MAAA,CACA;MACAC,SACA;QACAC;QACAC;MACA,GACA;QACAD;QACAC;MACA,GACA;QACAD;QACAC;MACA,GACA;QACAD;QACAC;MACA,EACA;MACAC;MACAC;MACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MAEAC;MACAC;MACAP;IACA;EACA;EAEAQ;IAAA;IACA;IACA;IACA;IACA;IACA;MACA;IACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;EAEAC,4BACA;IACAC;EACA,GACA;EAEAC;IACAC;MACA;QACAC;QACA;MACA;MACA;QACAA;QACA;MACA;IACA;IACAC;IACAC;MAAA;MACA;MACA;QACAnC;MACA;QACAA;MACA;MAAA;MAEA;QACAA;MACA;QACAA;MACA;MAAA;MAEA;QACAA;QACAoC;QACAC;MACA;QACA;QAEA;MACA;IACA;IAEAC;MACA;IACA;IAEAC;MACA;IACA;IAEA;IACAC;MACA;MACA;IACA;IAEAC;MACA;QACA;MACA;QACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"217.js","sourcesContent":["<!-- 全部数据 -->\n\n<template>\n\t<view class=\"\">\n\t\t<tm-nav-bar left-icon=\"arrow-left\" :title=\"desc? getNameByKey(desc) : getNameByKey(activeType)\" @clickLeft=\"back\" :rbgs=\"false\"/>\n\t\t<view class=\"content\">\n\t\t\t<view class=\"over\" style=\"margin-top: 30rpx\" @click=\"flag = !flag\">\n\t\t\t\t<text>日期筛选</text>\n\t\t\t\t<uni-icons type=\"down\" size=\"24\"></uni-icons>\n\t\t\t</view>\n\t\t\t<view class=\"time\" v-show=\"flag\">\n\t\t\t\t<punch-calendar @switchMonth=\"switchMonth\" @chooseDay=\"chooseDay\" :errorList=\"errorList\" :successList=\"successList\" ref=\"calendar\"></punch-calendar>\n\t\t\t</view>\n\t\t\t<view class=\"flx flx_sb bloodl_box\" v-if=\"activeType == 'bloodLiquidAll'\" style=\"flex-wrap: wrap;\">\n\t\t\t\t<view class=\"flx flx_ac\" v-for=\"(v,i) in blData\" :key=\"i\" style=\"flex: 0 0 calc((100% - 0rpx) / 2);height: 50rpx;\">\n\t\t\t\t\t<view class=\"yuan\" :style=\"{backgroundColor:v.color}\"></view>\n\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t{{ v.name }}\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view :class=\"'list'\" v-for=\"(item, index) in dataList\" :key=\"index\" @click=\"goInfo(index)\">\n\t\t\t\t<view v-if=\"!customType.includes(activeType)\" class=\"row\" >\n\t\t\t\t\t<view class=\"data\">\n\t\t\t\t\t\t<image src=\"https://img.agrimedia.cn/apptest/%E6%89%8B%E8%A1%A8-%E7%BA%BF%E6%80%A73-0.png\" mode=\"widthFix\"></image>\t\t\t\t\t\t\n\t\t\t\t\t\t<view v-if=\"activeType == 'stepIndex'\">\n\t\t\t\t\t\t\t步数：{{item.data_msg.step}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodPressure'\">\n\t\t\t\t\t\t\t{{item.data_msg.bloodPressureHigh}}/{{item.data_msg.bloodPressureLow}} mmHg\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodOxygen'\">\n\t\t\t\t\t\t\t{{ item.data_msg[0] ? item.data_msg[0] + (item.data_msg[1]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[1] ? item.data_msg[1] + (item.data_msg[2]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[2] ? item.data_msg[2] + (item.data_msg[3]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[3] ? item.data_msg[3] + (item.data_msg[4]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[4] ? item.data_msg[4] : ''}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodGlucose'\">\n\t\t\t\t\t\t\t{{item.data_msg}}毫摩尔/升\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bodyTemperature'\">\n\t\t\t\t\t\t\t{{item.data_msg}} ℃\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'pulseReat'\">\n\t\t\t\t\t\t\t{{ item.data_msg[0] ? item.data_msg[0] + (item.data_msg[1]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[1] ? item.data_msg[1] + (item.data_msg[2]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[2] ? item.data_msg[2] + (item.data_msg[3]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[3] ? item.data_msg[3] + (item.data_msg[4]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[4] ? item.data_msg[4] : ''}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodLiquid'\">\n\t\t\t\t\t\t\t{{(item.data_msg.uricAcidVal /10).toFixed(2)}} 微摩尔/升\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodLiquidAll'\" style=\"font-size: 24rpx;\" >\n\t\t\t\t\t\t\t<view>总胆固醇：{{(item.data_msg.cholesterol/100).toFixed(2)}} </view>\n\t\t\t\t\t\t\t<view>甘油三脂：{{(item.data_msg.triacylglycerol/100).toFixed(2)}} </view>\n\t\t\t\t\t\t\t<view>高密度脂蛋白:{{(item.data_msg.highDensity/100).toFixed(2)}}</view>\n\t\t\t\t\t\t\t<view>低密度脂蛋白：{{(item.data_msg.lowDensity/100).toFixed(2)}} </view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'ECGData'\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t<view>心率:{{item.data_msg.meanHeartRate || item.data_msg.heartRate}} 次/分</view>\n\t\t\t\t\t\t\t<view>HRV：{{item.data_msg.averageHRV || item.data_msg.hrv}} 毫秒</view>\n\t\t\t\t\t\t\t<view>QTc：{{item.data_msg.averageTimeInterval || item.data_msg.QTC}} 毫秒</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bodyData'\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t<view>BMI:{{item.data_msg.BMI}}</view>\n\t\t\t\t\t\t\t<view>体脂率：{{item.data_msg.bodyFatPercentage}}</view>\n\t\t\t\t\t\t\t<view>肌肉率：{{item.data_msg.muscleRate}}</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t\t<view class=\"time\">\n\t\t\t\t\t\t{{item.date_str}} {{item.hour_minute}} \n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"\" v-else>\n\t\t\t\t\t<detail_components :key_name=\"activeType\" :item=\"item\"></detail_components>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view class=\"end\">到底了</view>\n\t\t</view>\n\t\t\n\t\t<ecg-info ref=\"popShow\" :ecgData=\"ecgData\"></ecg-info>\n\t</view>\n</template>\n\n<script>\n\timport { getArrMaxValue } from '@/utils/utils.js'\n\timport { mapGetters } from \"vuex\";\n\texport default {\n\t\tprops: {\n\t\t\tactiveType: {\n\t\t\t\ttype: String,\n\t\t\t\tdefault: ''\n\t\t\t}\n\t\t},\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tcustomType:[\n\t\t\t\t\t// 'bodyData',\n\t\t\t\t\t// 'bloodLiquid',\n\t\t\t\t\t// 'bloodLiquidAll',\n\t\t\t\t\t// 'ECGData'\n\t\t\t\t],\n\t\t\t\tblData:[\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'总胆固醇',\n\t\t\t\t\t\tcolor:'#46b4ff',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'甘油三酯',\n\t\t\t\t\t\tcolor:'#29cf6c',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'高密度脂蛋白',\n\t\t\t\t\t\tcolor:'#fcc05d',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'低密度脂蛋白',\n\t\t\t\t\t\tcolor:'#fa4e33',\n\t\t\t\t\t}\n\t\t\t\t],\n\t\t\t\tdesc: '',\n\t\t\t\tdataList: [],\n\t\t\t\tkeyNameMap: {\n\t\t\t\t    bloodGlucose: \"血糖\",\n\t\t\t\t\tbloodOxygen: \"血氧\",\n\t\t\t\t\tbloodPressure: '血压',\n\t\t\t\t\tpulseReat: '心率',\n\t\t\t\t    bloodLiquid: \"尿酸\",\n\t\t\t\t\tmeiTuo: '梅脱',\n\t\t\t\t\tupdataDate: '更新时间',\n\t\t\t\t\tbodyTemperature: '体温',\n\t\t\t\t\tECGData: '心电图',\n\t\t\t\t\tstepIndex: '步数',\n\t\t\t\t\tbodyData:'身体成分',\n\t\t\t\t\tbloodLiquidAll: '血脂'\n\t\t\t\t},\n\t\t\t\ttime: new Date().toISOString().substring(0, 10),\n\t\t\t\tflag: true,\n\t\t\t\tsuccessList: ['1676995200000'],\n\t\t\t\terrorList: ['1676908800000'],\n\t\t\t\t\n\t\t\t\tshowPopup: false,\n\t\t\t\tecgData: [],\n\t\t\t\tbodyData: []\n\t\t\t}\n\t\t},\n\t\t\n\t\tmounted() {\n\t\t\t// 初始化\n\t\t\tthis.$refs.calendar.initCalendar()\n\t\t\tthis.queryList()\n\t\t\t// 模拟异步赋值\n\t\t\tlet timer = setTimeout(()=>{\n\t\t\t\tthis.addTimer()\n\t\t\t},2000)\n\t\t},\n\t\t\n\t\t// onShow(e) {\n\t\t// \tlet routes = getCurrentPages(); // 获取当前打开过的页面路由数组\n\t\t// \tlet curRoute = routes[routes.length - 1].route //获取当前页面路由\n\t\t// \tlet curParam = routes[routes.length - 1].options; //获取路由参数\n\t\t// \t// 拼接参数\n\t\t// \tlet param = ''\n\t\t// \tfor (let key in curParam) {\n\t\t// \t    param += '&' + key + '=' + curParam[key]\n\t\t// \t}\n\n\t\tcomputed: {\n\t\t\t...mapGetters({\n\t\t\t\tgetActiceDevice: \"api/getActiceDevice\"\n\t\t\t})\n\t\t},\n\t\t\n\t\tmethods: {\n\t\t\tgoInfo(idx){\n\t\t\t\tif(this.activeType == 'ECGData'){\n\t\t\t\t\tuni.setStorageSync('infoData', JSON.stringify(this.dataList[idx]));\n\t\t\t\t\tthis.$refs.popShow.open(1)\n\t\t\t\t}\n\t\t\t\tif(this.activeType == 'bodyData'){\n\t\t\t\t\tuni.setStorageSync('bodyData', JSON.stringify(this.dataList[idx]));\n\t\t\t\t\tthis.$refs.popShow.open(2)\n\t\t\t\t}\n\t\t\t},\n\t\t\tgetArrMaxValue,\n\t\t\tqueryList() {\n\t\t\t\tlet type = '';\n\t\t\t\tif (this.activeType == 'step') {\n\t\t\t\t\ttype = 'step_split'\n\t\t\t\t} else {\n\t\t\t\t\ttype = this.activeType\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tif (this.activeType == 'bloodLiquidAll') {\n\t\t\t\t\ttype = 'bloodLiquid'\n\t\t\t\t} else {\n\t\t\t\t\ttype = this.activeType\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tthis.$store.dispatch('api/getDeviceListDays', { \n\t\t\t\t\ttype: type,\n\t\t\t\t\tdevice_real_time: this.time,\n\t\t\t\t\tdevice_id:this.getActiceDevice.device_id\n\t\t\t\t}).then(res => {\n\t\t\t\t\tthis.dataList = res.data\n\t\t\t\t\t\n\t\t\t\t\tconsole.log(this.dataList)\n\t\t\t\t});\n\t\t\t},\n\t\t\t\n\t\t\tgetNameByKey(key) {\n\t\t\t    return this.keyNameMap[key] || \"Key not found\";\n\t\t\t},\n\t\t\t\n\t\t\taddTimer() {\n\t\t\t\tthis.successList = [...this.successList, '1681920000000']\n\t\t\t},\n\n\t\t\t// 点击某一天\n\t\t\tchooseDay(val) {\n\t\t\t\tthis.time = val.year + '-' + val.month + '-' + val.day;\n\t\t\t\tthis.queryList()\n\t\t\t},\n\t\t\t\n\t\t\tback() {\n\t\t\t\tif (this.activeType == 'ECGData' || this.activeType == 'bodyData') {\n\t\t\t\t\tthis.$emit('back', 1)\n\t\t\t\t} else {\n\t\t\t\t\tthis.$emit('back', 2)\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n</script>\n\n<style lang=\"scss\" scoped>\n\t.bloodl_box{\n\t\tmargin-top: 30rpx;\n\t\tpadding: 0 40rpx;\n\t\t.name{\n\t\t\tfont-size: 24rpx;\n\t\t\tcolor: #999;\n\t\t}\n\t\t.yuan{\n\t\t\twidth: 14rpx;\n\t\t\theight: 14rpx;\n\t\t\tborder-radius: 50%;\n\t\t\tmargin-right: 10rpx;\n\t\t}\n\t}\n\t.content {\n\t\tmargin: 0rpx 100rpx;\n\t\t.over {\n\t\t\tmargin: 0rpx 30rpx;\n\t\t\tbackground-color: #fff;\n\t\t\tpadding: 30rpx;\n\t\t\tborder-radius: 20rpx;\n\t\t\tfont-weight: 800;\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tjustify-content: space-between;\n\t\t\tborder-radius: 20rpx;\n\t\t}\n\t\t.time {\n\t\t\twidth: 100%;\n\t\t\tmargin-bottom: 100rpx;\n\t\t}\n\t\t.list {\n\t\t\tbackground-color: #fff;\n\t\t\toverflow: hidden;\n\t\t\tpadding: 30rpx;\n\t\t\tmargin: 30rpx 30rpx;\n\t\t\tborder-radius: 30rpx;\n\t\t\t.row {\n\t\t\t\t// height: 100rpx;\n\t\t\t\tdisplay: flex;\n\t\t\t\talign-items: center;\n\t\t\t\tjustify-content: space-between;\n\t\t\t}\n\t\t\t.data {\n\t\t\t\tdisplay: flex;\n\t\t\t\talign-items: center;\n\t\t\t\tfont-weight: 500;\n\t\t\t\tfont-size: 36rpx;\n\t\t\t\twidth: 900rpx;\n\t\t\t\timage {\n\t\t\t\t\twidth: 50rpx;\n\t\t\t\t}\n\t\t\t}\n\t\t\t.time {\n\t\t\t\tfont-weight: 300;\n\t\t\t\tfont-size: 24rpx;\n\t\t\t}\n\t\t}\n\t}\n\t\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///217\n"); +eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 52));\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\nvar _utils = __webpack_require__(/*! @/utils/utils.js */ 146);\nvar _vuex = __webpack_require__(/*! vuex */ 65);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar _default = {\n props: {\n activeType: {\n type: String,\n default: ''\n }\n },\n data: function data() {\n return {\n customType: [\n // 'bodyData',\n // 'bloodLiquid',\n // 'bloodLiquidAll',\n // 'ECGData'\n ],\n blData: [{\n name: '总胆固醇',\n color: '#46b4ff'\n }, {\n name: '甘油三酯',\n color: '#29cf6c'\n }, {\n name: '高密度脂蛋白',\n color: '#fcc05d'\n }, {\n name: '低密度脂蛋白',\n color: '#fa4e33'\n }],\n desc: '',\n dataList: [],\n keyNameMap: {\n bloodGlucose: \"血糖\",\n bloodOxygen: \"血氧\",\n bloodPressure: '血压',\n pulseReat: '心率',\n bloodLiquid: \"尿酸\",\n meiTuo: '梅脱',\n updataDate: '更新时间',\n bodyTemperature: '体温',\n ECGData: '心电图',\n stepIndex: '步数',\n bodyData: '身体成分',\n bloodLiquidAll: '血脂'\n },\n time: new Date().toISOString().substring(0, 10),\n flag: true,\n successList: ['1676995200000'],\n errorList: ['1676908800000'],\n showPopup: false,\n ecgData: [],\n bodyData: []\n };\n },\n mounted: function mounted() {\n var _this = this;\n // 初始化\n this.$refs.calendar.initCalendar();\n this.queryList();\n // 模拟异步赋值\n var timer = setTimeout(function () {\n _this.addTimer();\n }, 2000);\n },\n // onShow(e) {\n // \tlet routes = getCurrentPages(); // 获取当前打开过的页面路由数组\n // \tlet curRoute = routes[routes.length - 1].route //获取当前页面路由\n // \tlet curParam = routes[routes.length - 1].options; //获取路由参数\n // \t// 拼接参数\n // \tlet param = ''\n // \tfor (let key in curParam) {\n // \t param += '&' + key + '=' + curParam[key]\n // \t}\n\n computed: _objectSpread({}, (0, _vuex.mapGetters)({\n getActiceDevice: \"api/getActiceDevice\"\n })),\n methods: {\n goInfo: function goInfo(idx) {\n if (this.activeType == 'ECGData') {\n uni.setStorageSync('infoData', JSON.stringify(this.dataList[idx]));\n this.$refs.popShow.open(1);\n }\n if (this.activeType == 'bodyData') {\n uni.setStorageSync('bodyData', JSON.stringify(this.dataList[idx]));\n this.$refs.popShow.open(2);\n }\n },\n getArrMaxValue: _utils.getArrMaxValue,\n queryList: function queryList() {\n var _this2 = this;\n var type = '';\n if (this.activeType == 'step') {\n type = 'step_split';\n } else {\n type = this.activeType;\n }\n ;\n if (this.activeType == 'bloodLiquidAll') {\n type = 'bloodLiquid';\n } else {\n type = this.activeType;\n }\n ;\n this.$store.dispatch('api/getDeviceListDays', {\n type: type,\n device_real_time: this.time,\n device_id: this.getActiceDevice.device_id\n }).then(function (res) {\n _this2.dataList = res.data;\n __f__(\"log\", _this2.dataList, \" at components/all-data/all-data.vue:209\");\n });\n },\n getNameByKey: function getNameByKey(key) {\n return this.keyNameMap[key] || \"Key not found\";\n },\n addTimer: function addTimer() {\n this.successList = [].concat((0, _toConsumableArray2.default)(this.successList), ['1681920000000']);\n },\n // 点击某一天\n chooseDay: function chooseDay(val) {\n this.time = val.year + '-' + val.month + '-' + val.day;\n this.queryList();\n },\n back: function back() {\n if (this.activeType == 'ECGData' || this.activeType == 'bodyData') {\n this.$emit('back', 1);\n } else {\n this.$emit('back', 2);\n }\n }\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///components/all-data/all-data.vue"],"names":["props","activeType","type","default","data","customType","blData","name","color","desc","dataList","keyNameMap","bloodGlucose","bloodOxygen","bloodPressure","pulseReat","bloodLiquid","meiTuo","updataDate","bodyTemperature","ECGData","stepIndex","bodyData","bloodLiquidAll","time","flag","successList","errorList","showPopup","ecgData","mounted","computed","getActiceDevice","methods","goInfo","uni","getArrMaxValue","queryList","device_real_time","device_id","getNameByKey","addTimer","chooseDay","back"],"mappings":";;;;;;;;;AAuFA;AACA;AAAA;AAAA;AAAA,eACA;EACAA;IACAC;MACAC;MACAC;IACA;EACA;EACAC;IACA;MACAC;QACA;QACA;QACA;QACA;MAAA,CACA;MACAC,SACA;QACAC;QACAC;MACA,GACA;QACAD;QACAC;MACA,GACA;QACAD;QACAC;MACA,GACA;QACAD;QACAC;MACA,EACA;MACAC;MACAC;MACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;QACAC;MACA;MACAC;MACAC;MACAC;MACAC;MAEAC;MACAC;MACAP;IACA;EACA;EAEAQ;IAAA;IACA;IACA;IACA;IACA;IACA;MACA;IACA;EACA;EAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;EAEAC,4BACA;IACAC;EACA,GACA;EAEAC;IACAC;MACA;QACAC;QACA;MACA;MACA;QACAA;QACA;MACA;IACA;IACAC;IACAC;MAAA;MACA;MACA;QACAnC;MACA;QACAA;MACA;MAAA;MAEA;QACAA;MACA;QACAA;MACA;MAAA;MAEA;QACAA;QACAoC;QACAC;MACA;QACA;QAEA;MACA;IACA;IAEAC;MACA;IACA;IAEAC;MACA;IACA;IAEA;IACAC;MACA;MACA;IACA;IAEAC;MACA;QACA;MACA;QACA;MACA;IACA;EACA;AACA;AAAA,2B","file":"217.js","sourcesContent":["<!-- 全部数据 -->\n\n<template>\n\t<view class=\"\">\n\t\t<tm-nav-bar left-icon=\"arrow-left\" :title=\"desc? getNameByKey(desc) : getNameByKey(activeType)\" @clickLeft=\"back\" :rbgs=\"false\"/>\n\t\t<view class=\"content\">\n\t\t\t<view class=\"over\" style=\"margin-top: 30rpx\" @click=\"flag = !flag\">\n\t\t\t\t<text>日期筛选</text>\n\t\t\t\t<uni-icons type=\"down\" size=\"24\"></uni-icons>\n\t\t\t</view>\n\t\t\t<view class=\"time\" v-show=\"flag\">\n\t\t\t\t<punch-calendar @switchMonth=\"switchMonth\" @chooseDay=\"chooseDay\" :errorList=\"errorList\" :successList=\"successList\" ref=\"calendar\"></punch-calendar>\n\t\t\t</view>\n\t\t\t<view class=\"flx flx_sb bloodl_box\" v-if=\"activeType == 'bloodLiquidAll'\" style=\"flex-wrap: wrap;\">\n\t\t\t\t<view class=\"flx flx_ac\" v-for=\"(v,i) in blData\" :key=\"i\" style=\"flex: 0 0 calc((100% - 0rpx) / 2);height: 50rpx;\">\n\t\t\t\t\t<view class=\"yuan\" :style=\"{backgroundColor:v.color}\"></view>\n\t\t\t\t\t<view class=\"name\">\n\t\t\t\t\t\t{{ v.name }}\n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view :class=\"'list'\" v-for=\"(item, index) in dataList\" :key=\"index\" @click=\"goInfo(index)\">\n\t\t\t\t<view v-if=\"!customType.includes(activeType)\" class=\"row\" >\n\t\t\t\t\t<view class=\"data\">\n\t\t\t\t\t\t<image src=\"https://img.agrimedia.cn/apptest/%E6%89%8B%E8%A1%A8-%E7%BA%BF%E6%80%A73-0.png\" mode=\"widthFix\"></image>\t\t\t\t\t\t\n\t\t\t\t\t\t<view v-if=\"activeType == 'stepIndex'\">\n\t\t\t\t\t\t\t步数：{{item.data_msg.step}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodPressure'\">\n\t\t\t\t\t\t\t{{item.data_msg.bloodPressureHigh}}/{{item.data_msg.bloodPressureLow}} mmHg\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodOxygen'\">\n\t\t\t\t\t\t\t{{ item.data_msg[0] ? item.data_msg[0] + (item.data_msg[1]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[1] ? item.data_msg[1] + (item.data_msg[2]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[2] ? item.data_msg[2] + (item.data_msg[3]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[3] ? item.data_msg[3] + (item.data_msg[4]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[4] ? item.data_msg[4] : ''}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodGlucose'\">\n\t\t\t\t\t\t\t{{item.data_msg}}毫摩尔/升\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bodyTemperature'\">\n\t\t\t\t\t\t\t{{item.data_msg}} ℃\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'pulseReat'\">\n\t\t\t\t\t\t\t{{ item.data_msg[0] ? item.data_msg[0] + (item.data_msg[1]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[1] ? item.data_msg[1] + (item.data_msg[2]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[2] ? item.data_msg[2] + (item.data_msg[3]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[3] ? item.data_msg[3] + (item.data_msg[4]?' | ':'') : ''}}\n\t\t\t\t\t\t\t{{ item.data_msg[4] ? item.data_msg[4] : ''}}\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodLiquid'\">\n\t\t\t\t\t\t\t{{(item.data_msg.uricAcidVal /10).toFixed(2)}} 微摩尔/升\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bloodLiquidAll'\" style=\"font-size: 24rpx;\" >\n\t\t\t\t\t\t\t<view>总胆固醇：{{(item.data_msg.cholesterol/100).toFixed(2)}} </view>\n\t\t\t\t\t\t\t<view>甘油三脂：{{(item.data_msg.triacylglycerol/100).toFixed(2)}} </view>\n\t\t\t\t\t\t\t<view>高密度脂蛋白:{{(item.data_msg.highDensity/100).toFixed(2)}}</view>\n\t\t\t\t\t\t\t<view>低密度脂蛋白：{{(item.data_msg.lowDensity/100).toFixed(2)}} </view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'ECGData'\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t<view>心率:{{item.data_msg.meanHeartRate || item.data_msg.heartRate}} 次/分</view>\n\t\t\t\t\t\t\t<view>HRV：{{item.data_msg.averageHRV || item.data_msg.hrv}} 毫秒</view>\n\t\t\t\t\t\t\t<view>QTc：{{item.data_msg.averageTimeInterval || item.data_msg.QTC}} 毫秒</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t\t<view v-if=\"activeType == 'bodyData'\" style=\"font-size: 24rpx;\">\n\t\t\t\t\t\t\t<view>BMI:{{item.data_msg.BMI}}</view>\n\t\t\t\t\t\t\t<view>体脂率：{{item.data_msg.bodyFatPercentage}}</view>\n\t\t\t\t\t\t\t<view>肌肉率：{{item.data_msg.muscleRate}}</view>\n\t\t\t\t\t\t</view>\n\t\t\t\t\t</view>\n\t\t\t\t\t<view class=\"time\">\n\t\t\t\t\t\t{{item.date_str}} {{item.hour_minute}} \n\t\t\t\t\t</view>\n\t\t\t\t</view>\n\t\t\t\t<view class=\"\" v-else>\n\t\t\t\t\t<detail_components :key_name=\"activeType\" :item=\"item\"></detail_components>\n\t\t\t\t</view>\n\t\t\t</view>\n\t\t\t<view class=\"end\">到底了</view>\n\t\t</view>\n\t\t\n\t\t<ecg-info ref=\"popShow\" :ecgData=\"ecgData\"></ecg-info>\n\t</view>\n</template>\n\n<script>\n\timport { getArrMaxValue } from '@/utils/utils.js'\n\timport { mapGetters } from \"vuex\";\n\texport default {\n\t\tprops: {\n\t\t\tactiveType: {\n\t\t\t\ttype: String,\n\t\t\t\tdefault: ''\n\t\t\t}\n\t\t},\n\t\tdata() {\n\t\t\treturn {\n\t\t\t\tcustomType:[\n\t\t\t\t\t// 'bodyData',\n\t\t\t\t\t// 'bloodLiquid',\n\t\t\t\t\t// 'bloodLiquidAll',\n\t\t\t\t\t// 'ECGData'\n\t\t\t\t],\n\t\t\t\tblData:[\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'总胆固醇',\n\t\t\t\t\t\tcolor:'#46b4ff',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'甘油三酯',\n\t\t\t\t\t\tcolor:'#29cf6c',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'高密度脂蛋白',\n\t\t\t\t\t\tcolor:'#fcc05d',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname:'低密度脂蛋白',\n\t\t\t\t\t\tcolor:'#fa4e33',\n\t\t\t\t\t}\n\t\t\t\t],\n\t\t\t\tdesc: '',\n\t\t\t\tdataList: [],\n\t\t\t\tkeyNameMap: {\n\t\t\t\t    bloodGlucose: \"血糖\",\n\t\t\t\t\tbloodOxygen: \"血氧\",\n\t\t\t\t\tbloodPressure: '血压',\n\t\t\t\t\tpulseReat: '心率',\n\t\t\t\t    bloodLiquid: \"尿酸\",\n\t\t\t\t\tmeiTuo: '梅脱',\n\t\t\t\t\tupdataDate: '更新时间',\n\t\t\t\t\tbodyTemperature: '体温',\n\t\t\t\t\tECGData: '心电图',\n\t\t\t\t\tstepIndex: '步数',\n\t\t\t\t\tbodyData:'身体成分',\n\t\t\t\t\tbloodLiquidAll: '血脂'\n\t\t\t\t},\n\t\t\t\ttime: new Date().toISOString().substring(0, 10),\n\t\t\t\tflag: true,\n\t\t\t\tsuccessList: ['1676995200000'],\n\t\t\t\terrorList: ['1676908800000'],\n\t\t\t\t\n\t\t\t\tshowPopup: false,\n\t\t\t\tecgData: [],\n\t\t\t\tbodyData: []\n\t\t\t}\n\t\t},\n\t\t\n\t\tmounted() {\n\t\t\t// 初始化\n\t\t\tthis.$refs.calendar.initCalendar()\n\t\t\tthis.queryList()\n\t\t\t// 模拟异步赋值\n\t\t\tlet timer = setTimeout(()=>{\n\t\t\t\tthis.addTimer()\n\t\t\t},2000)\n\t\t},\n\t\t\n\t\t// onShow(e) {\n\t\t// \tlet routes = getCurrentPages(); // 获取当前打开过的页面路由数组\n\t\t// \tlet curRoute = routes[routes.length - 1].route //获取当前页面路由\n\t\t// \tlet curParam = routes[routes.length - 1].options; //获取路由参数\n\t\t// \t// 拼接参数\n\t\t// \tlet param = ''\n\t\t// \tfor (let key in curParam) {\n\t\t// \t    param += '&' + key + '=' + curParam[key]\n\t\t// \t}\n\n\t\tcomputed: {\n\t\t\t...mapGetters({\n\t\t\t\tgetActiceDevice: \"api/getActiceDevice\"\n\t\t\t})\n\t\t},\n\t\t\n\t\tmethods: {\n\t\t\tgoInfo(idx){\n\t\t\t\tif(this.activeType == 'ECGData'){\n\t\t\t\t\tuni.setStorageSync('infoData', JSON.stringify(this.dataList[idx]));\n\t\t\t\t\tthis.$refs.popShow.open(1)\n\t\t\t\t}\n\t\t\t\tif(this.activeType == 'bodyData'){\n\t\t\t\t\tuni.setStorageSync('bodyData', JSON.stringify(this.dataList[idx]));\n\t\t\t\t\tthis.$refs.popShow.open(2)\n\t\t\t\t}\n\t\t\t},\n\t\t\tgetArrMaxValue,\n\t\t\tqueryList() {\n\t\t\t\tlet type = '';\n\t\t\t\tif (this.activeType == 'step') {\n\t\t\t\t\ttype = 'step_split'\n\t\t\t\t} else {\n\t\t\t\t\ttype = this.activeType\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tif (this.activeType == 'bloodLiquidAll') {\n\t\t\t\t\ttype = 'bloodLiquid'\n\t\t\t\t} else {\n\t\t\t\t\ttype = this.activeType\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tthis.$store.dispatch('api/getDeviceListDays', { \n\t\t\t\t\ttype: type,\n\t\t\t\t\tdevice_real_time: this.time,\n\t\t\t\t\tdevice_id:this.getActiceDevice.device_id\n\t\t\t\t}).then(res => {\n\t\t\t\t\tthis.dataList = res.data\n\t\t\t\t\t\n\t\t\t\t\tconsole.log(this.dataList)\n\t\t\t\t});\n\t\t\t},\n\t\t\t\n\t\t\tgetNameByKey(key) {\n\t\t\t    return this.keyNameMap[key] || \"Key not found\";\n\t\t\t},\n\t\t\t\n\t\t\taddTimer() {\n\t\t\t\tthis.successList = [...this.successList, '1681920000000']\n\t\t\t},\n\n\t\t\t// 点击某一天\n\t\t\tchooseDay(val) {\n\t\t\t\tthis.time = val.year + '-' + val.month + '-' + val.day;\n\t\t\t\tthis.queryList()\n\t\t\t},\n\t\t\t\n\t\t\tback() {\n\t\t\t\tif (this.activeType == 'ECGData' || this.activeType == 'bodyData') {\n\t\t\t\t\tthis.$emit('back', 1)\n\t\t\t\t} else {\n\t\t\t\t\tthis.$emit('back', 2)\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n</script>\n\n<style lang=\"scss\" scoped>\n\t.bloodl_box{\n\t\tmargin-top: 50rpx;\n\t\tpadding: 0 40rpx;\n\t\t.name{\n\t\t\tfont-size: 24rpx;\n\t\t\tcolor: #999;\n\t\t}\n\t\t.yuan{\n\t\t\twidth: 14rpx;\n\t\t\theight: 14rpx;\n\t\t\tborder-radius: 50%;\n\t\t\tmargin-right: 10rpx;\n\t\t}\n\t}\n\t.content {\n\t\tmargin: 0rpx 100rpx;\n\t\t.over {\n\t\t\tmargin: 0rpx 30rpx;\n\t\t\tbackground-color: #fff;\n\t\t\tpadding: 30rpx;\n\t\t\tborder-radius: 20rpx;\n\t\t\tfont-weight: 800;\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t\tjustify-content: space-between;\n\t\t\tborder-radius: 20rpx;\n\t\t}\n\t\t.time {\n\t\t\twidth: 100%;\n\t\t}\n\t\t.list {\n\t\t\tbackground-color: #fff;\n\t\t\toverflow: hidden;\n\t\t\tpadding: 30rpx;\n\t\t\tmargin: 30rpx 30rpx;\n\t\t\tborder-radius: 30rpx;\n\t\t\t.row {\n\t\t\t\t// height: 100rpx;\n\t\t\t\tdisplay: flex;\n\t\t\t\talign-items: center;\n\t\t\t\tjustify-content: space-between;\n\t\t\t}\n\t\t\t.data {\n\t\t\t\tdisplay: flex;\n\t\t\t\talign-items: center;\n\t\t\t\tfont-weight: 500;\n\t\t\t\tfont-size: 36rpx;\n\t\t\t\twidth: 900rpx;\n\t\t\t\timage {\n\t\t\t\t\twidth: 50rpx;\n\t\t\t\t}\n\t\t\t}\n\t\t\t.time {\n\t\t\t\tfont-weight: 300;\n\t\t\t\tfont-size: 24rpx;\n\t\t\t}\n\t\t}\n\t}\n\t\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///217\n"); /***/ }), /* 218 */ @@ -19884,7 +19991,7 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _index = _interopRequireDefault(__webpack_require__(/*! ../store/index.js */ 148));\nvar _utils = _interopRequireDefault(__webpack_require__(/*! ../utils/utils.js */ 146));\nvar _api = __webpack_require__(/*! ./api.js */ 151);\nvar HOST = location && location.origin;\nvar _default = function _default() {\n var readBaseUrl = Object({\"NODE_ENV\":\"development\",\"VUE_APP_DARK_MODE\":\"false\",\"VUE_APP_NAME\":\"中鼎云医\",\"VUE_APP_PLATFORM\":\"app-plus\",\"BASE_URL\":\"/\"}).bcUrl;\n // 初始化请求配置\n uni.$u.http.setConfig(function (config) {\n if (readBaseUrl) {\n config.baseURL = readBaseUrl; // 测试地址\n }\n\n config.baseURL = _api.baseUrl; // 测试地址\n\n return config;\n });\n\n // 请求拦截\n uni.$u.http.interceptors.request.use(function (config) {\n // 可使用async await 做异步操作\n\n if (!config.baseURL) {\n config.url = '/' + config.url;\n }\n config.data = config.data || {};\n // config.baseURL = 'http://test.sc2.agrimedia.cn'; // 不使用请求代理 上线记得注释掉 ***********************************************************\n\n var apiToken = _index.default.getters['api/getApiToken'];\n var serverTime = parseInt(Date.now() / 1000) - _index.default.getters['api/getServerTime'];\n config.header.systemType = 0;\n config.header.ApiToken = apiToken;\n // config.header.systemSn = utils.getSunmiSerial()\n config.header.timestamp = serverTime;\n var ob = config.method == 'GET' ? config.params : config.data;\n var custom = config.custom.hideLoading || false;\n if (!custom) {\n uni.showLoading({\n mask: true,\n title: \"加载中...\"\n });\n }\n return config;\n }, function (config) {\n // 可使用async await 做异步操作\n return Promise.reject(config);\n });\n\n // 响应拦截\n uni.$u.http.interceptors.response.use(function (response) {\n var _response$config;\n uni.hideLoading({});\n\n /* 对响应成功做点什么 可使用async await 做异步操作*/\n var data = response.data;\n var custom = (_response$config = response.config) === null || _response$config === void 0 ? void 0 : _response$config.custom;\n if (data.code !== 200) {\n if (data.code === 401 || data.code === 1005) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n\n // setTimeout(e => {\n // \tutils.goPath('/pages/login/login');\n // },1000)\n } else if (data.code === 400) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n } else if (data.code === 0) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n } else if (data.code === 7776) {\n _index.default.commit('api/setActiceDevice', {});\n }\n if (custom.toast !== false) {\n uni.$u.toast(data.msg);\n }\n if (data.code == 7777) {\n _index.default.commit('api/setApiToken', '');\n uni.showToast({\n mask: true,\n title: '请重新登录',\n icon: 'none'\n });\n setTimeout(function () {\n uni.reLaunch({\n url: '/pages/login/login'\n });\n }, 1000);\n }\n __f__(\"log\", response.config.url, \" at config/request.js:108\");\n return Promise.reject(data);\n }\n return data.data === undefined ? {} : data.data;\n }, function (response) {\n uni.showToast({\n mask: true,\n title: '服务器响应失败' + response.statusCode,\n icon: 'none'\n });\n return Promise.reject(response);\n });\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///config/request.js"],"names":["HOST","location","origin","readBaseUrl","process","bcUrl","uni","$u","http","setConfig","config","baseURL","baseUrl","interceptors","request","use","url","data","apiToken","store","getters","serverTime","parseInt","Date","now","header","systemType","ApiToken","timestamp","ob","method","params","custom","hideLoading","showLoading","mask","title","Promise","reject","response","code","showToast","msg","icon","commit","toast","setTimeout","reLaunch","undefined","statusCode"],"mappings":";;;;;;;AAAA;AACA;AAEA;AAEA,IAAMA,IAAI,GAAGC,QAAQ,IAAIA,QAAQ,CAACC,MAAM;AAAA,eACzB,oBAAM;EACpB,IAAIC,WAAW,GAAGC,iIAAW,CAACC,KAAK;EACnC;EACAC,GAAG,CAACC,EAAE,CAACC,IAAI,CAACC,SAAS,CAAC,UAACC,MAAM,EAAK;IACjC,IAAGP,WAAW,EAAE;MACfO,MAAM,CAACC,OAAO,GAAGR,WAAW,CAAC,CAAE;IAChC;;IAGCO,MAAM,CAACC,OAAO,GAAGC,YAAO,CAAC,CAAE;;IAE5B,OAAOF,MAAM;EACd,CAAC,CAAC;;EAGF;EACAJ,GAAG,CAACC,EAAE,CAACC,IAAI,CAACK,YAAY,CAACC,OAAO,CAACC,GAAG,CAAC,UAACL,MAAM,EAAK;IAAE;;IAGlD,IAAG,CAACA,MAAM,CAACC,OAAO,EAAC;MAClBD,MAAM,CAACM,GAAG,GAAG,GAAG,GAACN,MAAM,CAACM,GAAG;IAC5B;IAEAN,MAAM,CAACO,IAAI,GAAGP,MAAM,CAACO,IAAI,IAAI,CAAC,CAAC;IAC/B;;IAEA,IAAIC,QAAQ,GAAGC,cAAK,CAACC,OAAO,CAAC,iBAAiB,CAAC;IAC/C,IAAIC,UAAU,GAAIC,QAAQ,CAACC,IAAI,CAACC,GAAG,EAAE,GAAE,IAAI,CAAC,GAAGL,cAAK,CAACC,OAAO,CAAC,mBAAmB,CAAE;IAElFV,MAAM,CAACe,MAAM,CAACC,UAAU,GAAG,CAAC;IAC5BhB,MAAM,CAACe,MAAM,CAACE,QAAQ,GAAGT,QAAQ;IACjC;IACAR,MAAM,CAACe,MAAM,CAACG,SAAS,GAAGP,UAAU;IACpC,IAAIQ,EAAE,GAAInB,MAAM,CAACoB,MAAM,IAAI,KAAK,GAAEpB,MAAM,CAACqB,MAAM,GAAGrB,MAAM,CAACO,IAAK;IAC9D,IAAMe,MAAM,GAAGtB,MAAM,CAACsB,MAAM,CAACC,WAAW,IAAI,KAAK;IACjD,IAAG,CAACD,MAAM,EAAC;MACV1B,GAAG,CAAC4B,WAAW,CAAC;QACfC,IAAI,EAAE,IAAI;QACVC,KAAK,EAAC;MACP,CAAC,CAAC;IACH;IAEA,OAAO1B,MAAM;EACd,CAAC,EAAE,UAAAA,MAAM,EAAI;IAAE;IACd,OAAO2B,OAAO,CAACC,MAAM,CAAC5B,MAAM,CAAC;EAC9B,CAAC,CAAC;;EAEF;EACAJ,GAAG,CAACC,EAAE,CAACC,IAAI,CAACK,YAAY,CAAC0B,QAAQ,CAACxB,GAAG,CAAC,UAACwB,QAAQ,EAAK;IAAA;IAEnDjC,GAAG,CAAC2B,WAAW,CAAC,CAAC,CAAC,CAAC;;IAEnB;IACA,IAAMhB,IAAI,GAAGsB,QAAQ,CAACtB,IAAI;IAC1B,IAAMe,MAAM,uBAAGO,QAAQ,CAAC7B,MAAM,qDAAf,iBAAiBsB,MAAM;IAEtC,IAAIf,IAAI,CAACuB,IAAI,KAAK,GAAG,EAAE;MACtB,IAAIvB,IAAI,CAACuB,IAAI,KAAK,GAAG,IAAIvB,IAAI,CAACuB,IAAI,KAAK,IAAI,EAAE;QAC5ClC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAACnB,IAAI,CAACyB,GAAG;UACdC,IAAI,EAAC;QACN,CAAC,CAAC;;QAEF;QACA;QACA;MACD,CAAC,MAAM,IAAI1B,IAAI,CAACuB,IAAI,KAAK,GAAG,EAAE;QAC7BlC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAEnB,IAAI,CAACyB,GAAG;UACfC,IAAI,EAAE;QACP,CAAC,CAAC;MACH,CAAC,MAAM,IAAI1B,IAAI,CAACuB,IAAI,KAAK,CAAC,EAAE;QAC3BlC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAEnB,IAAI,CAACyB,GAAG;UACfC,IAAI,EAAE;QACP,CAAC,CAAC;MACH,CAAC,MAAK,IAAI1B,IAAI,CAACuB,IAAI,KAAK,IAAI,EAAE;QAC7BrB,cAAK,CAACyB,MAAM,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;MACxC;MAEA,IAAIZ,MAAM,CAACa,KAAK,KAAK,KAAK,EAAE;QAC3BvC,GAAG,CAACC,EAAE,CAACsC,KAAK,CAAC5B,IAAI,CAACyB,GAAG,CAAC;MACvB;MAEA,IAAIzB,IAAI,CAACuB,IAAI,IAAI,IAAI,EAAE;QACtBrB,cAAK,CAACyB,MAAM,CAAC,iBAAiB,EAAC,EAAE,CAAC;QAClCtC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAE,OAAO;UACdO,IAAI,EAAE;QACP,CAAC,CAAC;QACFG,UAAU,CAAC,YAAM;UAChBxC,GAAG,CAACyC,QAAQ,CAAC;YACZ/B,GAAG,EAAE;UACN,CAAC,CAAC;QACH,CAAC,EAAE,IAAI,CAAC;MACT;MAEA,aAAYuB,QAAQ,CAAC7B,MAAM,CAACM,GAAG;MAC/B,OAAOqB,OAAO,CAACC,MAAM,CAACrB,IAAI,CAAC;IAC5B;IACA,OAAOA,IAAI,CAACA,IAAI,KAAK+B,SAAS,GAAG,CAAC,CAAC,GAAG/B,IAAI,CAACA,IAAI;EAChD,CAAC,EAAE,UAACsB,QAAQ,EAAK;IAChBjC,GAAG,CAACmC,SAAS,CAAC;MACbN,IAAI,EAAE,IAAI;MACVC,KAAK,EAAE,SAAS,GAAGG,QAAQ,CAACU,UAAU;MACtCN,IAAI,EAAE;IACP,CAAC,CAAC;IACF,OAAON,OAAO,CAACC,MAAM,CAACC,QAAQ,CAAC;EAChC,CAAC,CAAC;AACH,CAAC;AAAA,2B","file":"423.js","sourcesContent":["import store from \"../store/index.js\";\nimport utils from \"../utils/utils.js\";\n\nimport { baseUrl } from \"./api.js\";\n\nconst HOST = location && location.origin \nexport default () => {\n\tlet readBaseUrl = process.env.bcUrl\n\t// 初始化请求配置\n\tuni.$u.http.setConfig((config) => {\n\t\tif(readBaseUrl ){\n\t\t\tconfig.baseURL = readBaseUrl;  // 测试地址\n\t\t}\n\t\t\n\n\t\t\tconfig.baseURL = baseUrl;  // 测试地址\n\n\t\treturn config\n\t});\n\t\n\t\n\t// 请求拦截\n\tuni.$u.http.interceptors.request.use((config) => { // 可使用async await 做异步操作\n\t\t\n\t\t\n\t\tif(!config.baseURL){\n\t\t\tconfig.url = '/'+config.url\n\t\t}\n\t\t\n\t\tconfig.data = config.data || {};\n\t\t// config.baseURL = 'http://test.sc2.agrimedia.cn';  // 不使用请求代理  上线记得注释掉 ***********************************************************\n\t\t\n\t\tlet apiToken = store.getters['api/getApiToken']\n\t\tlet serverTime = (parseInt(Date.now() /1000) - store.getters['api/getServerTime'])\n\t\t\n\t\tconfig.header.systemType = 0;\n\t\tconfig.header.ApiToken = apiToken\n\t\t// config.header.systemSn = utils.getSunmiSerial()\n\t\tconfig.header.timestamp = serverTime\n\t\tlet ob = (config.method == 'GET'? config.params : config.data)\n\t\tconst custom = config.custom.hideLoading || false\n\t\tif(!custom){\n\t\t\tuni.showLoading({\n\t\t\t\tmask: true,\n\t\t\t\ttitle:\"加载中...\"\n\t\t\t});\n\t\t}\n\t\t\n\t\treturn config\n\t}, config => { // 可使用async await 做异步操作\n\t\treturn Promise.reject(config)\n\t})\n\n\t// 响应拦截\n\tuni.$u.http.interceptors.response.use((response) => {\n\t\t\n\t\tuni.hideLoading({});\n\t\t\n\t\t/* 对响应成功做点什么 可使用async await 做异步操作*/\n\t\tconst data = response.data\n\t\tconst custom = response.config?.custom\n\t\t\n\t\tif (data.code !== 200) {\n\t\t\tif (data.code === 401 || data.code === 1005) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle:data.msg,\n\t\t\t\t\ticon:'none'\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\t// setTimeout(e => {\n\t\t\t\t// \tutils.goPath('/pages/login/login');\n\t\t\t\t// },1000)\n\t\t\t} else if (data.code === 400) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: data.msg,\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t} else if (data.code === 0) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: data.msg,\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t}else if (data.code === 7776) {\n\t\t\t\tstore.commit('api/setActiceDevice', {})\n\t\t\t}\n\t\t\t\n\t\t\tif (custom.toast !== false) {\n\t\t\t\tuni.$u.toast(data.msg)\n\t\t\t}\n\t\t\t\n\t\t\tif (data.code == 7777) {\n\t\t\t\tstore.commit('api/setApiToken','')\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: '请重新登录',\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tuni.reLaunch({\n\t\t\t\t\t\turl: '/pages/login/login'\n\t\t\t\t\t})\n\t\t\t\t}, 1000)\n\t\t\t}\n\t\t\t\n\t\t\tconsole.log(response.config.url)\n\t\t\treturn Promise.reject(data)\n\t\t}\n\t\treturn data.data === undefined ? {} : data.data;\n\t}, (response) => {\n\t\tuni.showToast({\n\t\t\tmask: true,\n\t\t\ttitle: '服务器响应失败' + response.statusCode,\n\t\t\ticon: 'none'\n\t\t})\n\t\treturn Promise.reject(response)\n\t})\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///423\n"); +eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _index = _interopRequireDefault(__webpack_require__(/*! ../store/index.js */ 148));\nvar _utils = _interopRequireDefault(__webpack_require__(/*! ../utils/utils.js */ 146));\nvar _api = __webpack_require__(/*! ./api.js */ 151);\nvar HOST = location && location.origin;\nvar _default = function _default() {\n var readBaseUrl = Object({\"NODE_ENV\":\"development\",\"VUE_APP_DARK_MODE\":\"false\",\"VUE_APP_NAME\":\"中鼎云医\",\"VUE_APP_PLATFORM\":\"app-plus\",\"BASE_URL\":\"/\"}).bcUrl;\n // 初始化请求配置\n uni.$u.http.setConfig(function (config) {\n if (readBaseUrl) {\n config.baseURL = readBaseUrl; // 测试地址\n }\n\n config.baseURL = _api.baseUrl; // 测试地址\n\n return config;\n });\n\n // 请求拦截\n uni.$u.http.interceptors.request.use(function (config) {\n // 可使用async await 做异步操作\n\n if (!config.baseURL) {\n config.url = '/' + config.url;\n }\n config.data = config.data || {};\n config.baseURL = 'https://ai.agrimedia.cn/'; // 不使用请求代理 上线记得注释掉 ***********************************************************\n\n var apiToken = _index.default.getters['api/getApiToken'];\n var serverTime = parseInt(Date.now() / 1000) - _index.default.getters['api/getServerTime'];\n config.header.systemType = 0;\n config.header.ApiToken = apiToken;\n // config.header.systemSn = utils.getSunmiSerial()\n config.header.timestamp = serverTime;\n var ob = config.method == 'GET' ? config.params : config.data;\n var custom = config.custom.hideLoading || false;\n if (!custom) {\n uni.showLoading({\n mask: true,\n title: \"加载中...\"\n });\n }\n return config;\n }, function (config) {\n // 可使用async await 做异步操作\n return Promise.reject(config);\n });\n\n // 响应拦截\n uni.$u.http.interceptors.response.use(function (response) {\n var _response$config;\n uni.hideLoading({});\n\n /* 对响应成功做点什么 可使用async await 做异步操作*/\n var data = response.data;\n var custom = (_response$config = response.config) === null || _response$config === void 0 ? void 0 : _response$config.custom;\n if (data.code !== 200) {\n if (data.code === 401 || data.code === 1005) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n\n // setTimeout(e => {\n // \tutils.goPath('/pages/login/login');\n // },1000)\n } else if (data.code === 400) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n } else if (data.code === 0) {\n uni.showToast({\n mask: true,\n title: data.msg,\n icon: 'none'\n });\n } else if (data.code === 7776) {\n _index.default.commit('api/setActiceDevice', {});\n }\n if (custom.toast !== false) {\n uni.$u.toast(data.msg);\n }\n if (data.code == 7777) {\n _index.default.commit('api/setApiToken', '');\n uni.showToast({\n mask: true,\n title: '请重新登录',\n icon: 'none'\n });\n setTimeout(function () {\n uni.reLaunch({\n url: '/pages/login/login'\n });\n }, 1000);\n }\n __f__(\"log\", response.config.url, \" at config/request.js:108\");\n return Promise.reject(data);\n }\n return data.data === undefined ? {} : data.data;\n }, function (response) {\n uni.showToast({\n mask: true,\n title: '服务器响应失败' + response.statusCode,\n icon: 'none'\n });\n return Promise.reject(response);\n });\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 15)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///config/request.js"],"names":["HOST","location","origin","readBaseUrl","process","bcUrl","uni","$u","http","setConfig","config","baseURL","baseUrl","interceptors","request","use","url","data","apiToken","store","getters","serverTime","parseInt","Date","now","header","systemType","ApiToken","timestamp","ob","method","params","custom","hideLoading","showLoading","mask","title","Promise","reject","response","code","showToast","msg","icon","commit","toast","setTimeout","reLaunch","undefined","statusCode"],"mappings":";;;;;;;AAAA;AACA;AAEA;AAEA,IAAMA,IAAI,GAAGC,QAAQ,IAAIA,QAAQ,CAACC,MAAM;AAAA,eACzB,oBAAM;EACpB,IAAIC,WAAW,GAAGC,iIAAW,CAACC,KAAK;EACnC;EACAC,GAAG,CAACC,EAAE,CAACC,IAAI,CAACC,SAAS,CAAC,UAACC,MAAM,EAAK;IACjC,IAAGP,WAAW,EAAE;MACfO,MAAM,CAACC,OAAO,GAAGR,WAAW,CAAC,CAAE;IAChC;;IAGCO,MAAM,CAACC,OAAO,GAAGC,YAAO,CAAC,CAAE;;IAE5B,OAAOF,MAAM;EACd,CAAC,CAAC;;EAGF;EACAJ,GAAG,CAACC,EAAE,CAACC,IAAI,CAACK,YAAY,CAACC,OAAO,CAACC,GAAG,CAAC,UAACL,MAAM,EAAK;IAAE;;IAGlD,IAAG,CAACA,MAAM,CAACC,OAAO,EAAC;MAClBD,MAAM,CAACM,GAAG,GAAG,GAAG,GAACN,MAAM,CAACM,GAAG;IAC5B;IAEAN,MAAM,CAACO,IAAI,GAAGP,MAAM,CAACO,IAAI,IAAI,CAAC,CAAC;IAC/BP,MAAM,CAACC,OAAO,GAAG,0BAA0B,CAAC,CAAE;;IAE9C,IAAIO,QAAQ,GAAGC,cAAK,CAACC,OAAO,CAAC,iBAAiB,CAAC;IAC/C,IAAIC,UAAU,GAAIC,QAAQ,CAACC,IAAI,CAACC,GAAG,EAAE,GAAE,IAAI,CAAC,GAAGL,cAAK,CAACC,OAAO,CAAC,mBAAmB,CAAE;IAElFV,MAAM,CAACe,MAAM,CAACC,UAAU,GAAG,CAAC;IAC5BhB,MAAM,CAACe,MAAM,CAACE,QAAQ,GAAGT,QAAQ;IACjC;IACAR,MAAM,CAACe,MAAM,CAACG,SAAS,GAAGP,UAAU;IACpC,IAAIQ,EAAE,GAAInB,MAAM,CAACoB,MAAM,IAAI,KAAK,GAAEpB,MAAM,CAACqB,MAAM,GAAGrB,MAAM,CAACO,IAAK;IAC9D,IAAMe,MAAM,GAAGtB,MAAM,CAACsB,MAAM,CAACC,WAAW,IAAI,KAAK;IACjD,IAAG,CAACD,MAAM,EAAC;MACV1B,GAAG,CAAC4B,WAAW,CAAC;QACfC,IAAI,EAAE,IAAI;QACVC,KAAK,EAAC;MACP,CAAC,CAAC;IACH;IAEA,OAAO1B,MAAM;EACd,CAAC,EAAE,UAAAA,MAAM,EAAI;IAAE;IACd,OAAO2B,OAAO,CAACC,MAAM,CAAC5B,MAAM,CAAC;EAC9B,CAAC,CAAC;;EAEF;EACAJ,GAAG,CAACC,EAAE,CAACC,IAAI,CAACK,YAAY,CAAC0B,QAAQ,CAACxB,GAAG,CAAC,UAACwB,QAAQ,EAAK;IAAA;IAEnDjC,GAAG,CAAC2B,WAAW,CAAC,CAAC,CAAC,CAAC;;IAEnB;IACA,IAAMhB,IAAI,GAAGsB,QAAQ,CAACtB,IAAI;IAC1B,IAAMe,MAAM,uBAAGO,QAAQ,CAAC7B,MAAM,qDAAf,iBAAiBsB,MAAM;IAEtC,IAAIf,IAAI,CAACuB,IAAI,KAAK,GAAG,EAAE;MACtB,IAAIvB,IAAI,CAACuB,IAAI,KAAK,GAAG,IAAIvB,IAAI,CAACuB,IAAI,KAAK,IAAI,EAAE;QAC5ClC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAACnB,IAAI,CAACyB,GAAG;UACdC,IAAI,EAAC;QACN,CAAC,CAAC;;QAEF;QACA;QACA;MACD,CAAC,MAAM,IAAI1B,IAAI,CAACuB,IAAI,KAAK,GAAG,EAAE;QAC7BlC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAEnB,IAAI,CAACyB,GAAG;UACfC,IAAI,EAAE;QACP,CAAC,CAAC;MACH,CAAC,MAAM,IAAI1B,IAAI,CAACuB,IAAI,KAAK,CAAC,EAAE;QAC3BlC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAEnB,IAAI,CAACyB,GAAG;UACfC,IAAI,EAAE;QACP,CAAC,CAAC;MACH,CAAC,MAAK,IAAI1B,IAAI,CAACuB,IAAI,KAAK,IAAI,EAAE;QAC7BrB,cAAK,CAACyB,MAAM,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;MACxC;MAEA,IAAIZ,MAAM,CAACa,KAAK,KAAK,KAAK,EAAE;QAC3BvC,GAAG,CAACC,EAAE,CAACsC,KAAK,CAAC5B,IAAI,CAACyB,GAAG,CAAC;MACvB;MAEA,IAAIzB,IAAI,CAACuB,IAAI,IAAI,IAAI,EAAE;QACtBrB,cAAK,CAACyB,MAAM,CAAC,iBAAiB,EAAC,EAAE,CAAC;QAClCtC,GAAG,CAACmC,SAAS,CAAC;UACbN,IAAI,EAAE,IAAI;UACVC,KAAK,EAAE,OAAO;UACdO,IAAI,EAAE;QACP,CAAC,CAAC;QACFG,UAAU,CAAC,YAAM;UAChBxC,GAAG,CAACyC,QAAQ,CAAC;YACZ/B,GAAG,EAAE;UACN,CAAC,CAAC;QACH,CAAC,EAAE,IAAI,CAAC;MACT;MAEA,aAAYuB,QAAQ,CAAC7B,MAAM,CAACM,GAAG;MAC/B,OAAOqB,OAAO,CAACC,MAAM,CAACrB,IAAI,CAAC;IAC5B;IACA,OAAOA,IAAI,CAACA,IAAI,KAAK+B,SAAS,GAAG,CAAC,CAAC,GAAG/B,IAAI,CAACA,IAAI;EAChD,CAAC,EAAE,UAACsB,QAAQ,EAAK;IAChBjC,GAAG,CAACmC,SAAS,CAAC;MACbN,IAAI,EAAE,IAAI;MACVC,KAAK,EAAE,SAAS,GAAGG,QAAQ,CAACU,UAAU;MACtCN,IAAI,EAAE;IACP,CAAC,CAAC;IACF,OAAON,OAAO,CAACC,MAAM,CAACC,QAAQ,CAAC;EAChC,CAAC,CAAC;AACH,CAAC;AAAA,2B","file":"423.js","sourcesContent":["import store from \"../store/index.js\";\nimport utils from \"../utils/utils.js\";\n\nimport { baseUrl } from \"./api.js\";\n\nconst HOST = location && location.origin \nexport default () => {\n\tlet readBaseUrl = process.env.bcUrl\n\t// 初始化请求配置\n\tuni.$u.http.setConfig((config) => {\n\t\tif(readBaseUrl ){\n\t\t\tconfig.baseURL = readBaseUrl;  // 测试地址\n\t\t}\n\t\t\n\n\t\t\tconfig.baseURL = baseUrl;  // 测试地址\n\n\t\treturn config\n\t});\n\t\n\t\n\t// 请求拦截\n\tuni.$u.http.interceptors.request.use((config) => { // 可使用async await 做异步操作\n\t\t\n\t\t\n\t\tif(!config.baseURL){\n\t\t\tconfig.url = '/'+config.url\n\t\t}\n\t\t\n\t\tconfig.data = config.data || {};\n\t\tconfig.baseURL = 'https://ai.agrimedia.cn/';  // 不使用请求代理  上线记得注释掉 ***********************************************************\n\t\t\n\t\tlet apiToken = store.getters['api/getApiToken']\n\t\tlet serverTime = (parseInt(Date.now() /1000) - store.getters['api/getServerTime'])\n\t\t\n\t\tconfig.header.systemType = 0;\n\t\tconfig.header.ApiToken = apiToken\n\t\t// config.header.systemSn = utils.getSunmiSerial()\n\t\tconfig.header.timestamp = serverTime\n\t\tlet ob = (config.method == 'GET'? config.params : config.data)\n\t\tconst custom = config.custom.hideLoading || false\n\t\tif(!custom){\n\t\t\tuni.showLoading({\n\t\t\t\tmask: true,\n\t\t\t\ttitle:\"加载中...\"\n\t\t\t});\n\t\t}\n\t\t\n\t\treturn config\n\t}, config => { // 可使用async await 做异步操作\n\t\treturn Promise.reject(config)\n\t})\n\n\t// 响应拦截\n\tuni.$u.http.interceptors.response.use((response) => {\n\t\t\n\t\tuni.hideLoading({});\n\t\t\n\t\t/* 对响应成功做点什么 可使用async await 做异步操作*/\n\t\tconst data = response.data\n\t\tconst custom = response.config?.custom\n\t\t\n\t\tif (data.code !== 200) {\n\t\t\tif (data.code === 401 || data.code === 1005) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle:data.msg,\n\t\t\t\t\ticon:'none'\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\t// setTimeout(e => {\n\t\t\t\t// \tutils.goPath('/pages/login/login');\n\t\t\t\t// },1000)\n\t\t\t} else if (data.code === 400) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: data.msg,\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t} else if (data.code === 0) {\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: data.msg,\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t}else if (data.code === 7776) {\n\t\t\t\tstore.commit('api/setActiceDevice', {})\n\t\t\t}\n\t\t\t\n\t\t\tif (custom.toast !== false) {\n\t\t\t\tuni.$u.toast(data.msg)\n\t\t\t}\n\t\t\t\n\t\t\tif (data.code == 7777) {\n\t\t\t\tstore.commit('api/setApiToken','')\n\t\t\t\tuni.showToast({\n\t\t\t\t\tmask: true,\n\t\t\t\t\ttitle: '请重新登录',\n\t\t\t\t\ticon: 'none'\n\t\t\t\t})\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tuni.reLaunch({\n\t\t\t\t\t\turl: '/pages/login/login'\n\t\t\t\t\t})\n\t\t\t\t}, 1000)\n\t\t\t}\n\t\t\t\n\t\t\tconsole.log(response.config.url)\n\t\t\treturn Promise.reject(data)\n\t\t}\n\t\treturn data.data === undefined ? {} : data.data;\n\t}, (response) => {\n\t\tuni.showToast({\n\t\t\tmask: true,\n\t\t\ttitle: '服务器响应失败' + response.statusCode,\n\t\t\ticon: 'none'\n\t\t})\n\t\treturn Promise.reject(response)\n\t})\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///423\n"); /***/ }) ],[[0,"app-config"]]]); \ No newline at end of file diff --git a/unpackage/dist/dev/app-plus/app-view.js b/unpackage/dist/dev/app-plus/app-view.js index 29ed255..630bf88 100644 --- a/unpackage/dist/dev/app-plus/app-view.js +++ b/unpackage/dist/dev/app-plus/app-view.js @@ -10421,88 +10421,91 @@ var render = function () { "uni-popup", { ref: "popup", attrs: { _i: 1 } }, [ - _vm._$g(2, "i") - ? _c( - "uni-view", - { staticClass: _vm._$g(2, "sc"), attrs: { _i: 2 } }, - [ - _c( + _c( + "uni-view", + { staticClass: _vm._$g(2, "sc"), attrs: { _i: 2 } }, + [ + _vm._$g(3, "i") + ? _c( "uni-view", - { attrs: { _i: 3 } }, + { staticClass: _vm._$g(3, "sc"), attrs: { _i: 3 } }, [ _c( "uni-view", - { - staticClass: _vm._$g(4, "sc"), - attrs: { _i: 4 }, - on: { - click: function ($event) { - return _vm.$handleViewEvent($event) - }, - }, - }, - [_vm._v("×")] - ), - _c( - "uni-view", - { staticClass: _vm._$g(5, "sc"), attrs: { _i: 5 } }, + { staticClass: _vm._$g(4, "sc"), attrs: { _i: 4 } }, [ _c( - "v-uni-scroll-view", + "uni-view", { - staticClass: _vm._$g(6, "sc"), - attrs: { - "scroll-x": true, - "show-scrollbar": true, - _i: 6, + staticClass: _vm._$g(5, "sc"), + attrs: { _i: 5 }, + on: { + click: function ($event) { + return _vm.$handleViewEvent($event) + }, }, }, + [_vm._v("×")] + ), + _c( + "uni-view", + { staticClass: _vm._$g(6, "sc"), attrs: { _i: 6 } }, [ _c( - "uni-view", + "v-uni-scroll-view", { staticClass: _vm._$g(7, "sc"), - attrs: { _i: 7 }, + attrs: { + "scroll-x": true, + "show-scrollbar": true, + _i: 7, + }, }, [ - _c("v-uni-canvas", { - staticStyle: { - width: "3000px", - height: "300px", + _c( + "uni-view", + { + staticClass: _vm._$g(8, "sc"), + attrs: { _i: 8 }, }, - attrs: { "canvas-id": "ecg", _i: 8 }, - }), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(9, "sc"), - style: _vm._$g(9, "s"), - attrs: { _i: 9 }, - }, - [ - _c("v-uni-canvas", { - staticStyle: { - width: "3000px", - height: "300px", + [ + _c("v-uni-canvas", { + staticStyle: { + width: "3000px", + height: "300px", + }, + attrs: { "canvas-id": "ecg", _i: 9 }, + }), + ], + 1 + ), + _c( + "uni-view", + { + staticClass: _vm._$g(10, "sc"), + style: _vm._$g(10, "s"), + attrs: { _i: 10 }, }, - attrs: { "canvas-id": "myCanvas", _i: 10 }, - }), + [ + _c("v-uni-canvas", { + staticStyle: { + width: "3000px", + height: "300px", + }, + attrs: { + "canvas-id": "myCanvas", + _i: 11, + }, + }), + ], + 1 + ), ], 1 ), ], 1 ), - ], - 1 - ), - _c( - "uni-view", - { staticClass: _vm._$g(11, "sc"), attrs: { _i: 11 } }, - [ _c( "uni-view", { @@ -10513,103 +10516,101 @@ var render = function () { _c( "uni-view", { - staticStyle: { - "margin-top": "10rpx", - "margin-right": "10rpx", - }, + staticClass: _vm._$g(13, "sc"), attrs: { _i: 13 }, }, [ - _c("v-uni-image", { - staticStyle: { width: "40rpx" }, - attrs: { - src: _vm._$g(14, "a-src"), - mode: "widthFix", - _i: 14, + _c( + "uni-view", + { + staticStyle: { + "margin-top": "10rpx", + "margin-right": "10rpx", + }, + attrs: { _i: 14 }, }, - }), + [ + _c("v-uni-image", { + staticStyle: { width: "40rpx" }, + attrs: { + src: _vm._$g(15, "a-src"), + mode: "widthFix", + _i: 15, + }, + }), + ], + 1 + ), + _c( + "uni-view", + { + staticStyle: { color: "red" }, + attrs: { _i: 16 }, + }, + [_vm._v("心率")] + ), ], 1 ), _c( "uni-view", { - staticStyle: { color: "red" }, - attrs: { _i: 15 }, + staticClass: _vm._$g(17, "sc"), + attrs: { _i: 17 }, }, - [_vm._v("心率")] - ), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(16, "sc"), - attrs: { _i: 16 }, - }, - [ - _vm._l( - _vm._$g(17, "f"), - function (item, index, $20, $30) { - return _c( - "uni-view", - { - key: item, - staticClass: _vm._$g("17-" + $30, "sc"), - attrs: { _i: "17-" + $30 }, - }, - [ - _c( - "uni-view", - { attrs: { _i: "18-" + $30 } }, - [ - _c( - "span", - { - staticClass: _vm._$g( - "19-" + $30, - "sc" - ), - attrs: { _i: "19-" + $30 }, - }, - [ - _vm._v( - _vm._$g("19-" + $30, "t0-0") - ), - ] - ), - _c( - "span", - { - staticClass: _vm._$g( - "20-" + $30, - "sc" - ), - attrs: { _i: "20-" + $30 }, - }, - [ - _vm._v( - _vm._$g("20-" + $30, "t0-0") - ), - ] - ), - ], - 1 - ), - _c( + [ + _vm._l( + _vm._$g(18, "f"), + function (item, index, $20, $30) { + return _c( "uni-view", { + key: item, staticClass: _vm._$g( - "21-" + $30, + "18-" + $30, "sc" ), - attrs: { _i: "21-" + $30 }, + attrs: { _i: "18-" + $30 }, }, - [_vm._v(_vm._$g("21-" + $30, "t0-0"))] - ), - _vm._$g("22-" + $30, "i") - ? _c( + [ + _c( + "uni-view", + { attrs: { _i: "19-" + $30 } }, + [ + _c( + "span", + { + staticClass: _vm._$g( + "20-" + $30, + "sc" + ), + attrs: { _i: "20-" + $30 }, + }, + [ + _vm._v( + _vm._$g("20-" + $30, "t0-0") + ), + ] + ), + _c( + "span", + { + staticClass: _vm._$g( + "21-" + $30, + "sc" + ), + attrs: { _i: "21-" + $30 }, + }, + [ + _vm._v( + _vm._$g("21-" + $30, "t0-0") + ), + ] + ), + ], + 1 + ), + _c( "uni-view", { staticClass: _vm._$g( @@ -10623,74 +10624,81 @@ var render = function () { _vm._$g("22-" + $30, "t0-0") ), ] - ) - : _vm._e(), - ], - 1 - ) - } - ), - _vm._l( - _vm._$g(23, "f"), - function (item, index, $21, $31) { - return _c( - "uni-view", - { - key: item, - staticClass: _vm._$g("23-" + $31, "sc"), - attrs: { _i: "23-" + $31 }, - }, - [ - _c( - "uni-view", - { attrs: { _i: "24-" + $31 } }, - [ - _c( - "span", - { - staticClass: _vm._$g( - "25-" + $31, - "sc" - ), - attrs: { _i: "25-" + $31 }, - }, - [ - _vm._v( - _vm._$g("25-" + $31, "t0-0") - ), - ] - ), - _c( - "span", - { - staticClass: _vm._$g( - "26-" + $31, - "sc" - ), - attrs: { _i: "26-" + $31 }, - }, - [ - _vm._v( - _vm._$g("26-" + $31, "t0-0") - ), - ] ), + _vm._$g("23-" + $30, "i") + ? _c( + "uni-view", + { + staticClass: _vm._$g( + "23-" + $30, + "sc" + ), + attrs: { _i: "23-" + $30 }, + }, + [ + _vm._v( + _vm._$g("23-" + $30, "t0-0") + ), + ] + ) + : _vm._e(), ], 1 - ), - _c( + ) + } + ), + _vm._l( + _vm._$g(24, "f"), + function (item, index, $21, $31) { + return _c( "uni-view", { + key: item, staticClass: _vm._$g( - "27-" + $31, + "24-" + $31, "sc" ), - attrs: { _i: "27-" + $31 }, + attrs: { _i: "24-" + $31 }, }, - [_vm._v(_vm._$g("27-" + $31, "t0-0"))] - ), - _vm._$g("28-" + $31, "i") - ? _c( + [ + _c( + "uni-view", + { attrs: { _i: "25-" + $31 } }, + [ + _c( + "span", + { + staticClass: _vm._$g( + "26-" + $31, + "sc" + ), + attrs: { _i: "26-" + $31 }, + }, + [ + _vm._v( + _vm._$g("26-" + $31, "t0-0") + ), + ] + ), + _c( + "span", + { + staticClass: _vm._$g( + "27-" + $31, + "sc" + ), + attrs: { _i: "27-" + $31 }, + }, + [ + _vm._v( + _vm._$g("27-" + $31, "t0-0") + ), + ] + ), + ], + 1 + ), + _c( "uni-view", { staticClass: _vm._$g( @@ -10704,23 +10712,35 @@ var render = function () { _vm._$g("28-" + $31, "t0-0") ), ] - ) - : _vm._e(), - ], - 1 - ) - } + ), + _vm._$g("29-" + $31, "i") + ? _c( + "uni-view", + { + staticClass: _vm._$g( + "29-" + $31, + "sc" + ), + attrs: { _i: "29-" + $31 }, + }, + [ + _vm._v( + _vm._$g("29-" + $31, "t0-0") + ), + ] + ) + : _vm._e(), + ], + 1 + ) + } + ), + ], + 2 ), ], - 2 + 1 ), - ], - 1 - ), - _c( - "uni-view", - { staticClass: _vm._$g(29, "sc"), attrs: { _i: 29 } }, - [ _c( "uni-view", { @@ -10731,52 +10751,55 @@ var render = function () { _c( "uni-view", { - staticStyle: { - "margin-top": "10rpx", - "margin-right": "10rpx", - }, + staticClass: _vm._$g(31, "sc"), attrs: { _i: 31 }, }, [ - _c("v-uni-image", { - staticStyle: { width: "40rpx" }, - attrs: { - src: _vm._$g(32, "a-src"), - mode: "widthFix", - _i: 32, + _c( + "uni-view", + { + staticStyle: { + "margin-top": "10rpx", + "margin-right": "10rpx", + }, + attrs: { _i: 32 }, }, - }), + [ + _c("v-uni-image", { + staticStyle: { width: "40rpx" }, + attrs: { + src: _vm._$g(33, "a-src"), + mode: "widthFix", + _i: 33, + }, + }), + ], + 1 + ), + _c( + "uni-view", + { + staticStyle: { color: "red" }, + attrs: { _i: 34 }, + }, + [_vm._v("心率变异性")] + ), ], 1 ), _c( "uni-view", - { - staticStyle: { color: "red" }, - attrs: { _i: 33 }, - }, - [_vm._v("心率变异性")] + { attrs: { _i: 35 } }, + [ + _c("xdt", { attrs: { _i: 36 } }), + _c("xdt", { attrs: { _i: 37 } }), + _c("xdt", { attrs: { _i: 38 } }), + ], + 1 ), ], 1 ), - _c( - "uni-view", - { attrs: { _i: 34 } }, - [ - _c("xdt", { attrs: { _i: 35 } }), - _c("xdt", { attrs: { _i: 36 } }), - _c("xdt", { attrs: { _i: 37 } }), - ], - 1 - ), - ], - 1 - ), - _c( - "uni-view", - { staticClass: _vm._$g(38, "sc"), attrs: { _i: 38 } }, - [ _c( "uni-view", { @@ -10787,146 +10810,146 @@ var render = function () { _c( "uni-view", { - staticStyle: { - "margin-top": "10rpx", - "margin-right": "10rpx", - }, + staticClass: _vm._$g(40, "sc"), attrs: { _i: 40 }, }, [ - _c("v-uni-image", { - staticStyle: { width: "40rpx" }, - attrs: { - src: _vm._$g(41, "a-src"), - mode: "widthFix", - _i: 41, + _c( + "uni-view", + { + staticStyle: { + "margin-top": "10rpx", + "margin-right": "10rpx", + }, + attrs: { _i: 41 }, }, - }), + [ + _c("v-uni-image", { + staticStyle: { width: "40rpx" }, + attrs: { + src: _vm._$g(42, "a-src"), + mode: "widthFix", + _i: 42, + }, + }), + ], + 1 + ), + _c( + "uni-view", + { + staticStyle: { color: "red" }, + attrs: { _i: 43 }, + }, + [_vm._v("心电图")] + ), ], 1 ), _c( "uni-view", - { - staticStyle: { color: "red" }, - attrs: { _i: 42 }, - }, - [_vm._v("心电图")] + { attrs: { _i: 44 } }, + [ + _c("xdt", { attrs: { _i: 45 } }), + _c("xdt", { attrs: { _i: 46 } }), + _c("xdt", { attrs: { _i: 47 } }), + _c("xdt", { attrs: { _i: 48 } }), + _c("xdt", { attrs: { _i: 49 } }), + _c("xdt", { attrs: { _i: 50 } }), + ], + 1 ), ], 1 ), - _c( - "uni-view", - { attrs: { _i: 43 } }, - [ - _c("xdt", { attrs: { _i: 44 } }), - _c("xdt", { attrs: { _i: 45 } }), - _c("xdt", { attrs: { _i: 46 } }), - _c("xdt", { attrs: { _i: 47 } }), - _c("xdt", { attrs: { _i: 48 } }), - _c("xdt", { attrs: { _i: 49 } }), - ], - 1 - ), + _c("uni-view", { + staticStyle: { height: "20rpx" }, + attrs: { _i: 51 }, + }), ], 1 ), - _c("uni-view", { - staticStyle: { height: "20rpx" }, - attrs: { _i: 50 }, - }), ], 1 - ), - ], - 1 - ) - : _vm._e(), - _vm._$g(51, "i") - ? _c( - "uni-view", - { staticClass: _vm._$g(51, "sc"), attrs: { _i: 51 } }, - [ - _c( + ) + : _vm._e(), + _vm._$g(52, "i") + ? _c( "uni-view", - { attrs: { _i: 52 } }, + { staticClass: _vm._$g(52, "sc"), attrs: { _i: 52 } }, [ _c( "uni-view", - { - staticClass: _vm._$g(53, "sc"), - attrs: { _i: 53 }, - on: { - click: function ($event) { - return _vm.$handleViewEvent($event) - }, - }, - }, - [_vm._v("×")] - ), - _c( - "uni-view", - { attrs: { _i: 54 } }, + { staticClass: _vm._$g(53, "sc"), attrs: { _i: 53 } }, [ _c( "uni-view", { - staticClass: _vm._$g(55, "sc"), - staticStyle: { - "background-color": "#fff", - padding: "30rpx 0 0 30rpx", + staticClass: _vm._$g(54, "sc"), + attrs: { _i: 54 }, + on: { + click: function ($event) { + return _vm.$handleViewEvent($event) + }, }, - attrs: { _i: 55 }, }, - [ - _c( - "uni-view", - { attrs: { _i: 56 } }, - [ - _c("v-uni-text", { - staticClass: _vm._$g(57, "sc"), - style: _vm._$g(57, "s"), - attrs: { _i: 57 }, - }), - ], - 1 - ), - _c( - "uni-view", - { attrs: { _i: 58 } }, - [ - _c("v-uni-text", { attrs: { _i: 59 } }, [ - _vm._v(_vm._$g(59, "t0-0")), - ]), - ], - 1 - ), - ], - 1 + [_vm._v("×")] ), _c( "uni-view", - { - staticStyle: { position: "relative" }, - attrs: { _i: 60 }, - }, + { attrs: { _i: 55 } }, [ - _c("v-uni-image", { - staticStyle: { width: "100%" }, - attrs: { - src: _vm._$g(61, "a-src"), - mode: "widthFix", - _i: 61, - }, - }), _c( "uni-view", { - staticClass: _vm._$g(62, "sc"), - attrs: { _i: 62 }, + staticClass: _vm._$g(56, "sc"), + staticStyle: { + "background-color": "#fff", + padding: "30rpx 0 0 30rpx", + }, + attrs: { _i: 56 }, }, [ + _c( + "uni-view", + { attrs: { _i: 57 } }, + [ + _c("v-uni-text", { + staticClass: _vm._$g(58, "sc"), + style: _vm._$g(58, "s"), + attrs: { _i: 58 }, + }), + ], + 1 + ), + _c( + "uni-view", + { attrs: { _i: 59 } }, + [ + _c("v-uni-text", { attrs: { _i: 60 } }, [ + _vm._v(_vm._$g(60, "t0-0")), + ]), + ], + 1 + ), + ], + 1 + ), + _c( + "uni-view", + { + staticStyle: { position: "relative" }, + attrs: { _i: 61 }, + }, + [ + _c("v-uni-image", { + staticStyle: { width: "100%" }, + attrs: { + src: _vm._$g(62, "a-src"), + mode: "widthFix", + _i: 62, + }, + }), _c( "uni-view", { @@ -10947,37 +10970,43 @@ var render = function () { staticClass: _vm._$g(65, "sc"), attrs: { _i: 65 }, }, - [_vm._v(_vm._$g(65, "t0-0"))] + [ + _c( + "uni-view", + { + staticClass: _vm._$g( + 66, + "sc" + ), + attrs: { _i: 66 }, + }, + [_vm._v(_vm._$g(66, "t0-0"))] + ), + _c( + "uni-view", + { + staticClass: _vm._$g( + 67, + "sc" + ), + attrs: { _i: 67 }, + }, + [_vm._v("千卡")] + ), + ], + 1 ), _c( "uni-view", { - staticClass: _vm._$g(66, "sc"), - attrs: { _i: 66 }, + staticClass: _vm._$g(68, "sc"), + attrs: { _i: 68 }, }, - [_vm._v("千卡")] + [_vm._v("基础代谢")] ), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(67, "sc"), - attrs: { _i: 67 }, - }, - [_vm._v("基础代谢")] - ), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(68, "sc"), - attrs: { _i: 68 }, - }, - [ _c( "uni-view", { @@ -10991,37 +11020,43 @@ var render = function () { staticClass: _vm._$g(70, "sc"), attrs: { _i: 70 }, }, - [_vm._v(_vm._$g(70, "t0-0"))] + [ + _c( + "uni-view", + { + staticClass: _vm._$g( + 71, + "sc" + ), + attrs: { _i: 71 }, + }, + [_vm._v(_vm._$g(71, "t0-0"))] + ), + _c( + "uni-view", + { + staticClass: _vm._$g( + 72, + "sc" + ), + attrs: { _i: 72 }, + }, + [_vm._v("千克")] + ), + ], + 1 ), _c( "uni-view", { - staticClass: _vm._$g(71, "sc"), - attrs: { _i: 71 }, + staticClass: _vm._$g(73, "sc"), + attrs: { _i: 73 }, }, - [_vm._v("千克")] + [_vm._v("骨重")] ), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(72, "sc"), - attrs: { _i: 72 }, - }, - [_vm._v("骨重")] - ), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(73, "sc"), - attrs: { _i: 73 }, - }, - [ _c( "uni-view", { @@ -11035,40 +11070,46 @@ var render = function () { staticClass: _vm._$g(75, "sc"), attrs: { _i: 75 }, }, - [_vm._v(_vm._$g(75, "t0-0"))] + [ + _c( + "uni-view", + { + staticClass: _vm._$g( + 76, + "sc" + ), + attrs: { _i: 76 }, + }, + [_vm._v(_vm._$g(76, "t0-0"))] + ), + _c( + "uni-view", + { + staticClass: _vm._$g( + 77, + "sc" + ), + attrs: { _i: 77 }, + }, + [_vm._v("千克")] + ), + ], + 1 ), _c( "uni-view", { - staticClass: _vm._$g(76, "sc"), - attrs: { _i: 76 }, + staticClass: _vm._$g(78, "sc"), + attrs: { _i: 78 }, }, - [_vm._v("千克")] + [_vm._v("水分")] ), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(77, "sc"), - attrs: { _i: 77 }, - }, - [_vm._v("水分")] - ), ], 1 ), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(78, "sc"), - attrs: { _i: 78 }, - }, - [ _c( "uni-view", { @@ -11089,45 +11130,51 @@ var render = function () { staticClass: _vm._$g(81, "sc"), attrs: { _i: 81 }, }, - [_vm._v(_vm._$g(81, "t0-0"))] + [ + _c( + "uni-view", + { + staticClass: _vm._$g( + 82, + "sc" + ), + attrs: { _i: 82 }, + }, + [_vm._v(_vm._$g(82, "t0-0"))] + ), + _c( + "uni-view", + { + staticClass: _vm._$g( + 83, + "sc" + ), + attrs: { _i: 83 }, + }, + [_vm._v("千克")] + ), + ], + 1 ), _c( "uni-view", { - staticClass: _vm._$g(82, "sc"), - attrs: { _i: 82 }, + staticClass: _vm._$g(84, "sc"), + attrs: { _i: 84 }, }, - [_vm._v("千克")] + [_vm._v("脂肪")] ), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(83, "sc"), - attrs: { _i: 83 }, - }, - [_vm._v("脂肪")] - ), - ], - 1 - ), - _c( - "uni-view", - { - staticClass: _vm._$g(84, "sc"), - staticStyle: { - "margin-bottom": "0", - "margin-top": "174rpx", - }, - attrs: { _i: 84 }, - }, - [ _c( "uni-view", { staticClass: _vm._$g(85, "sc"), + staticStyle: { + "margin-bottom": "0", + "margin-top": "174rpx", + }, attrs: { _i: 85 }, }, [ @@ -11137,98 +11184,120 @@ var render = function () { staticClass: _vm._$g(86, "sc"), attrs: { _i: 86 }, }, - [_vm._v(_vm._$g(86, "t0-0"))] + [ + _c( + "uni-view", + { + staticClass: _vm._$g( + 87, + "sc" + ), + attrs: { _i: 87 }, + }, + [_vm._v(_vm._$g(87, "t0-0"))] + ), + _c( + "uni-view", + { + staticClass: _vm._$g( + 88, + "sc" + ), + attrs: { _i: 88 }, + }, + [_vm._v("千克")] + ), + ], + 1 ), _c( "uni-view", { - staticClass: _vm._$g(87, "sc"), - attrs: { _i: 87 }, + staticClass: _vm._$g(89, "sc"), + attrs: { _i: 89 }, }, - [_vm._v("千克")] + [_vm._v("蛋白质")] ), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(88, "sc"), - attrs: { _i: 88 }, - }, - [_vm._v("蛋白质")] - ), ], 1 ), + _c( + "uni-view", + { + staticClass: _vm._$g(90, "sc"), + attrs: { _i: 90 }, + }, + [ + _vm._v( + _vm._$g(90, "t0-0") + + "性," + + _vm._$g(90, "t0-1") + + "千克" + ), + ] + ), + _c( + "uni-view", + { + staticClass: _vm._$g(91, "sc"), + attrs: { _i: 91 }, + }, + [_vm._v(_vm._$g(91, "t0-0") + "厘米")] + ), ], 1 ), _c( "uni-view", { - staticClass: _vm._$g(89, "sc"), - attrs: { _i: 89 }, + staticClass: _vm._$g(92, "sc"), + staticStyle: { + padding: "0", + margin: "30rpx", + }, + attrs: { _i: 92 }, }, - [ - _vm._v( - _vm._$g(89, "t0-0") + - "性," + - _vm._$g(89, "t0-1") + - "千克" - ), - ] - ), - _c( - "uni-view", - { - staticClass: _vm._$g(90, "sc"), - attrs: { _i: 90 }, - }, - [_vm._v(_vm._$g(90, "t0-0") + "厘米")] + _vm._l( + _vm._$g(93, "f"), + function (v, i, $22, $32) { + return _c( + "uni-view", + { key: v, attrs: { _i: "93-" + $32 } }, + [ + _c("body_info_components", { + attrs: { _i: "94-" + $32 }, + }), + ], + 1 + ) + } + ), + 1 ), + _c("uni-view", { + staticStyle: { height: "40rpx" }, + attrs: { _i: 95 }, + }), ], 1 ), - _c( - "uni-view", - { - staticClass: _vm._$g(91, "sc"), - staticStyle: { padding: "0", margin: "30rpx" }, - attrs: { _i: 91 }, - }, - _vm._l(_vm._$g(92, "f"), function (v, i, $22, $32) { - return _c( - "uni-view", - { key: v, attrs: { _i: "92-" + $32 } }, - [ - _c("body_info_components", { - attrs: { _i: "93-" + $32 }, - }), - ], - 1 - ) - }), - 1 - ), _c("uni-view", { - staticStyle: { height: "40rpx" }, - attrs: { _i: 94 }, + staticStyle: { height: "20rpx" }, + attrs: { _i: 96 }, }), ], 1 ), - _c("uni-view", { - staticStyle: { height: "20rpx" }, - attrs: { _i: 95 }, - }), ], 1 - ), - ], - 1 - ) - : _vm._e(), + ) + : _vm._e(), + ], + 1 + ), ], 1 ), @@ -12391,7 +12460,7 @@ if(false) {} var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../../../Applications/HBuilderX.app/Contents/HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-0b42eb78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.pop-close[data-v-0b42eb78] {\n display: flex;\n flex-direction: row-reverse;\n font-size: 100rpx;\n padding-right: 50rpx;\n}\n.pop-main[data-v-0b42eb78] {\n width: 100%;\n height: 100vh;\n background-color: #fff;\n overflow-y: scroll;\n}\n.box1[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.box2[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.myScoll[data-v-0b42eb78] {\n width: 100%;\n height: 396rpx;\n white-space: nowrap;\n position: relative;\n}\n.list[data-v-0b42eb78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.dxxl[data-v-0b42eb78] {\n background-color: #fff;\n padding: 20rpx;\n padding-top: 40rpx;\n}\n.sl_box[data-v-0b42eb78] {\n text-align: center;\n}\n.sl_box .all[data-v-0b42eb78] {\n width: calc(100% / 3);\n margin-top: 40rpx;\n}\n.sl_box .sl_box_cankao[data-v-0b42eb78],\n.sl_box .sl_box_desc[data-v-0b42eb78] {\n font-size: 24rpx;\n color: #999;\n}\n.sl_box .sl_box_unit[data-v-0b42eb78] {\n font-size: 26rpx;\n}\n.sl_box .sl_box_wz[data-v-0b42eb78] {\n margin-right: 10rpx;\n font-size: 30rpx;\n font-weight: bold;\n}\n", ""]); +exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-0b42eb78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.pop-close[data-v-0b42eb78] {\n display: flex;\n flex-direction: row-reverse;\n font-size: 100rpx;\n padding-right: 50rpx;\n}\n.pop-main[data-v-0b42eb78] {\n width: 100%;\n height: 100vh;\n background-color: #fff;\n overflow-y: scroll;\n padding: 50rpx;\n}\n.pops[data-v-0b42eb78] {\n border: 1rpx solid gray;\n border-radius: 20rpx;\n margin: 50rpx;\n margin-top: 100rpx;\n}\n.box1[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.box2[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.myScoll[data-v-0b42eb78] {\n width: 100%;\n height: 396rpx;\n white-space: nowrap;\n position: relative;\n}\n.list[data-v-0b42eb78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.dxxl[data-v-0b42eb78] {\n background-color: #fff;\n padding: 20rpx;\n padding-top: 40rpx;\n}\n.sl_box[data-v-0b42eb78] {\n text-align: center;\n}\n.sl_box .all[data-v-0b42eb78] {\n width: calc(100% / 3);\n margin-top: 40rpx;\n}\n.sl_box .sl_box_cankao[data-v-0b42eb78],\n.sl_box .sl_box_desc[data-v-0b42eb78] {\n font-size: 24rpx;\n color: #999;\n}\n.sl_box .sl_box_unit[data-v-0b42eb78] {\n font-size: 26rpx;\n}\n.sl_box .sl_box_wz[data-v-0b42eb78] {\n margin-right: 10rpx;\n font-size: 30rpx;\n font-weight: bold;\n}\n", ""]); // Exports module.exports = exports; @@ -12444,7 +12513,7 @@ if(false) {} var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../../../Applications/HBuilderX.app/Contents/HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-0b42eb78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.pop-close[data-v-0b42eb78] {\n display: flex;\n flex-direction: row-reverse;\n font-size: 100rpx;\n padding-right: 50rpx;\n}\n.pop-main[data-v-0b42eb78] {\n width: 60%;\n height: 100vh;\n background-color: #fff;\n overflow-y: scroll;\n}\n.box1[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.box2[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.myScoll[data-v-0b42eb78] {\n width: 100%;\n height: 396rpx;\n white-space: nowrap;\n position: relative;\n}\n.list[data-v-0b42eb78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.dxxl[data-v-0b42eb78] {\n background-color: #fff;\n padding: 20rpx;\n padding-top: 40rpx;\n}\n.sl_box[data-v-0b42eb78] {\n text-align: center;\n}\n.sl_box .all[data-v-0b42eb78] {\n width: calc(100% / 3);\n margin-top: 40rpx;\n}\n.sl_box .sl_box_cankao[data-v-0b42eb78],\n.sl_box .sl_box_desc[data-v-0b42eb78] {\n font-size: 24rpx;\n color: #999;\n}\n.sl_box .sl_box_unit[data-v-0b42eb78] {\n font-size: 26rpx;\n}\n.sl_box .sl_box_wz[data-v-0b42eb78] {\n margin-right: 10rpx;\n font-size: 30rpx;\n font-weight: bold;\n}\n", ""]); +exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-0b42eb78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.pop-close[data-v-0b42eb78] {\n display: flex;\n flex-direction: row-reverse;\n font-size: 100rpx;\n padding-right: 50rpx;\n margin-top: 50rpx;\n}\n.pop-main[data-v-0b42eb78] {\n width: 60%;\n height: 100vh;\n background-color: #fff;\n overflow-y: scroll;\n}\n.box1[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.box2[data-v-0b42eb78] {\n position: absolute;\n left: 0px;\n width: 3000rpx;\n}\n.myScoll[data-v-0b42eb78] {\n width: 100%;\n height: 396rpx;\n white-space: nowrap;\n position: relative;\n}\n.list[data-v-0b42eb78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.dxxl[data-v-0b42eb78] {\n background-color: #fff;\n padding: 20rpx;\n padding-top: 40rpx;\n}\n.sl_box[data-v-0b42eb78] {\n text-align: center;\n}\n.sl_box .all[data-v-0b42eb78] {\n width: calc(100% / 3);\n margin-top: 40rpx;\n}\n.sl_box .sl_box_cankao[data-v-0b42eb78],\n.sl_box .sl_box_desc[data-v-0b42eb78] {\n font-size: 24rpx;\n color: #999;\n}\n.sl_box .sl_box_unit[data-v-0b42eb78] {\n font-size: 26rpx;\n}\n.sl_box .sl_box_wz[data-v-0b42eb78] {\n margin-right: 10rpx;\n font-size: 30rpx;\n font-weight: bold;\n}\n", ""]); // Exports module.exports = exports; @@ -12591,7 +12660,7 @@ if(false) {} var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../../../Applications/HBuilderX.app/Contents/HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-88422a78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.bloodl_box[data-v-88422a78] {\n margin-top: 30rpx;\n padding: 0 40rpx;\n}\n.bloodl_box .name[data-v-88422a78] {\n font-size: 24rpx;\n color: #999;\n}\n.bloodl_box .yuan[data-v-88422a78] {\n width: 14rpx;\n height: 14rpx;\n border-radius: 50%;\n margin-right: 10rpx;\n}\n.content[data-v-88422a78] {\n margin: 0rpx 100rpx;\n}\n.content .over[data-v-88422a78] {\n margin: 0rpx 30rpx;\n background-color: #fff;\n padding: 30rpx;\n border-radius: 20rpx;\n font-weight: 800;\n display: flex;\n align-items: center;\n justify-content: space-between;\n border-radius: 20rpx;\n}\n.content .time[data-v-88422a78] {\n width: 100%;\n margin-bottom: 100rpx;\n}\n.content .list[data-v-88422a78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.content .list .row[data-v-88422a78] {\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n.content .list .data[data-v-88422a78] {\n display: flex;\n align-items: center;\n font-weight: 500;\n font-size: 36rpx;\n width: 900rpx;\n}\n.content .list .data uni-image[data-v-88422a78] {\n width: 50rpx;\n}\n.content .list .time[data-v-88422a78] {\n font-weight: 300;\n font-size: 24rpx;\n}\n", ""]); +exports.push([module.i, "@charset \"UTF-8\";\n/**\n * 这里是uni-app内置的常用样式变量\n *\n * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量\n * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App\n *\n */\n/**\n * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能\n *\n * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件\n */\n/* 颜色变量 */\n/* 行为相关颜色 */\n/* 文字基本颜色 */\n/* 背景颜色 */\n/* 边框颜色 */\n/* 尺寸变量 */\n/* 文字尺寸 */\n/* 图片尺寸 */\n/* Border Radius */\n/* 水平间距 */\n/* 垂直间距 */\n/* 透明度 */\n/* 文章场景相关 */\n.end[data-v-88422a78] {\n text-align: center;\n margin-top: 50rpx;\n margin-bottom: 100rpx;\n opacity: .5;\n}\n.bloodl_box[data-v-88422a78] {\n margin-top: 50rpx;\n padding: 0 40rpx;\n}\n.bloodl_box .name[data-v-88422a78] {\n font-size: 24rpx;\n color: #999;\n}\n.bloodl_box .yuan[data-v-88422a78] {\n width: 14rpx;\n height: 14rpx;\n border-radius: 50%;\n margin-right: 10rpx;\n}\n.content[data-v-88422a78] {\n margin: 0rpx 100rpx;\n}\n.content .over[data-v-88422a78] {\n margin: 0rpx 30rpx;\n background-color: #fff;\n padding: 30rpx;\n border-radius: 20rpx;\n font-weight: 800;\n display: flex;\n align-items: center;\n justify-content: space-between;\n border-radius: 20rpx;\n}\n.content .time[data-v-88422a78] {\n width: 100%;\n}\n.content .list[data-v-88422a78] {\n background-color: #fff;\n overflow: hidden;\n padding: 30rpx;\n margin: 30rpx 30rpx;\n border-radius: 30rpx;\n}\n.content .list .row[data-v-88422a78] {\n display: flex;\n align-items: center;\n justify-content: space-between;\n}\n.content .list .data[data-v-88422a78] {\n display: flex;\n align-items: center;\n font-weight: 500;\n font-size: 36rpx;\n width: 900rpx;\n}\n.content .list .data uni-image[data-v-88422a78] {\n width: 50rpx;\n}\n.content .list .time[data-v-88422a78] {\n font-weight: 300;\n font-size: 24rpx;\n}\n", ""]); // Exports module.exports = exports; diff --git a/unpackage/dist/dev/app-plus/hybrid/html/ai.html b/unpackage/dist/dev/app-plus/hybrid/html/ai.html index dd25976..7769ccd 100644 --- a/unpackage/dist/dev/app-plus/hybrid/html/ai.html +++ b/unpackage/dist/dev/app-plus/hybrid/html/ai.html @@ -46,22 +46,37 @@
点击说话
- - -
停止
-
- +
+ 我是您的健康助手, 请问您有什么帮助吗?
+ @@ -281,7 +291,9 @@ onTextChange: function (text) { // 监听识别结果的变化 - voiceTxt.value = text; + voiceTxt.innerText = text; + marquee("marquee", "voice-txt"); + statusTxt.value = '正在听…'; // 3秒钟内没有说话,就自动关闭 @@ -308,6 +320,8 @@ var QSindex = containsKeywordRegex(params.msg); Question = `请模仿全科医生的口吻与我: ${user}对话,我最近测量的${result.dataKey}数据为${JSON.stringify(TargetData)},(data_msg为值,hour_minute为检测时间) #限制:回复用户的内容中不要出现Null。#限制:回复不要带英文,要都转化成汉语。#限制:监测结果为Null的数据不做分析回复。` + console.log('指定问题', Question) + /* * 调用接口 传递关键信息 文字转语音 */ @@ -358,6 +372,10 @@ startRec.style.display = "none"; endRec.style.display = "block"; + // 字幕文字 + voiceTxt.innerText = filterString(str.output.text, ['*', ' ']); + marquee("marquee", "voice-txt"); + // 设置音频源 audioElement.src = blobUrl; @@ -442,7 +460,8 @@ endRec.style.display = "block"; // 字幕文字 - voiceTxt.value = filterString(str.output.text, ['*', ' ']); + voiceTxt.innerText = filterString(str.output.text, ['*', ' ']); + marquee("marquee", "voice-txt"); // 设置音频源 audioElement.src = blobUrl; @@ -454,7 +473,7 @@ replayVideoSegment(60, 120); // 计算所需时间 - const speakingTime = calculateSpeakingTime(voiceTxt.value); + const speakingTime = calculateSpeakingTime(voiceTxt.innerText); // 开始倒计时 var totalTime = speakingTime; @@ -507,7 +526,7 @@ // 开始识别 startRec.addEventListener("click", function() { /**开始识别**/ - voiceTxt.value = ''; + voiceTxt.innerText = ''; voice.start(); isCallbackExecuted = false; @@ -526,7 +545,7 @@ // 关闭识别 endRec.addEventListener("click", function() { /**关闭识别**/ - voiceTxt.value = ''; + voiceTxt.innerText = ''; statusTxt.value = ''; voice.stop(); @@ -615,7 +634,7 @@ const blobUrl = URL.createObjectURL(blob); // 字幕文字 - voiceTxt.value = str; + voiceTxt.innerText = str; // 设置音频源 audioElement.src = blobUrl; @@ -963,20 +982,27 @@ width: 100%; /* background-color: #000; */ } - .voice-box { + + #marquee { + display: block; width: 100%; - animation: textRoll linear 10s infinite; // 文字滚动动画 - white-space: nowrap; // 文字不换行 + height: 60px; + margin: 0 auto; + position: relative; + overflow: hidden; } - - @keyframes textRoll { - 0% { - transform: translateX(100%); - } - - 100% { - transform: translateX(-100%); - } + + #voice-txt { + position: absolute; + top: 0; + left: 100%; + line-height: 60px; + font-size:29px; + color: #fff; + display: block; + word-break: keep-all; + text-overflow: ellipsis; + white-space: nowrap; }