From 9302b7ea8515d557ddb4b402fa8ada645f64ad75 Mon Sep 17 00:00:00 2001 From: guotianx Date: Fri, 23 Jun 2023 23:47:28 +0800 Subject: [PATCH] feat(add): U86Z13A16-ZJH(HA) (#5904) * Add Honyar U86Z13A16-ZJH(HA) * Fix endpoint --- src/devices/honyar.ts | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/src/devices/honyar.ts b/src/devices/honyar.ts index 51573d80bf704..582e3d36812a6 100644 --- a/src/devices/honyar.ts +++ b/src/devices/honyar.ts @@ -2,6 +2,8 @@ import {Definition} from '../lib/types'; import * as exposes from '../lib/exposes'; import * as reporting from '../lib/reporting'; import extend from '../lib/extend'; +import fz from '../converters/fromZigbee'; +import tz from '../converters/toZigbee'; const e = exposes.presets; const definitions: Definition[] = [ @@ -27,6 +29,26 @@ const definitions: Definition[] = [ await reporting.onOff(endpoint3); }, }, + { + zigbeeModel: ['HY0043'], + model: 'U86Z13A16-ZJH(HA)', + vendor: 'Honyar', + description: 'Smart Power Socket 16A (with power monitoring)', + fromZigbee: [fz.on_off, fz.electrical_measurement, fz.metering], + toZigbee: [tz.on_off], + exposes: [e.switch(), e.power(), e.current(), e.voltage(), e.energy()], + configure: async (device, coordinatorEndpoint, logger) => { + const endpoint = device.getEndpoint(1); + await reporting.bind(endpoint, coordinatorEndpoint, ['genOnOff', 'haElectricalMeasurement', 'seMetering']); + await reporting.onOff(endpoint); + await reporting.readEletricalMeasurementMultiplierDivisors(endpoint); + await reporting.activePower(endpoint); + await reporting.rmsCurrent(endpoint); + await reporting.rmsVoltage(endpoint); + await reporting.readMeteringMultiplierDivisor(endpoint); + await reporting.currentSummDelivered(endpoint); + }, + }, ]; module.exports = definitions;