@switchbot/homebridge-switchbot 5.0.0-beta.9 → 5.0.0-beta.91
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.
- package/.github/ISSUE_TEMPLATE/e2e-verification.md +36 -0
- package/.github/workflows/ci.yml +32 -0
- package/.github/workflows/manual-e2e.yml +115 -0
- package/.github/workflows/release.yml +0 -4
- package/CHANGELOG.md +35 -0
- package/E2E-VERIFICATION.md +121 -0
- package/MIGRATION.md +44 -0
- package/README.md +56 -3
- package/config.schema.json +91 -14787
- package/dist/deviceFactory.d.ts +13 -0
- package/dist/deviceFactory.d.ts.map +1 -0
- package/dist/deviceFactory.js +81 -0
- package/dist/deviceFactory.js.map +1 -0
- package/dist/devices/deviceBase.d.ts +50 -0
- package/dist/devices/deviceBase.d.ts.map +1 -0
- package/dist/devices/deviceBase.js +119 -0
- package/dist/devices/deviceBase.js.map +1 -0
- package/dist/devices/genericDevice.d.ts +283 -0
- package/dist/devices/genericDevice.d.ts.map +1 -0
- package/dist/devices/genericDevice.js +1035 -0
- package/dist/devices/genericDevice.js.map +1 -0
- package/dist/homebridge-ui/public/index.html +630 -246
- package/dist/homebridge-ui/server.d.ts +3 -1
- package/dist/homebridge-ui/server.d.ts.map +1 -1
- package/dist/homebridge-ui/server.js +367 -36
- package/dist/homebridge-ui/server.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -32
- package/dist/index.js.map +1 -1
- package/dist/platform.d.ts +35 -0
- package/dist/platform.d.ts.map +1 -0
- package/dist/platform.js +514 -0
- package/dist/platform.js.map +1 -0
- package/dist/settings.d.ts +10 -249
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js +5 -30
- package/dist/settings.js.map +1 -1
- package/dist/switchbotClient.d.ts +32 -0
- package/dist/switchbotClient.d.ts.map +1 -0
- package/dist/switchbotClient.js +194 -0
- package/dist/switchbotClient.js.map +1 -0
- package/dist/utils.d.ts +39 -50
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +39 -688
- package/dist/utils.js.map +1 -1
- package/docs/assets/highlight.css +14 -0
- package/docs/assets/icons.js +1 -1
- package/docs/assets/icons.svg +1 -1
- package/docs/assets/main.js +2 -2
- package/docs/assets/style.css +3 -3
- package/docs/index.html +77 -13
- package/docs/variables/default.html +1 -1
- package/eslint.config.js +2 -8
- package/package.json +21 -28
- package/scripts/e2e/README.md +25 -0
- package/scripts/e2e/curtain-e2e.sh +70 -0
- package/scripts/e2e/fan-e2e.sh +75 -0
- package/scripts/e2e/light-advanced-e2e.sh +97 -0
- package/scripts/e2e/light-e2e.sh +75 -0
- package/scripts/e2e/list-accessories.sh +19 -0
- package/scripts/e2e/lock-e2e.sh +65 -0
- package/scripts/generate-matter-maps.js +60 -0
- package/scripts/run-e2e-local.sh +14 -0
- package/src/deviceFactory.ts +122 -0
- package/src/devices/deviceBase.ts +141 -0
- package/src/devices/genericDevice.ts +965 -0
- package/src/homebridge-ui/public/index.html +630 -246
- package/src/homebridge-ui/server.ts +434 -41
- package/src/index.ts +4 -33
- package/src/platform.ts +515 -0
- package/src/settings.ts +12 -277
- package/src/switchbotClient.ts +203 -0
- package/src/utils.ts +45 -713
- package/test/accessory-restore.spec.ts +73 -0
- package/test/device-mapping.spec.ts +37 -0
- package/test/deviceFactory.spec.ts +18 -0
- package/test/e2e/run-e2e.spec.ts +50 -0
- package/test/fan-swing.spec.ts +29 -0
- package/test/helpers/matter-harness.ts +53 -0
- package/test/lock-users.spec.ts +44 -0
- package/test/matter-childbridge.spec.ts +55 -0
- package/test/matter-descriptors.spec.ts +97 -0
- package/test/matter-device-state.spec.ts +101 -0
- package/test/matter-integration.spec.ts +70 -0
- package/test/platform.integration.spec.ts +55 -0
- package/test/switchbot-client-debounce.spec.ts +131 -0
- package/test/switchbot-client-openapi.spec.ts +56 -0
- package/test/switchbotClient.spec.ts +10 -0
- package/test/utils.spec.ts +20 -0
- package/vitest.config.ts +7 -0
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/clover.xml +0 -15847
- package/coverage/coverage-final.json +0 -42
- package/coverage/docs/assets/dmt/dmt-component-data.js.html +0 -85
- package/coverage/docs/assets/dmt/dmt-components.js.html +0 -286
- package/coverage/docs/assets/dmt/index.html +0 -131
- package/coverage/docs/assets/hierarchy.js.html +0 -85
- package/coverage/docs/assets/icons.js.html +0 -136
- package/coverage/docs/assets/index.html +0 -146
- package/coverage/docs/assets/main.js.html +0 -265
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -191
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -196
- package/coverage/src/device/blindtilt.ts.html +0 -3238
- package/coverage/src/device/bot.ts.html +0 -2803
- package/coverage/src/device/ceilinglight.ts.html +0 -2338
- package/coverage/src/device/colorbulb.ts.html +0 -2824
- package/coverage/src/device/contact.ts.html +0 -1465
- package/coverage/src/device/curtain.ts.html +0 -2869
- package/coverage/src/device/device.ts.html +0 -2500
- package/coverage/src/device/fan.ts.html +0 -2242
- package/coverage/src/device/hub.ts.html +0 -1408
- package/coverage/src/device/humidifier.ts.html +0 -2116
- package/coverage/src/device/index.html +0 -416
- package/coverage/src/device/iosensor.ts.html +0 -1375
- package/coverage/src/device/lightstrip.ts.html +0 -2617
- package/coverage/src/device/lock.ts.html +0 -1963
- package/coverage/src/device/meter.ts.html +0 -1372
- package/coverage/src/device/meterplus.ts.html +0 -1384
- package/coverage/src/device/meterpro.ts.html +0 -1618
- package/coverage/src/device/motion.ts.html +0 -1264
- package/coverage/src/device/plug.ts.html +0 -1372
- package/coverage/src/device/relayswitch.ts.html +0 -2284
- package/coverage/src/device/robotvacuumcleaner.ts.html +0 -1810
- package/coverage/src/device/waterdetector.ts.html +0 -1294
- package/coverage/src/homebridge-ui/index.html +0 -116
- package/coverage/src/homebridge-ui/server.ts.html +0 -229
- package/coverage/src/index.html +0 -161
- package/coverage/src/index.ts.html +0 -124
- package/coverage/src/irdevice/airconditioner.ts.html +0 -1687
- package/coverage/src/irdevice/airpurifier.ts.html +0 -844
- package/coverage/src/irdevice/camera.ts.html +0 -475
- package/coverage/src/irdevice/fan.ts.html +0 -766
- package/coverage/src/irdevice/index.html +0 -251
- package/coverage/src/irdevice/irdevice.ts.html +0 -1117
- package/coverage/src/irdevice/light.ts.html +0 -826
- package/coverage/src/irdevice/other.ts.html +0 -2458
- package/coverage/src/irdevice/tv.ts.html +0 -1222
- package/coverage/src/irdevice/vacuumcleaner.ts.html +0 -466
- package/coverage/src/irdevice/waterheater.ts.html +0 -469
- package/coverage/src/platform.ts.html +0 -8776
- package/coverage/src/settings.ts.html +0 -934
- package/coverage/src/utils.ts.html +0 -2092
- package/dist/devices-hap/airpurifier.d.ts +0 -54
- package/dist/devices-hap/airpurifier.d.ts.map +0 -1
- package/dist/devices-hap/airpurifier.js +0 -527
- package/dist/devices-hap/airpurifier.js.map +0 -1
- package/dist/devices-hap/blindtilt.d.ts +0 -90
- package/dist/devices-hap/blindtilt.d.ts.map +0 -1
- package/dist/devices-hap/blindtilt.js +0 -974
- package/dist/devices-hap/blindtilt.js.map +0 -1
- package/dist/devices-hap/bot.d.ts +0 -102
- package/dist/devices-hap/bot.d.ts.map +0 -1
- package/dist/devices-hap/bot.js +0 -811
- package/dist/devices-hap/bot.js.map +0 -1
- package/dist/devices-hap/ceilinglight.d.ts +0 -85
- package/dist/devices-hap/ceilinglight.d.ts.map +0 -1
- package/dist/devices-hap/ceilinglight.js +0 -701
- package/dist/devices-hap/ceilinglight.js.map +0 -1
- package/dist/devices-hap/colorbulb.d.ts +0 -88
- package/dist/devices-hap/colorbulb.d.ts.map +0 -1
- package/dist/devices-hap/colorbulb.js +0 -881
- package/dist/devices-hap/colorbulb.js.map +0 -1
- package/dist/devices-hap/contact.d.ts +0 -44
- package/dist/devices-hap/contact.d.ts.map +0 -1
- package/dist/devices-hap/contact.js +0 -409
- package/dist/devices-hap/contact.js.map +0 -1
- package/dist/devices-hap/curtain.d.ts +0 -73
- package/dist/devices-hap/curtain.d.ts.map +0 -1
- package/dist/devices-hap/curtain.js +0 -869
- package/dist/devices-hap/curtain.js.map +0 -1
- package/dist/devices-hap/device.d.ts +0 -98
- package/dist/devices-hap/device.d.ts.map +0 -1
- package/dist/devices-hap/device.js +0 -749
- package/dist/devices-hap/device.js.map +0 -1
- package/dist/devices-hap/fan.d.ts +0 -69
- package/dist/devices-hap/fan.d.ts.map +0 -1
- package/dist/devices-hap/fan.js +0 -649
- package/dist/devices-hap/fan.js.map +0 -1
- package/dist/devices-hap/hub.d.ts +0 -37
- package/dist/devices-hap/hub.d.ts.map +0 -1
- package/dist/devices-hap/hub.js +0 -392
- package/dist/devices-hap/hub.js.map +0 -1
- package/dist/devices-hap/humidifier.d.ts +0 -68
- package/dist/devices-hap/humidifier.d.ts.map +0 -1
- package/dist/devices-hap/humidifier.js +0 -628
- package/dist/devices-hap/humidifier.js.map +0 -1
- package/dist/devices-hap/iosensor.d.ts +0 -42
- package/dist/devices-hap/iosensor.d.ts.map +0 -1
- package/dist/devices-hap/iosensor.js +0 -382
- package/dist/devices-hap/iosensor.js.map +0 -1
- package/dist/devices-hap/lightstrip.d.ts +0 -79
- package/dist/devices-hap/lightstrip.d.ts.map +0 -1
- package/dist/devices-hap/lightstrip.js +0 -797
- package/dist/devices-hap/lightstrip.js.map +0 -1
- package/dist/devices-hap/lock.d.ts +0 -53
- package/dist/devices-hap/lock.d.ts.map +0 -1
- package/dist/devices-hap/lock.js +0 -561
- package/dist/devices-hap/lock.js.map +0 -1
- package/dist/devices-hap/meter.d.ts +0 -37
- package/dist/devices-hap/meter.d.ts.map +0 -1
- package/dist/devices-hap/meter.js +0 -379
- package/dist/devices-hap/meter.js.map +0 -1
- package/dist/devices-hap/meterplus.d.ts +0 -42
- package/dist/devices-hap/meterplus.d.ts.map +0 -1
- package/dist/devices-hap/meterplus.js +0 -384
- package/dist/devices-hap/meterplus.js.map +0 -1
- package/dist/devices-hap/meterpro.d.ts +0 -43
- package/dist/devices-hap/meterpro.d.ts.map +0 -1
- package/dist/devices-hap/meterpro.js +0 -468
- package/dist/devices-hap/meterpro.js.map +0 -1
- package/dist/devices-hap/motion.d.ts +0 -42
- package/dist/devices-hap/motion.d.ts.map +0 -1
- package/dist/devices-hap/motion.js +0 -345
- package/dist/devices-hap/motion.js.map +0 -1
- package/dist/devices-hap/plug.d.ts +0 -49
- package/dist/devices-hap/plug.d.ts.map +0 -1
- package/dist/devices-hap/plug.js +0 -395
- package/dist/devices-hap/plug.js.map +0 -1
- package/dist/devices-hap/relayswitch.d.ts +0 -96
- package/dist/devices-hap/relayswitch.d.ts.map +0 -1
- package/dist/devices-hap/relayswitch.js +0 -642
- package/dist/devices-hap/relayswitch.js.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.d.ts +0 -54
- package/dist/devices-hap/robotvacuumcleaner.d.ts.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.js +0 -523
- package/dist/devices-hap/robotvacuumcleaner.js.map +0 -1
- package/dist/devices-hap/waterdetector.d.ts +0 -41
- package/dist/devices-hap/waterdetector.d.ts.map +0 -1
- package/dist/devices-hap/waterdetector.js +0 -356
- package/dist/devices-hap/waterdetector.js.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.d.ts +0 -63
- package/dist/devices-matter/BaseMatterAccessory.d.ts.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.js +0 -100
- package/dist/devices-matter/BaseMatterAccessory.js.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.d.ts +0 -20
- package/dist/devices-matter/ColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.js +0 -95
- package/dist/devices-matter/ColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts +0 -18
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.js +0 -78
- package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/ContactSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.js +0 -34
- package/dist/devices-matter/ContactSensorAccessory.js.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.d.ts +0 -58
- package/dist/devices-matter/DimmableLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.js +0 -167
- package/dist/devices-matter/DimmableLightAccessory.js.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.d.ts +0 -14
- package/dist/devices-matter/DoorLockAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.js +0 -50
- package/dist/devices-matter/DoorLockAccessory.js.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts +0 -21
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.js +0 -107
- package/dist/devices-matter/ExtendedColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/FanAccessory.d.ts +0 -16
- package/dist/devices-matter/FanAccessory.d.ts.map +0 -1
- package/dist/devices-matter/FanAccessory.js +0 -81
- package/dist/devices-matter/FanAccessory.js.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/HumiditySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.js +0 -34
- package/dist/devices-matter/HumiditySensorAccessory.js.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LeakSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.js +0 -33
- package/dist/devices-matter/LeakSensorAccessory.js.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LightSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.js +0 -34
- package/dist/devices-matter/LightSensorAccessory.js.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/OccupancySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.js +0 -39
- package/dist/devices-matter/OccupancySensorAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.d.ts +0 -38
- package/dist/devices-matter/OnOffLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.js +0 -118
- package/dist/devices-matter/OnOffLightAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.d.ts +0 -12
- package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.js +0 -40
- package/dist/devices-matter/OnOffOutletAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts +0 -14
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.js +0 -42
- package/dist/devices-matter/OnOffSwitchAccessory.js.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts +0 -68
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.js +0 -334
- package/dist/devices-matter/RoboticVacuumAccessory.js.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts +0 -11
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.js +0 -49
- package/dist/devices-matter/SmokeCOAlarmAccessory.js.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.js +0 -36
- package/dist/devices-matter/TemperatureSensorAccessory.js.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.d.ts +0 -19
- package/dist/devices-matter/ThermostatAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.js +0 -95
- package/dist/devices-matter/ThermostatAccessory.js.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.d.ts +0 -19
- package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.js +0 -99
- package/dist/devices-matter/VenetianBlindAccessory.js.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.d.ts +0 -17
- package/dist/devices-matter/WindowBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.js +0 -80
- package/dist/devices-matter/WindowBlindAccessory.js.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts +0 -97
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.js +0 -265
- package/dist/devices-matter/custom/PowerStripAccessory.js.map +0 -1
- package/dist/devices-matter/custom/index.d.ts +0 -8
- package/dist/devices-matter/custom/index.d.ts.map +0 -1
- package/dist/devices-matter/custom/index.js +0 -8
- package/dist/devices-matter/custom/index.js.map +0 -1
- package/dist/devices-matter/index.d.ts +0 -29
- package/dist/devices-matter/index.d.ts.map +0 -1
- package/dist/devices-matter/index.js +0 -28
- package/dist/devices-matter/index.js.map +0 -1
- package/dist/index.test.d.ts +0 -2
- package/dist/index.test.d.ts.map +0 -1
- package/dist/index.test.js +0 -14
- package/dist/index.test.js.map +0 -1
- package/dist/irdevice/airconditioner.d.ts +0 -61
- package/dist/irdevice/airconditioner.d.ts.map +0 -1
- package/dist/irdevice/airconditioner.js +0 -472
- package/dist/irdevice/airconditioner.js.map +0 -1
- package/dist/irdevice/airpurifier.d.ts +0 -50
- package/dist/irdevice/airpurifier.d.ts.map +0 -1
- package/dist/irdevice/airpurifier.js +0 -213
- package/dist/irdevice/airpurifier.js.map +0 -1
- package/dist/irdevice/camera.d.ts +0 -32
- package/dist/irdevice/camera.d.ts.map +0 -1
- package/dist/irdevice/camera.js +0 -107
- package/dist/irdevice/camera.js.map +0 -1
- package/dist/irdevice/fan.d.ts +0 -36
- package/dist/irdevice/fan.d.ts.map +0 -1
- package/dist/irdevice/fan.js +0 -200
- package/dist/irdevice/fan.js.map +0 -1
- package/dist/irdevice/irdevice.d.ts +0 -68
- package/dist/irdevice/irdevice.d.ts.map +0 -1
- package/dist/irdevice/irdevice.js +0 -298
- package/dist/irdevice/irdevice.js.map +0 -1
- package/dist/irdevice/light.d.ts +0 -36
- package/dist/irdevice/light.d.ts.map +0 -1
- package/dist/irdevice/light.js +0 -206
- package/dist/irdevice/light.js.map +0 -1
- package/dist/irdevice/other.d.ts +0 -57
- package/dist/irdevice/other.d.ts.map +0 -1
- package/dist/irdevice/other.js +0 -778
- package/dist/irdevice/other.js.map +0 -1
- package/dist/irdevice/tv.d.ts +0 -45
- package/dist/irdevice/tv.d.ts.map +0 -1
- package/dist/irdevice/tv.js +0 -327
- package/dist/irdevice/tv.js.map +0 -1
- package/dist/irdevice/vacuumcleaner.d.ts +0 -28
- package/dist/irdevice/vacuumcleaner.d.ts.map +0 -1
- package/dist/irdevice/vacuumcleaner.js +0 -104
- package/dist/irdevice/vacuumcleaner.js.map +0 -1
- package/dist/irdevice/waterheater.d.ts +0 -30
- package/dist/irdevice/waterheater.d.ts.map +0 -1
- package/dist/irdevice/waterheater.js +0 -105
- package/dist/irdevice/waterheater.js.map +0 -1
- package/dist/platform-hap.d.ts +0 -149
- package/dist/platform-hap.d.ts.map +0 -1
- package/dist/platform-hap.js +0 -2861
- package/dist/platform-hap.js.map +0 -1
- package/dist/platform-matter.d.ts +0 -120
- package/dist/platform-matter.d.ts.map +0 -1
- package/dist/platform-matter.js +0 -966
- package/dist/platform-matter.js.map +0 -1
- package/dist/verifyconfig.test.d.ts +0 -2
- package/dist/verifyconfig.test.d.ts.map +0 -1
- package/dist/verifyconfig.test.js +0 -167
- package/dist/verifyconfig.test.js.map +0 -1
- package/src/custom.d.ts +0 -7
- package/src/devices-hap/airpurifier.ts +0 -563
- package/src/devices-hap/blindtilt.ts +0 -1049
- package/src/devices-hap/bot.ts +0 -900
- package/src/devices-hap/ceilinglight.ts +0 -742
- package/src/devices-hap/colorbulb.ts +0 -904
- package/src/devices-hap/contact.ts +0 -457
- package/src/devices-hap/curtain.ts +0 -944
- package/src/devices-hap/device.ts +0 -811
- package/src/devices-hap/fan.ts +0 -711
- package/src/devices-hap/hub.ts +0 -439
- package/src/devices-hap/humidifier.ts +0 -669
- package/src/devices-hap/iosensor.ts +0 -427
- package/src/devices-hap/lightstrip.ts +0 -836
- package/src/devices-hap/lock.ts +0 -620
- package/src/devices-hap/meter.ts +0 -426
- package/src/devices-hap/meterplus.ts +0 -430
- package/src/devices-hap/meterpro.ts +0 -522
- package/src/devices-hap/motion.ts +0 -390
- package/src/devices-hap/plug.ts +0 -423
- package/src/devices-hap/relayswitch.ts +0 -727
- package/src/devices-hap/robotvacuumcleaner.ts +0 -568
- package/src/devices-hap/waterdetector.ts +0 -400
- package/src/devices-matter/BaseMatterAccessory.ts +0 -131
- package/src/devices-matter/ColorLightAccessory.ts +0 -110
- package/src/devices-matter/ColorTemperatureLightAccessory.ts +0 -92
- package/src/devices-matter/ContactSensorAccessory.ts +0 -41
- package/src/devices-matter/DimmableLightAccessory.ts +0 -192
- package/src/devices-matter/DoorLockAccessory.ts +0 -60
- package/src/devices-matter/ExtendedColorLightAccessory.ts +0 -123
- package/src/devices-matter/FanAccessory.ts +0 -95
- package/src/devices-matter/HumiditySensorAccessory.ts +0 -41
- package/src/devices-matter/LeakSensorAccessory.ts +0 -40
- package/src/devices-matter/LightSensorAccessory.ts +0 -41
- package/src/devices-matter/OccupancySensorAccessory.ts +0 -48
- package/src/devices-matter/OnOffLightAccessory.ts +0 -133
- package/src/devices-matter/OnOffOutletAccessory.ts +0 -46
- package/src/devices-matter/OnOffSwitchAccessory.ts +0 -51
- package/src/devices-matter/RoboticVacuumAccessory.ts +0 -407
- package/src/devices-matter/SmokeCOAlarmAccessory.ts +0 -59
- package/src/devices-matter/TemperatureSensorAccessory.ts +0 -43
- package/src/devices-matter/ThermostatAccessory.ts +0 -110
- package/src/devices-matter/VenetianBlindAccessory.ts +0 -115
- package/src/devices-matter/WindowBlindAccessory.ts +0 -92
- package/src/devices-matter/custom/PowerStripAccessory.ts +0 -309
- package/src/devices-matter/custom/index.ts +0 -8
- package/src/devices-matter/index.ts +0 -29
- package/src/index.test.ts +0 -19
- package/src/irdevice/airconditioner.ts +0 -533
- package/src/irdevice/airpurifier.ts +0 -252
- package/src/irdevice/camera.ts +0 -129
- package/src/irdevice/fan.ts +0 -226
- package/src/irdevice/irdevice.ts +0 -344
- package/src/irdevice/light.ts +0 -246
- package/src/irdevice/other.ts +0 -790
- package/src/irdevice/tv.ts +0 -378
- package/src/irdevice/vacuumcleaner.ts +0 -126
- package/src/irdevice/waterheater.ts +0 -127
- package/src/platform-hap.ts +0 -2997
- package/src/platform-matter.ts +0 -1092
- package/src/verifyconfig.test.ts +0 -197
|
@@ -1,1687 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
<!doctype html>
|
|
3
|
-
<html lang="en">
|
|
4
|
-
|
|
5
|
-
<head>
|
|
6
|
-
<title>Code coverage report for src/irdevice/airconditioner.ts</title>
|
|
7
|
-
<meta charset="utf-8" />
|
|
8
|
-
<link rel="stylesheet" href="../../prettify.css" />
|
|
9
|
-
<link rel="stylesheet" href="../../base.css" />
|
|
10
|
-
<link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
|
|
11
|
-
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
-
<style type='text/css'>
|
|
13
|
-
.coverage-summary .sorter {
|
|
14
|
-
background-image: url(../../sort-arrow-sprite.png);
|
|
15
|
-
}
|
|
16
|
-
</style>
|
|
17
|
-
</head>
|
|
18
|
-
|
|
19
|
-
<body>
|
|
20
|
-
<div class='wrapper'>
|
|
21
|
-
<div class='pad1'>
|
|
22
|
-
<h1><a href="../../index.html">All files</a> / <a href="index.html">src/irdevice</a> airconditioner.ts</h1>
|
|
23
|
-
<div class='clearfix'>
|
|
24
|
-
|
|
25
|
-
<div class='fl pad1y space-right2'>
|
|
26
|
-
<span class="strong">0.47% </span>
|
|
27
|
-
<span class="quiet">Statements</span>
|
|
28
|
-
<span class='fraction'>2/418</span>
|
|
29
|
-
</div>
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
<div class='fl pad1y space-right2'>
|
|
33
|
-
<span class="strong">0% </span>
|
|
34
|
-
<span class="quiet">Branches</span>
|
|
35
|
-
<span class='fraction'>0/1</span>
|
|
36
|
-
</div>
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
<div class='fl pad1y space-right2'>
|
|
40
|
-
<span class="strong">0% </span>
|
|
41
|
-
<span class="quiet">Functions</span>
|
|
42
|
-
<span class='fraction'>0/1</span>
|
|
43
|
-
</div>
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
<div class='fl pad1y space-right2'>
|
|
47
|
-
<span class="strong">0.47% </span>
|
|
48
|
-
<span class="quiet">Lines</span>
|
|
49
|
-
<span class='fraction'>2/418</span>
|
|
50
|
-
</div>
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
</div>
|
|
54
|
-
<p class="quiet">
|
|
55
|
-
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
-
</p>
|
|
57
|
-
<template id="filterTemplate">
|
|
58
|
-
<div class="quiet">
|
|
59
|
-
Filter:
|
|
60
|
-
<input type="search" id="fileSearch">
|
|
61
|
-
</div>
|
|
62
|
-
</template>
|
|
63
|
-
</div>
|
|
64
|
-
<div class='status-line low'></div>
|
|
65
|
-
<pre><table class="coverage">
|
|
66
|
-
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
67
|
-
<a name='L2'></a><a href='#L2'>2</a>
|
|
68
|
-
<a name='L3'></a><a href='#L3'>3</a>
|
|
69
|
-
<a name='L4'></a><a href='#L4'>4</a>
|
|
70
|
-
<a name='L5'></a><a href='#L5'>5</a>
|
|
71
|
-
<a name='L6'></a><a href='#L6'>6</a>
|
|
72
|
-
<a name='L7'></a><a href='#L7'>7</a>
|
|
73
|
-
<a name='L8'></a><a href='#L8'>8</a>
|
|
74
|
-
<a name='L9'></a><a href='#L9'>9</a>
|
|
75
|
-
<a name='L10'></a><a href='#L10'>10</a>
|
|
76
|
-
<a name='L11'></a><a href='#L11'>11</a>
|
|
77
|
-
<a name='L12'></a><a href='#L12'>12</a>
|
|
78
|
-
<a name='L13'></a><a href='#L13'>13</a>
|
|
79
|
-
<a name='L14'></a><a href='#L14'>14</a>
|
|
80
|
-
<a name='L15'></a><a href='#L15'>15</a>
|
|
81
|
-
<a name='L16'></a><a href='#L16'>16</a>
|
|
82
|
-
<a name='L17'></a><a href='#L17'>17</a>
|
|
83
|
-
<a name='L18'></a><a href='#L18'>18</a>
|
|
84
|
-
<a name='L19'></a><a href='#L19'>19</a>
|
|
85
|
-
<a name='L20'></a><a href='#L20'>20</a>
|
|
86
|
-
<a name='L21'></a><a href='#L21'>21</a>
|
|
87
|
-
<a name='L22'></a><a href='#L22'>22</a>
|
|
88
|
-
<a name='L23'></a><a href='#L23'>23</a>
|
|
89
|
-
<a name='L24'></a><a href='#L24'>24</a>
|
|
90
|
-
<a name='L25'></a><a href='#L25'>25</a>
|
|
91
|
-
<a name='L26'></a><a href='#L26'>26</a>
|
|
92
|
-
<a name='L27'></a><a href='#L27'>27</a>
|
|
93
|
-
<a name='L28'></a><a href='#L28'>28</a>
|
|
94
|
-
<a name='L29'></a><a href='#L29'>29</a>
|
|
95
|
-
<a name='L30'></a><a href='#L30'>30</a>
|
|
96
|
-
<a name='L31'></a><a href='#L31'>31</a>
|
|
97
|
-
<a name='L32'></a><a href='#L32'>32</a>
|
|
98
|
-
<a name='L33'></a><a href='#L33'>33</a>
|
|
99
|
-
<a name='L34'></a><a href='#L34'>34</a>
|
|
100
|
-
<a name='L35'></a><a href='#L35'>35</a>
|
|
101
|
-
<a name='L36'></a><a href='#L36'>36</a>
|
|
102
|
-
<a name='L37'></a><a href='#L37'>37</a>
|
|
103
|
-
<a name='L38'></a><a href='#L38'>38</a>
|
|
104
|
-
<a name='L39'></a><a href='#L39'>39</a>
|
|
105
|
-
<a name='L40'></a><a href='#L40'>40</a>
|
|
106
|
-
<a name='L41'></a><a href='#L41'>41</a>
|
|
107
|
-
<a name='L42'></a><a href='#L42'>42</a>
|
|
108
|
-
<a name='L43'></a><a href='#L43'>43</a>
|
|
109
|
-
<a name='L44'></a><a href='#L44'>44</a>
|
|
110
|
-
<a name='L45'></a><a href='#L45'>45</a>
|
|
111
|
-
<a name='L46'></a><a href='#L46'>46</a>
|
|
112
|
-
<a name='L47'></a><a href='#L47'>47</a>
|
|
113
|
-
<a name='L48'></a><a href='#L48'>48</a>
|
|
114
|
-
<a name='L49'></a><a href='#L49'>49</a>
|
|
115
|
-
<a name='L50'></a><a href='#L50'>50</a>
|
|
116
|
-
<a name='L51'></a><a href='#L51'>51</a>
|
|
117
|
-
<a name='L52'></a><a href='#L52'>52</a>
|
|
118
|
-
<a name='L53'></a><a href='#L53'>53</a>
|
|
119
|
-
<a name='L54'></a><a href='#L54'>54</a>
|
|
120
|
-
<a name='L55'></a><a href='#L55'>55</a>
|
|
121
|
-
<a name='L56'></a><a href='#L56'>56</a>
|
|
122
|
-
<a name='L57'></a><a href='#L57'>57</a>
|
|
123
|
-
<a name='L58'></a><a href='#L58'>58</a>
|
|
124
|
-
<a name='L59'></a><a href='#L59'>59</a>
|
|
125
|
-
<a name='L60'></a><a href='#L60'>60</a>
|
|
126
|
-
<a name='L61'></a><a href='#L61'>61</a>
|
|
127
|
-
<a name='L62'></a><a href='#L62'>62</a>
|
|
128
|
-
<a name='L63'></a><a href='#L63'>63</a>
|
|
129
|
-
<a name='L64'></a><a href='#L64'>64</a>
|
|
130
|
-
<a name='L65'></a><a href='#L65'>65</a>
|
|
131
|
-
<a name='L66'></a><a href='#L66'>66</a>
|
|
132
|
-
<a name='L67'></a><a href='#L67'>67</a>
|
|
133
|
-
<a name='L68'></a><a href='#L68'>68</a>
|
|
134
|
-
<a name='L69'></a><a href='#L69'>69</a>
|
|
135
|
-
<a name='L70'></a><a href='#L70'>70</a>
|
|
136
|
-
<a name='L71'></a><a href='#L71'>71</a>
|
|
137
|
-
<a name='L72'></a><a href='#L72'>72</a>
|
|
138
|
-
<a name='L73'></a><a href='#L73'>73</a>
|
|
139
|
-
<a name='L74'></a><a href='#L74'>74</a>
|
|
140
|
-
<a name='L75'></a><a href='#L75'>75</a>
|
|
141
|
-
<a name='L76'></a><a href='#L76'>76</a>
|
|
142
|
-
<a name='L77'></a><a href='#L77'>77</a>
|
|
143
|
-
<a name='L78'></a><a href='#L78'>78</a>
|
|
144
|
-
<a name='L79'></a><a href='#L79'>79</a>
|
|
145
|
-
<a name='L80'></a><a href='#L80'>80</a>
|
|
146
|
-
<a name='L81'></a><a href='#L81'>81</a>
|
|
147
|
-
<a name='L82'></a><a href='#L82'>82</a>
|
|
148
|
-
<a name='L83'></a><a href='#L83'>83</a>
|
|
149
|
-
<a name='L84'></a><a href='#L84'>84</a>
|
|
150
|
-
<a name='L85'></a><a href='#L85'>85</a>
|
|
151
|
-
<a name='L86'></a><a href='#L86'>86</a>
|
|
152
|
-
<a name='L87'></a><a href='#L87'>87</a>
|
|
153
|
-
<a name='L88'></a><a href='#L88'>88</a>
|
|
154
|
-
<a name='L89'></a><a href='#L89'>89</a>
|
|
155
|
-
<a name='L90'></a><a href='#L90'>90</a>
|
|
156
|
-
<a name='L91'></a><a href='#L91'>91</a>
|
|
157
|
-
<a name='L92'></a><a href='#L92'>92</a>
|
|
158
|
-
<a name='L93'></a><a href='#L93'>93</a>
|
|
159
|
-
<a name='L94'></a><a href='#L94'>94</a>
|
|
160
|
-
<a name='L95'></a><a href='#L95'>95</a>
|
|
161
|
-
<a name='L96'></a><a href='#L96'>96</a>
|
|
162
|
-
<a name='L97'></a><a href='#L97'>97</a>
|
|
163
|
-
<a name='L98'></a><a href='#L98'>98</a>
|
|
164
|
-
<a name='L99'></a><a href='#L99'>99</a>
|
|
165
|
-
<a name='L100'></a><a href='#L100'>100</a>
|
|
166
|
-
<a name='L101'></a><a href='#L101'>101</a>
|
|
167
|
-
<a name='L102'></a><a href='#L102'>102</a>
|
|
168
|
-
<a name='L103'></a><a href='#L103'>103</a>
|
|
169
|
-
<a name='L104'></a><a href='#L104'>104</a>
|
|
170
|
-
<a name='L105'></a><a href='#L105'>105</a>
|
|
171
|
-
<a name='L106'></a><a href='#L106'>106</a>
|
|
172
|
-
<a name='L107'></a><a href='#L107'>107</a>
|
|
173
|
-
<a name='L108'></a><a href='#L108'>108</a>
|
|
174
|
-
<a name='L109'></a><a href='#L109'>109</a>
|
|
175
|
-
<a name='L110'></a><a href='#L110'>110</a>
|
|
176
|
-
<a name='L111'></a><a href='#L111'>111</a>
|
|
177
|
-
<a name='L112'></a><a href='#L112'>112</a>
|
|
178
|
-
<a name='L113'></a><a href='#L113'>113</a>
|
|
179
|
-
<a name='L114'></a><a href='#L114'>114</a>
|
|
180
|
-
<a name='L115'></a><a href='#L115'>115</a>
|
|
181
|
-
<a name='L116'></a><a href='#L116'>116</a>
|
|
182
|
-
<a name='L117'></a><a href='#L117'>117</a>
|
|
183
|
-
<a name='L118'></a><a href='#L118'>118</a>
|
|
184
|
-
<a name='L119'></a><a href='#L119'>119</a>
|
|
185
|
-
<a name='L120'></a><a href='#L120'>120</a>
|
|
186
|
-
<a name='L121'></a><a href='#L121'>121</a>
|
|
187
|
-
<a name='L122'></a><a href='#L122'>122</a>
|
|
188
|
-
<a name='L123'></a><a href='#L123'>123</a>
|
|
189
|
-
<a name='L124'></a><a href='#L124'>124</a>
|
|
190
|
-
<a name='L125'></a><a href='#L125'>125</a>
|
|
191
|
-
<a name='L126'></a><a href='#L126'>126</a>
|
|
192
|
-
<a name='L127'></a><a href='#L127'>127</a>
|
|
193
|
-
<a name='L128'></a><a href='#L128'>128</a>
|
|
194
|
-
<a name='L129'></a><a href='#L129'>129</a>
|
|
195
|
-
<a name='L130'></a><a href='#L130'>130</a>
|
|
196
|
-
<a name='L131'></a><a href='#L131'>131</a>
|
|
197
|
-
<a name='L132'></a><a href='#L132'>132</a>
|
|
198
|
-
<a name='L133'></a><a href='#L133'>133</a>
|
|
199
|
-
<a name='L134'></a><a href='#L134'>134</a>
|
|
200
|
-
<a name='L135'></a><a href='#L135'>135</a>
|
|
201
|
-
<a name='L136'></a><a href='#L136'>136</a>
|
|
202
|
-
<a name='L137'></a><a href='#L137'>137</a>
|
|
203
|
-
<a name='L138'></a><a href='#L138'>138</a>
|
|
204
|
-
<a name='L139'></a><a href='#L139'>139</a>
|
|
205
|
-
<a name='L140'></a><a href='#L140'>140</a>
|
|
206
|
-
<a name='L141'></a><a href='#L141'>141</a>
|
|
207
|
-
<a name='L142'></a><a href='#L142'>142</a>
|
|
208
|
-
<a name='L143'></a><a href='#L143'>143</a>
|
|
209
|
-
<a name='L144'></a><a href='#L144'>144</a>
|
|
210
|
-
<a name='L145'></a><a href='#L145'>145</a>
|
|
211
|
-
<a name='L146'></a><a href='#L146'>146</a>
|
|
212
|
-
<a name='L147'></a><a href='#L147'>147</a>
|
|
213
|
-
<a name='L148'></a><a href='#L148'>148</a>
|
|
214
|
-
<a name='L149'></a><a href='#L149'>149</a>
|
|
215
|
-
<a name='L150'></a><a href='#L150'>150</a>
|
|
216
|
-
<a name='L151'></a><a href='#L151'>151</a>
|
|
217
|
-
<a name='L152'></a><a href='#L152'>152</a>
|
|
218
|
-
<a name='L153'></a><a href='#L153'>153</a>
|
|
219
|
-
<a name='L154'></a><a href='#L154'>154</a>
|
|
220
|
-
<a name='L155'></a><a href='#L155'>155</a>
|
|
221
|
-
<a name='L156'></a><a href='#L156'>156</a>
|
|
222
|
-
<a name='L157'></a><a href='#L157'>157</a>
|
|
223
|
-
<a name='L158'></a><a href='#L158'>158</a>
|
|
224
|
-
<a name='L159'></a><a href='#L159'>159</a>
|
|
225
|
-
<a name='L160'></a><a href='#L160'>160</a>
|
|
226
|
-
<a name='L161'></a><a href='#L161'>161</a>
|
|
227
|
-
<a name='L162'></a><a href='#L162'>162</a>
|
|
228
|
-
<a name='L163'></a><a href='#L163'>163</a>
|
|
229
|
-
<a name='L164'></a><a href='#L164'>164</a>
|
|
230
|
-
<a name='L165'></a><a href='#L165'>165</a>
|
|
231
|
-
<a name='L166'></a><a href='#L166'>166</a>
|
|
232
|
-
<a name='L167'></a><a href='#L167'>167</a>
|
|
233
|
-
<a name='L168'></a><a href='#L168'>168</a>
|
|
234
|
-
<a name='L169'></a><a href='#L169'>169</a>
|
|
235
|
-
<a name='L170'></a><a href='#L170'>170</a>
|
|
236
|
-
<a name='L171'></a><a href='#L171'>171</a>
|
|
237
|
-
<a name='L172'></a><a href='#L172'>172</a>
|
|
238
|
-
<a name='L173'></a><a href='#L173'>173</a>
|
|
239
|
-
<a name='L174'></a><a href='#L174'>174</a>
|
|
240
|
-
<a name='L175'></a><a href='#L175'>175</a>
|
|
241
|
-
<a name='L176'></a><a href='#L176'>176</a>
|
|
242
|
-
<a name='L177'></a><a href='#L177'>177</a>
|
|
243
|
-
<a name='L178'></a><a href='#L178'>178</a>
|
|
244
|
-
<a name='L179'></a><a href='#L179'>179</a>
|
|
245
|
-
<a name='L180'></a><a href='#L180'>180</a>
|
|
246
|
-
<a name='L181'></a><a href='#L181'>181</a>
|
|
247
|
-
<a name='L182'></a><a href='#L182'>182</a>
|
|
248
|
-
<a name='L183'></a><a href='#L183'>183</a>
|
|
249
|
-
<a name='L184'></a><a href='#L184'>184</a>
|
|
250
|
-
<a name='L185'></a><a href='#L185'>185</a>
|
|
251
|
-
<a name='L186'></a><a href='#L186'>186</a>
|
|
252
|
-
<a name='L187'></a><a href='#L187'>187</a>
|
|
253
|
-
<a name='L188'></a><a href='#L188'>188</a>
|
|
254
|
-
<a name='L189'></a><a href='#L189'>189</a>
|
|
255
|
-
<a name='L190'></a><a href='#L190'>190</a>
|
|
256
|
-
<a name='L191'></a><a href='#L191'>191</a>
|
|
257
|
-
<a name='L192'></a><a href='#L192'>192</a>
|
|
258
|
-
<a name='L193'></a><a href='#L193'>193</a>
|
|
259
|
-
<a name='L194'></a><a href='#L194'>194</a>
|
|
260
|
-
<a name='L195'></a><a href='#L195'>195</a>
|
|
261
|
-
<a name='L196'></a><a href='#L196'>196</a>
|
|
262
|
-
<a name='L197'></a><a href='#L197'>197</a>
|
|
263
|
-
<a name='L198'></a><a href='#L198'>198</a>
|
|
264
|
-
<a name='L199'></a><a href='#L199'>199</a>
|
|
265
|
-
<a name='L200'></a><a href='#L200'>200</a>
|
|
266
|
-
<a name='L201'></a><a href='#L201'>201</a>
|
|
267
|
-
<a name='L202'></a><a href='#L202'>202</a>
|
|
268
|
-
<a name='L203'></a><a href='#L203'>203</a>
|
|
269
|
-
<a name='L204'></a><a href='#L204'>204</a>
|
|
270
|
-
<a name='L205'></a><a href='#L205'>205</a>
|
|
271
|
-
<a name='L206'></a><a href='#L206'>206</a>
|
|
272
|
-
<a name='L207'></a><a href='#L207'>207</a>
|
|
273
|
-
<a name='L208'></a><a href='#L208'>208</a>
|
|
274
|
-
<a name='L209'></a><a href='#L209'>209</a>
|
|
275
|
-
<a name='L210'></a><a href='#L210'>210</a>
|
|
276
|
-
<a name='L211'></a><a href='#L211'>211</a>
|
|
277
|
-
<a name='L212'></a><a href='#L212'>212</a>
|
|
278
|
-
<a name='L213'></a><a href='#L213'>213</a>
|
|
279
|
-
<a name='L214'></a><a href='#L214'>214</a>
|
|
280
|
-
<a name='L215'></a><a href='#L215'>215</a>
|
|
281
|
-
<a name='L216'></a><a href='#L216'>216</a>
|
|
282
|
-
<a name='L217'></a><a href='#L217'>217</a>
|
|
283
|
-
<a name='L218'></a><a href='#L218'>218</a>
|
|
284
|
-
<a name='L219'></a><a href='#L219'>219</a>
|
|
285
|
-
<a name='L220'></a><a href='#L220'>220</a>
|
|
286
|
-
<a name='L221'></a><a href='#L221'>221</a>
|
|
287
|
-
<a name='L222'></a><a href='#L222'>222</a>
|
|
288
|
-
<a name='L223'></a><a href='#L223'>223</a>
|
|
289
|
-
<a name='L224'></a><a href='#L224'>224</a>
|
|
290
|
-
<a name='L225'></a><a href='#L225'>225</a>
|
|
291
|
-
<a name='L226'></a><a href='#L226'>226</a>
|
|
292
|
-
<a name='L227'></a><a href='#L227'>227</a>
|
|
293
|
-
<a name='L228'></a><a href='#L228'>228</a>
|
|
294
|
-
<a name='L229'></a><a href='#L229'>229</a>
|
|
295
|
-
<a name='L230'></a><a href='#L230'>230</a>
|
|
296
|
-
<a name='L231'></a><a href='#L231'>231</a>
|
|
297
|
-
<a name='L232'></a><a href='#L232'>232</a>
|
|
298
|
-
<a name='L233'></a><a href='#L233'>233</a>
|
|
299
|
-
<a name='L234'></a><a href='#L234'>234</a>
|
|
300
|
-
<a name='L235'></a><a href='#L235'>235</a>
|
|
301
|
-
<a name='L236'></a><a href='#L236'>236</a>
|
|
302
|
-
<a name='L237'></a><a href='#L237'>237</a>
|
|
303
|
-
<a name='L238'></a><a href='#L238'>238</a>
|
|
304
|
-
<a name='L239'></a><a href='#L239'>239</a>
|
|
305
|
-
<a name='L240'></a><a href='#L240'>240</a>
|
|
306
|
-
<a name='L241'></a><a href='#L241'>241</a>
|
|
307
|
-
<a name='L242'></a><a href='#L242'>242</a>
|
|
308
|
-
<a name='L243'></a><a href='#L243'>243</a>
|
|
309
|
-
<a name='L244'></a><a href='#L244'>244</a>
|
|
310
|
-
<a name='L245'></a><a href='#L245'>245</a>
|
|
311
|
-
<a name='L246'></a><a href='#L246'>246</a>
|
|
312
|
-
<a name='L247'></a><a href='#L247'>247</a>
|
|
313
|
-
<a name='L248'></a><a href='#L248'>248</a>
|
|
314
|
-
<a name='L249'></a><a href='#L249'>249</a>
|
|
315
|
-
<a name='L250'></a><a href='#L250'>250</a>
|
|
316
|
-
<a name='L251'></a><a href='#L251'>251</a>
|
|
317
|
-
<a name='L252'></a><a href='#L252'>252</a>
|
|
318
|
-
<a name='L253'></a><a href='#L253'>253</a>
|
|
319
|
-
<a name='L254'></a><a href='#L254'>254</a>
|
|
320
|
-
<a name='L255'></a><a href='#L255'>255</a>
|
|
321
|
-
<a name='L256'></a><a href='#L256'>256</a>
|
|
322
|
-
<a name='L257'></a><a href='#L257'>257</a>
|
|
323
|
-
<a name='L258'></a><a href='#L258'>258</a>
|
|
324
|
-
<a name='L259'></a><a href='#L259'>259</a>
|
|
325
|
-
<a name='L260'></a><a href='#L260'>260</a>
|
|
326
|
-
<a name='L261'></a><a href='#L261'>261</a>
|
|
327
|
-
<a name='L262'></a><a href='#L262'>262</a>
|
|
328
|
-
<a name='L263'></a><a href='#L263'>263</a>
|
|
329
|
-
<a name='L264'></a><a href='#L264'>264</a>
|
|
330
|
-
<a name='L265'></a><a href='#L265'>265</a>
|
|
331
|
-
<a name='L266'></a><a href='#L266'>266</a>
|
|
332
|
-
<a name='L267'></a><a href='#L267'>267</a>
|
|
333
|
-
<a name='L268'></a><a href='#L268'>268</a>
|
|
334
|
-
<a name='L269'></a><a href='#L269'>269</a>
|
|
335
|
-
<a name='L270'></a><a href='#L270'>270</a>
|
|
336
|
-
<a name='L271'></a><a href='#L271'>271</a>
|
|
337
|
-
<a name='L272'></a><a href='#L272'>272</a>
|
|
338
|
-
<a name='L273'></a><a href='#L273'>273</a>
|
|
339
|
-
<a name='L274'></a><a href='#L274'>274</a>
|
|
340
|
-
<a name='L275'></a><a href='#L275'>275</a>
|
|
341
|
-
<a name='L276'></a><a href='#L276'>276</a>
|
|
342
|
-
<a name='L277'></a><a href='#L277'>277</a>
|
|
343
|
-
<a name='L278'></a><a href='#L278'>278</a>
|
|
344
|
-
<a name='L279'></a><a href='#L279'>279</a>
|
|
345
|
-
<a name='L280'></a><a href='#L280'>280</a>
|
|
346
|
-
<a name='L281'></a><a href='#L281'>281</a>
|
|
347
|
-
<a name='L282'></a><a href='#L282'>282</a>
|
|
348
|
-
<a name='L283'></a><a href='#L283'>283</a>
|
|
349
|
-
<a name='L284'></a><a href='#L284'>284</a>
|
|
350
|
-
<a name='L285'></a><a href='#L285'>285</a>
|
|
351
|
-
<a name='L286'></a><a href='#L286'>286</a>
|
|
352
|
-
<a name='L287'></a><a href='#L287'>287</a>
|
|
353
|
-
<a name='L288'></a><a href='#L288'>288</a>
|
|
354
|
-
<a name='L289'></a><a href='#L289'>289</a>
|
|
355
|
-
<a name='L290'></a><a href='#L290'>290</a>
|
|
356
|
-
<a name='L291'></a><a href='#L291'>291</a>
|
|
357
|
-
<a name='L292'></a><a href='#L292'>292</a>
|
|
358
|
-
<a name='L293'></a><a href='#L293'>293</a>
|
|
359
|
-
<a name='L294'></a><a href='#L294'>294</a>
|
|
360
|
-
<a name='L295'></a><a href='#L295'>295</a>
|
|
361
|
-
<a name='L296'></a><a href='#L296'>296</a>
|
|
362
|
-
<a name='L297'></a><a href='#L297'>297</a>
|
|
363
|
-
<a name='L298'></a><a href='#L298'>298</a>
|
|
364
|
-
<a name='L299'></a><a href='#L299'>299</a>
|
|
365
|
-
<a name='L300'></a><a href='#L300'>300</a>
|
|
366
|
-
<a name='L301'></a><a href='#L301'>301</a>
|
|
367
|
-
<a name='L302'></a><a href='#L302'>302</a>
|
|
368
|
-
<a name='L303'></a><a href='#L303'>303</a>
|
|
369
|
-
<a name='L304'></a><a href='#L304'>304</a>
|
|
370
|
-
<a name='L305'></a><a href='#L305'>305</a>
|
|
371
|
-
<a name='L306'></a><a href='#L306'>306</a>
|
|
372
|
-
<a name='L307'></a><a href='#L307'>307</a>
|
|
373
|
-
<a name='L308'></a><a href='#L308'>308</a>
|
|
374
|
-
<a name='L309'></a><a href='#L309'>309</a>
|
|
375
|
-
<a name='L310'></a><a href='#L310'>310</a>
|
|
376
|
-
<a name='L311'></a><a href='#L311'>311</a>
|
|
377
|
-
<a name='L312'></a><a href='#L312'>312</a>
|
|
378
|
-
<a name='L313'></a><a href='#L313'>313</a>
|
|
379
|
-
<a name='L314'></a><a href='#L314'>314</a>
|
|
380
|
-
<a name='L315'></a><a href='#L315'>315</a>
|
|
381
|
-
<a name='L316'></a><a href='#L316'>316</a>
|
|
382
|
-
<a name='L317'></a><a href='#L317'>317</a>
|
|
383
|
-
<a name='L318'></a><a href='#L318'>318</a>
|
|
384
|
-
<a name='L319'></a><a href='#L319'>319</a>
|
|
385
|
-
<a name='L320'></a><a href='#L320'>320</a>
|
|
386
|
-
<a name='L321'></a><a href='#L321'>321</a>
|
|
387
|
-
<a name='L322'></a><a href='#L322'>322</a>
|
|
388
|
-
<a name='L323'></a><a href='#L323'>323</a>
|
|
389
|
-
<a name='L324'></a><a href='#L324'>324</a>
|
|
390
|
-
<a name='L325'></a><a href='#L325'>325</a>
|
|
391
|
-
<a name='L326'></a><a href='#L326'>326</a>
|
|
392
|
-
<a name='L327'></a><a href='#L327'>327</a>
|
|
393
|
-
<a name='L328'></a><a href='#L328'>328</a>
|
|
394
|
-
<a name='L329'></a><a href='#L329'>329</a>
|
|
395
|
-
<a name='L330'></a><a href='#L330'>330</a>
|
|
396
|
-
<a name='L331'></a><a href='#L331'>331</a>
|
|
397
|
-
<a name='L332'></a><a href='#L332'>332</a>
|
|
398
|
-
<a name='L333'></a><a href='#L333'>333</a>
|
|
399
|
-
<a name='L334'></a><a href='#L334'>334</a>
|
|
400
|
-
<a name='L335'></a><a href='#L335'>335</a>
|
|
401
|
-
<a name='L336'></a><a href='#L336'>336</a>
|
|
402
|
-
<a name='L337'></a><a href='#L337'>337</a>
|
|
403
|
-
<a name='L338'></a><a href='#L338'>338</a>
|
|
404
|
-
<a name='L339'></a><a href='#L339'>339</a>
|
|
405
|
-
<a name='L340'></a><a href='#L340'>340</a>
|
|
406
|
-
<a name='L341'></a><a href='#L341'>341</a>
|
|
407
|
-
<a name='L342'></a><a href='#L342'>342</a>
|
|
408
|
-
<a name='L343'></a><a href='#L343'>343</a>
|
|
409
|
-
<a name='L344'></a><a href='#L344'>344</a>
|
|
410
|
-
<a name='L345'></a><a href='#L345'>345</a>
|
|
411
|
-
<a name='L346'></a><a href='#L346'>346</a>
|
|
412
|
-
<a name='L347'></a><a href='#L347'>347</a>
|
|
413
|
-
<a name='L348'></a><a href='#L348'>348</a>
|
|
414
|
-
<a name='L349'></a><a href='#L349'>349</a>
|
|
415
|
-
<a name='L350'></a><a href='#L350'>350</a>
|
|
416
|
-
<a name='L351'></a><a href='#L351'>351</a>
|
|
417
|
-
<a name='L352'></a><a href='#L352'>352</a>
|
|
418
|
-
<a name='L353'></a><a href='#L353'>353</a>
|
|
419
|
-
<a name='L354'></a><a href='#L354'>354</a>
|
|
420
|
-
<a name='L355'></a><a href='#L355'>355</a>
|
|
421
|
-
<a name='L356'></a><a href='#L356'>356</a>
|
|
422
|
-
<a name='L357'></a><a href='#L357'>357</a>
|
|
423
|
-
<a name='L358'></a><a href='#L358'>358</a>
|
|
424
|
-
<a name='L359'></a><a href='#L359'>359</a>
|
|
425
|
-
<a name='L360'></a><a href='#L360'>360</a>
|
|
426
|
-
<a name='L361'></a><a href='#L361'>361</a>
|
|
427
|
-
<a name='L362'></a><a href='#L362'>362</a>
|
|
428
|
-
<a name='L363'></a><a href='#L363'>363</a>
|
|
429
|
-
<a name='L364'></a><a href='#L364'>364</a>
|
|
430
|
-
<a name='L365'></a><a href='#L365'>365</a>
|
|
431
|
-
<a name='L366'></a><a href='#L366'>366</a>
|
|
432
|
-
<a name='L367'></a><a href='#L367'>367</a>
|
|
433
|
-
<a name='L368'></a><a href='#L368'>368</a>
|
|
434
|
-
<a name='L369'></a><a href='#L369'>369</a>
|
|
435
|
-
<a name='L370'></a><a href='#L370'>370</a>
|
|
436
|
-
<a name='L371'></a><a href='#L371'>371</a>
|
|
437
|
-
<a name='L372'></a><a href='#L372'>372</a>
|
|
438
|
-
<a name='L373'></a><a href='#L373'>373</a>
|
|
439
|
-
<a name='L374'></a><a href='#L374'>374</a>
|
|
440
|
-
<a name='L375'></a><a href='#L375'>375</a>
|
|
441
|
-
<a name='L376'></a><a href='#L376'>376</a>
|
|
442
|
-
<a name='L377'></a><a href='#L377'>377</a>
|
|
443
|
-
<a name='L378'></a><a href='#L378'>378</a>
|
|
444
|
-
<a name='L379'></a><a href='#L379'>379</a>
|
|
445
|
-
<a name='L380'></a><a href='#L380'>380</a>
|
|
446
|
-
<a name='L381'></a><a href='#L381'>381</a>
|
|
447
|
-
<a name='L382'></a><a href='#L382'>382</a>
|
|
448
|
-
<a name='L383'></a><a href='#L383'>383</a>
|
|
449
|
-
<a name='L384'></a><a href='#L384'>384</a>
|
|
450
|
-
<a name='L385'></a><a href='#L385'>385</a>
|
|
451
|
-
<a name='L386'></a><a href='#L386'>386</a>
|
|
452
|
-
<a name='L387'></a><a href='#L387'>387</a>
|
|
453
|
-
<a name='L388'></a><a href='#L388'>388</a>
|
|
454
|
-
<a name='L389'></a><a href='#L389'>389</a>
|
|
455
|
-
<a name='L390'></a><a href='#L390'>390</a>
|
|
456
|
-
<a name='L391'></a><a href='#L391'>391</a>
|
|
457
|
-
<a name='L392'></a><a href='#L392'>392</a>
|
|
458
|
-
<a name='L393'></a><a href='#L393'>393</a>
|
|
459
|
-
<a name='L394'></a><a href='#L394'>394</a>
|
|
460
|
-
<a name='L395'></a><a href='#L395'>395</a>
|
|
461
|
-
<a name='L396'></a><a href='#L396'>396</a>
|
|
462
|
-
<a name='L397'></a><a href='#L397'>397</a>
|
|
463
|
-
<a name='L398'></a><a href='#L398'>398</a>
|
|
464
|
-
<a name='L399'></a><a href='#L399'>399</a>
|
|
465
|
-
<a name='L400'></a><a href='#L400'>400</a>
|
|
466
|
-
<a name='L401'></a><a href='#L401'>401</a>
|
|
467
|
-
<a name='L402'></a><a href='#L402'>402</a>
|
|
468
|
-
<a name='L403'></a><a href='#L403'>403</a>
|
|
469
|
-
<a name='L404'></a><a href='#L404'>404</a>
|
|
470
|
-
<a name='L405'></a><a href='#L405'>405</a>
|
|
471
|
-
<a name='L406'></a><a href='#L406'>406</a>
|
|
472
|
-
<a name='L407'></a><a href='#L407'>407</a>
|
|
473
|
-
<a name='L408'></a><a href='#L408'>408</a>
|
|
474
|
-
<a name='L409'></a><a href='#L409'>409</a>
|
|
475
|
-
<a name='L410'></a><a href='#L410'>410</a>
|
|
476
|
-
<a name='L411'></a><a href='#L411'>411</a>
|
|
477
|
-
<a name='L412'></a><a href='#L412'>412</a>
|
|
478
|
-
<a name='L413'></a><a href='#L413'>413</a>
|
|
479
|
-
<a name='L414'></a><a href='#L414'>414</a>
|
|
480
|
-
<a name='L415'></a><a href='#L415'>415</a>
|
|
481
|
-
<a name='L416'></a><a href='#L416'>416</a>
|
|
482
|
-
<a name='L417'></a><a href='#L417'>417</a>
|
|
483
|
-
<a name='L418'></a><a href='#L418'>418</a>
|
|
484
|
-
<a name='L419'></a><a href='#L419'>419</a>
|
|
485
|
-
<a name='L420'></a><a href='#L420'>420</a>
|
|
486
|
-
<a name='L421'></a><a href='#L421'>421</a>
|
|
487
|
-
<a name='L422'></a><a href='#L422'>422</a>
|
|
488
|
-
<a name='L423'></a><a href='#L423'>423</a>
|
|
489
|
-
<a name='L424'></a><a href='#L424'>424</a>
|
|
490
|
-
<a name='L425'></a><a href='#L425'>425</a>
|
|
491
|
-
<a name='L426'></a><a href='#L426'>426</a>
|
|
492
|
-
<a name='L427'></a><a href='#L427'>427</a>
|
|
493
|
-
<a name='L428'></a><a href='#L428'>428</a>
|
|
494
|
-
<a name='L429'></a><a href='#L429'>429</a>
|
|
495
|
-
<a name='L430'></a><a href='#L430'>430</a>
|
|
496
|
-
<a name='L431'></a><a href='#L431'>431</a>
|
|
497
|
-
<a name='L432'></a><a href='#L432'>432</a>
|
|
498
|
-
<a name='L433'></a><a href='#L433'>433</a>
|
|
499
|
-
<a name='L434'></a><a href='#L434'>434</a>
|
|
500
|
-
<a name='L435'></a><a href='#L435'>435</a>
|
|
501
|
-
<a name='L436'></a><a href='#L436'>436</a>
|
|
502
|
-
<a name='L437'></a><a href='#L437'>437</a>
|
|
503
|
-
<a name='L438'></a><a href='#L438'>438</a>
|
|
504
|
-
<a name='L439'></a><a href='#L439'>439</a>
|
|
505
|
-
<a name='L440'></a><a href='#L440'>440</a>
|
|
506
|
-
<a name='L441'></a><a href='#L441'>441</a>
|
|
507
|
-
<a name='L442'></a><a href='#L442'>442</a>
|
|
508
|
-
<a name='L443'></a><a href='#L443'>443</a>
|
|
509
|
-
<a name='L444'></a><a href='#L444'>444</a>
|
|
510
|
-
<a name='L445'></a><a href='#L445'>445</a>
|
|
511
|
-
<a name='L446'></a><a href='#L446'>446</a>
|
|
512
|
-
<a name='L447'></a><a href='#L447'>447</a>
|
|
513
|
-
<a name='L448'></a><a href='#L448'>448</a>
|
|
514
|
-
<a name='L449'></a><a href='#L449'>449</a>
|
|
515
|
-
<a name='L450'></a><a href='#L450'>450</a>
|
|
516
|
-
<a name='L451'></a><a href='#L451'>451</a>
|
|
517
|
-
<a name='L452'></a><a href='#L452'>452</a>
|
|
518
|
-
<a name='L453'></a><a href='#L453'>453</a>
|
|
519
|
-
<a name='L454'></a><a href='#L454'>454</a>
|
|
520
|
-
<a name='L455'></a><a href='#L455'>455</a>
|
|
521
|
-
<a name='L456'></a><a href='#L456'>456</a>
|
|
522
|
-
<a name='L457'></a><a href='#L457'>457</a>
|
|
523
|
-
<a name='L458'></a><a href='#L458'>458</a>
|
|
524
|
-
<a name='L459'></a><a href='#L459'>459</a>
|
|
525
|
-
<a name='L460'></a><a href='#L460'>460</a>
|
|
526
|
-
<a name='L461'></a><a href='#L461'>461</a>
|
|
527
|
-
<a name='L462'></a><a href='#L462'>462</a>
|
|
528
|
-
<a name='L463'></a><a href='#L463'>463</a>
|
|
529
|
-
<a name='L464'></a><a href='#L464'>464</a>
|
|
530
|
-
<a name='L465'></a><a href='#L465'>465</a>
|
|
531
|
-
<a name='L466'></a><a href='#L466'>466</a>
|
|
532
|
-
<a name='L467'></a><a href='#L467'>467</a>
|
|
533
|
-
<a name='L468'></a><a href='#L468'>468</a>
|
|
534
|
-
<a name='L469'></a><a href='#L469'>469</a>
|
|
535
|
-
<a name='L470'></a><a href='#L470'>470</a>
|
|
536
|
-
<a name='L471'></a><a href='#L471'>471</a>
|
|
537
|
-
<a name='L472'></a><a href='#L472'>472</a>
|
|
538
|
-
<a name='L473'></a><a href='#L473'>473</a>
|
|
539
|
-
<a name='L474'></a><a href='#L474'>474</a>
|
|
540
|
-
<a name='L475'></a><a href='#L475'>475</a>
|
|
541
|
-
<a name='L476'></a><a href='#L476'>476</a>
|
|
542
|
-
<a name='L477'></a><a href='#L477'>477</a>
|
|
543
|
-
<a name='L478'></a><a href='#L478'>478</a>
|
|
544
|
-
<a name='L479'></a><a href='#L479'>479</a>
|
|
545
|
-
<a name='L480'></a><a href='#L480'>480</a>
|
|
546
|
-
<a name='L481'></a><a href='#L481'>481</a>
|
|
547
|
-
<a name='L482'></a><a href='#L482'>482</a>
|
|
548
|
-
<a name='L483'></a><a href='#L483'>483</a>
|
|
549
|
-
<a name='L484'></a><a href='#L484'>484</a>
|
|
550
|
-
<a name='L485'></a><a href='#L485'>485</a>
|
|
551
|
-
<a name='L486'></a><a href='#L486'>486</a>
|
|
552
|
-
<a name='L487'></a><a href='#L487'>487</a>
|
|
553
|
-
<a name='L488'></a><a href='#L488'>488</a>
|
|
554
|
-
<a name='L489'></a><a href='#L489'>489</a>
|
|
555
|
-
<a name='L490'></a><a href='#L490'>490</a>
|
|
556
|
-
<a name='L491'></a><a href='#L491'>491</a>
|
|
557
|
-
<a name='L492'></a><a href='#L492'>492</a>
|
|
558
|
-
<a name='L493'></a><a href='#L493'>493</a>
|
|
559
|
-
<a name='L494'></a><a href='#L494'>494</a>
|
|
560
|
-
<a name='L495'></a><a href='#L495'>495</a>
|
|
561
|
-
<a name='L496'></a><a href='#L496'>496</a>
|
|
562
|
-
<a name='L497'></a><a href='#L497'>497</a>
|
|
563
|
-
<a name='L498'></a><a href='#L498'>498</a>
|
|
564
|
-
<a name='L499'></a><a href='#L499'>499</a>
|
|
565
|
-
<a name='L500'></a><a href='#L500'>500</a>
|
|
566
|
-
<a name='L501'></a><a href='#L501'>501</a>
|
|
567
|
-
<a name='L502'></a><a href='#L502'>502</a>
|
|
568
|
-
<a name='L503'></a><a href='#L503'>503</a>
|
|
569
|
-
<a name='L504'></a><a href='#L504'>504</a>
|
|
570
|
-
<a name='L505'></a><a href='#L505'>505</a>
|
|
571
|
-
<a name='L506'></a><a href='#L506'>506</a>
|
|
572
|
-
<a name='L507'></a><a href='#L507'>507</a>
|
|
573
|
-
<a name='L508'></a><a href='#L508'>508</a>
|
|
574
|
-
<a name='L509'></a><a href='#L509'>509</a>
|
|
575
|
-
<a name='L510'></a><a href='#L510'>510</a>
|
|
576
|
-
<a name='L511'></a><a href='#L511'>511</a>
|
|
577
|
-
<a name='L512'></a><a href='#L512'>512</a>
|
|
578
|
-
<a name='L513'></a><a href='#L513'>513</a>
|
|
579
|
-
<a name='L514'></a><a href='#L514'>514</a>
|
|
580
|
-
<a name='L515'></a><a href='#L515'>515</a>
|
|
581
|
-
<a name='L516'></a><a href='#L516'>516</a>
|
|
582
|
-
<a name='L517'></a><a href='#L517'>517</a>
|
|
583
|
-
<a name='L518'></a><a href='#L518'>518</a>
|
|
584
|
-
<a name='L519'></a><a href='#L519'>519</a>
|
|
585
|
-
<a name='L520'></a><a href='#L520'>520</a>
|
|
586
|
-
<a name='L521'></a><a href='#L521'>521</a>
|
|
587
|
-
<a name='L522'></a><a href='#L522'>522</a>
|
|
588
|
-
<a name='L523'></a><a href='#L523'>523</a>
|
|
589
|
-
<a name='L524'></a><a href='#L524'>524</a>
|
|
590
|
-
<a name='L525'></a><a href='#L525'>525</a>
|
|
591
|
-
<a name='L526'></a><a href='#L526'>526</a>
|
|
592
|
-
<a name='L527'></a><a href='#L527'>527</a>
|
|
593
|
-
<a name='L528'></a><a href='#L528'>528</a>
|
|
594
|
-
<a name='L529'></a><a href='#L529'>529</a>
|
|
595
|
-
<a name='L530'></a><a href='#L530'>530</a>
|
|
596
|
-
<a name='L531'></a><a href='#L531'>531</a>
|
|
597
|
-
<a name='L532'></a><a href='#L532'>532</a>
|
|
598
|
-
<a name='L533'></a><a href='#L533'>533</a>
|
|
599
|
-
<a name='L534'></a><a href='#L534'>534</a>
|
|
600
|
-
<a name='L535'></a><a href='#L535'>535</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
|
|
601
|
-
<span class="cline-any cline-neutral"> </span>
|
|
602
|
-
<span class="cline-any cline-neutral"> </span>
|
|
603
|
-
<span class="cline-any cline-neutral"> </span>
|
|
604
|
-
<span class="cline-any cline-neutral"> </span>
|
|
605
|
-
<span class="cline-any cline-neutral"> </span>
|
|
606
|
-
<span class="cline-any cline-neutral"> </span>
|
|
607
|
-
<span class="cline-any cline-neutral"> </span>
|
|
608
|
-
<span class="cline-any cline-neutral"> </span>
|
|
609
|
-
<span class="cline-any cline-neutral"> </span>
|
|
610
|
-
<span class="cline-any cline-yes">1x</span>
|
|
611
|
-
<span class="cline-any cline-neutral"> </span>
|
|
612
|
-
<span class="cline-any cline-neutral"> </span>
|
|
613
|
-
<span class="cline-any cline-neutral"> </span>
|
|
614
|
-
<span class="cline-any cline-neutral"> </span>
|
|
615
|
-
<span class="cline-any cline-neutral"> </span>
|
|
616
|
-
<span class="cline-any cline-neutral"> </span>
|
|
617
|
-
<span class="cline-any cline-yes">1x</span>
|
|
618
|
-
<span class="cline-any cline-neutral"> </span>
|
|
619
|
-
<span class="cline-any cline-no"> </span>
|
|
620
|
-
<span class="cline-any cline-neutral"> </span>
|
|
621
|
-
<span class="cline-any cline-neutral"> </span>
|
|
622
|
-
<span class="cline-any cline-neutral"> </span>
|
|
623
|
-
<span class="cline-any cline-neutral"> </span>
|
|
624
|
-
<span class="cline-any cline-neutral"> </span>
|
|
625
|
-
<span class="cline-any cline-neutral"> </span>
|
|
626
|
-
<span class="cline-any cline-neutral"> </span>
|
|
627
|
-
<span class="cline-any cline-neutral"> </span>
|
|
628
|
-
<span class="cline-any cline-neutral"> </span>
|
|
629
|
-
<span class="cline-any cline-neutral"> </span>
|
|
630
|
-
<span class="cline-any cline-no"> </span>
|
|
631
|
-
<span class="cline-any cline-neutral"> </span>
|
|
632
|
-
<span class="cline-any cline-no"> </span>
|
|
633
|
-
<span class="cline-any cline-neutral"> </span>
|
|
634
|
-
<span class="cline-any cline-neutral"> </span>
|
|
635
|
-
<span class="cline-any cline-neutral"> </span>
|
|
636
|
-
<span class="cline-any cline-neutral"> </span>
|
|
637
|
-
<span class="cline-any cline-neutral"> </span>
|
|
638
|
-
<span class="cline-any cline-neutral"> </span>
|
|
639
|
-
<span class="cline-any cline-no"> </span>
|
|
640
|
-
<span class="cline-any cline-no"> </span>
|
|
641
|
-
<span class="cline-any cline-no"> </span>
|
|
642
|
-
<span class="cline-any cline-no"> </span>
|
|
643
|
-
<span class="cline-any cline-no"> </span>
|
|
644
|
-
<span class="cline-any cline-no"> </span>
|
|
645
|
-
<span class="cline-any cline-neutral"> </span>
|
|
646
|
-
<span class="cline-any cline-neutral"> </span>
|
|
647
|
-
<span class="cline-any cline-no"> </span>
|
|
648
|
-
<span class="cline-any cline-no"> </span>
|
|
649
|
-
<span class="cline-any cline-no"> </span>
|
|
650
|
-
<span class="cline-any cline-no"> </span>
|
|
651
|
-
<span class="cline-any cline-no"> </span>
|
|
652
|
-
<span class="cline-any cline-neutral"> </span>
|
|
653
|
-
<span class="cline-any cline-no"> </span>
|
|
654
|
-
<span class="cline-any cline-no"> </span>
|
|
655
|
-
<span class="cline-any cline-no"> </span>
|
|
656
|
-
<span class="cline-any cline-no"> </span>
|
|
657
|
-
<span class="cline-any cline-no"> </span>
|
|
658
|
-
<span class="cline-any cline-no"> </span>
|
|
659
|
-
<span class="cline-any cline-neutral"> </span>
|
|
660
|
-
<span class="cline-any cline-no"> </span>
|
|
661
|
-
<span class="cline-any cline-neutral"> </span>
|
|
662
|
-
<span class="cline-any cline-neutral"> </span>
|
|
663
|
-
<span class="cline-any cline-no"> </span>
|
|
664
|
-
<span class="cline-any cline-neutral"> </span>
|
|
665
|
-
<span class="cline-any cline-no"> </span>
|
|
666
|
-
<span class="cline-any cline-neutral"> </span>
|
|
667
|
-
<span class="cline-any cline-neutral"> </span>
|
|
668
|
-
<span class="cline-any cline-no"> </span>
|
|
669
|
-
<span class="cline-any cline-no"> </span>
|
|
670
|
-
<span class="cline-any cline-no"> </span>
|
|
671
|
-
<span class="cline-any cline-no"> </span>
|
|
672
|
-
<span class="cline-any cline-no"> </span>
|
|
673
|
-
<span class="cline-any cline-no"> </span>
|
|
674
|
-
<span class="cline-any cline-no"> </span>
|
|
675
|
-
<span class="cline-any cline-no"> </span>
|
|
676
|
-
<span class="cline-any cline-no"> </span>
|
|
677
|
-
<span class="cline-any cline-no"> </span>
|
|
678
|
-
<span class="cline-any cline-no"> </span>
|
|
679
|
-
<span class="cline-any cline-no"> </span>
|
|
680
|
-
<span class="cline-any cline-neutral"> </span>
|
|
681
|
-
<span class="cline-any cline-no"> </span>
|
|
682
|
-
<span class="cline-any cline-no"> </span>
|
|
683
|
-
<span class="cline-any cline-no"> </span>
|
|
684
|
-
<span class="cline-any cline-neutral"> </span>
|
|
685
|
-
<span class="cline-any cline-no"> </span>
|
|
686
|
-
<span class="cline-any cline-no"> </span>
|
|
687
|
-
<span class="cline-any cline-no"> </span>
|
|
688
|
-
<span class="cline-any cline-neutral"> </span>
|
|
689
|
-
<span class="cline-any cline-no"> </span>
|
|
690
|
-
<span class="cline-any cline-no"> </span>
|
|
691
|
-
<span class="cline-any cline-no"> </span>
|
|
692
|
-
<span class="cline-any cline-no"> </span>
|
|
693
|
-
<span class="cline-any cline-no"> </span>
|
|
694
|
-
<span class="cline-any cline-neutral"> </span>
|
|
695
|
-
<span class="cline-any cline-no"> </span>
|
|
696
|
-
<span class="cline-any cline-no"> </span>
|
|
697
|
-
<span class="cline-any cline-no"> </span>
|
|
698
|
-
<span class="cline-any cline-neutral"> </span>
|
|
699
|
-
<span class="cline-any cline-no"> </span>
|
|
700
|
-
<span class="cline-any cline-no"> </span>
|
|
701
|
-
<span class="cline-any cline-no"> </span>
|
|
702
|
-
<span class="cline-any cline-no"> </span>
|
|
703
|
-
<span class="cline-any cline-no"> </span>
|
|
704
|
-
<span class="cline-any cline-no"> </span>
|
|
705
|
-
<span class="cline-any cline-no"> </span>
|
|
706
|
-
<span class="cline-any cline-neutral"> </span>
|
|
707
|
-
<span class="cline-any cline-no"> </span>
|
|
708
|
-
<span class="cline-any cline-no"> </span>
|
|
709
|
-
<span class="cline-any cline-no"> </span>
|
|
710
|
-
<span class="cline-any cline-no"> </span>
|
|
711
|
-
<span class="cline-any cline-no"> </span>
|
|
712
|
-
<span class="cline-any cline-no"> </span>
|
|
713
|
-
<span class="cline-any cline-no"> </span>
|
|
714
|
-
<span class="cline-any cline-neutral"> </span>
|
|
715
|
-
<span class="cline-any cline-no"> </span>
|
|
716
|
-
<span class="cline-any cline-no"> </span>
|
|
717
|
-
<span class="cline-any cline-no"> </span>
|
|
718
|
-
<span class="cline-any cline-no"> </span>
|
|
719
|
-
<span class="cline-any cline-no"> </span>
|
|
720
|
-
<span class="cline-any cline-no"> </span>
|
|
721
|
-
<span class="cline-any cline-no"> </span>
|
|
722
|
-
<span class="cline-any cline-no"> </span>
|
|
723
|
-
<span class="cline-any cline-neutral"> </span>
|
|
724
|
-
<span class="cline-any cline-neutral"> </span>
|
|
725
|
-
<span class="cline-any cline-neutral"> </span>
|
|
726
|
-
<span class="cline-any cline-no"> </span>
|
|
727
|
-
<span class="cline-any cline-no"> </span>
|
|
728
|
-
<span class="cline-any cline-no"> </span>
|
|
729
|
-
<span class="cline-any cline-no"> </span>
|
|
730
|
-
<span class="cline-any cline-no"> </span>
|
|
731
|
-
<span class="cline-any cline-no"> </span>
|
|
732
|
-
<span class="cline-any cline-no"> </span>
|
|
733
|
-
<span class="cline-any cline-no"> </span>
|
|
734
|
-
<span class="cline-any cline-no"> </span>
|
|
735
|
-
<span class="cline-any cline-no"> </span>
|
|
736
|
-
<span class="cline-any cline-no"> </span>
|
|
737
|
-
<span class="cline-any cline-neutral"> </span>
|
|
738
|
-
<span class="cline-any cline-no"> </span>
|
|
739
|
-
<span class="cline-any cline-no"> </span>
|
|
740
|
-
<span class="cline-any cline-no"> </span>
|
|
741
|
-
<span class="cline-any cline-no"> </span>
|
|
742
|
-
<span class="cline-any cline-neutral"> </span>
|
|
743
|
-
<span class="cline-any cline-no"> </span>
|
|
744
|
-
<span class="cline-any cline-no"> </span>
|
|
745
|
-
<span class="cline-any cline-no"> </span>
|
|
746
|
-
<span class="cline-any cline-no"> </span>
|
|
747
|
-
<span class="cline-any cline-no"> </span>
|
|
748
|
-
<span class="cline-any cline-no"> </span>
|
|
749
|
-
<span class="cline-any cline-neutral"> </span>
|
|
750
|
-
<span class="cline-any cline-neutral"> </span>
|
|
751
|
-
<span class="cline-any cline-neutral"> </span>
|
|
752
|
-
<span class="cline-any cline-neutral"> </span>
|
|
753
|
-
<span class="cline-any cline-neutral"> </span>
|
|
754
|
-
<span class="cline-any cline-neutral"> </span>
|
|
755
|
-
<span class="cline-any cline-neutral"> </span>
|
|
756
|
-
<span class="cline-any cline-neutral"> </span>
|
|
757
|
-
<span class="cline-any cline-neutral"> </span>
|
|
758
|
-
<span class="cline-any cline-neutral"> </span>
|
|
759
|
-
<span class="cline-any cline-no"> </span>
|
|
760
|
-
<span class="cline-any cline-no"> </span>
|
|
761
|
-
<span class="cline-any cline-no"> </span>
|
|
762
|
-
<span class="cline-any cline-no"> </span>
|
|
763
|
-
<span class="cline-any cline-no"> </span>
|
|
764
|
-
<span class="cline-any cline-no"> </span>
|
|
765
|
-
<span class="cline-any cline-no"> </span>
|
|
766
|
-
<span class="cline-any cline-no"> </span>
|
|
767
|
-
<span class="cline-any cline-no"> </span>
|
|
768
|
-
<span class="cline-any cline-no"> </span>
|
|
769
|
-
<span class="cline-any cline-no"> </span>
|
|
770
|
-
<span class="cline-any cline-no"> </span>
|
|
771
|
-
<span class="cline-any cline-no"> </span>
|
|
772
|
-
<span class="cline-any cline-neutral"> </span>
|
|
773
|
-
<span class="cline-any cline-no"> </span>
|
|
774
|
-
<span class="cline-any cline-no"> </span>
|
|
775
|
-
<span class="cline-any cline-no"> </span>
|
|
776
|
-
<span class="cline-any cline-no"> </span>
|
|
777
|
-
<span class="cline-any cline-no"> </span>
|
|
778
|
-
<span class="cline-any cline-no"> </span>
|
|
779
|
-
<span class="cline-any cline-no"> </span>
|
|
780
|
-
<span class="cline-any cline-no"> </span>
|
|
781
|
-
<span class="cline-any cline-no"> </span>
|
|
782
|
-
<span class="cline-any cline-no"> </span>
|
|
783
|
-
<span class="cline-any cline-no"> </span>
|
|
784
|
-
<span class="cline-any cline-no"> </span>
|
|
785
|
-
<span class="cline-any cline-no"> </span>
|
|
786
|
-
<span class="cline-any cline-neutral"> </span>
|
|
787
|
-
<span class="cline-any cline-no"> </span>
|
|
788
|
-
<span class="cline-any cline-no"> </span>
|
|
789
|
-
<span class="cline-any cline-no"> </span>
|
|
790
|
-
<span class="cline-any cline-no"> </span>
|
|
791
|
-
<span class="cline-any cline-no"> </span>
|
|
792
|
-
<span class="cline-any cline-no"> </span>
|
|
793
|
-
<span class="cline-any cline-no"> </span>
|
|
794
|
-
<span class="cline-any cline-neutral"> </span>
|
|
795
|
-
<span class="cline-any cline-neutral"> </span>
|
|
796
|
-
<span class="cline-any cline-no"> </span>
|
|
797
|
-
<span class="cline-any cline-no"> </span>
|
|
798
|
-
<span class="cline-any cline-neutral"> </span>
|
|
799
|
-
<span class="cline-any cline-no"> </span>
|
|
800
|
-
<span class="cline-any cline-no"> </span>
|
|
801
|
-
<span class="cline-any cline-neutral"> </span>
|
|
802
|
-
<span class="cline-any cline-no"> </span>
|
|
803
|
-
<span class="cline-any cline-no"> </span>
|
|
804
|
-
<span class="cline-any cline-no"> </span>
|
|
805
|
-
<span class="cline-any cline-no"> </span>
|
|
806
|
-
<span class="cline-any cline-no"> </span>
|
|
807
|
-
<span class="cline-any cline-no"> </span>
|
|
808
|
-
<span class="cline-any cline-no"> </span>
|
|
809
|
-
<span class="cline-any cline-no"> </span>
|
|
810
|
-
<span class="cline-any cline-no"> </span>
|
|
811
|
-
<span class="cline-any cline-no"> </span>
|
|
812
|
-
<span class="cline-any cline-no"> </span>
|
|
813
|
-
<span class="cline-any cline-no"> </span>
|
|
814
|
-
<span class="cline-any cline-neutral"> </span>
|
|
815
|
-
<span class="cline-any cline-no"> </span>
|
|
816
|
-
<span class="cline-any cline-no"> </span>
|
|
817
|
-
<span class="cline-any cline-no"> </span>
|
|
818
|
-
<span class="cline-any cline-no"> </span>
|
|
819
|
-
<span class="cline-any cline-neutral"> </span>
|
|
820
|
-
<span class="cline-any cline-no"> </span>
|
|
821
|
-
<span class="cline-any cline-no"> </span>
|
|
822
|
-
<span class="cline-any cline-no"> </span>
|
|
823
|
-
<span class="cline-any cline-no"> </span>
|
|
824
|
-
<span class="cline-any cline-no"> </span>
|
|
825
|
-
<span class="cline-any cline-no"> </span>
|
|
826
|
-
<span class="cline-any cline-no"> </span>
|
|
827
|
-
<span class="cline-any cline-no"> </span>
|
|
828
|
-
<span class="cline-any cline-neutral"> </span>
|
|
829
|
-
<span class="cline-any cline-no"> </span>
|
|
830
|
-
<span class="cline-any cline-no"> </span>
|
|
831
|
-
<span class="cline-any cline-no"> </span>
|
|
832
|
-
<span class="cline-any cline-no"> </span>
|
|
833
|
-
<span class="cline-any cline-no"> </span>
|
|
834
|
-
<span class="cline-any cline-no"> </span>
|
|
835
|
-
<span class="cline-any cline-no"> </span>
|
|
836
|
-
<span class="cline-any cline-neutral"> </span>
|
|
837
|
-
<span class="cline-any cline-no"> </span>
|
|
838
|
-
<span class="cline-any cline-no"> </span>
|
|
839
|
-
<span class="cline-any cline-no"> </span>
|
|
840
|
-
<span class="cline-any cline-no"> </span>
|
|
841
|
-
<span class="cline-any cline-no"> </span>
|
|
842
|
-
<span class="cline-any cline-neutral"> </span>
|
|
843
|
-
<span class="cline-any cline-no"> </span>
|
|
844
|
-
<span class="cline-any cline-no"> </span>
|
|
845
|
-
<span class="cline-any cline-no"> </span>
|
|
846
|
-
<span class="cline-any cline-no"> </span>
|
|
847
|
-
<span class="cline-any cline-no"> </span>
|
|
848
|
-
<span class="cline-any cline-neutral"> </span>
|
|
849
|
-
<span class="cline-any cline-no"> </span>
|
|
850
|
-
<span class="cline-any cline-no"> </span>
|
|
851
|
-
<span class="cline-any cline-no"> </span>
|
|
852
|
-
<span class="cline-any cline-no"> </span>
|
|
853
|
-
<span class="cline-any cline-no"> </span>
|
|
854
|
-
<span class="cline-any cline-neutral"> </span>
|
|
855
|
-
<span class="cline-any cline-no"> </span>
|
|
856
|
-
<span class="cline-any cline-no"> </span>
|
|
857
|
-
<span class="cline-any cline-no"> </span>
|
|
858
|
-
<span class="cline-any cline-no"> </span>
|
|
859
|
-
<span class="cline-any cline-no"> </span>
|
|
860
|
-
<span class="cline-any cline-no"> </span>
|
|
861
|
-
<span class="cline-any cline-no"> </span>
|
|
862
|
-
<span class="cline-any cline-neutral"> </span>
|
|
863
|
-
<span class="cline-any cline-no"> </span>
|
|
864
|
-
<span class="cline-any cline-no"> </span>
|
|
865
|
-
<span class="cline-any cline-no"> </span>
|
|
866
|
-
<span class="cline-any cline-no"> </span>
|
|
867
|
-
<span class="cline-any cline-no"> </span>
|
|
868
|
-
<span class="cline-any cline-no"> </span>
|
|
869
|
-
<span class="cline-any cline-no"> </span>
|
|
870
|
-
<span class="cline-any cline-no"> </span>
|
|
871
|
-
<span class="cline-any cline-no"> </span>
|
|
872
|
-
<span class="cline-any cline-no"> </span>
|
|
873
|
-
<span class="cline-any cline-no"> </span>
|
|
874
|
-
<span class="cline-any cline-no"> </span>
|
|
875
|
-
<span class="cline-any cline-no"> </span>
|
|
876
|
-
<span class="cline-any cline-no"> </span>
|
|
877
|
-
<span class="cline-any cline-neutral"> </span>
|
|
878
|
-
<span class="cline-any cline-no"> </span>
|
|
879
|
-
<span class="cline-any cline-no"> </span>
|
|
880
|
-
<span class="cline-any cline-no"> </span>
|
|
881
|
-
<span class="cline-any cline-no"> </span>
|
|
882
|
-
<span class="cline-any cline-no"> </span>
|
|
883
|
-
<span class="cline-any cline-no"> </span>
|
|
884
|
-
<span class="cline-any cline-no"> </span>
|
|
885
|
-
<span class="cline-any cline-no"> </span>
|
|
886
|
-
<span class="cline-any cline-no"> </span>
|
|
887
|
-
<span class="cline-any cline-no"> </span>
|
|
888
|
-
<span class="cline-any cline-no"> </span>
|
|
889
|
-
<span class="cline-any cline-no"> </span>
|
|
890
|
-
<span class="cline-any cline-no"> </span>
|
|
891
|
-
<span class="cline-any cline-no"> </span>
|
|
892
|
-
<span class="cline-any cline-neutral"> </span>
|
|
893
|
-
<span class="cline-any cline-no"> </span>
|
|
894
|
-
<span class="cline-any cline-no"> </span>
|
|
895
|
-
<span class="cline-any cline-no"> </span>
|
|
896
|
-
<span class="cline-any cline-no"> </span>
|
|
897
|
-
<span class="cline-any cline-no"> </span>
|
|
898
|
-
<span class="cline-any cline-no"> </span>
|
|
899
|
-
<span class="cline-any cline-no"> </span>
|
|
900
|
-
<span class="cline-any cline-no"> </span>
|
|
901
|
-
<span class="cline-any cline-no"> </span>
|
|
902
|
-
<span class="cline-any cline-no"> </span>
|
|
903
|
-
<span class="cline-any cline-no"> </span>
|
|
904
|
-
<span class="cline-any cline-no"> </span>
|
|
905
|
-
<span class="cline-any cline-no"> </span>
|
|
906
|
-
<span class="cline-any cline-no"> </span>
|
|
907
|
-
<span class="cline-any cline-no"> </span>
|
|
908
|
-
<span class="cline-any cline-no"> </span>
|
|
909
|
-
<span class="cline-any cline-no"> </span>
|
|
910
|
-
<span class="cline-any cline-no"> </span>
|
|
911
|
-
<span class="cline-any cline-no"> </span>
|
|
912
|
-
<span class="cline-any cline-neutral"> </span>
|
|
913
|
-
<span class="cline-any cline-no"> </span>
|
|
914
|
-
<span class="cline-any cline-no"> </span>
|
|
915
|
-
<span class="cline-any cline-no"> </span>
|
|
916
|
-
<span class="cline-any cline-no"> </span>
|
|
917
|
-
<span class="cline-any cline-no"> </span>
|
|
918
|
-
<span class="cline-any cline-no"> </span>
|
|
919
|
-
<span class="cline-any cline-no"> </span>
|
|
920
|
-
<span class="cline-any cline-no"> </span>
|
|
921
|
-
<span class="cline-any cline-no"> </span>
|
|
922
|
-
<span class="cline-any cline-no"> </span>
|
|
923
|
-
<span class="cline-any cline-no"> </span>
|
|
924
|
-
<span class="cline-any cline-no"> </span>
|
|
925
|
-
<span class="cline-any cline-no"> </span>
|
|
926
|
-
<span class="cline-any cline-no"> </span>
|
|
927
|
-
<span class="cline-any cline-no"> </span>
|
|
928
|
-
<span class="cline-any cline-no"> </span>
|
|
929
|
-
<span class="cline-any cline-no"> </span>
|
|
930
|
-
<span class="cline-any cline-no"> </span>
|
|
931
|
-
<span class="cline-any cline-no"> </span>
|
|
932
|
-
<span class="cline-any cline-no"> </span>
|
|
933
|
-
<span class="cline-any cline-no"> </span>
|
|
934
|
-
<span class="cline-any cline-no"> </span>
|
|
935
|
-
<span class="cline-any cline-no"> </span>
|
|
936
|
-
<span class="cline-any cline-no"> </span>
|
|
937
|
-
<span class="cline-any cline-neutral"> </span>
|
|
938
|
-
<span class="cline-any cline-no"> </span>
|
|
939
|
-
<span class="cline-any cline-no"> </span>
|
|
940
|
-
<span class="cline-any cline-no"> </span>
|
|
941
|
-
<span class="cline-any cline-no"> </span>
|
|
942
|
-
<span class="cline-any cline-no"> </span>
|
|
943
|
-
<span class="cline-any cline-neutral"> </span>
|
|
944
|
-
<span class="cline-any cline-no"> </span>
|
|
945
|
-
<span class="cline-any cline-no"> </span>
|
|
946
|
-
<span class="cline-any cline-no"> </span>
|
|
947
|
-
<span class="cline-any cline-no"> </span>
|
|
948
|
-
<span class="cline-any cline-neutral"> </span>
|
|
949
|
-
<span class="cline-any cline-no"> </span>
|
|
950
|
-
<span class="cline-any cline-no"> </span>
|
|
951
|
-
<span class="cline-any cline-no"> </span>
|
|
952
|
-
<span class="cline-any cline-no"> </span>
|
|
953
|
-
<span class="cline-any cline-no"> </span>
|
|
954
|
-
<span class="cline-any cline-neutral"> </span>
|
|
955
|
-
<span class="cline-any cline-no"> </span>
|
|
956
|
-
<span class="cline-any cline-no"> </span>
|
|
957
|
-
<span class="cline-any cline-no"> </span>
|
|
958
|
-
<span class="cline-any cline-no"> </span>
|
|
959
|
-
<span class="cline-any cline-neutral"> </span>
|
|
960
|
-
<span class="cline-any cline-no"> </span>
|
|
961
|
-
<span class="cline-any cline-no"> </span>
|
|
962
|
-
<span class="cline-any cline-no"> </span>
|
|
963
|
-
<span class="cline-any cline-no"> </span>
|
|
964
|
-
<span class="cline-any cline-no"> </span>
|
|
965
|
-
<span class="cline-any cline-no"> </span>
|
|
966
|
-
<span class="cline-any cline-no"> </span>
|
|
967
|
-
<span class="cline-any cline-no"> </span>
|
|
968
|
-
<span class="cline-any cline-no"> </span>
|
|
969
|
-
<span class="cline-any cline-neutral"> </span>
|
|
970
|
-
<span class="cline-any cline-no"> </span>
|
|
971
|
-
<span class="cline-any cline-no"> </span>
|
|
972
|
-
<span class="cline-any cline-no"> </span>
|
|
973
|
-
<span class="cline-any cline-no"> </span>
|
|
974
|
-
<span class="cline-any cline-no"> </span>
|
|
975
|
-
<span class="cline-any cline-no"> </span>
|
|
976
|
-
<span class="cline-any cline-no"> </span>
|
|
977
|
-
<span class="cline-any cline-no"> </span>
|
|
978
|
-
<span class="cline-any cline-no"> </span>
|
|
979
|
-
<span class="cline-any cline-no"> </span>
|
|
980
|
-
<span class="cline-any cline-neutral"> </span>
|
|
981
|
-
<span class="cline-any cline-no"> </span>
|
|
982
|
-
<span class="cline-any cline-no"> </span>
|
|
983
|
-
<span class="cline-any cline-neutral"> </span>
|
|
984
|
-
<span class="cline-any cline-no"> </span>
|
|
985
|
-
<span class="cline-any cline-no"> </span>
|
|
986
|
-
<span class="cline-any cline-no"> </span>
|
|
987
|
-
<span class="cline-any cline-no"> </span>
|
|
988
|
-
<span class="cline-any cline-no"> </span>
|
|
989
|
-
<span class="cline-any cline-no"> </span>
|
|
990
|
-
<span class="cline-any cline-no"> </span>
|
|
991
|
-
<span class="cline-any cline-no"> </span>
|
|
992
|
-
<span class="cline-any cline-no"> </span>
|
|
993
|
-
<span class="cline-any cline-no"> </span>
|
|
994
|
-
<span class="cline-any cline-no"> </span>
|
|
995
|
-
<span class="cline-any cline-no"> </span>
|
|
996
|
-
<span class="cline-any cline-no"> </span>
|
|
997
|
-
<span class="cline-any cline-neutral"> </span>
|
|
998
|
-
<span class="cline-any cline-no"> </span>
|
|
999
|
-
<span class="cline-any cline-no"> </span>
|
|
1000
|
-
<span class="cline-any cline-no"> </span>
|
|
1001
|
-
<span class="cline-any cline-no"> </span>
|
|
1002
|
-
<span class="cline-any cline-no"> </span>
|
|
1003
|
-
<span class="cline-any cline-no"> </span>
|
|
1004
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1005
|
-
<span class="cline-any cline-no"> </span>
|
|
1006
|
-
<span class="cline-any cline-no"> </span>
|
|
1007
|
-
<span class="cline-any cline-no"> </span>
|
|
1008
|
-
<span class="cline-any cline-no"> </span>
|
|
1009
|
-
<span class="cline-any cline-no"> </span>
|
|
1010
|
-
<span class="cline-any cline-no"> </span>
|
|
1011
|
-
<span class="cline-any cline-no"> </span>
|
|
1012
|
-
<span class="cline-any cline-no"> </span>
|
|
1013
|
-
<span class="cline-any cline-no"> </span>
|
|
1014
|
-
<span class="cline-any cline-no"> </span>
|
|
1015
|
-
<span class="cline-any cline-no"> </span>
|
|
1016
|
-
<span class="cline-any cline-no"> </span>
|
|
1017
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1018
|
-
<span class="cline-any cline-no"> </span>
|
|
1019
|
-
<span class="cline-any cline-no"> </span>
|
|
1020
|
-
<span class="cline-any cline-no"> </span>
|
|
1021
|
-
<span class="cline-any cline-no"> </span>
|
|
1022
|
-
<span class="cline-any cline-no"> </span>
|
|
1023
|
-
<span class="cline-any cline-no"> </span>
|
|
1024
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1025
|
-
<span class="cline-any cline-no"> </span>
|
|
1026
|
-
<span class="cline-any cline-no"> </span>
|
|
1027
|
-
<span class="cline-any cline-no"> </span>
|
|
1028
|
-
<span class="cline-any cline-no"> </span>
|
|
1029
|
-
<span class="cline-any cline-no"> </span>
|
|
1030
|
-
<span class="cline-any cline-no"> </span>
|
|
1031
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1032
|
-
<span class="cline-any cline-no"> </span>
|
|
1033
|
-
<span class="cline-any cline-no"> </span>
|
|
1034
|
-
<span class="cline-any cline-no"> </span>
|
|
1035
|
-
<span class="cline-any cline-no"> </span>
|
|
1036
|
-
<span class="cline-any cline-no"> </span>
|
|
1037
|
-
<span class="cline-any cline-no"> </span>
|
|
1038
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1039
|
-
<span class="cline-any cline-no"> </span>
|
|
1040
|
-
<span class="cline-any cline-no"> </span>
|
|
1041
|
-
<span class="cline-any cline-no"> </span>
|
|
1042
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1043
|
-
<span class="cline-any cline-no"> </span>
|
|
1044
|
-
<span class="cline-any cline-no"> </span>
|
|
1045
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1046
|
-
<span class="cline-any cline-no"> </span>
|
|
1047
|
-
<span class="cline-any cline-no"> </span>
|
|
1048
|
-
<span class="cline-any cline-no"> </span>
|
|
1049
|
-
<span class="cline-any cline-no"> </span>
|
|
1050
|
-
<span class="cline-any cline-no"> </span>
|
|
1051
|
-
<span class="cline-any cline-no"> </span>
|
|
1052
|
-
<span class="cline-any cline-no"> </span>
|
|
1053
|
-
<span class="cline-any cline-no"> </span>
|
|
1054
|
-
<span class="cline-any cline-no"> </span>
|
|
1055
|
-
<span class="cline-any cline-no"> </span>
|
|
1056
|
-
<span class="cline-any cline-no"> </span>
|
|
1057
|
-
<span class="cline-any cline-no"> </span>
|
|
1058
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1059
|
-
<span class="cline-any cline-no"> </span>
|
|
1060
|
-
<span class="cline-any cline-no"> </span>
|
|
1061
|
-
<span class="cline-any cline-no"> </span>
|
|
1062
|
-
<span class="cline-any cline-no"> </span>
|
|
1063
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1064
|
-
<span class="cline-any cline-no"> </span>
|
|
1065
|
-
<span class="cline-any cline-no"> </span>
|
|
1066
|
-
<span class="cline-any cline-no"> </span>
|
|
1067
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1068
|
-
<span class="cline-any cline-no"> </span>
|
|
1069
|
-
<span class="cline-any cline-no"> </span>
|
|
1070
|
-
<span class="cline-any cline-no"> </span>
|
|
1071
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1072
|
-
<span class="cline-any cline-no"> </span>
|
|
1073
|
-
<span class="cline-any cline-no"> </span>
|
|
1074
|
-
<span class="cline-any cline-no"> </span>
|
|
1075
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1076
|
-
<span class="cline-any cline-no"> </span>
|
|
1077
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1078
|
-
<span class="cline-any cline-no"> </span>
|
|
1079
|
-
<span class="cline-any cline-no"> </span>
|
|
1080
|
-
<span class="cline-any cline-no"> </span>
|
|
1081
|
-
<span class="cline-any cline-no"> </span>
|
|
1082
|
-
<span class="cline-any cline-no"> </span>
|
|
1083
|
-
<span class="cline-any cline-no"> </span>
|
|
1084
|
-
<span class="cline-any cline-no"> </span>
|
|
1085
|
-
<span class="cline-any cline-no"> </span>
|
|
1086
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1087
|
-
<span class="cline-any cline-no"> </span>
|
|
1088
|
-
<span class="cline-any cline-no"> </span>
|
|
1089
|
-
<span class="cline-any cline-no"> </span>
|
|
1090
|
-
<span class="cline-any cline-no"> </span>
|
|
1091
|
-
<span class="cline-any cline-no"> </span>
|
|
1092
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1093
|
-
<span class="cline-any cline-no"> </span>
|
|
1094
|
-
<span class="cline-any cline-no"> </span>
|
|
1095
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1096
|
-
<span class="cline-any cline-no"> </span>
|
|
1097
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1098
|
-
<span class="cline-any cline-no"> </span>
|
|
1099
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1100
|
-
<span class="cline-any cline-no"> </span>
|
|
1101
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1102
|
-
<span class="cline-any cline-no"> </span>
|
|
1103
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1104
|
-
<span class="cline-any cline-no"> </span>
|
|
1105
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1106
|
-
<span class="cline-any cline-no"> </span>
|
|
1107
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1108
|
-
<span class="cline-any cline-no"> </span>
|
|
1109
|
-
<span class="cline-any cline-no"> </span>
|
|
1110
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1111
|
-
<span class="cline-any cline-no"> </span>
|
|
1112
|
-
<span class="cline-any cline-no"> </span>
|
|
1113
|
-
<span class="cline-any cline-no"> </span>
|
|
1114
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1115
|
-
<span class="cline-any cline-no"> </span>
|
|
1116
|
-
<span class="cline-any cline-no"> </span>
|
|
1117
|
-
<span class="cline-any cline-no"> </span>
|
|
1118
|
-
<span class="cline-any cline-no"> </span>
|
|
1119
|
-
<span class="cline-any cline-no"> </span>
|
|
1120
|
-
<span class="cline-any cline-no"> </span>
|
|
1121
|
-
<span class="cline-any cline-no"> </span>
|
|
1122
|
-
<span class="cline-any cline-no"> </span>
|
|
1123
|
-
<span class="cline-any cline-no"> </span>
|
|
1124
|
-
<span class="cline-any cline-no"> </span>
|
|
1125
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1126
|
-
<span class="cline-any cline-no"> </span>
|
|
1127
|
-
<span class="cline-any cline-no"> </span>
|
|
1128
|
-
<span class="cline-any cline-no"> </span>
|
|
1129
|
-
<span class="cline-any cline-no"> </span>
|
|
1130
|
-
<span class="cline-any cline-no"> </span>
|
|
1131
|
-
<span class="cline-any cline-no"> </span>
|
|
1132
|
-
<span class="cline-any cline-no"> </span>
|
|
1133
|
-
<span class="cline-any cline-no"> </span>
|
|
1134
|
-
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/* Copyright(C) 2021-2024, donavanbecker (https://github.com/donavanbecker). All rights reserved.
|
|
1135
|
-
*
|
|
1136
|
-
* airconditioners.ts: @switchbot/homebridge-switchbot.
|
|
1137
|
-
*/
|
|
1138
|
-
import type { CharacteristicValue, PlatformAccessory, Service } from 'homebridge'
|
|
1139
|
-
import type { bodyChange, irdevice } from 'node-switchbot'
|
|
1140
|
-
|
|
1141
|
-
import type { SwitchBotPlatform } from '../platform.js'
|
|
1142
|
-
import type { irAirConfig, irDevicesConfig } from '../settings.js'
|
|
1143
|
-
|
|
1144
|
-
import { irdeviceBase } from './irdevice.js'
|
|
1145
|
-
|
|
1146
|
-
/**
|
|
1147
|
-
* Platform Accessory
|
|
1148
|
-
* An instance of this class is created for each accessory your platform registers
|
|
1149
|
-
* Each accessory may expose multiple services of different service types.
|
|
1150
|
-
*/
|
|
1151
|
-
export <span class="fstat-no" title="function not covered" ><span class="branch-0 cbranch-no" title="branch not covered" >class AirConditioner extends irdeviceBase {</span></span>
|
|
1152
|
-
// Services
|
|
1153
|
-
<span class="cstat-no" title="statement not covered" > private HeaterCooler: {</span>
|
|
1154
|
-
Name: CharacteristicValue
|
|
1155
|
-
Service: Service
|
|
1156
|
-
Active: CharacteristicValue
|
|
1157
|
-
CurrentHeaterCoolerState: CharacteristicValue
|
|
1158
|
-
TargetHeaterCoolerState: CharacteristicValue
|
|
1159
|
-
CurrentTemperature: CharacteristicValue
|
|
1160
|
-
ThresholdTemperature: CharacteristicValue
|
|
1161
|
-
RotationSpeed: CharacteristicValue
|
|
1162
|
-
}
|
|
1163
|
-
|
|
1164
|
-
<span class="cstat-no" title="statement not covered" > meter?: PlatformAccessory</span>
|
|
1165
|
-
|
|
1166
|
-
<span class="cstat-no" title="statement not covered" > private HumiditySensor?: {</span>
|
|
1167
|
-
Name: CharacteristicValue
|
|
1168
|
-
Service: Service
|
|
1169
|
-
CurrentRelativeHumidity: CharacteristicValue
|
|
1170
|
-
}
|
|
1171
|
-
|
|
1172
|
-
// Others
|
|
1173
|
-
<span class="cstat-no" title="statement not covered" > state!: string</span>
|
|
1174
|
-
<span class="cstat-no" title="statement not covered" > Busy: any</span>
|
|
1175
|
-
<span class="cstat-no" title="statement not covered" > Timeout: any = null</span>
|
|
1176
|
-
<span class="cstat-no" title="statement not covered" > CurrentMode!: number</span>
|
|
1177
|
-
<span class="cstat-no" title="statement not covered" > ValidValues: number[]</span>
|
|
1178
|
-
<span class="cstat-no" title="statement not covered" > CurrentFanSpeed!: number</span>
|
|
1179
|
-
|
|
1180
|
-
// Config
|
|
1181
|
-
<span class="cstat-no" title="statement not covered" > hide_automode?: boolean</span>
|
|
1182
|
-
<span class="cstat-no" title="statement not covered" > set_max_heat?: number</span>
|
|
1183
|
-
<span class="cstat-no" title="statement not covered" > set_min_heat?: number</span>
|
|
1184
|
-
<span class="cstat-no" title="statement not covered" > set_max_cool?: number</span>
|
|
1185
|
-
<span class="cstat-no" title="statement not covered" > set_min_cool?: number</span>
|
|
1186
|
-
|
|
1187
|
-
<span class="cstat-no" title="statement not covered" > constructor(</span>
|
|
1188
|
-
<span class="cstat-no" title="statement not covered" > readonly platform: SwitchBotPlatform,</span>
|
|
1189
|
-
<span class="cstat-no" title="statement not covered" > accessory: PlatformAccessory,</span>
|
|
1190
|
-
<span class="cstat-no" title="statement not covered" > device: irdevice & irDevicesConfig,</span>
|
|
1191
|
-
<span class="cstat-no" title="statement not covered" > ) {</span>
|
|
1192
|
-
<span class="cstat-no" title="statement not covered" > super(platform, accessory, device)</span>
|
|
1193
|
-
// Set category
|
|
1194
|
-
<span class="cstat-no" title="statement not covered" > accessory.category = this.hap.Categories.AIR_CONDITIONER</span>
|
|
1195
|
-
|
|
1196
|
-
// default placeholders
|
|
1197
|
-
<span class="cstat-no" title="statement not covered" > this.getAirConditionerConfigSettings(accessory, device)</span>
|
|
1198
|
-
|
|
1199
|
-
<span class="cstat-no" title="statement not covered" > this.ValidValues = this.hide_automode ? [1, 2] : [0, 1, 2]</span>
|
|
1200
|
-
|
|
1201
|
-
// Initialize HeaterCooler Service
|
|
1202
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.HeaterCooler = accessory.context.HeaterCooler ?? {}</span>
|
|
1203
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler = {</span>
|
|
1204
|
-
<span class="cstat-no" title="statement not covered" > Name: accessory.displayName,</span>
|
|
1205
|
-
<span class="cstat-no" title="statement not covered" > Service: accessory.getService(this.hap.Service.HeaterCooler) ?? accessory.addService(this.hap.Service.HeaterCooler) as Service,</span>
|
|
1206
|
-
<span class="cstat-no" title="statement not covered" > Active: accessory.context.Active ?? this.hap.Characteristic.Active.INACTIVE,</span>
|
|
1207
|
-
<span class="cstat-no" title="statement not covered" > CurrentHeaterCoolerState: accessory.context.CurrentHeaterCoolerState ?? this.hap.Characteristic.CurrentHeaterCoolerState.IDLE,</span>
|
|
1208
|
-
<span class="cstat-no" title="statement not covered" > TargetHeaterCoolerState: accessory.context.TargetHeaterCoolerState ?? this.hap.Characteristic.TargetHeaterCoolerState.AUTO,</span>
|
|
1209
|
-
<span class="cstat-no" title="statement not covered" > CurrentTemperature: accessory.context.CurrentTemperature ?? 24,</span>
|
|
1210
|
-
<span class="cstat-no" title="statement not covered" > ThresholdTemperature: accessory.context.ThresholdTemperature ?? 24,</span>
|
|
1211
|
-
<span class="cstat-no" title="statement not covered" > RotationSpeed: accessory.context.RotationSpeed ?? 4,</span>
|
|
1212
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1213
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.HeaterCooler = this.HeaterCooler as object</span>
|
|
1214
|
-
|
|
1215
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.setCharacteristic(this.hap.Characteristic.Name, this.HeaterCooler.Name).getCharacteristic(this.hap.Characteristic.Active).onGet(() => {</span>
|
|
1216
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.Active</span>
|
|
1217
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.ActiveSet.bind(this))</span>
|
|
1218
|
-
|
|
1219
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.CurrentTemperature).onGet(async () => {</span>
|
|
1220
|
-
<span class="cstat-no" title="statement not covered" > return await this.CurrentTemperatureGet()</span>
|
|
1221
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1222
|
-
|
|
1223
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.TargetHeaterCoolerState).setProps({</span>
|
|
1224
|
-
<span class="cstat-no" title="statement not covered" > validValues: this.ValidValues,</span>
|
|
1225
|
-
<span class="cstat-no" title="statement not covered" > }).onGet(async () => {</span>
|
|
1226
|
-
<span class="cstat-no" title="statement not covered" > return await this.TargetHeaterCoolerStateGet()</span>
|
|
1227
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.TargetHeaterCoolerStateSet.bind(this))</span>
|
|
1228
|
-
|
|
1229
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.CurrentHeaterCoolerState).onGet(async () => {</span>
|
|
1230
|
-
<span class="cstat-no" title="statement not covered" > return await this.CurrentHeaterCoolerStateGet()</span>
|
|
1231
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1232
|
-
|
|
1233
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.HeatingThresholdTemperature).setProps({</span>
|
|
1234
|
-
<span class="cstat-no" title="statement not covered" > minValue: this.set_min_heat,</span>
|
|
1235
|
-
<span class="cstat-no" title="statement not covered" > maxValue: this.set_max_heat,</span>
|
|
1236
|
-
<span class="cstat-no" title="statement not covered" > minStep: 0.5,</span>
|
|
1237
|
-
<span class="cstat-no" title="statement not covered" > }).onGet(async () => {</span>
|
|
1238
|
-
<span class="cstat-no" title="statement not covered" > return await this.ThresholdTemperatureGet()</span>
|
|
1239
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.ThresholdTemperatureSet.bind(this))</span>
|
|
1240
|
-
|
|
1241
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.CoolingThresholdTemperature).setProps({</span>
|
|
1242
|
-
<span class="cstat-no" title="statement not covered" > minValue: this.set_min_cool,</span>
|
|
1243
|
-
<span class="cstat-no" title="statement not covered" > maxValue: this.set_max_cool,</span>
|
|
1244
|
-
<span class="cstat-no" title="statement not covered" > minStep: 0.5,</span>
|
|
1245
|
-
<span class="cstat-no" title="statement not covered" > }).onGet(async () => {</span>
|
|
1246
|
-
<span class="cstat-no" title="statement not covered" > return await this.ThresholdTemperatureGet()</span>
|
|
1247
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.ThresholdTemperatureSet.bind(this))</span>
|
|
1248
|
-
|
|
1249
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.getCharacteristic(this.hap.Characteristic.RotationSpeed).setProps({</span>
|
|
1250
|
-
<span class="cstat-no" title="statement not covered" > format: 'int',</span>
|
|
1251
|
-
<span class="cstat-no" title="statement not covered" > minStep: 1,</span>
|
|
1252
|
-
<span class="cstat-no" title="statement not covered" > minValue: 1,</span>
|
|
1253
|
-
<span class="cstat-no" title="statement not covered" > maxValue: 4,</span>
|
|
1254
|
-
<span class="cstat-no" title="statement not covered" > }).onGet(async () => {</span>
|
|
1255
|
-
<span class="cstat-no" title="statement not covered" > return await this.RotationSpeedGet()</span>
|
|
1256
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.RotationSpeedSet.bind(this))</span>
|
|
1257
|
-
|
|
1258
|
-
// Initialize HumiditySensor property
|
|
1259
|
-
|
|
1260
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).meterType && (this.device as irAirConfig).meterId) {</span>
|
|
1261
|
-
<span class="cstat-no" title="statement not covered" > const meterUuid = this.platform.api.hap.uuid.generate(`${(device as irAirConfig).meterId}-${(device as irAirConfig).meterType}`)</span>
|
|
1262
|
-
<span class="cstat-no" title="statement not covered" > this.meter = this.platform.accessories.find(accessory => accessory.UUID === meterUuid)</span>
|
|
1263
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.HumiditySensor = accessory.context.HumiditySensor ?? {}</span>
|
|
1264
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor = {</span>
|
|
1265
|
-
<span class="cstat-no" title="statement not covered" > Name: this.meter!.displayName,</span>
|
|
1266
|
-
<span class="cstat-no" title="statement not covered" > Service: this.meter!.getService(this.hap.Service.HumiditySensor) ?? this.meter!.addService(this.hap.Service.HumiditySensor) as Service,</span>
|
|
1267
|
-
<span class="cstat-no" title="statement not covered" > CurrentRelativeHumidity: this.meter!.context.CurrentRelativeHumidity || 0,</span>
|
|
1268
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1269
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.HumiditySensor = this.HumiditySensor as object</span>
|
|
1270
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1271
|
-
|
|
1272
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).meterType && (this.device as irAirConfig).meterId) {</span>
|
|
1273
|
-
<span class="cstat-no" title="statement not covered" > const meterUuid = this.platform.api.hap.uuid.generate(`${(device as irAirConfig).meterId}-${(device as irAirConfig).meterType}`)</span>
|
|
1274
|
-
<span class="cstat-no" title="statement not covered" > this.meter = this.platform.accessories.find(accessory => accessory.UUID === meterUuid)</span>
|
|
1275
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1276
|
-
|
|
1277
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter && this.HumiditySensor) {</span>
|
|
1278
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor.Service.setCharacteristic(this.hap.Characteristic.Name, this.HumiditySensor.Name).getCharacteristic(this.hap.Characteristic.CurrentRelativeHumidity).onGet(async () => {</span>
|
|
1279
|
-
<span class="cstat-no" title="statement not covered" > return await this.CurrentRelativeHumidityGet()</span>
|
|
1280
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1281
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1282
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1283
|
-
|
|
1284
|
-
/**
|
|
1285
|
-
* Pushes the requested changes to the SwitchBot API
|
|
1286
|
-
* deviceType commandType Command command parameter Description
|
|
1287
|
-
* AirConditioner: "command" "swing" "default" = swing
|
|
1288
|
-
* AirConditioner: "command" "timer" "default" = timer
|
|
1289
|
-
* AirConditioner: "command" "lowSpeed" "default" = fan speed to low
|
|
1290
|
-
* AirConditioner: "command" "middleSpeed" "default" = fan speed to medium
|
|
1291
|
-
* AirConditioner: "command" "highSpeed" "default" = fan speed to high
|
|
1292
|
-
*/
|
|
1293
|
-
<span class="cstat-no" title="statement not covered" > async pushAirConditionerOnChanges(): Promise<void> {</span>
|
|
1294
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerOnChanges Active: ${this.HeaterCooler.Active}, disablePushOn: ${this.deviceDisablePushOn}`)</span>
|
|
1295
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === this.hap.Characteristic.Active.ACTIVE && !this.deviceDisablePushOn) {</span>
|
|
1296
|
-
<span class="cstat-no" title="statement not covered" > const commandType: string = await this.commandType()</span>
|
|
1297
|
-
<span class="cstat-no" title="statement not covered" > const command: string = await this.commandOn()</span>
|
|
1298
|
-
<span class="cstat-no" title="statement not covered" > const bodyChange: bodyChange = {</span>
|
|
1299
|
-
<span class="cstat-no" title="statement not covered" > command,</span>
|
|
1300
|
-
<span class="cstat-no" title="statement not covered" > parameter: 'default',</span>
|
|
1301
|
-
<span class="cstat-no" title="statement not covered" > commandType,</span>
|
|
1302
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1303
|
-
<span class="cstat-no" title="statement not covered" > await this.pushChanges(bodyChange)</span>
|
|
1304
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1305
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1306
|
-
|
|
1307
|
-
<span class="cstat-no" title="statement not covered" > async pushAirConditionerOffChanges(): Promise<void> {</span>
|
|
1308
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerOffChanges Active: ${this.HeaterCooler.Active}, disablePushOff: ${this.deviceDisablePushOff}`)</span>
|
|
1309
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === this.hap.Characteristic.Active.INACTIVE && !this.deviceDisablePushOff) {</span>
|
|
1310
|
-
<span class="cstat-no" title="statement not covered" > const commandType: string = await this.commandType()</span>
|
|
1311
|
-
<span class="cstat-no" title="statement not covered" > const command: string = await this.commandOff()</span>
|
|
1312
|
-
<span class="cstat-no" title="statement not covered" > const bodyChange: bodyChange = {</span>
|
|
1313
|
-
<span class="cstat-no" title="statement not covered" > command,</span>
|
|
1314
|
-
<span class="cstat-no" title="statement not covered" > parameter: 'default',</span>
|
|
1315
|
-
<span class="cstat-no" title="statement not covered" > commandType,</span>
|
|
1316
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1317
|
-
<span class="cstat-no" title="statement not covered" > await this.pushChanges(bodyChange)</span>
|
|
1318
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1319
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1320
|
-
|
|
1321
|
-
<span class="cstat-no" title="statement not covered" > async pushAirConditionerStatusChanges(): Promise<void> {</span>
|
|
1322
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerStatusChanges Active: ${this.HeaterCooler.Active}, disablePushOff: ${this.deviceDisablePushOff}, disablePushOn: ${this.deviceDisablePushOn}`)</span>
|
|
1323
|
-
<span class="cstat-no" title="statement not covered" > if (!this.Busy) {</span>
|
|
1324
|
-
<span class="cstat-no" title="statement not covered" > this.Busy = true</span>
|
|
1325
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentHeaterCoolerState = this.hap.Characteristic.CurrentHeaterCoolerState.IDLE</span>
|
|
1326
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1327
|
-
<span class="cstat-no" title="statement not covered" > clearTimeout(this.Timeout)</span>
|
|
1328
|
-
|
|
1329
|
-
// Make a new Timeout set to go off in 1000ms (1 second)
|
|
1330
|
-
<span class="cstat-no" title="statement not covered" > this.Timeout = setTimeout(this.pushAirConditionerDetailsChanges.bind(this), 1500)</span>
|
|
1331
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1332
|
-
|
|
1333
|
-
<span class="cstat-no" title="statement not covered" > async pushAirConditionerDetailsChanges(): Promise<void> {</span>
|
|
1334
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerDetailsChanges Active: ${this.HeaterCooler.Active}, disablePushOff: ${this.deviceDisablePushOff}, disablePushOn: ${this.deviceDisablePushOn}`)</span>
|
|
1335
|
-
// await this.deviceContext();
|
|
1336
|
-
<span class="cstat-no" title="statement not covered" > if (this.CurrentMode === undefined) {</span>
|
|
1337
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentMode = 1</span>
|
|
1338
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1339
|
-
<span class="cstat-no" title="statement not covered" > if (this.CurrentFanSpeed === undefined) {</span>
|
|
1340
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentFanSpeed = 1</span>
|
|
1341
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1342
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === this.hap.Characteristic.Active.ACTIVE) {</span>
|
|
1343
|
-
<span class="cstat-no" title="statement not covered" > this.state = 'on'</span>
|
|
1344
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1345
|
-
<span class="cstat-no" title="statement not covered" > this.state = 'off'</span>
|
|
1346
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1347
|
-
<span class="cstat-no" title="statement not covered" > if (this.CurrentMode === 1) {</span>
|
|
1348
|
-
// Remove or make configurable?
|
|
1349
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.ThresholdTemperature = 25</span>
|
|
1350
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`CurrentMode: ${this.CurrentMode}, ThresholdTemperature: ${this.HeaterCooler.ThresholdTemperature}`)</span>
|
|
1351
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1352
|
-
<span class="cstat-no" title="statement not covered" > const parameter = `${this.HeaterCooler.ThresholdTemperature},${this.CurrentMode},${this.CurrentFanSpeed},${this.state}`</span>
|
|
1353
|
-
|
|
1354
|
-
<span class="cstat-no" title="statement not covered" > await this.UpdateCurrentHeaterCoolerState()</span>
|
|
1355
|
-
<span class="cstat-no" title="statement not covered" > const bodyChange: bodyChange = {</span>
|
|
1356
|
-
<span class="cstat-no" title="statement not covered" > command: 'setAll',</span>
|
|
1357
|
-
<span class="cstat-no" title="statement not covered" > parameter: `${parameter}`,</span>
|
|
1358
|
-
<span class="cstat-no" title="statement not covered" > commandType: 'command',</span>
|
|
1359
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1360
|
-
<span class="cstat-no" title="statement not covered" > await this.pushChanges(bodyChange)</span>
|
|
1361
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1362
|
-
|
|
1363
|
-
<span class="cstat-no" title="statement not covered" > private async UpdateCurrentHeaterCoolerState() {</span>
|
|
1364
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === this.hap.Characteristic.Active.ACTIVE) {</span>
|
|
1365
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === undefined) {</span>
|
|
1366
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Active = this.hap.Characteristic.Active.INACTIVE</span>
|
|
1367
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1368
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Active = this.HeaterCooler.Active ? this.HeaterCooler.Active : this.accessory.context.Active</span>
|
|
1369
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1370
|
-
|
|
1371
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.CurrentTemperature === undefined && this.accessory.context.CurrentTemperature === undefined) {</span>
|
|
1372
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentTemperature = 24</span>
|
|
1373
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1374
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentTemperature = this.HeaterCooler.CurrentTemperature || this.accessory.context.CurrentTemperature</span>
|
|
1375
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1376
|
-
|
|
1377
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.ThresholdTemperature === undefined && this.accessory.context.ThresholdTemperature === undefined) {</span>
|
|
1378
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.ThresholdTemperature = 24</span>
|
|
1379
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1380
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.ThresholdTemperature = this.HeaterCooler.ThresholdTemperature || this.accessory.context.ThresholdTemperature</span>
|
|
1381
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1382
|
-
|
|
1383
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.RotationSpeed === undefined && this.accessory.context.RotationSpeed === undefined) {</span>
|
|
1384
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = 4</span>
|
|
1385
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1386
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = this.HeaterCooler.RotationSpeed || this.accessory.context.RotationSpeed</span>
|
|
1387
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1388
|
-
|
|
1389
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).hide_automode) {</span>
|
|
1390
|
-
<span class="cstat-no" title="statement not covered" > this.hide_automode = (this.device as irAirConfig).hide_automode</span>
|
|
1391
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.hide_automode = this.hide_automode</span>
|
|
1392
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1393
|
-
<span class="cstat-no" title="statement not covered" > this.hide_automode = (this.device as irAirConfig).hide_automode</span>
|
|
1394
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.hide_automode = this.hide_automode</span>
|
|
1395
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1396
|
-
|
|
1397
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).set_max_heat) {</span>
|
|
1398
|
-
<span class="cstat-no" title="statement not covered" > this.set_max_heat = (this.device as irAirConfig).set_max_heat</span>
|
|
1399
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_max_heat = this.set_max_heat</span>
|
|
1400
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1401
|
-
<span class="cstat-no" title="statement not covered" > this.set_max_heat = 35</span>
|
|
1402
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_max_heat = this.set_max_heat</span>
|
|
1403
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1404
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).set_min_heat) {</span>
|
|
1405
|
-
<span class="cstat-no" title="statement not covered" > this.set_min_heat = (this.device as irAirConfig).set_min_heat</span>
|
|
1406
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_min_heat = this.set_min_heat</span>
|
|
1407
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1408
|
-
<span class="cstat-no" title="statement not covered" > this.set_min_heat = 0</span>
|
|
1409
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_min_heat = this.set_min_heat</span>
|
|
1410
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1411
|
-
|
|
1412
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).set_max_cool) {</span>
|
|
1413
|
-
<span class="cstat-no" title="statement not covered" > this.set_max_cool = (this.device as irAirConfig).set_max_cool</span>
|
|
1414
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_max_cool = this.set_max_cool</span>
|
|
1415
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1416
|
-
<span class="cstat-no" title="statement not covered" > this.set_max_cool = 35</span>
|
|
1417
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_max_cool = this.set_max_cool</span>
|
|
1418
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1419
|
-
<span class="cstat-no" title="statement not covered" > if ((this.device as irAirConfig).set_min_cool) {</span>
|
|
1420
|
-
<span class="cstat-no" title="statement not covered" > this.set_min_cool = (this.device as irAirConfig).set_min_cool</span>
|
|
1421
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_min_cool = this.set_min_cool</span>
|
|
1422
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1423
|
-
<span class="cstat-no" title="statement not covered" > this.set_min_cool = 0</span>
|
|
1424
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.set_min_cool = this.set_min_cool</span>
|
|
1425
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1426
|
-
|
|
1427
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter) {</span>
|
|
1428
|
-
<span class="cstat-no" title="statement not covered" > if (this.HumiditySensor!.CurrentRelativeHumidity === undefined && this.accessory.context.CurrentRelativeHumidity === undefined) {</span>
|
|
1429
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor!.CurrentRelativeHumidity = 0</span>
|
|
1430
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1431
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor!.CurrentRelativeHumidity = this.HumiditySensor!.CurrentRelativeHumidity ?? this.accessory.context.CurrentRelativeHumidity</span>
|
|
1432
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1433
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1434
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.ThresholdTemperature < this.HeaterCooler.CurrentTemperature</span>
|
|
1435
|
-
<span class="cstat-no" title="statement not covered" > && this.HeaterCooler.TargetHeaterCoolerState !== this.hap.Characteristic.TargetHeaterCoolerState.HEAT) {</span>
|
|
1436
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentHeaterCoolerState = this.hap.Characteristic.CurrentHeaterCoolerState.COOLING</span>
|
|
1437
|
-
<span class="cstat-no" title="statement not covered" > } else if (this.HeaterCooler.ThresholdTemperature > this.HeaterCooler.CurrentTemperature && this.HeaterCooler.TargetHeaterCoolerState !== this.hap.Characteristic.TargetHeaterCoolerState.COOL) {</span>
|
|
1438
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentHeaterCoolerState = this.hap.Characteristic.CurrentHeaterCoolerState.HEATING</span>
|
|
1439
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1440
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentHeaterCoolerState = this.hap.Characteristic.CurrentHeaterCoolerState.IDLE</span>
|
|
1441
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1442
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1443
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentHeaterCoolerState = this.hap.Characteristic.CurrentHeaterCoolerState.INACTIVE</span>
|
|
1444
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1445
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1446
|
-
|
|
1447
|
-
<span class="cstat-no" title="statement not covered" > async pushChanges(bodyChange: any): Promise<void> {</span>
|
|
1448
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('pushChanges')</span>
|
|
1449
|
-
<span class="cstat-no" title="statement not covered" > if (this.device.connectionType === 'OpenAPI' && !this.deviceDisablePushDetail) {</span>
|
|
1450
|
-
<span class="cstat-no" title="statement not covered" > this.infoLog(`Sending request to SwitchBot API, body: ${JSON.stringify(bodyChange)}`)</span>
|
|
1451
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1452
|
-
<span class="cstat-no" title="statement not covered" > const response = await this.pushChangeRequest(bodyChange)</span>
|
|
1453
|
-
<span class="cstat-no" title="statement not covered" > const deviceStatus: any = response.body</span>
|
|
1454
|
-
<span class="cstat-no" title="statement not covered" > await this.pushStatusCodes(deviceStatus)</span>
|
|
1455
|
-
<span class="cstat-no" title="statement not covered" > if (await this.successfulStatusCodes(deviceStatus)) {</span>
|
|
1456
|
-
<span class="cstat-no" title="statement not covered" > await this.successfulPushChange(deviceStatus, bodyChange)</span>
|
|
1457
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1458
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1459
|
-
<span class="cstat-no" title="statement not covered" > await this.statusCode(deviceStatus.statusCode)</span>
|
|
1460
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1461
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1462
|
-
<span class="cstat-no" title="statement not covered" > await this.apiError(e)</span>
|
|
1463
|
-
<span class="cstat-no" title="statement not covered" > await this.pushChangeError(e)</span>
|
|
1464
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1465
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1466
|
-
<span class="cstat-no" title="statement not covered" > this.warnLog(`Connection Type: ${this.device.connectionType}, commands will not be sent to OpenAPI`)</span>
|
|
1467
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Connection Type: ${this.device.connectionType}, disablePushDetails: ${this.deviceDisablePushDetail}`)</span>
|
|
1468
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1469
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1470
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1471
|
-
|
|
1472
|
-
<span class="cstat-no" title="statement not covered" > async CurrentTemperatureGet(): Promise<CharacteristicValue> {</span>
|
|
1473
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter?.context?.CurrentTemperature) {</span>
|
|
1474
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.CurrentTemperature = this.meter.context.CurrentTemperature</span>
|
|
1475
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Using CurrentTemperature from ${this.meter.context.deviceType} (${this.meter.context.deviceId})`)</span>
|
|
1476
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1477
|
-
|
|
1478
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentTemperature = this.accessory.context.CurrentTemperature || 24</span>
|
|
1479
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get CurrentTemperature: ${this.HeaterCooler.CurrentTemperature}`)</span>
|
|
1480
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.CurrentTemperature</span>
|
|
1481
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1482
|
-
|
|
1483
|
-
<span class="cstat-no" title="statement not covered" > async CurrentRelativeHumidityGet(): Promise<CharacteristicValue> {</span>
|
|
1484
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter?.context?.CurrentRelativeHumidity) {</span>
|
|
1485
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.CurrentRelativeHumidity = this.meter.context.CurrentRelativeHumidity</span>
|
|
1486
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Using CurrentRelativeHumidity from ${this.meter.context.deviceType} (${this.meter.context.deviceId})`)</span>
|
|
1487
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1488
|
-
|
|
1489
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor!.CurrentRelativeHumidity = this.accessory.context.CurrentRelativeHumidity || 0</span>
|
|
1490
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get CurrentRelativeHumidity: ${this.HumiditySensor!.CurrentRelativeHumidity}`)</span>
|
|
1491
|
-
<span class="cstat-no" title="statement not covered" > return this.HumiditySensor!.CurrentRelativeHumidity as CharacteristicValue</span>
|
|
1492
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1493
|
-
|
|
1494
|
-
<span class="cstat-no" title="statement not covered" > async RotationSpeedGet(): Promise<number> {</span>
|
|
1495
|
-
<span class="cstat-no" title="statement not covered" > if (!this.CurrentFanSpeed || this.CurrentFanSpeed === 1) {</span>
|
|
1496
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = 4</span>
|
|
1497
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1498
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = this.CurrentFanSpeed - 1</span>
|
|
1499
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1500
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get RotationSpeed: ${this.HeaterCooler.RotationSpeed}`)</span>
|
|
1501
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.RotationSpeed</span>
|
|
1502
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1503
|
-
|
|
1504
|
-
<span class="cstat-no" title="statement not covered" > async RotationSpeedSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1505
|
-
<span class="cstat-no" title="statement not covered" > if (value === 4) {</span>
|
|
1506
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentFanSpeed = 1</span>
|
|
1507
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1508
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentFanSpeed = Number(value) + 1</span>
|
|
1509
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1510
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = value</span>
|
|
1511
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set RotationSpeed: ${this.HeaterCooler.RotationSpeed}, CurrentFanSpeed: ${this.CurrentFanSpeed}`)</span>
|
|
1512
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerStatusChanges()</span>
|
|
1513
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1514
|
-
|
|
1515
|
-
<span class="cstat-no" title="statement not covered" > async ActiveSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1516
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set Active: ${value}`)</span>
|
|
1517
|
-
|
|
1518
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Active = value</span>
|
|
1519
|
-
<span class="cstat-no" title="statement not covered" > if (this.HeaterCooler.Active === this.hap.Characteristic.Active.ACTIVE) {</span>
|
|
1520
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerOnChanges, Active: ${this.HeaterCooler.Active}`)</span>
|
|
1521
|
-
<span class="cstat-no" title="statement not covered" > if (this.deviceDisablePushOn) {</span>
|
|
1522
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerStatusChanges()</span>
|
|
1523
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1524
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerOnChanges()</span>
|
|
1525
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1526
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1527
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`pushAirConditionerOffChanges, Active: ${this.HeaterCooler.Active}`)</span>
|
|
1528
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerOffChanges()</span>
|
|
1529
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1530
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1531
|
-
|
|
1532
|
-
<span class="cstat-no" title="statement not covered" > async TargetHeaterCoolerStateGet(): Promise<CharacteristicValue> {</span>
|
|
1533
|
-
<span class="cstat-no" title="statement not covered" > const targetState = this.HeaterCooler.TargetHeaterCoolerState || this.accessory.context.TargetHeaterCoolerState</span>
|
|
1534
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.TargetHeaterCoolerState = this.ValidValues.includes(targetState) ? targetState : this.ValidValues[0]</span>
|
|
1535
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get (${this.getTargetHeaterCoolerStateName()}) TargetHeaterCoolerState: ${this.HeaterCooler.TargetHeaterCoolerState}, ValidValues: ${this.ValidValues}, hide_automode: ${this.hide_automode}`)</span>
|
|
1536
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.TargetHeaterCoolerState</span>
|
|
1537
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1538
|
-
|
|
1539
|
-
<span class="cstat-no" title="statement not covered" > async TargetHeaterCoolerStateSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1540
|
-
<span class="cstat-no" title="statement not covered" > if (!this.hide_automode && value === this.hap.Characteristic.TargetHeaterCoolerState.AUTO) {</span>
|
|
1541
|
-
<span class="cstat-no" title="statement not covered" > this.TargetHeaterCoolerStateAUTO()</span>
|
|
1542
|
-
<span class="cstat-no" title="statement not covered" > } else if (value === this.hap.Characteristic.TargetHeaterCoolerState.HEAT) {</span>
|
|
1543
|
-
<span class="cstat-no" title="statement not covered" > this.TargetHeaterCoolerStateHEAT()</span>
|
|
1544
|
-
<span class="cstat-no" title="statement not covered" > } else if (value === this.hap.Characteristic.TargetHeaterCoolerState.COOL) {</span>
|
|
1545
|
-
<span class="cstat-no" title="statement not covered" > this.TargetHeaterCoolerStateCOOL()</span>
|
|
1546
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1547
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`Set TargetHeaterCoolerState: ${this.HeaterCooler.TargetHeaterCoolerState}, hide_automode: ${this.hide_automode} `)</span>
|
|
1548
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1549
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerStatusChanges()</span>
|
|
1550
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1551
|
-
|
|
1552
|
-
<span class="cstat-no" title="statement not covered" > async TargetHeaterCoolerStateAUTO(): Promise<void> {</span>
|
|
1553
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.TargetHeaterCoolerState = this.hap.Characteristic.TargetHeaterCoolerState.AUTO</span>
|
|
1554
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentMode = 1</span>
|
|
1555
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set (AUTO) TargetHeaterCoolerState: ${this.HeaterCooler.TargetHeaterCoolerState}`)</span>
|
|
1556
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Switchbot CurrentMode: ${this.CurrentMode}`)</span>
|
|
1557
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1558
|
-
|
|
1559
|
-
<span class="cstat-no" title="statement not covered" > async TargetHeaterCoolerStateCOOL(): Promise<void> {</span>
|
|
1560
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.TargetHeaterCoolerState = this.hap.Characteristic.TargetHeaterCoolerState.COOL</span>
|
|
1561
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentMode = 2</span>
|
|
1562
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set (COOL) TargetHeaterCoolerState: ${this.HeaterCooler.TargetHeaterCoolerState}`)</span>
|
|
1563
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Switchbot CurrentMode: ${this.CurrentMode}`)</span>
|
|
1564
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1565
|
-
|
|
1566
|
-
<span class="cstat-no" title="statement not covered" > async TargetHeaterCoolerStateHEAT(): Promise<void> {</span>
|
|
1567
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.TargetHeaterCoolerState = this.hap.Characteristic.TargetHeaterCoolerState.HEAT</span>
|
|
1568
|
-
<span class="cstat-no" title="statement not covered" > this.CurrentMode = 5</span>
|
|
1569
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set (HEAT) TargetHeaterCoolerState: ${this.HeaterCooler.TargetHeaterCoolerState}`)</span>
|
|
1570
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Switchbot CurrentMode: ${this.CurrentMode}`)</span>
|
|
1571
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1572
|
-
|
|
1573
|
-
<span class="cstat-no" title="statement not covered" > async CurrentHeaterCoolerStateGet(): Promise<CharacteristicValue> {</span>
|
|
1574
|
-
<span class="cstat-no" title="statement not covered" > await this.UpdateCurrentHeaterCoolerState()</span>
|
|
1575
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get (${this.getTargetHeaterCoolerStateName()}) CurrentHeaterCoolerState: ${this.HeaterCooler.CurrentHeaterCoolerState}`)</span>
|
|
1576
|
-
|
|
1577
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.CurrentHeaterCoolerState</span>
|
|
1578
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1579
|
-
|
|
1580
|
-
<span class="cstat-no" title="statement not covered" > private getTargetHeaterCoolerStateName(): string {</span>
|
|
1581
|
-
<span class="cstat-no" title="statement not covered" > switch (this.HeaterCooler.TargetHeaterCoolerState) {</span>
|
|
1582
|
-
<span class="cstat-no" title="statement not covered" > case this.hap.Characteristic.TargetHeaterCoolerState.AUTO:</span>
|
|
1583
|
-
<span class="cstat-no" title="statement not covered" > return 'AUTO'</span>
|
|
1584
|
-
<span class="cstat-no" title="statement not covered" > case this.hap.Characteristic.TargetHeaterCoolerState.HEAT:</span>
|
|
1585
|
-
<span class="cstat-no" title="statement not covered" > return 'HEAT'</span>
|
|
1586
|
-
<span class="cstat-no" title="statement not covered" > case this.hap.Characteristic.TargetHeaterCoolerState.COOL:</span>
|
|
1587
|
-
<span class="cstat-no" title="statement not covered" > return 'COOL'</span>
|
|
1588
|
-
<span class="cstat-no" title="statement not covered" > default:</span>
|
|
1589
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.TargetHeaterCoolerState.toString()</span>
|
|
1590
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1591
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1592
|
-
|
|
1593
|
-
<span class="cstat-no" title="statement not covered" > async ThresholdTemperatureGet(): Promise<CharacteristicValue> {</span>
|
|
1594
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Active = this.HeaterCooler.Active === undefined</span>
|
|
1595
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.Active.INACTIVE</span>
|
|
1596
|
-
<span class="cstat-no" title="statement not covered" > : this.HeaterCooler.Active ?? this.accessory.context.Active</span>
|
|
1597
|
-
|
|
1598
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.CurrentTemperature = (this.HeaterCooler.CurrentTemperature === undefined && this.accessory.context.CurrentTemperature === undefined)</span>
|
|
1599
|
-
<span class="cstat-no" title="statement not covered" > ? 24</span>
|
|
1600
|
-
<span class="cstat-no" title="statement not covered" > : this.HeaterCooler.CurrentTemperature ?? this.accessory.context.CurrentTemperature</span>
|
|
1601
|
-
|
|
1602
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.ThresholdTemperature = this.HeaterCooler.ThresholdTemperature === undefined</span>
|
|
1603
|
-
<span class="cstat-no" title="statement not covered" > ? 24</span>
|
|
1604
|
-
<span class="cstat-no" title="statement not covered" > : this.HeaterCooler.ThresholdTemperature ?? this.accessory.context.ThresholdTemperature</span>
|
|
1605
|
-
|
|
1606
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.RotationSpeed = (this.HeaterCooler.RotationSpeed === undefined && this.accessory.context.RotationSpeed === undefined)</span>
|
|
1607
|
-
<span class="cstat-no" title="statement not covered" > ? 4</span>
|
|
1608
|
-
<span class="cstat-no" title="statement not covered" > : this.HeaterCooler.RotationSpeed ?? this.accessory.context.RotationSpeed</span>
|
|
1609
|
-
|
|
1610
|
-
<span class="cstat-no" title="statement not covered" > await this.getAirConditionerConfigSettings(this.accessory, this.device)</span>
|
|
1611
|
-
|
|
1612
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter && this.HumiditySensor?.Service) {</span>
|
|
1613
|
-
<span class="cstat-no" title="statement not covered" > this.HumiditySensor.CurrentRelativeHumidity = (this.HumiditySensor.CurrentRelativeHumidity === undefined && this.accessory.context.CurrentRelativeHumidity === undefined)</span>
|
|
1614
|
-
<span class="cstat-no" title="statement not covered" > ? 0</span>
|
|
1615
|
-
<span class="cstat-no" title="statement not covered" > : this.HumiditySensor.CurrentRelativeHumidity ?? this.accessory.context.CurrentRelativeHumidity</span>
|
|
1616
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1617
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Get ThresholdTemperature: ${this.HeaterCooler.ThresholdTemperature}`)</span>
|
|
1618
|
-
<span class="cstat-no" title="statement not covered" > return this.HeaterCooler.ThresholdTemperature</span>
|
|
1619
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1620
|
-
|
|
1621
|
-
<span class="cstat-no" title="statement not covered" > async ThresholdTemperatureSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1622
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.ThresholdTemperature = value</span>
|
|
1623
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Set ThresholdTemperature: ${this.HeaterCooler.ThresholdTemperature}, ThresholdTemperatureCached: ${this.accessory.context.ThresholdTemperature}`)</span>
|
|
1624
|
-
<span class="cstat-no" title="statement not covered" > this.pushAirConditionerStatusChanges()</span>
|
|
1625
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1626
|
-
|
|
1627
|
-
<span class="cstat-no" title="statement not covered" > async updateHomeKitCharacteristics(): Promise<void> {</span>
|
|
1628
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('updateHomeKitCharacteristics')</span>
|
|
1629
|
-
// Active
|
|
1630
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.Active, this.HeaterCooler.Active, 'Active')</span>
|
|
1631
|
-
// RotationSpeed
|
|
1632
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.RotationSpeed, this.HeaterCooler.RotationSpeed, 'RotationSpeed')</span>
|
|
1633
|
-
// CurrentTemperature
|
|
1634
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.CurrentTemperature, this.HeaterCooler.CurrentTemperature, 'CurrentTemperature')</span>
|
|
1635
|
-
// TargetHeaterCoolerState
|
|
1636
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.TargetHeaterCoolerState, this.HeaterCooler.TargetHeaterCoolerState, 'TargetHeaterCoolerState')</span>
|
|
1637
|
-
// CurrentHeaterCoolerState
|
|
1638
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.CurrentHeaterCoolerState, this.HeaterCooler.CurrentHeaterCoolerState, 'CurrentHeaterCoolerState')</span>
|
|
1639
|
-
// HeatingThresholdTemperature
|
|
1640
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.HeatingThresholdTemperature, this.HeaterCooler.ThresholdTemperature, 'ThresholdTemperature')</span>
|
|
1641
|
-
// CoolingThresholdTemperature
|
|
1642
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HeaterCooler.Service, this.hap.Characteristic.CoolingThresholdTemperature, this.HeaterCooler.ThresholdTemperature, 'ThresholdTemperature')</span>
|
|
1643
|
-
<span class="cstat-no" title="statement not covered" > if (this.meter && this.HumiditySensor?.Service) {</span>
|
|
1644
|
-
// CurrentRelativeHumidity
|
|
1645
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.HumiditySensor.Service, this.hap.Characteristic.CurrentRelativeHumidity, this.HumiditySensor.CurrentRelativeHumidity, 'CurrentRelativeHumidity')</span>
|
|
1646
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1647
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1648
|
-
|
|
1649
|
-
<span class="cstat-no" title="statement not covered" > async apiError(e: any): Promise<void> {</span>
|
|
1650
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.Active, e)</span>
|
|
1651
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.RotationSpeed, e)</span>
|
|
1652
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.CurrentTemperature, e)</span>
|
|
1653
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.CurrentRelativeHumidity, e)</span>
|
|
1654
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.TargetHeaterCoolerState, e)</span>
|
|
1655
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.CurrentHeaterCoolerState, e)</span>
|
|
1656
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.HeatingThresholdTemperature, e)</span>
|
|
1657
|
-
<span class="cstat-no" title="statement not covered" > this.HeaterCooler.Service.updateCharacteristic(this.hap.Characteristic.CoolingThresholdTemperature, e)</span>
|
|
1658
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1659
|
-
|
|
1660
|
-
<span class="cstat-no" title="statement not covered" > async getAirConditionerConfigSettings(accessory: PlatformAccessory, device: irdevice & irDevicesConfig): Promise<void> {</span>
|
|
1661
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.hide_automode = this.hide_automode = (device as irAirConfig).hide_automode</span>
|
|
1662
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.set_max_heat = this.set_max_heat = (device as irAirConfig).set_max_heat ?? 35</span>
|
|
1663
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.set_min_heat = this.set_min_heat = (device as irAirConfig).set_min_heat ?? 0</span>
|
|
1664
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.set_max_cool = this.set_max_cool = (device as irAirConfig).set_max_cool ?? 35</span>
|
|
1665
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.set_min_cool = this.set_min_cool = (device as irAirConfig).set_min_cool ?? 0</span>
|
|
1666
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1667
|
-
<span class="cstat-no" title="statement not covered" >}</span>
|
|
1668
|
-
</pre></td></tr></table></pre>
|
|
1669
|
-
|
|
1670
|
-
<div class='push'></div><!-- for sticky footer -->
|
|
1671
|
-
</div><!-- /wrapper -->
|
|
1672
|
-
<div class='footer quiet pad2 space-top1 center small'>
|
|
1673
|
-
Code coverage generated by
|
|
1674
|
-
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
1675
|
-
at 2025-08-21T05:12:41.588Z
|
|
1676
|
-
</div>
|
|
1677
|
-
<script src="../../prettify.js"></script>
|
|
1678
|
-
<script>
|
|
1679
|
-
window.onload = function () {
|
|
1680
|
-
prettyPrint();
|
|
1681
|
-
};
|
|
1682
|
-
</script>
|
|
1683
|
-
<script src="../../sorter.js"></script>
|
|
1684
|
-
<script src="../../block-navigation.js"></script>
|
|
1685
|
-
</body>
|
|
1686
|
-
</html>
|
|
1687
|
-
|