<!DOCTYPE html>
|
<html>
|
<head>
|
<meta charset="utf-8">
|
<title>温控控制</title>
|
<meta name="viewport"
|
content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
|
<link href="./css/mui.min.css" rel="stylesheet" />
|
<link rel="stylesheet" href="./css/mui.picker.css" />
|
<link rel="stylesheet" href="./css/mui.picker.min.css" />
|
<link rel="stylesheet" href="./css/mui.poppicker.css" />
|
<style>
|
.mui-bar-nav {
|
background: #245ca7;
|
-webkit-box-shadow: none;
|
box-shadow: none;
|
}
|
|
.mui-title {
|
color: #FFFFFF;
|
}
|
|
.mui-icon-back:before,
|
.mui-icon-left-nav:before {
|
color: #FFFFFF;
|
}
|
|
.mui-grid-view.mui-grid-9 .mui-media .mui-icon {
|
font-size: 2.4em;
|
position: relative;
|
border-radius: 50px;
|
padding: 12px;
|
}
|
|
.mui-grid-view.mui-grid-9 .mui-media {
|
background: #c6c8ca;
|
height: 120px;
|
width: 33.3333%;
|
}
|
|
.mui-grid-view.mui-grid-9 {
|
padding: 5px 5px;
|
border-top: none;
|
border-left: none;
|
}
|
|
.mui-table-view.mui-grid-view .mui-table-view-cell .mui-media-body {
|
color: #0062cc;
|
margin-top: unset;
|
}
|
|
.img_ico {
|
width: 70px;
|
height: auto;
|
display: block;
|
margin: auto;
|
margin-top: 10px;
|
}
|
|
.title {
|
background-color: #FFFFFF;
|
display: block;
|
padding: 0 15px;
|
box-sizing: border-box;
|
color: #333;
|
height: 40px;
|
line-height: 40px;
|
}
|
|
/*空调操作弹出窗*/
|
.mark_air {
|
background: rgba(0, 0, 0, .8);
|
position: fixed;
|
left: 0px;
|
top: 0px;
|
right: 0px;
|
bottom: 0px;
|
z-index: 10000;
|
display: flex;
|
}
|
|
.mark_air_layer {
|
background: #fff;
|
width: 80%;
|
margin: auto;
|
border-radius: 5px;
|
}
|
|
.mark_air_layer .title {
|
background: #245ca7;
|
line-height: 40px;
|
padding: 0 15px;
|
box-sizing: border-box;
|
color: #fff;
|
}
|
|
.mark_air_layer .title a {
|
line-height: 40px;
|
font-size: 2.5rem;
|
float: right;
|
}
|
|
.mark_air_layer .mark_air_btn button {
|
background: #ff6355;
|
color: #fff;
|
font-size: 18px;
|
}
|
|
.mark_air_btn {
|
margin: 10px;
|
text-align: center;
|
}
|
|
.mark_air_layer .mark_air_btn button:hover {
|
opacity: .8;
|
}
|
|
a {
|
text-decoration: none;
|
color: #f7f7f7;
|
}
|
|
.mui-table-view-cell {
|
position: relative;
|
overflow: hidden;
|
height: 50px;
|
padding: 11px 15px;
|
}
|
|
.mui-table-view-cell span {
|
line-height: 30px;
|
}
|
|
.mui-input-row.mui-input-range {
|
padding-right: 10px;
|
height: 60px;
|
}
|
|
.mui-input-row label {
|
padding: 25px 15px;
|
}
|
|
.mui-input-range input[type=range] {
|
margin: 30px 0;
|
}
|
|
.mui-table-view-cell select {
|
width: 30%;
|
float: right;
|
margin-top: -4px;
|
font-size: 16px;
|
height: unset;
|
}
|
</style>
|
</head>
|
<body>
|
<header class="mui-bar mui-bar-nav">
|
<a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left"></a>
|
<h1 class="mui-title"><span id="depotName"></span>空调设备</h1>
|
</header>
|
<div class="mui-content">
|
<div id="deviceList1">
|
<div class="title"><strong>仓库正面</strong></div>
|
<ul class="mui-table-view mui-grid-view mui-grid-9">
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##1</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_OPEN.gif">
|
</a>
|
</li>
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##2</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_OPEN.gif">
|
</a>
|
</li>
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##3</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_CLOSE.png">
|
</a>
|
</li>
|
</ul>
|
</div>
|
<div id="deviceList2">
|
|
|
<!-- <div class="title"><strong>仓库背面</strong></div>
|
<ul class="mui-table-view mui-grid-view mui-grid-9">
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##1</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_CLOSE.png">
|
|
</a>
|
</li>
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##3</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_CLOSE.png">
|
</a>
|
</li>
|
<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3">
|
<a href="javascript:void(0)" onclick="openDialog()">
|
<div class="mui-media-body">##2</div>
|
<img class="img_ico" src="./images/device-status/STATUS_05_OPEN.gif">
|
</a>
|
</li>
|
</ul> -->
|
</div>
|
|
<!--弹出-->
|
<div class="mark_air" id="openOne">
|
<div class="mark_air_layer">
|
<div class="title">
|
<span style="font-size: 16px;" id="markName1">设备操作</span>
|
<a onclick="closeDialog()" class="close">×</a>
|
</div>
|
<div class="mark_air_body">
|
<ul class="mui-table-view">
|
|
<li class="mui-table-view-cell">
|
<span>开关</span>
|
<div id="openStatus" class="mui-switch mui-switch-blue">
|
<div class="mui-switch-handle"></div>
|
</div>
|
</li>
|
<li class="mui-table-view-cell">
|
<span>模式</span>
|
<select id="targetModel">
|
<option>请选择</option>
|
<option value="01">制冷</option>
|
<option value="02">通风</option>
|
</select>
|
</li>
|
<div class="mui-input-row mui-input-range">
|
<label>温度</label>
|
<input type="range" id='targetTemp' value="20" min="9" max="25">
|
</div>
|
</ul>
|
</div>
|
<div class="mark_air_btn mx-3 mb-3">
|
<button class="btn btn-block" style="height: 40px;width: 60%;" onclick="toExecute()">确定</button>
|
</div>
|
|
</div>
|
</div>
|
</div>
|
<script src="./js/mui.js"></script>
|
<script src="./js/jquery.min.js"></script>
|
<script src="./js/echarts.min.js"></script>
|
<script src="./js/mui.picker.js"></script>
|
<script src="./js/mui.picker.min.js"></script>
|
<script src="./js/mui.poppicker.js"></script>
|
<script type="text/javascript" charset="utf-8">
|
var url; //接口路径
|
var deviceList; //设备集合
|
var indexTag = null; //设备操作时的标记
|
//空调设置参数
|
var openStatus = true;
|
var targetModel = '';
|
var targetTemp = '';
|
|
//获取仓库下的通风设备请求参数
|
var data1 = {
|
"interfaceId": "5402",
|
"sign": "10402",
|
"outId": "10402",
|
"reqDateTime": new Date(),
|
"tokenAuth": "",
|
"data": {
|
"depotId": "",
|
"type": "05"
|
}
|
};
|
|
var data0 = {
|
|
}
|
//控制设备参数
|
var data2 = {
|
"interfaceId": "5404",
|
"sign": "10404",
|
"outId": "10404",
|
"reqDateTime": new Date(),
|
"tokenAuth": "",
|
"data": {
|
"type": "",
|
"depotId": "",
|
"passCode": "",
|
"serId": "",
|
"id": "",
|
"name": "",
|
"targetStatus": "",
|
"targetModel": "",
|
"targetTemp": "20"
|
}
|
};
|
mui.init()
|
mui.plusReady(function() {
|
//获取参数
|
var curr = plus.webview.currentWebview();
|
var user = JSON.parse(localStorage.getItem('user'));
|
$("#depotName").html(curr.depotName);
|
//参数赋值
|
data1.tokenAuth = user.tokenAuth;
|
data1.data.depotId = curr.depotId;
|
data2.tokenAuth = user.tokenAuth;
|
url = user.url + "/api-phone/gateway";
|
getDeviceList();
|
})
|
|
//监听弹窗中开关
|
mui('.mui-content .mui-switch').each(function() {
|
this.addEventListener('toggle', function(event) {
|
openStatus = (event.detail.isActive ? 'true' : 'false');
|
});
|
});
|
|
//获取仓库信息
|
function getDeviceList() {
|
//发送请求获取仓库信息
|
mui.ajax(url, {
|
type: "POST",
|
dataType: "json",
|
crossDomain: true,
|
contentType: "application/json;charset=utf-8",
|
data: JSON.stringify(data1),
|
success: function(result) {
|
if (result.code == "0000") {
|
deviceList = result.data;
|
if (deviceList != null && deviceList.length > 0) {
|
renderDeviceList();
|
} else {
|
mui.alert("暂无设备!", "提示", ["确定"], function() {}, "div")
|
}
|
} else {
|
mui.alert("暂无设备!", "提示", ["确定"], function() {}, "div")
|
}
|
},
|
error: function() {
|
mui.alert("系统繁忙,请重试!", "提示", ["确定"], function() {}, "div")
|
}
|
})
|
}
|
|
//渲染
|
function renderDeviceList() {
|
//标记仓库正反面的设备数
|
var count1 = 0;
|
var count2 = 0;
|
|
var html1 = '';
|
var html2 = '';
|
html1 += '<div class="title"><strong>仓库正面</strong></div><ul class="mui-table-view mui-grid-view mui-grid-9">';
|
html2 += '<div class="title"><strong>仓库背面</strong></div><ul class="mui-table-view mui-grid-view mui-grid-9">';
|
var img_url;
|
$.each(deviceList, function(index, item) {
|
img_url = '';
|
//设置设备图片路径
|
if (item.type == "05") {
|
if (item.status == "OPEN") {
|
img_url = './images/device-status/STATUS_05_OPEN.gif';
|
} else {
|
img_url = './images/device-status/STATUS_05_CLOSE.png';
|
}
|
}
|
//仓库正面
|
if (item.location == '01') {
|
html1 +=
|
'<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3"><a href="javascript:void(0)" ' +
|
'onclick="openDialog(\'' + index + '\')">';
|
html1 += '<div class="mui-media-body">' + item.name + '</div><img class="img_ico" ';
|
html1 += 'src="' + img_url + '">';
|
html1 += '</a></li>';
|
count1++;
|
}
|
//仓库背面
|
if (item.location == '02') {
|
html2 +=
|
'<li class="mui-table-view-cell mui-media mui-col-xs-4 mui-col-sm-3"><a href="javascript:void(0)" ' +
|
'onclick="openDialog(\'' + index + '\')">';
|
html2 += '<div class="mui-media-body">' + item.name + '</div><img class="img_ico" ';
|
html2 += 'src="' + img_url + '">';
|
html2 += '</a></li>';
|
count2++;
|
}
|
})
|
html1 += '</ul>';
|
html2 += '</ul>';
|
if (count1 > 0) {
|
$("#deviceList1").html(html1);
|
} else {
|
$("#deviceList1").html("");
|
}
|
if (count2 > 0) {
|
$("#deviceList2").html(html2);
|
} else {
|
$("#deviceList2").html("");
|
}
|
}
|
|
//设备操作
|
function toExecute() {
|
if (indexTag != null && indexTag >= 0) {
|
//获取目标模式和温度
|
targetModel = mui("#targetModel")[0].value;
|
targetTemp = mui("#targetTemp")[0].value;
|
//赋值参数
|
data2.data.type = deviceList[indexTag].type;
|
data2.data.depotId = deviceList[indexTag].depotId;
|
data2.data.passCode = deviceList[indexTag].passCode;
|
data2.data.serId = deviceList[indexTag].serId;
|
data2.data.id = deviceList[indexTag].id;
|
data2.data.name = deviceList[indexTag].name;
|
if (openStatus) {
|
data2.data.targetStatus = 'OPEN';
|
} else {
|
data2.data.targetStatus = 'CLOSE';
|
}
|
data2.data.targetModel = targetModel;
|
data2.data.targetTemp = targetTemp;
|
|
//发送操作请求
|
toControlDevice();
|
|
//关闭弹窗
|
closeDialog();
|
}
|
}
|
|
//设备操作请求
|
function toControlDevice() {
|
mui.ajax(url, {
|
type: "POST",
|
dataType: "json",
|
crossDomain: true,
|
contentType: "application/json;charset=utf-8",
|
data: JSON.stringify(data2),
|
success: function(result) {
|
if (result.code == "0000") {
|
mui.alert("操作命令发送成功,请等待30秒后重新打开此页面!", "提示", ["确定"], function() {}, "div")
|
} else {
|
mui.alert(result.msg, "提示", ["确定"], function() {}, "div")
|
}
|
},
|
error: function() {
|
mui.alert("系统繁忙,请重试!", "提示", ["确定"], function() {}, "div")
|
}
|
})
|
}
|
|
//打开弹窗
|
function openDialog(index) {
|
indexTag = index;
|
$("#markName1").html("设备操作 - " + deviceList[index].name);
|
|
//弹窗开关赋值
|
$("#openStatus").removeClass("mui-active");
|
if (deviceList[index].status == "OPEN") {
|
$("#openStatus").addClass("mui-active");
|
}
|
|
$('#openOne').css('display', 'flex');
|
}
|
|
//关闭弹窗
|
function closeDialog() {
|
indexTag = null;
|
$("#openOne").css('display', 'none');
|
}
|
|
//监听时间选择
|
function searchTime(tag) {
|
var date = new Date();
|
var year = date.getFullYear();
|
var month, day;
|
month = date.getMonth() + 1;
|
if (month >= 1 && month <= 9) {
|
month = "0" + month;
|
}
|
day = date.getDate();
|
if (day >= 1 && day <= 9) {
|
day = "0" + day;
|
}
|
var dateTime = year + "-" + month + "-" + day;
|
var dtPicker = new mui.DtPicker({
|
type: 'datetime',
|
beginDate: new Date(2010, 00, 01), //起始日期
|
value: dateTime //默认时间
|
});
|
dtPicker.show(function(selectItems) {
|
var y = selectItems.y.text; //获取选择的年
|
var m = selectItems.m.text; //获取选择的月
|
var d = selectItems.d.text; //获取选择的日
|
var h = selectItems.h.text; //获取选择的日
|
var i = selectItems.i.text; //获取选择的日
|
dateTime = y + "-" + m + "-" + d + " " + h + ":" + i;
|
$("#" + tag).val(dateTime);
|
})
|
}
|
</script>
|
</body>
|
</html>
|