diff --git a/converters/vindriktning.js b/converters/vindriktning.js index 586948c..074ddb7 100644 --- a/converters/vindriktning.js +++ b/converters/vindriktning.js @@ -5,59 +5,37 @@ const ota = require('zigbee-herdsman-converters/lib/ota'); const e = exposes.presets; const ea = exposes.access; -const fzLocal = { - pm1: { - cluster: 0x0430, //'1072', - type: ['attributeReport', 'readResponse'], - convert: (model, msg, publish, options, meta) => { - if (msg.data.hasOwnProperty(0x0000)) { - return {pm1: parseFloat(msg.data[0x0000])}; - } - }, - }, - pm10: { - cluster: 0x0431, //'1073', - type: ['attributeReport', 'readResponse'], - convert: (model, msg, publish, options, meta) => { - if (msg.data.hasOwnProperty(0x0000)) { - return {pm10: parseFloat(msg.data[0x0000])}; - } - }, - }, -}; const definition = { zigbeeModel: ['Vindriktning z03mmc'], model: 'Vindriktning (03mmc)', vendor: 'IKEA', description: 'Air Quality Sensor', - fromZigbee: [fz.temperature, fz.humidity, fz.pm25, - // fzLocal.pm1, fzLocal.pm10, - ], + fromZigbee: [fz.temperature, fz.humidity, fz.pm25, fz.pm1, fz.pm10], toZigbee: [], ota: ota.zigbeeOTA, exposes: [ e.pm25(), - // exposes.numeric('pm1', ea.STATE).withUnit('μg/m³').withDescription('Measured PM1.0 (particulate matter) concentration'), - // exposes.numeric('pm10', ea.STATE).withUnit('μg/m³').withDescription('Measured PM10 (particulate matter) concentration'), + e.pm1(), + e.pm10(), e.temperature(), e.humidity(), ], configure: async (device, coordinatorEndpoint, logger) => { const endpoint = device.getEndpoint(1); - const bindClusters = ['msTemperatureMeasurement', 'msRelativeHumidity', 'pm25Measurement']; //, 0x0430, 0x0431]; + const bindClusters = ['msTemperatureMeasurement', 'msRelativeHumidity', 'pm25Measurement', 'pm1Measurement', 'pm10Measurement']; await reporting.bind(endpoint, coordinatorEndpoint, bindClusters); await reporting.temperature(endpoint, {min: 10, max: 300, change: 10}); await reporting.humidity(endpoint, {min: 10, max: 300, change: 50}); const payload = [{ - attribute: {ID: 0x0000, type: 0x39}, + attribute: 'measuredValue', minimumReportInterval: 10, maximumReportInterval: 120, reportableChange: 2, }] await endpoint.configureReporting('pm25Measurement', payload); - // await endpoint.configureReporting(0x0430, payload); - // await endpoint.configureReporting(0x0431, payload); + await endpoint.configureReporting('pm1Measurement', payload); + await endpoint.configureReporting('pm10Measurement', payload); }, icon: '', }; diff --git a/src/custom_zcl/zcl_concentration.h b/src/custom_zcl/zcl_concentration.h index 0f19b1b..1ed651e 100644 --- a/src/custom_zcl/zcl_concentration.h +++ b/src/custom_zcl/zcl_concentration.h @@ -7,8 +7,8 @@ */ #define ZCL_CLUSTER_CM_PM25 0x042a -#define ZCL_CLUSTER_CM_PM1 0x0430 -#define ZCL_CLUSTER_CM_PM10 0x0431 +#define ZCL_CLUSTER_CM_PM1 0x042c +#define ZCL_CLUSTER_CM_PM10 0x042d /**