Skip to content

Commit

Permalink
feat(add): TCM-300Z (#7538)
Browse files Browse the repository at this point in the history
* Add ShinaSystem's TCM-300Z(SiHAS Zigbee Thermostat)

* Fix indentation.

* Fix indentation.

* Fix Trailing spaces

* Unused thermostat_ac_louver_position

* Update shinasystem.ts

---------

Co-authored-by: Koen Kanters <[email protected]>
  • Loading branch information
shinasys and Koenkk authored May 20, 2024
1 parent 0b953ea commit 380417b
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions src/devices/shinasystem.ts
Original file line number Diff line number Diff line change
Expand Up @@ -857,6 +857,40 @@ const definitions: Definition[] = [
}),
],
},
{
zigbeeModel: ['TCM-300Z'],
model: 'TCM-300Z',
vendor: 'ShinaSystem',
description: 'SiHAS Zigbee thermostat',
fromZigbee: [fz.thermostat, fz.hvac_user_interface],
toZigbee: [tz.thermostat_system_mode, tz.thermostat_occupied_heating_setpoint,
tz.thermostat_occupied_cooling_setpoint, tz.thermostat_local_temperature,
tz.thermostat_keypad_lockout],
exposes: [
e.climate()
.withSystemMode(['off', 'heat', 'cool'])
.withLocalTemperature()
.withSetpoint('occupied_heating_setpoint', 10, 70, 0.5)
.withSetpoint('occupied_cooling_setpoint', 10, 70, 0.5),
e.enum('keypad_lockout', ea.ALL, ['unlock', 'lock1', 'lock2', 'lock3'])
.withDescription('Enables or disables the device’s buttons. ' +
'Lock1 locks the temperature setting and the cooling/heating mode button input. ' +
'Lock2 locks the power button input. ' +
'Lock3 locks all button inputs.'),
],
configure: async (device, coordinatorEndpoint) => {
const endpoint = device.getEndpoint(1);
await reporting.bind(endpoint, coordinatorEndpoint, ['hvacThermostat']);
await reporting.bind(endpoint, coordinatorEndpoint, ['hvacUserInterfaceCfg']);
await reporting.thermostatOccupiedHeatingSetpoint(endpoint);
await reporting.thermostatOccupiedCoolingSetpoint(endpoint);
await reporting.thermostatTemperature(endpoint, {min: 10, max: 600, change: 0.1});
await reporting.thermostatSystemMode(endpoint, {min: 0, max: 600});
await reporting.thermostatKeypadLockMode(endpoint, {min: 0, max: 600});
await endpoint.read('hvacThermostat', ['systemMode', 'occupiedHeatingSetpoint', 'occupiedCoolingSetpoint', 'localTemp']);
await endpoint.read('hvacUserInterfaceCfg', ['keypadLockout']);
},
},
];

export default definitions;
Expand Down

0 comments on commit 380417b

Please sign in to comment.