|
@@ -11,48 +11,45 @@
|
|
:data-theme="'theme-' + proxy.$settingStore.themeColor.name"
|
|
:data-theme="'theme-' + proxy.$settingStore.themeColor.name"
|
|
>
|
|
>
|
|
<template #default>
|
|
<template #default>
|
|
-
|
|
|
|
- <view style=" background: linear-gradient(to bottom, #FAFBFF, #E7F3FF);">
|
|
|
|
- <view class="flex" style="padding: 15px 15px 0">
|
|
|
|
|
|
+ <view style="background: linear-gradient(to bottom, #fafbff, #e7f3ff)">
|
|
|
|
+ <view class="flex" style="padding: 15px 15px 0">
|
|
<view style="margin: auto auto auto 0">
|
|
<view style="margin: auto auto auto 0">
|
|
- <view style="font-size: 16px;color:#000"> {{ detailData.deviceName }} </view>
|
|
|
|
|
|
+ <view style="font-size: 16px; color: #000"> {{ detailData.deviceName }} </view>
|
|
</view>
|
|
</view>
|
|
|
|
|
|
<view style="margin: auto 0 auto 0">
|
|
<view style="margin: auto 0 auto 0">
|
|
- <view style="margin-left: 20px; font-size: 12px;color: #ffffff;padding: 2px 10px; border-radius: 20px; line-height: 20px;"
|
|
|
|
- :style="{ fontSize: '15px', backgroundColor: detailData.deviceStatus == 1 ? '#16bf00' : 'red' } ">
|
|
|
|
|
|
+ <view
|
|
|
|
+ style="margin-left: 20px; font-size: 12px; color: #ffffff; padding: 2px 10px; border-radius: 20px; line-height: 20px"
|
|
|
|
+ :style="{ fontSize: '15px', backgroundColor: detailData.deviceStatus == 1 ? '#16bf00' : 'red' }"
|
|
|
|
+ >
|
|
{{ detailData.deviceStatus == 1 ? "在线" : "离线" }}
|
|
{{ detailData.deviceStatus == 1 ? "在线" : "离线" }}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
- <view class=" p15" style="color:rgba(0,0,0,.7)" >
|
|
|
|
|
|
+ <view class="p15" style="color: rgba(0, 0, 0, 0.7)">
|
|
<!-- <uni-section class="block mb10" title="基本信息" type="line"></uni-section> -->
|
|
<!-- <uni-section class="block mb10" title="基本信息" type="line"></uni-section> -->
|
|
- <view class=" basicBox p0">
|
|
|
|
|
|
+ <view class="basicBox p0">
|
|
<u-empty v-if="dataList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
<u-empty v-if="dataList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
|
|
|
|
<u-row>
|
|
<u-row>
|
|
- <u-col span="9" class="basicLeft">
|
|
|
|
- <view v-for="po in dataList" :key="po">
|
|
|
|
- <view style="text-align: left; padding: 0px 5px 0px 5px">{{ po.title }}:</view>
|
|
|
|
- <view style="text-align: left; padding: 0px 5px 0px 5px">{{ po.value }}</view>
|
|
|
|
|
|
+ <u-col span="9" class="basicLeft">
|
|
|
|
+ <view v-for="po in dataList" :key="po">
|
|
|
|
+ <view style="text-align: left; padding: 0px 5px 0px 5px">{{ po.title }}:</view>
|
|
|
|
+ <view style="text-align: left; padding: 0px 5px 0px 5px">{{ po.value }}</view>
|
|
</view>
|
|
</view>
|
|
- </u-col>
|
|
|
|
- <u-col span="3">
|
|
|
|
- <image style="width: 80px; height: 80px; margin: auto 15px auto 0" :src="'/static/images/jg.png'" mode="aspectFill"></image>
|
|
|
|
- </u-col>
|
|
|
|
- </u-row>
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
|
|
+ </u-col>
|
|
|
|
+ <u-col span="3">
|
|
|
|
+ <image style="width: 80px; height: 80px; margin: auto 15px auto 0" :src="'/static/images/device/jg.png'" mode="aspectFill"></image>
|
|
|
|
+ </u-col>
|
|
|
|
+ </u-row>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
-
|
|
|
|
|
|
|
|
<view class="bg-white p15 mb15">
|
|
<view class="bg-white p15 mb15">
|
|
<!-- 分段器组件 -->
|
|
<!-- 分段器组件 -->
|
|
- <view class="app-subsection">
|
|
|
|
- <u-subsection :list="list" mode="subsection" :current="tabPosition" @change="tabPositionChange" style="width: 100%;font-size:16px"></u-subsection>
|
|
|
|
|
|
+ <view class="app-subsection">
|
|
|
|
+ <u-subsection :list="list" mode="subsection" :current="tabPosition" @change="tabPositionChange" style="width: 100%; font-size: 16px"></u-subsection>
|
|
</view>
|
|
</view>
|
|
|
|
|
|
<view v-if="tabPosition == 1">
|
|
<view v-if="tabPosition == 1">
|
|
@@ -78,31 +75,27 @@
|
|
</view>
|
|
</view>
|
|
<view v-if="tabPosition == 0">
|
|
<view v-if="tabPosition == 0">
|
|
<u-empty v-if="realTimeDataList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
<u-empty v-if="realTimeDataList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
- <view v-else class="flex" style="flex-wrap: wrap; line-height: 36px;font-size:16px">
|
|
|
|
- <view style="width: 100%;border-bottom:1px solid #F3F3F3" v-for="realTime in realTimeDataList" :key="realTime">
|
|
|
|
|
|
+ <view v-else class="flex" style="flex-wrap: wrap; line-height: 36px; font-size: 16px">
|
|
|
|
+ <view style="width: 100%; border-bottom: 1px solid #f3f3f3" v-for="realTime in realTimeDataList" :key="realTime">
|
|
{{ realTime.attributeName + ":" }}
|
|
{{ realTime.attributeName + ":" }}
|
|
- <view style="color:#000;display:inline-block;">{{ realTime.value }}</view>
|
|
|
|
|
|
+ <view style="color: #000; display: inline-block">{{ realTime.value }}</view>
|
|
{{ realTime.attributeUnit ? realTime.attributeUnit : "" }}
|
|
{{ realTime.attributeUnit ? realTime.attributeUnit : "" }}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
|
|
<view v-if="tabPosition == 2">
|
|
<view v-if="tabPosition == 2">
|
|
- <br/>
|
|
|
|
- <u-row
|
|
|
|
- gutter="10"
|
|
|
|
- style="justify-content:center"
|
|
|
|
- >
|
|
|
|
- <u-empty v-if="deviceCotrolList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
|
|
|
|
+ <br />
|
|
|
|
+ <u-row gutter="10" style="justify-content: center">
|
|
|
|
+ <u-empty v-if="deviceCotrolList.length <= 0" text="暂无数据" mode="data" icon="http://cdn.uviewui.com/uview/empty/data.png"> </u-empty>
|
|
|
|
|
|
- <u-col v-else span="3" v-for="(item, index) in deviceCotrolList" :key="index">
|
|
|
|
- <view class="demo-layout" @click="goAction(item)">{{ item.commandName }}</view>
|
|
|
|
- </u-col>
|
|
|
|
-
|
|
|
|
|
|
+ <u-col v-else span="3" v-for="(item, index) in deviceCotrolList" :key="index">
|
|
|
|
+ <view class="demo-layout" @click="goAction(item)">{{ item.commandName }}</view>
|
|
|
|
+ </u-col>
|
|
</u-row>
|
|
</u-row>
|
|
- <br/>
|
|
|
|
- <br/>
|
|
|
|
- <br/>
|
|
|
|
|
|
+ <br />
|
|
|
|
+ <br />
|
|
|
|
+ <br />
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
|
|
@@ -131,9 +124,9 @@
|
|
<script setup>
|
|
<script setup>
|
|
/*----------------------------------依赖引入-----------------------------------*/
|
|
/*----------------------------------依赖引入-----------------------------------*/
|
|
import { onLoad, onShow, onReady, onHide, onLaunch, onNavigationBarButtonTap, onPageScroll } from "@dcloudio/uni-app";
|
|
import { onLoad, onShow, onReady, onHide, onLaunch, onNavigationBarButtonTap, onPageScroll } from "@dcloudio/uni-app";
|
|
-import { ref, reactive, computed, getCurrentInstance, toRefs, inject,watch } from "vue";
|
|
|
|
|
|
+import { ref, reactive, computed, getCurrentInstance, toRefs, inject, watch } from "vue";
|
|
/*----------------------------------接口引入-----------------------------------*/
|
|
/*----------------------------------接口引入-----------------------------------*/
|
|
-import { dmpDeviceInfo,dmpProductAttribute, historyMetrics, last,getList } from "@/api/business/fireIot/deviceManage.js";
|
|
|
|
|
|
+import { dmpDeviceInfo, dmpProductAttribute, historyMetrics, last, getList } from "@/api/business/fireIot/deviceManage.js";
|
|
/*----------------------------------组件引入-----------------------------------*/
|
|
/*----------------------------------组件引入-----------------------------------*/
|
|
import chart from "./chart.vue";
|
|
import chart from "./chart.vue";
|
|
/*----------------------------------store引入-----------------------------------*/
|
|
/*----------------------------------store引入-----------------------------------*/
|
|
@@ -180,8 +173,8 @@ const calendarStartTime = ref(""); //日历开始时间
|
|
const calendarEndTime = ref(""); //日历结束时间
|
|
const calendarEndTime = ref(""); //日历结束时间
|
|
const productId = ref(0); //产品id
|
|
const productId = ref(0); //产品id
|
|
const deviceId = ref(0); //设备id
|
|
const deviceId = ref(0); //设备id
|
|
-const detailData = ref({}) //设备详情数据存储
|
|
|
|
-const deviceCotrolList = ref([]) //设备调试数据存储
|
|
|
|
|
|
+const detailData = ref({}); //设备详情数据存储
|
|
|
|
+const deviceCotrolList = ref([]); //设备调试数据存储
|
|
function open() {
|
|
function open() {
|
|
calendar.value.open();
|
|
calendar.value.open();
|
|
}
|
|
}
|
|
@@ -190,25 +183,23 @@ function open() {
|
|
* @初始化
|
|
* @初始化
|
|
*/
|
|
*/
|
|
|
|
|
|
-
|
|
|
|
- /**
|
|
|
|
|
|
+/**
|
|
* @详情查询
|
|
* @详情查询
|
|
* @api接口查询
|
|
* @api接口查询
|
|
*/
|
|
*/
|
|
function dmpDeviceInfoApi() {
|
|
function dmpDeviceInfoApi() {
|
|
- dmpDeviceInfo({ productId: productId.value, deviceId:deviceId.value,current: 1, size: 10 }).then((requset) => {
|
|
|
|
|
|
+ dmpDeviceInfo({ productId: productId.value, deviceId: deviceId.value, current: 1, size: 10 }).then((requset) => {
|
|
if (requset.status === "SUCCESS") {
|
|
if (requset.status === "SUCCESS") {
|
|
dataList.value[0].value = requset.data.records[0].deviceName;
|
|
dataList.value[0].value = requset.data.records[0].deviceName;
|
|
dataList.value[1].value = requset.data.records[0].deviceId;
|
|
dataList.value[1].value = requset.data.records[0].deviceId;
|
|
- dataList.value[2].value = requset.data.records[0].simCode ;
|
|
|
|
- dataList.value[3].value = requset.data.records[0].installAddress
|
|
|
|
|
|
+ dataList.value[2].value = requset.data.records[0].simCode;
|
|
|
|
+ dataList.value[3].value = requset.data.records[0].installAddress;
|
|
dataList.value[4].value = requset.data.records[0].createdTime ? requset.data.records[0].createdTime.replace("T", " ") : requset.data.records[0].createdTime;
|
|
dataList.value[4].value = requset.data.records[0].createdTime ? requset.data.records[0].createdTime.replace("T", " ") : requset.data.records[0].createdTime;
|
|
- detailData.value=requset.data.records[0]
|
|
|
|
|
|
+ detailData.value = requset.data.records[0];
|
|
}
|
|
}
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
|
|
-
|
|
|
|
function init() {
|
|
function init() {
|
|
dmpDeviceInfoApi();
|
|
dmpDeviceInfoApi();
|
|
dmpProductAttribute({
|
|
dmpProductAttribute({
|
|
@@ -216,7 +207,7 @@ function init() {
|
|
size: 100,
|
|
size: 100,
|
|
attributeName: "",
|
|
attributeName: "",
|
|
productId: productId.value,
|
|
productId: productId.value,
|
|
- deviceId:deviceId.value,
|
|
|
|
|
|
+ deviceId: deviceId.value,
|
|
}).then((requset) => {
|
|
}).then((requset) => {
|
|
if (requset.status === "SUCCESS") {
|
|
if (requset.status === "SUCCESS") {
|
|
checkboxDataList.value = requset.data.records;
|
|
checkboxDataList.value = requset.data.records;
|
|
@@ -247,14 +238,13 @@ function init() {
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
|
|
-
|
|
|
|
-function deviceControlData(){
|
|
|
|
|
|
+function deviceControlData() {
|
|
getList({
|
|
getList({
|
|
current: 1,
|
|
current: 1,
|
|
size: 10,
|
|
size: 10,
|
|
- productCode:detailData.value.productCode,
|
|
|
|
|
|
+ productCode: detailData.value.productCode,
|
|
}).then((response) => {
|
|
}).then((response) => {
|
|
- deviceCotrolList.value=response.data.records
|
|
|
|
|
|
+ deviceCotrolList.value = response.data.records;
|
|
// console.log(response.data.records)
|
|
// console.log(response.data.records)
|
|
// dataList.value = response.data.records;
|
|
// dataList.value = response.data.records;
|
|
// state.total = response.data.total;
|
|
// state.total = response.data.total;
|
|
@@ -265,7 +255,7 @@ function deviceControlData(){
|
|
/**
|
|
/**
|
|
* @tabs切换change事件
|
|
* @tabs切换change事件
|
|
*/
|
|
*/
|
|
-const list = ref(["实时数据", "历史数据","设备调试"]);
|
|
|
|
|
|
+const list = ref(["实时数据", "历史数据", "设备调试"]);
|
|
const tabPosition = ref(0);
|
|
const tabPosition = ref(0);
|
|
function tabPositionChange(index) {
|
|
function tabPositionChange(index) {
|
|
tabPosition.value = index;
|
|
tabPosition.value = index;
|
|
@@ -295,8 +285,8 @@ function calendarConfirm(e) {
|
|
*/
|
|
*/
|
|
function historyMetricsApi() {
|
|
function historyMetricsApi() {
|
|
historyMetrics({
|
|
historyMetrics({
|
|
- startTime: calendarStartTime.value?calendarStartTime.value+' 00:00:00':calendarStartTime.value,
|
|
|
|
- endTime: calendarEndTime.value?calendarEndTime.value+' 23:59:59':calendarEndTime.value,
|
|
|
|
|
|
+ startTime: calendarStartTime.value ? calendarStartTime.value + " 00:00:00" : calendarStartTime.value,
|
|
|
|
+ endTime: calendarEndTime.value ? calendarEndTime.value + " 23:59:59" : calendarEndTime.value,
|
|
deviceUUId: detailData.value.deviceUuid,
|
|
deviceUUId: detailData.value.deviceUuid,
|
|
// deviceId: commonStore.deviceDetailsArray.deviceId,
|
|
// deviceId: commonStore.deviceDetailsArray.deviceId,
|
|
// deviceType: commonStore.deviceDetailsArray.deviceType,
|
|
// deviceType: commonStore.deviceDetailsArray.deviceType,
|
|
@@ -336,9 +326,9 @@ onReady(() => {});
|
|
onShow(() => {
|
|
onShow(() => {
|
|
//设置导航栏颜色
|
|
//设置导航栏颜色
|
|
uni.setNavigationBarColor({
|
|
uni.setNavigationBarColor({
|
|
- frontColor: '#000000', //字体颜色
|
|
|
|
- backgroundColor: '#ffffff' //背景颜色
|
|
|
|
- })
|
|
|
|
|
|
+ frontColor: "#000000", //字体颜色
|
|
|
|
+ backgroundColor: "#ffffff", //背景颜色
|
|
|
|
+ });
|
|
//调用系统主题颜色
|
|
//调用系统主题颜色
|
|
// proxy.$settingStore.systemThemeColor([1]);
|
|
// proxy.$settingStore.systemThemeColor([1]);
|
|
});
|
|
});
|
|
@@ -351,34 +341,31 @@ onLoad((options) => {
|
|
productId.value = parseInt(options.productId);
|
|
productId.value = parseInt(options.productId);
|
|
init();
|
|
init();
|
|
}
|
|
}
|
|
-
|
|
|
|
});
|
|
});
|
|
|
|
|
|
watch(
|
|
watch(
|
|
() => tabPosition.value,
|
|
() => tabPosition.value,
|
|
(val) => {
|
|
(val) => {
|
|
- if(val==2){
|
|
|
|
- deviceControlData()
|
|
|
|
|
|
+ if (val == 2) {
|
|
|
|
+ deviceControlData();
|
|
}
|
|
}
|
|
-
|
|
|
|
}
|
|
}
|
|
);
|
|
);
|
|
</script>
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
<style lang="scss" scoped>
|
|
-uni-page-body{
|
|
|
|
|
|
+uni-page-body {
|
|
background-color: #fff;
|
|
background-color: #fff;
|
|
}
|
|
}
|
|
|
|
|
|
-.basicBox{
|
|
|
|
- font-size:16px;
|
|
|
|
- .basicLeft view{
|
|
|
|
- display:inline-block;
|
|
|
|
- line-height:30px;
|
|
|
|
- .subsection__item__text{
|
|
|
|
- font-size:16px!important
|
|
|
|
|
|
+.basicBox {
|
|
|
|
+ font-size: 16px;
|
|
|
|
+ .basicLeft view {
|
|
|
|
+ display: inline-block;
|
|
|
|
+ line-height: 30px;
|
|
|
|
+ .subsection__item__text {
|
|
|
|
+ font-size: 16px !important;
|
|
}
|
|
}
|
|
-
|
|
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.app-subsection {
|
|
.app-subsection {
|
|
@@ -386,9 +373,9 @@ uni-page-body{
|
|
margin-bottom: 10px;
|
|
margin-bottom: 10px;
|
|
// padding: 0px 5rem;
|
|
// padding: 0px 5rem;
|
|
}
|
|
}
|
|
-.demo-layout{
|
|
|
|
- border:1px solid #e0e0e0;
|
|
|
|
- padding:15px 10px;
|
|
|
|
- box-shadow:0px 0px 12px rgba(0, 0, 0, 0.12);
|
|
|
|
|
|
+.demo-layout {
|
|
|
|
+ border: 1px solid #e0e0e0;
|
|
|
|
+ padding: 15px 10px;
|
|
|
|
+ box-shadow: 0px 0px 12px rgba(0, 0, 0, 0.12);
|
|
}
|
|
}
|
|
</style>
|
|
</style>
|