2
0

feat(sensors): add battery level

Also refactored some common parts for sensors. Refactored to parse data in payload and set it as object
This commit is contained in:
Pierre CLEMENT
2018-01-01 01:06:33 +01:00
parent 8608f4eed4
commit 8948caf0d1
6 changed files with 60 additions and 55 deletions

View File

@@ -1,6 +1,7 @@
module.exports = function(RED) {
"use strict";
var mustache = require("mustache");
var miDevicesUtils = require('../utils');
function XiaomiSwitchNode(config) {
RED.nodes.createNode(this, config);
@@ -12,7 +13,7 @@ module.exports = function(RED) {
var node = this;
node.status({fill:"grey",shape:"ring",text:"battery"});
node.status({fill:"grey", shape:"ring", text:"battery - na"});
if (this.gateway) {
node.on('input', function(msg) {
@@ -20,20 +21,11 @@ module.exports = function(RED) {
var payload = msg.payload;
if (payload.sid == node.sid && ["switch", "sensor_switch.aq2"].indexOf(payload.model) >= 0) {
var data = JSON.parse(payload.data)
if (data.voltage) {
if (data.voltage < 2500) {
node.status({fill:"red",shape:"dot",text:"battery"});
} else if (data.voltage < 2900) {
node.status({fill:"yellow",shape:"dot",text:"battery"});
} else {
node.status({fill:"green",shape:"dot",text:"battery"});
}
}
var data = payload.data;
miDevicesUtils.setStatus(node, data);
if (node.output == "0") {
msg.payload = payload;
miDevicesUtils.prepareFullDataOutput(payload);
node.send([msg]);
} else if (node.output == "1") {
var status = null;