matterbridge 3.1.4 → 3.1.5-dev-20250718-054cd80

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (209) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/README-DEV.md +59 -0
  3. package/dist/cli.js +2 -91
  4. package/dist/cliEmitter.js +0 -30
  5. package/dist/clusters/export.js +0 -2
  6. package/dist/defaultConfigSchema.js +0 -24
  7. package/dist/deviceManager.js +1 -94
  8. package/dist/devices/batteryStorage.js +1 -48
  9. package/dist/devices/evse.js +10 -74
  10. package/dist/devices/export.js +0 -2
  11. package/dist/devices/heatPump.js +2 -50
  12. package/dist/devices/laundryDryer.js +6 -83
  13. package/dist/devices/laundryWasher.js +7 -91
  14. package/dist/devices/roboticVacuumCleaner.js +6 -89
  15. package/dist/devices/solarPower.js +0 -38
  16. package/dist/devices/waterHeater.js +2 -82
  17. package/dist/frontend.js +21 -429
  18. package/dist/globalMatterbridge.js +0 -47
  19. package/dist/helpers.js +0 -53
  20. package/dist/index.js +1 -30
  21. package/dist/logger/export.js +0 -1
  22. package/dist/matter/behaviors.js +0 -2
  23. package/dist/matter/clusters.js +0 -2
  24. package/dist/matter/devices.js +0 -2
  25. package/dist/matter/endpoints.js +0 -2
  26. package/dist/matter/export.js +0 -3
  27. package/dist/matter/types.js +0 -3
  28. package/dist/matterbridge.js +66 -802
  29. package/dist/matterbridgeAccessoryPlatform.js +0 -36
  30. package/dist/matterbridgeBehaviors.js +1 -61
  31. package/dist/matterbridgeDeviceTypes.js +15 -579
  32. package/dist/matterbridgeDynamicPlatform.js +0 -36
  33. package/dist/matterbridgeEndpoint.js +42 -1106
  34. package/dist/matterbridgeEndpointHelpers.js +12 -322
  35. package/dist/matterbridgePlatform.js +0 -233
  36. package/dist/matterbridgeTypes.js +0 -25
  37. package/dist/pluginManager.js +46 -350
  38. package/dist/shelly.js +7 -168
  39. package/dist/storage/export.js +0 -1
  40. package/dist/update.js +0 -54
  41. package/dist/utils/colorUtils.js +2 -263
  42. package/dist/utils/commandLine.js +0 -54
  43. package/dist/utils/copyDirectory.js +1 -38
  44. package/dist/utils/createDirectory.js +0 -33
  45. package/dist/utils/createZip.js +2 -47
  46. package/dist/utils/deepCopy.js +0 -39
  47. package/dist/utils/deepEqual.js +1 -72
  48. package/dist/utils/error.js +9 -0
  49. package/dist/utils/export.js +0 -1
  50. package/dist/utils/hex.js +0 -58
  51. package/dist/utils/isvalid.js +0 -101
  52. package/dist/utils/network.js +5 -81
  53. package/dist/utils/spawn.js +0 -18
  54. package/dist/utils/wait.js +9 -62
  55. package/npm-shrinkwrap.json +5 -5
  56. package/package.json +1 -2
  57. package/dist/cli.d.ts +0 -26
  58. package/dist/cli.d.ts.map +0 -1
  59. package/dist/cli.js.map +0 -1
  60. package/dist/cliEmitter.d.ts +0 -34
  61. package/dist/cliEmitter.d.ts.map +0 -1
  62. package/dist/cliEmitter.js.map +0 -1
  63. package/dist/clusters/export.d.ts +0 -2
  64. package/dist/clusters/export.d.ts.map +0 -1
  65. package/dist/clusters/export.js.map +0 -1
  66. package/dist/defaultConfigSchema.d.ts +0 -28
  67. package/dist/defaultConfigSchema.d.ts.map +0 -1
  68. package/dist/defaultConfigSchema.js.map +0 -1
  69. package/dist/deviceManager.d.ts +0 -112
  70. package/dist/deviceManager.d.ts.map +0 -1
  71. package/dist/deviceManager.js.map +0 -1
  72. package/dist/devices/batteryStorage.d.ts +0 -48
  73. package/dist/devices/batteryStorage.d.ts.map +0 -1
  74. package/dist/devices/batteryStorage.js.map +0 -1
  75. package/dist/devices/evse.d.ts +0 -75
  76. package/dist/devices/evse.d.ts.map +0 -1
  77. package/dist/devices/evse.js.map +0 -1
  78. package/dist/devices/export.d.ts +0 -9
  79. package/dist/devices/export.d.ts.map +0 -1
  80. package/dist/devices/export.js.map +0 -1
  81. package/dist/devices/heatPump.d.ts +0 -47
  82. package/dist/devices/heatPump.d.ts.map +0 -1
  83. package/dist/devices/heatPump.js.map +0 -1
  84. package/dist/devices/laundryDryer.d.ts +0 -87
  85. package/dist/devices/laundryDryer.d.ts.map +0 -1
  86. package/dist/devices/laundryDryer.js.map +0 -1
  87. package/dist/devices/laundryWasher.d.ts +0 -242
  88. package/dist/devices/laundryWasher.d.ts.map +0 -1
  89. package/dist/devices/laundryWasher.js.map +0 -1
  90. package/dist/devices/roboticVacuumCleaner.d.ts +0 -110
  91. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  92. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  93. package/dist/devices/solarPower.d.ts +0 -40
  94. package/dist/devices/solarPower.d.ts.map +0 -1
  95. package/dist/devices/solarPower.js.map +0 -1
  96. package/dist/devices/waterHeater.d.ts +0 -111
  97. package/dist/devices/waterHeater.d.ts.map +0 -1
  98. package/dist/devices/waterHeater.js.map +0 -1
  99. package/dist/frontend.d.ts +0 -304
  100. package/dist/frontend.d.ts.map +0 -1
  101. package/dist/frontend.js.map +0 -1
  102. package/dist/globalMatterbridge.d.ts +0 -59
  103. package/dist/globalMatterbridge.d.ts.map +0 -1
  104. package/dist/globalMatterbridge.js.map +0 -1
  105. package/dist/helpers.d.ts +0 -48
  106. package/dist/helpers.d.ts.map +0 -1
  107. package/dist/helpers.js.map +0 -1
  108. package/dist/index.d.ts +0 -33
  109. package/dist/index.d.ts.map +0 -1
  110. package/dist/index.js.map +0 -1
  111. package/dist/logger/export.d.ts +0 -2
  112. package/dist/logger/export.d.ts.map +0 -1
  113. package/dist/logger/export.js.map +0 -1
  114. package/dist/matter/behaviors.d.ts +0 -2
  115. package/dist/matter/behaviors.d.ts.map +0 -1
  116. package/dist/matter/behaviors.js.map +0 -1
  117. package/dist/matter/clusters.d.ts +0 -2
  118. package/dist/matter/clusters.d.ts.map +0 -1
  119. package/dist/matter/clusters.js.map +0 -1
  120. package/dist/matter/devices.d.ts +0 -2
  121. package/dist/matter/devices.d.ts.map +0 -1
  122. package/dist/matter/devices.js.map +0 -1
  123. package/dist/matter/endpoints.d.ts +0 -2
  124. package/dist/matter/endpoints.d.ts.map +0 -1
  125. package/dist/matter/endpoints.js.map +0 -1
  126. package/dist/matter/export.d.ts +0 -5
  127. package/dist/matter/export.d.ts.map +0 -1
  128. package/dist/matter/export.js.map +0 -1
  129. package/dist/matter/types.d.ts +0 -3
  130. package/dist/matter/types.d.ts.map +0 -1
  131. package/dist/matter/types.js.map +0 -1
  132. package/dist/matterbridge.d.ts +0 -444
  133. package/dist/matterbridge.d.ts.map +0 -1
  134. package/dist/matterbridge.js.map +0 -1
  135. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -42
  136. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  137. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  138. package/dist/matterbridgeBehaviors.d.ts +0 -1340
  139. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  140. package/dist/matterbridgeBehaviors.js.map +0 -1
  141. package/dist/matterbridgeDeviceTypes.d.ts +0 -709
  142. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  143. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  144. package/dist/matterbridgeDynamicPlatform.d.ts +0 -42
  145. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  146. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  147. package/dist/matterbridgeEndpoint.d.ts +0 -1250
  148. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  149. package/dist/matterbridgeEndpoint.js.map +0 -1
  150. package/dist/matterbridgeEndpointHelpers.d.ts +0 -3198
  151. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  152. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  153. package/dist/matterbridgePlatform.d.ts +0 -310
  154. package/dist/matterbridgePlatform.d.ts.map +0 -1
  155. package/dist/matterbridgePlatform.js.map +0 -1
  156. package/dist/matterbridgeTypes.d.ts +0 -195
  157. package/dist/matterbridgeTypes.d.ts.map +0 -1
  158. package/dist/matterbridgeTypes.js.map +0 -1
  159. package/dist/pluginManager.d.ts +0 -291
  160. package/dist/pluginManager.d.ts.map +0 -1
  161. package/dist/pluginManager.js.map +0 -1
  162. package/dist/shelly.d.ts +0 -174
  163. package/dist/shelly.d.ts.map +0 -1
  164. package/dist/shelly.js.map +0 -1
  165. package/dist/storage/export.d.ts +0 -2
  166. package/dist/storage/export.d.ts.map +0 -1
  167. package/dist/storage/export.js.map +0 -1
  168. package/dist/update.d.ts +0 -59
  169. package/dist/update.d.ts.map +0 -1
  170. package/dist/update.js.map +0 -1
  171. package/dist/utils/colorUtils.d.ts +0 -117
  172. package/dist/utils/colorUtils.d.ts.map +0 -1
  173. package/dist/utils/colorUtils.js.map +0 -1
  174. package/dist/utils/commandLine.d.ts +0 -59
  175. package/dist/utils/commandLine.d.ts.map +0 -1
  176. package/dist/utils/commandLine.js.map +0 -1
  177. package/dist/utils/copyDirectory.d.ts +0 -33
  178. package/dist/utils/copyDirectory.d.ts.map +0 -1
  179. package/dist/utils/copyDirectory.js.map +0 -1
  180. package/dist/utils/createDirectory.d.ts +0 -34
  181. package/dist/utils/createDirectory.d.ts.map +0 -1
  182. package/dist/utils/createDirectory.js.map +0 -1
  183. package/dist/utils/createZip.d.ts +0 -39
  184. package/dist/utils/createZip.d.ts.map +0 -1
  185. package/dist/utils/createZip.js.map +0 -1
  186. package/dist/utils/deepCopy.d.ts +0 -32
  187. package/dist/utils/deepCopy.d.ts.map +0 -1
  188. package/dist/utils/deepCopy.js.map +0 -1
  189. package/dist/utils/deepEqual.d.ts +0 -54
  190. package/dist/utils/deepEqual.d.ts.map +0 -1
  191. package/dist/utils/deepEqual.js.map +0 -1
  192. package/dist/utils/export.d.ts +0 -12
  193. package/dist/utils/export.d.ts.map +0 -1
  194. package/dist/utils/export.js.map +0 -1
  195. package/dist/utils/hex.d.ts +0 -49
  196. package/dist/utils/hex.d.ts.map +0 -1
  197. package/dist/utils/hex.js.map +0 -1
  198. package/dist/utils/isvalid.d.ts +0 -103
  199. package/dist/utils/isvalid.d.ts.map +0 -1
  200. package/dist/utils/isvalid.js.map +0 -1
  201. package/dist/utils/network.d.ts +0 -74
  202. package/dist/utils/network.d.ts.map +0 -1
  203. package/dist/utils/network.js.map +0 -1
  204. package/dist/utils/spawn.d.ts +0 -11
  205. package/dist/utils/spawn.d.ts.map +0 -1
  206. package/dist/utils/spawn.js.map +0 -1
  207. package/dist/utils/wait.d.ts +0 -56
  208. package/dist/utils/wait.d.ts.map +0 -1
  209. package/dist/utils/wait.js.map +0 -1
