You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iot/projects/IoTCenter/wwwroot/js/device.js

234 lines
9.1 KiB

isDebug = true;
useSignalR = true;
dataUrl = baseUrl + '/App/GetDevice?number=' + new URI().search(true).number;
data = function data() {
return {
f7params: f7params,
server: localStorage.getItem('server'),
token: localStorage.getItem('token'),
model: null
};
};
loadDataSuccess = function () {
Vue.nextTick(function () {
UpdateCamera();
UpdateChart();
});
};
methods = {
VolumeChange(e) {
muted = e.target.muted;
volume = e.target.volume;
},
HasChart() {
var o = this.model;
return o.name === '温湿度传感器' || o.name === 'PM2.5感应器' || o.name === '光强检测器' || o.name === '智能插座';
},
GetDatas() {
return Enumerable.from(this.model.data).orderBy('o=>o.key').toArray();
},
GetDevice(nameOrNumber) {
return this.model;
},
GetDeviceDataAttr(name, attr) {
var data = Enumerable.from(this.model.data).where(o => o.name === name).firstOrDefault();
if (data !== null) {
return data[attr];
}
return null;
},
GetDataValue(name) {
return this.GetDeviceDataAttr(name, 'value');
},
GetDataValueByKey(key) {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.key.toLowerCase() === key; })
.firstOrDefault();
if (data !== null) {
return data.value;
}
return null;
},
GetSimpleApis() {
return Enumerable.from(this.model.product.apis).where(function (o) { return o.parameters.length === 1; }).orderBy(function (o) { return o.name;}).toArray();
},
GetParameter(api,name) {
return Enumerable.from(api.parameters).where(function (o) { return o.name === name;}).firstOrDefault();
},
CallCommand(id) {
ajax('/App/ExecCommand', { token: token, connectionId: connectionId, id: id }, 'post');
},
CallApi(number, method, query) {
ajax('/App/ExecApi', { token: token, connectionId: connectionId, number: number, method: method, query: query }, 'post');
},
AjaxSubmit(event, deviceNumber, dataName) {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.name === dataName; })
.firstOrDefault();
if (data !== null) {
data.value = $(event.target).val();
}
var form = $(event.target).parents('form');
var url = form.attr('action') + '?' + form.serialize() + "&token=" + token + "&connectionId=" + connectionId;
Vue.nextTick(function () {
ajax(url, null, 'get');
});
},
GetSPButtons() {
return Enumerable.from(JSON.parse(this.GetDataValue("指令")))
.orderBy(function (o) { return o.order; })
.toArray();
},
SendSPCmd(event) {
var form = $(event.target).parents('form');
var url = form.attr('action') + '?' + form.serialize();
url += "&token=" + token + "&connectionId=" + connectionId;
url = new URI(url).setQuery('name', event.target.value).toString();
Vue.nextTick(function () {
ajax(url, null, 'get');
});
},
AddSPButton() {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.name === "指令"; })
.firstOrDefault();
var buttons = this.GetButtons();
var newBtn = { "name": "测试", "portName": "/dev/ttyS0", "baudRate": 9600, "parity": 0, "dataBits": 8, "stopBits": 1, "message": "0123456789ABCDEF", "order": 100 };
buttons.push(newBtn);
data.value = JSON.stringify(buttons);
},
RemoveSPButton(name) {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.name === "指令"; })
.firstOrDefault();
var buttons = this.GetButtons();
for (var i = buttons.length - 1; i >= 0; i--) {
if (buttons[i].name === name) {
buttons.splice(i, 1);
break;
}
}
data.value = JSON.stringify(buttons);
},
SaveSPButtons() {
var buttons = [];
$('#irbuttons').find('.irbtn').each(function () {
buttons.push({
name: $(this).find("input[name='Name']").val(),
portName: $(this).find("input[name='PortName']").val(),
baudRate: $(this).find("input[name='BaudRate']").val(),
parity: $(this).find("input[name='Parity']").val(),
dataBits: $(this).find("input[name='DataBits']").val(),
stopBits: $(this).find("input[name='StopBits']").val(),
message: $(this).find("input[name='Message']").val(),
order: $(this).find("input[name='order']").val()
});
});
var value = JSON.stringify(buttons);
ajax('/App/ExecApi', { token: token, connectionId: connectionId, number: this.model.number, method: "/SerialPort/Buttons", buttons: value }, 'post');
},
GetButtons() {
return Enumerable.from(JSON.parse(this.GetDataValue("指令")))
.orderBy(function (o) { return o.order; })
.toArray();
},
Study(code) {
ajax('/App/ExecApi', { token: token, connectionId: connectionId, number: this.model.number, method: "/Ir/Study", type: 5,code:code }, 'post');
},
AddButton() {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.name === "指令"; })
.firstOrDefault();
var buttons = this.GetButtons();
var newBtn = { name:"测试", value:"603",order:100};
buttons.push(newBtn);
data.value = JSON.stringify(buttons);
},
RemoveButton(name) {
var data = Enumerable.from(this.model.data)
.where(function (o) { return o.name === "指令"; })
.firstOrDefault();
var buttons = this.GetButtons();
for (var i = buttons.length - 1; i >= 0; i--) {
if (buttons[i].name === name) {
buttons.splice(i, 1);
break;
}
}
data.value = JSON.stringify(buttons);
},
SaveButtons() {
var buttons = [];
$('#irbuttons').find('.irbtn').each(function () {
buttons.push({
name: $(this).find("input[name='name']").val(),
value: $(this).find("input[name='value']").val(),
order: $(this).find("input[name='order']").val()
});
});
var value = JSON.stringify(buttons);
ajax('/App/ExecApi', { token: token, connectionId: connectionId, number: this.model.number, method: "/Ir/Buttons", buttons: value }, 'post');
},
TestButton(code) {
ajax('/App/ExecApi', { token: token, connectionId: connectionId, number: this.model.number, method: "/Ir/Send", type: 5, code: code }, 'post');
},
SendCode1(event) {
console.log(event.target + ',' + event.type + ',' + event.target.checked);
var form = $(event.target).parents('form');
var url = form.attr('action') + '?' + form.serialize();
var code = form.find('#Code').val();
if (form.hasClass('type1')) {
if (event.target.name === "power" && event.target.value === "1") {
code = 1;
}
else {
var list = {};
list['power'] = form.find("[name = 'power']:checked").val();
list['pattern'] = form.find("[name = 'pattern']:checked").val();
list['direction'] = form.find("[name = 'direction']:checked").val();
list['wind'] = form.find("[name = 'wind']:checked").val();
list['temperature'] = form.find("[name = 'temperature']").val();
list[event.target.name] = event.target.value;
code = 0;
for (var name in list) {
code += parseInt(list[name]);
}
}
url = new URI(url).setQuery('Code', code).toString();
}
url += "&token=" + token + "&connectionId=" + connectionId;
form.find('#Code').val(code);
Vue.nextTick(function () {
ajax(url, null, 'get');
});
},
GetCommands() {
return Enumerable.from(this.model.commands).orderBy('o=>o.displayOrder').toArray();
}
};
function onMessage(method, json, to, from) {
debug(method + ':' + json);
var item = JSON.parse(json);
console.log(method + ':' + json);
if (method === 'DeviceEntityInserted' ||
method === 'DeviceEntityUpdated' ||
method === 'DeviceEntityDeleted') {
loadData();
}
else if (method === 'DataEntityInserted' ||
method === 'DataEntityUpdated' ||
method === 'DataEntityDeleted') {
var device = vm.model.id === item.deviceId ? vm.model : null;
if (device) {
updateItem(device.data, item);
toastr.info(device.displayName + '更新');
if ($('canvas#' + device.number).length) {
UpdateChart(device.number);
}
if ($('#camera').val() === device.number && item.name === '推流') {
UpdateCamera();
}
}
}
}
start();