@@ -1,53 +1,12 @@
1
- /**
2
- * @description This file contains the Evse class.
3
- * @file src/devices/energy-evse.ts
4
- * @author Luca Liguori
5
- * @contributor Ludovic BOUÉ
6
- * @created 2025-05-27
7
- * @version 1.1.0
8
- * @license Apache-2.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License.
23
- */
24
1
  import { EnergyEvseServer } from '@matter/main/behaviors/energy-evse';
25
2
  import { EnergyEvseModeServer } from '@matter/main/behaviors/energy-evse-mode';
26
3
  import { EnergyEvse, EnergyEvseMode } from '@matter/main/clusters';
27
4
  import { DeviceEnergyManagement } from '@matter/main/clusters/device-energy-management';
28
5
  import { ModeBase } from '@matter/main/clusters/mode-base';
29
- // Matterbridge
30
6
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
31
7
  import { MatterbridgeServer } from '../matterbridgeBehaviors.js';
32
8
  import { deviceEnergyManagement, electricalSensor, evse, powerSource } from '../matterbridgeDeviceTypes.js';
33
9
  export class Evse extends MatterbridgeEndpoint {
34
- /**
35
- * Creates an instance of the EVSE class.
36
- *
37
- * @param {string} name - The name of the EVSE.
38
- * @param {string} serial - The serial number of the EVSE.
39
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
40
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. This is a fixed attribute that defaults to a predefined set of EnergyEvseMode cluster modes.
41
- * @param {EnergyEvse.State} [state] - The current state of the EVSE. Defaults to NotPluggedIn.
42
- * @param {EnergyEvse.SupplyState} [supplyState] - The supply state of the EVSE. Defaults to Disabled.
43
- * @param {EnergyEvse.FaultState} [faultState] - The fault state of the EVSE. Defaults to NoError.
44
- * @param {number} [voltage] - The voltage value in millivolts. Defaults to null if not provided.
45
- * @param {number} [current] - The current value in milliamperes. Defaults to null if not provided.
46
- * @param {number} [power] - The power value in milliwatts. Defaults to null if not provided.
47
- * @param {number} [energy] - The total consumption value in mW/h. Defaults to null if not provided.
48
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
49
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
50
- */
51
10
  constructor(name, serial, currentMode, supportedModes, state, supplyState, faultState, voltage = null, current = null, power = null, energy = null, absMinPower, absMaxPower) {
52
11
  super([evse, powerSource, electricalSensor, deviceEnergyManagement], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
53
12
  this.createDefaultIdentifyClusterServer()
@@ -62,47 +21,30 @@ export class Evse extends MatterbridgeEndpoint {
62
21
  .createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes)
63
22
  .addRequiredClusterServers();
64
23
  }
65
- /**
66
- * Creates a default EnergyEvseServer Cluster Server.
67
- *
68
- * @param {EnergyEvse.State} [state] - The initial state of the EnergyEvse cluster. Defaults to EnergyEvse.State.NotPluggedIn.
69
- * @param {EnergyEvse.SupplyState} [supplyState] - The initial supply state of the EnergyEvse cluster. Defaults to EnergyEvse.SupplyState.ChargingEnabled.
70
- * @param {EnergyEvse.FaultState} [faultState] - The initial fault state of the EnergyEvse cluster. Defaults to EnergyEvse.FaultState.NoError.
71
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
72
- */
73
24
  createDefaultEnergyEvseClusterServer(state, supplyState, faultState) {
74
25
  this.behaviors.require(MatterbridgeEnergyEvseServer, {
75
26
  state: state !== undefined ? state : EnergyEvse.State.NotPluggedIn,
76
27
  supplyState: supplyState !== undefined ? supplyState : EnergyEvse.SupplyState.ChargingEnabled,
77
28
  faultState: faultState !== undefined ? faultState : EnergyEvse.FaultState.NoError,
78
- chargingEnabledUntil: null, // Persistent attribute. A null value indicates the EVSE is always enabled for charging.
79
- circuitCapacity: 32_000, // Persistent attribute in mA. 32A in mA.
80
- minimumChargeCurrent: 6_000, // Persistent attribute in mA. 6A in mA.
81
- maximumChargeCurrent: 32_000, // Persistent attribute in mA. 32A in mA.
82
- userMaximumChargeCurrent: 32_000, // Persistent attribute in mA. 32A in mA.
83
- sessionId: null, // Persistent attribute
84
- sessionDuration: null, // Persistent attribute
85
- sessionEnergyCharged: null, // Persistent attribute
29
+ chargingEnabledUntil: null,
30
+ circuitCapacity: 32_000,
31
+ minimumChargeCurrent: 6_000,
32
+ maximumChargeCurrent: 32_000,
33
+ userMaximumChargeCurrent: 32_000,
34
+ sessionId: null,
35
+ sessionDuration: null,
36
+ sessionEnergyCharged: null,
86
37
  });
87
38
  return this;
88
39
  }
89
- /**
90
- * Creates a default EnergyEvseMode Cluster Server.
91
- *
92
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
93
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. Defaults all EnergyEvseMode cluster modes.
94
- *
95
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
96
- */
97
40
  createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes) {
98
41
  this.behaviors.require(MatterbridgeEnergyEvseModeServer, {
99
42
  supportedModes: supportedModes ?? [
100
43
  { label: 'On demand', mode: 1, modeTags: [{ value: EnergyEvseMode.ModeTag.Manual }] },
101
44
  { label: 'Scheduled', mode: 2, modeTags: [{ value: EnergyEvseMode.ModeTag.TimeOfUse }] },
102
45
  { label: 'Solar charging', mode: 3, modeTags: [{ value: EnergyEvseMode.ModeTag.SolarCharging }] },
103
- // { label: 'Home to vehicle and Vehicle to home', mode: 4, modeTags: [{ value: EnergyEvseMode.ModeTag.V2X }] }, // This mode is not valid in charging only EVSEs
104
- ], // FixedAttribute
105
- currentMode: currentMode ?? 1, // Persistent attribute
46
+ ],
47
+ currentMode: currentMode ?? 1,
106
48
  });
107
49
  return this;
108
50
  }
@@ -118,8 +60,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
118
60
  this.state.state = EnergyEvse.State.PluggedInDemand;
119
61
  }
120
62
  this.state.chargingEnabledUntil = 0;
121
- // super.disable();
122
- // disable is not implemented in matter.js
123
63
  }
124
64
  enableCharging(request) {
125
65
  const device = this.endpoint.stateOf(MatterbridgeServer);
@@ -133,9 +73,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
133
73
  this.state.chargingEnabledUntil = request.chargingEnabledUntil;
134
74
  this.state.minimumChargeCurrent = request.minimumChargeCurrent;
135
75
  this.state.maximumChargeCurrent = request.maximumChargeCurrent;
136
- // The implementation should also stop the charging session at the required time and update the sessionId, sessionDuration, and sessionEnergyCharged attributes if needed.
137
- // super.enableCharging();
138
- // enableCharging is not implemented in matter.js
139
76
  }
140
77
  }
141
78
  export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
@@ -153,4 +90,3 @@ export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
153
90
  return { status: ModeBase.ModeChangeStatus.Success, statusText: 'Success' };
154
91
  }
155
92
  }
156
- //# sourceMappingURL=evse.js.map
@@ -1,4 +1,3 @@
1
- // Single class device types
2
1
  export * from './roboticVacuumCleaner.js';
3
2
  export * from './laundryWasher.js';
4
3
  export * from './laundryDryer.js';
@@ -7,4 +6,3 @@ export * from './evse.js';
7
6
  export * from './solarPower.js';
8
7
  export * from './batteryStorage.js';
9
8
  export * from './heatPump.js';
10
- //# sourceMappingURL=export.js.map
@@ -1,52 +1,8 @@
1
- /**
2
- * @description This file contains the HeatPump class.
3
- * @file src/devices/heatPump.ts
4
- * @author Luca Liguori
5
- * @created 2025-06-29
6
- * @version 1.0.0
7
- * @license Apache-2.0
8
- *
9
- * Copyright 2025, 2026, 2027 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
- // @matter
24
1
  import { NumberTag, PowerSourceTag } from '@matter/main';
25
2
  import { DeviceEnergyManagement } from '@matter/main/clusters/device-energy-management';
26
- // Matterbridge
27
3
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
28
4
  import { deviceEnergyManagement, electricalSensor, powerSource, heatPump, temperatureSensor, thermostatDevice } from '../matterbridgeDeviceTypes.js';
29
5
  export class HeatPump extends MatterbridgeEndpoint {
30
- /**
31
- * Creates an instance of the HeatPump class.
32
- *
33
- * @param {string} name - The name of the HeatPump.
34
- * @param {string} serial - The serial number of the HeatPump.
35
- * @param {number} voltage - The voltage value in millivolts.
36
- * @param {number} current - The current value in milliamperes.
37
- * @param {number} power - The power value in milliwatts.
38
- * @param {number} energyImported - The total production value in mW/h.
39
- * @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
40
- * @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
41
- *
42
- * @remarks
43
- * - The HeatPump includes clusters for power source, electrical power measurement, electrical energy measurement, and device energy management.
44
- * - It also includes child devices for flow temperature, return temperature, and a thermostat.
45
- * - The flow and return temperature sensors are set to default values of 45.00°C and 35.00°C respectively.
46
- * - The heating only thermostat is set up with a default temperature setpoint of 21.00°C.
47
- * - The device energy management cluster is set to `esaType` as `SpaceHeating`, `esaCanGenerate` as `false`, and `esaState` as `Online`.
48
- * - The absolute minimum and maximum power values can be set to indicate the range of power consumption for the heat pump.
49
- */
50
6
  constructor(name, serial, voltage = null, current = null, power = null, energyImported = null, absMinPower = 0, absMaxPower = 0) {
51
7
  super([heatPump, powerSource, electricalSensor, deviceEnergyManagement], {
52
8
  tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Grid.namespaceId, tag: PowerSourceTag.Grid.tag, label: null }],
@@ -61,19 +17,16 @@ export class HeatPump extends MatterbridgeEndpoint {
61
17
  .createDefaultDeviceEnergyManagementClusterServer(DeviceEnergyManagement.EsaType.SpaceHeating, false, DeviceEnergyManagement.EsaState.Online, absMinPower, absMaxPower)
62
18
  .createDefaultDeviceEnergyManagementModeClusterServer()
63
19
  .addRequiredClusterServers();
64
- // Add the flow temperature sensor for the heat pump.
65
20
  this.addChildDeviceType('FlowTemperature', temperatureSensor, {
66
21
  tagList: [{ mfgCode: null, namespaceId: NumberTag.One.namespaceId, tag: NumberTag.One.tag, label: 'Flow' }],
67
22
  })
68
- .createDefaultTemperatureMeasurementClusterServer(4500) // Default flow temperature setpoint in hundredths of degrees Celsius (45.00°C).
23
+ .createDefaultTemperatureMeasurementClusterServer(4500)
69
24
  .addRequiredClusterServers();
70
- // Add the return temperature sensor for the heat pump.
71
25
  this.addChildDeviceType('ReturnTemperature', temperatureSensor, {
72
26
  tagList: [{ mfgCode: null, namespaceId: NumberTag.Two.namespaceId, tag: NumberTag.Two.tag, label: 'Return' }],
73
27
  })
74
- .createDefaultTemperatureMeasurementClusterServer(3500) // Default return temperature setpoint in hundredths of degrees Celsius (35.00°C).
28
+ .createDefaultTemperatureMeasurementClusterServer(3500)
75
29
  .addRequiredClusterServers();
76
- // Add the global thermostat for the heat pump.
77
30
  this.addChildDeviceType('Thermostat', thermostatDevice, {
78
31
  tagList: [{ mfgCode: null, namespaceId: NumberTag.One.namespaceId, tag: NumberTag.One.tag, label: 'Main Thermostat' }],
79
32
  })
@@ -81,4 +34,3 @@ export class HeatPump extends MatterbridgeEndpoint {
81
34
  .addRequiredClusterServers();
82
35
  }
83
36
  }
84
- //# sourceMappingURL=heatPump.js.map
@@ -1,53 +1,11 @@
1
- /**
2
- * @description This file contains the LaundryDryer class.
3
- * @file src/devices/laundryDryer.ts
4
- * @author Luca Liguori
5
- * @created 2025-06-29
6
- * @version 1.1.0
7
- * @license Apache-2.0
8
- *
9
- * Copyright 2025, 2026, 2027 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
1
  import { LaundryWasherMode } from '@matter/main/clusters/laundry-washer-mode';
24
2
  import { TemperatureControl } from '@matter/main/clusters/temperature-control';
25
3
  import { LaundryDryerControls } from '@matter/main/clusters/laundry-dryer-controls';
26
4
  import { LaundryDryerControlsServer } from '@matter/main/behaviors/laundry-dryer-controls';
27
- // Matterbridge
28
5
  import { laundryDryer, powerSource } from '../matterbridgeDeviceTypes.js';
29
6
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
30
7
  import { MatterbridgeLaundryWasherModeServer, MatterbridgeLevelTemperatureControlServer, MatterbridgeNumberTemperatureControlServer } from './laundryWasher.js';
31
8
  export class LaundryDryer extends MatterbridgeEndpoint {
32
- /**
33
- * Creates an instance of the LaundryDryer class.
34
- *
35
- * @param {string} name - The name of the laundry dryer.
36
- * @param {string} serial - The serial number of the laundry dryer.
37
- * @param {number} [currentMode] - The current mode of the laundry dryer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
38
- * @param {LaundryWasherMode.ModeOption[]} [supportedModes] - The supported modes of the laundry dryer. Defaults to a set of common modes (which include Delicate, Normal, Heavy, and Whites). Fixed attribute.
39
- * @param {number} [selectedTemperatureLevel] - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
40
- * @param {string[]} [supportedTemperatureLevels] - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
41
- * @param {number} [temperatureSetpoint] - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
42
- * @param {number} [minTemperature] - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
43
- * @param {number} [maxTemperature] - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
44
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
45
- * @param {OperationalState.OperationalStateEnum} [operationalState] - The operational state of the laundry washer. Defaults to OperationalState.OperationalStateEnum.Off.
46
- *
47
- * Remarks:
48
- * - If `temperatureSetpoint` is provided, the `createNumberTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
49
- * - If `temperatureSetpoint` is not provided, the `createLevelTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with feature TemperatureLevel.
50
- */
51
9
  constructor(name, serial, currentMode, supportedModes, selectedTemperatureLevel, supportedTemperatureLevels, temperatureSetpoint, minTemperature, maxTemperature, step, operationalState) {
52
10
  super([laundryDryer, powerSource], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
53
11
  this.createDefaultIdentifyClusterServer();
@@ -62,14 +20,6 @@ export class LaundryDryer extends MatterbridgeEndpoint {
62
20
  this.createLevelTemperatureControlClusterServer(selectedTemperatureLevel, supportedTemperatureLevels);
63
21
  this.createDefaultOperationalStateClusterServer(operationalState);
64
22
  }
65
- /**
66
- * Creates a default Laundry Washer Mode Cluster Server.
67
- *
68
- * @param {number} currentMode - The current mode of the laundry washer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
69
- * @param {LaundryWasherMode.ModeOption[]} supportedModes - The supported modes of the laundry washer. Defaults to a set of common modes (which include Delicate, Normal, Heavy, and Whites). Fixed attribute.
70
- *
71
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
72
- */
73
23
  createDefaultLaundryWasherModeClusterServer(currentMode = 2, supportedModes = [
74
24
  { label: 'Delicate', mode: 1, modeTags: [{ value: LaundryWasherMode.ModeTag.Delicate }] },
75
25
  { label: 'Normal', mode: 2, modeTags: [{ value: LaundryWasherMode.ModeTag.Normal }] },
@@ -77,34 +27,18 @@ export class LaundryDryer extends MatterbridgeEndpoint {
77
27
  { label: 'Whites', mode: 4, modeTags: [{ value: LaundryWasherMode.ModeTag.Whites }] },
78
28
  ]) {
79
29
  this.behaviors.require(MatterbridgeLaundryWasherModeServer, {
80
- supportedModes, // Fixed attribute.
81
- currentMode, // Persistent attribute.
30
+ supportedModes,
31
+ currentMode,
82
32
  });
83
33
  return this;
84
34
  }
85
- /**
86
- * Creates a default Laundry Dryer Controls Cluster Server.
87
- *
88
- * @param {LaundryDryerControls.DrynessLevel} selectedDrynessLevel - The selected dryness level. Default is undefined.
89
- * @param {LaundryDryerControls.DrynessLevel[]} supportedDrynessLevels - The supported dryness levels. Default is [Low, Normal, Extra, Max].
90
- *
91
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
92
- */
93
35
  createDefaultLaundryDryerControlsClusterServer(selectedDrynessLevel, supportedDrynessLevels) {
94
36
  this.behaviors.require(LaundryDryerControlsServer, {
95
37
  supportedDrynessLevels: supportedDrynessLevels ?? [LaundryDryerControls.DrynessLevel.Low, LaundryDryerControls.DrynessLevel.Normal, LaundryDryerControls.DrynessLevel.Extra, LaundryDryerControls.DrynessLevel.Max],
96
- selectedDrynessLevel, // Writable
38
+ selectedDrynessLevel,
97
39
  });
98
40
  return this;
99
41
  }
100
- /**
101
- * Creates a TemperatureControl Cluster Server with feature TemperatureLevel.
102
- *
103
- * @param {number} selectedTemperatureLevel - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
104
- * @param {string[]} supportedTemperatureLevels - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
105
- *
106
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
107
- */
108
42
  createLevelTemperatureControlClusterServer(selectedTemperatureLevel = 1, supportedTemperatureLevels = ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']) {
109
43
  this.behaviors.require(MatterbridgeLevelTemperatureControlServer.with(TemperatureControl.Feature.TemperatureLevel), {
110
44
  selectedTemperatureLevel,
@@ -112,24 +46,13 @@ export class LaundryDryer extends MatterbridgeEndpoint {
112
46
  });
113
47
  return this;
114
48
  }
115
- /**
116
- * Creates a TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
117
- *
118
- * @param {number} temperatureSetpoint - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
119
- * @param {number} minTemperature - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
120
- * @param {number} maxTemperature - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
121
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
122
- *
123
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
124
- */
125
49
  createNumberTemperatureControlClusterServer(temperatureSetpoint = 40 * 100, minTemperature = 30 * 100, maxTemperature = 60 * 100, step = 10 * 100) {
126
50
  this.behaviors.require(MatterbridgeNumberTemperatureControlServer.with(TemperatureControl.Feature.TemperatureNumber, TemperatureControl.Feature.TemperatureStep), {
127
51
  temperatureSetpoint,
128
- minTemperature, // Fixed attribute
129
- maxTemperature, // Fixed attribute
130
- step, // Fixed attribute
52
+ minTemperature,
53
+ maxTemperature,
54
+ step,
131
55
  });
132
56
  return this;
133
57
  }
134
58
  }
135
- //# sourceMappingURL=laundryDryer.js.map
@@ -1,25 +1,3 @@
1
- /**
2
- * @description This file contains the LaundryWasher class.
3
- * @file src/devices/laundryWasher.ts
4
- * @author Luca Liguori
5
- * @created 2025-05-25
6
- * @version 1.1.0
7
- * @license Apache-2.0
8
- *
9
- * Copyright 2025, 2026, 2027 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License.
22
- */
23
1
  import { LaundryWasherControls } from '@matter/main/clusters/laundry-washer-controls';
24
2
  import { LaundryWasherMode } from '@matter/main/clusters/laundry-washer-mode';
25
3
  import { TemperatureControl } from '@matter/main/clusters/temperature-control';
@@ -27,34 +5,10 @@ import { ModeBase } from '@matter/main/clusters/mode-base';
27
5
  import { TemperatureControlServer } from '@matter/main/behaviors/temperature-control';
28
6
  import { LaundryWasherModeServer } from '@matter/main/behaviors/laundry-washer-mode';
29
7
  import { LaundryWasherControlsServer } from '@matter/main/behaviors/laundry-washer-controls';
30
- // Matterbridge
31
8
  import { laundryWasher, powerSource } from '../matterbridgeDeviceTypes.js';
32
9
  import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
33
10
  import { MatterbridgeOnOffServer, MatterbridgeServer } from '../matterbridgeBehaviors.js';
34
11
  export class LaundryWasher extends MatterbridgeEndpoint {
35
- /**
36
- * Creates an instance of the LaundryWasher class.
37
- *
38
- * @param {string} name - The name of the laundry washer.
39
- * @param {string} serial - The serial number of the laundry washer.
40
- * @param {number} [currentMode] - The current mode of the laundry washer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
41
- * @param {LaundryWasherMode.ModeOption[]} [supportedModes] - The supported modes of the laundry washer. Defaults to a set of common modes (which include Delicate, Normal, Heavy, and Whites). Fixed attribute.
42
- * @param {number} [spinSpeedCurrent] - The current spin speed as index of the spinSpeeds array. Defaults to 2 (which corresponds to '1200').
43
- * @param {string[]} [spinSpeeds] - The supported spin speeds. Defaults to ['400', '800', '1200', '1600'].
44
- * @param {LaundryWasherControls.NumberOfRinses} [numberOfRinses] - The number of rinses. Defaults to LaundryWasherControls.NumberOfRinses.Normal (which corresponds to 1 rinse).
45
- * @param {LaundryWasherControls.NumberOfRinses[]} [supportedRinses] - The supported rinses. Defaults to [NumberOfRinses.None, NumberOfRinses.Normal, NumberOfRinses.Max, NumberOfRinses.Extra].
46
- * @param {number} [selectedTemperatureLevel] - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
47
- * @param {string[]} [supportedTemperatureLevels] - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
48
- * @param {number} [temperatureSetpoint] - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
49
- * @param {number} [minTemperature] - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
50
- * @param {number} [maxTemperature] - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
51
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
52
- * @param {OperationalState.OperationalStateEnum} [operationalState] - The operational state of the laundry washer. Defaults to OperationalState.OperationalStateEnum.Off.
53
- *
54
- * Remarks:
55
- * - If `temperatureSetpoint` is provided, the `createNumberTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
56
- * - If `temperatureSetpoint` is not provided, the `createLevelTemperatureControlClusterServer` method will be used to create the TemperatureControl Cluster Server with feature TemperatureLevel.
57
- */
58
12
  constructor(name, serial, currentMode, supportedModes, spinSpeedCurrent, spinSpeeds, numberOfRinses, supportedRinses, selectedTemperatureLevel, supportedTemperatureLevels, temperatureSetpoint, minTemperature, maxTemperature, step, operationalState) {
59
13
  super([laundryWasher, powerSource], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
60
14
  this.createDefaultIdentifyClusterServer();
@@ -69,14 +23,6 @@ export class LaundryWasher extends MatterbridgeEndpoint {
69
23
  this.createLevelTemperatureControlClusterServer(selectedTemperatureLevel, supportedTemperatureLevels);
70
24
  this.createDefaultOperationalStateClusterServer(operationalState);
71
25
  }
72
- /**
73
- * Creates a default Laundry Washer Mode Cluster Server.
74
- *
75
- * @param {number} currentMode - The current mode of the laundry washer. Defaults to 2 (Normal mode). Dead Front OnOff Cluster will set this to 2 when turned off. Persistent attribute.
76
- * @param {LaundryWasherMode.ModeOption[]} supportedModes - The supported modes of the laundry washer. Defaults to a set of common modes (which include Delicate, Normal, Heavy, and Whites). Fixed attribute.
77
- *
78
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
79
- */
80
26
  createDefaultLaundryWasherModeClusterServer(currentMode = 2, supportedModes = [
81
27
  { label: 'Delicate', mode: 1, modeTags: [{ value: LaundryWasherMode.ModeTag.Delicate }] },
82
28
  { label: 'Normal', mode: 2, modeTags: [{ value: LaundryWasherMode.ModeTag.Normal }] },
@@ -84,38 +30,20 @@ export class LaundryWasher extends MatterbridgeEndpoint {
84
30
  { label: 'Whites', mode: 4, modeTags: [{ value: LaundryWasherMode.ModeTag.Whites }] },
85
31
  ]) {
86
32
  this.behaviors.require(MatterbridgeLaundryWasherModeServer, {
87
- supportedModes, // Fixed attribute.
88
- currentMode, // Persistent attribute.
33
+ supportedModes,
34
+ currentMode,
89
35
  });
90
36
  return this;
91
37
  }
92
- /**
93
- * Creates a Laundry Washer Controls Cluster Server with feature Spin for selecting the spin speed and feature Rinse for selecting the number of rinses.
94
- *
95
- * @param {number} spinSpeedCurrent - The current spin speed as index of the spinSpeeds array. Default to 2 (which corresponds to '1200').
96
- * @param {string[]} spinSpeeds - The supported spin speeds. Default to ['400', '800', '1200', '1600'].
97
- * @param {LaundryWasherControls.NumberOfRinses} numberOfRinses - The number of rinses. Default to LaundryWasherControls.NumberOfRinses.Normal (which corresponds to 1 rinse).
98
- * @param {LaundryWasherControls.NumberOfRinses[]} supportedRinses - The supported rinses. Default to [NumberOfRinses.None, NumberOfRinses.Normal, NumberOfRinses.Max, NumberOfRinses.Extra].
99
- *
100
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
101
- */
102
38
  createDefaultLaundryWasherControlsClusterServer(spinSpeedCurrent = 2, spinSpeeds = ['400', '800', '1200', '1600'], numberOfRinses = LaundryWasherControls.NumberOfRinses.Normal, supportedRinses = [LaundryWasherControls.NumberOfRinses.None, LaundryWasherControls.NumberOfRinses.Normal, LaundryWasherControls.NumberOfRinses.Max, LaundryWasherControls.NumberOfRinses.Extra]) {
103
39
  this.behaviors.require(LaundryWasherControlsServer.with(LaundryWasherControls.Feature.Spin, LaundryWasherControls.Feature.Rinse), {
104
40
  spinSpeeds,
105
- spinSpeedCurrent, // Writable and nullable
41
+ spinSpeedCurrent,
106
42
  supportedRinses,
107
- numberOfRinses, // Writable
43
+ numberOfRinses,
108
44
  });
109
45
  return this;
110
46
  }
111
- /**
112
- * Creates a TemperatureControl Cluster Server with feature TemperatureLevel.
113
- *
114
- * @param {number} selectedTemperatureLevel - The selected temperature level as an index of the supportedTemperatureLevels array. Defaults to 1 (which corresponds to 'Warm').
115
- * @param {string[]} supportedTemperatureLevels - The supported temperature levels. Defaults to ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']. Fixed attribute.
116
- *
117
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
118
- */
119
47
  createLevelTemperatureControlClusterServer(selectedTemperatureLevel = 1, supportedTemperatureLevels = ['Cold', 'Warm', 'Hot', '30°', '40°', '60°', '80°']) {
120
48
  this.behaviors.require(MatterbridgeLevelTemperatureControlServer.with(TemperatureControl.Feature.TemperatureLevel), {
121
49
  selectedTemperatureLevel,
@@ -123,22 +51,12 @@ export class LaundryWasher extends MatterbridgeEndpoint {
123
51
  });
124
52
  return this;
125
53
  }
126
- /**
127
- * Creates a TemperatureControl Cluster Server with features TemperatureNumber and TemperatureStep.
128
- *
129
- * @param {number} temperatureSetpoint - The temperature setpoint * 100. Defaults to 40 * 100 (which corresponds to 40°C).
130
- * @param {number} minTemperature - The minimum temperature * 100. Defaults to 30 * 100 (which corresponds to 30°C). Fixed attribute.
131
- * @param {number} maxTemperature - The maximum temperature * 100. Defaults to 60 * 100 (which corresponds to 60°C). Fixed attribute.
132
- * @param {number} [step] - The step size for temperature changes. Defaults to 10 * 100 (which corresponds to 10°C). Fixed attribute.
133
- *
134
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
135
- */
136
54
  createNumberTemperatureControlClusterServer(temperatureSetpoint = 40 * 100, minTemperature = 30 * 100, maxTemperature = 60 * 100, step = 10 * 100) {
137
55
  this.behaviors.require(MatterbridgeNumberTemperatureControlServer.with(TemperatureControl.Feature.TemperatureNumber, TemperatureControl.Feature.TemperatureStep), {
138
56
  temperatureSetpoint,
139
- minTemperature, // Fixed attribute
140
- maxTemperature, // Fixed attribute
141
- step, // Fixed attribute
57
+ minTemperature,
58
+ maxTemperature,
59
+ step,
142
60
  });
143
61
  return this;
144
62
  }
@@ -187,7 +105,6 @@ export class MatterbridgeLaundryWasherModeServer extends LaundryWasherModeServer
187
105
  device.log.info(`MatterbridgeLaundryWasherModeServer initialized: currentMode is ${this.state.currentMode}`);
188
106
  this.reactTo(this.agent.get(MatterbridgeOnOffServer).events.onOff$Changed, this.handleOnOffChange);
189
107
  }
190
- // Dead Front OnOff Cluster
191
108
  handleOnOffChange(onOff) {
192
109
  const device = this.endpoint.stateOf(MatterbridgeServer);
193
110
  device.log.info(`HandleOnOffChange (endpoint ${this.endpoint.maybeId}.${this.endpoint.maybeNumber})`);
@@ -212,4 +129,3 @@ export class MatterbridgeLaundryWasherModeServer extends LaundryWasherModeServer
212
129
  }
213
130
  }
214
131
  }
215
- //# sourceMappingURL=laundryWasher.js.map