@switchbot/homebridge-switchbot 5.0.0-beta.9 → 5.0.0-beta.90
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,1963 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
<!doctype html>
|
|
3
|
-
<html lang="en">
|
|
4
|
-
|
|
5
|
-
<head>
|
|
6
|
-
<title>Code coverage report for src/device/lock.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/device</a> lock.ts</h1>
|
|
23
|
-
<div class='clearfix'>
|
|
24
|
-
|
|
25
|
-
<div class='fl pad1y space-right2'>
|
|
26
|
-
<span class="strong">1.05% </span>
|
|
27
|
-
<span class="quiet">Statements</span>
|
|
28
|
-
<span class='fraction'>5/472</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">1.05% </span>
|
|
48
|
-
<span class="quiet">Lines</span>
|
|
49
|
-
<span class='fraction'>5/472</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>
|
|
601
|
-
<a name='L536'></a><a href='#L536'>536</a>
|
|
602
|
-
<a name='L537'></a><a href='#L537'>537</a>
|
|
603
|
-
<a name='L538'></a><a href='#L538'>538</a>
|
|
604
|
-
<a name='L539'></a><a href='#L539'>539</a>
|
|
605
|
-
<a name='L540'></a><a href='#L540'>540</a>
|
|
606
|
-
<a name='L541'></a><a href='#L541'>541</a>
|
|
607
|
-
<a name='L542'></a><a href='#L542'>542</a>
|
|
608
|
-
<a name='L543'></a><a href='#L543'>543</a>
|
|
609
|
-
<a name='L544'></a><a href='#L544'>544</a>
|
|
610
|
-
<a name='L545'></a><a href='#L545'>545</a>
|
|
611
|
-
<a name='L546'></a><a href='#L546'>546</a>
|
|
612
|
-
<a name='L547'></a><a href='#L547'>547</a>
|
|
613
|
-
<a name='L548'></a><a href='#L548'>548</a>
|
|
614
|
-
<a name='L549'></a><a href='#L549'>549</a>
|
|
615
|
-
<a name='L550'></a><a href='#L550'>550</a>
|
|
616
|
-
<a name='L551'></a><a href='#L551'>551</a>
|
|
617
|
-
<a name='L552'></a><a href='#L552'>552</a>
|
|
618
|
-
<a name='L553'></a><a href='#L553'>553</a>
|
|
619
|
-
<a name='L554'></a><a href='#L554'>554</a>
|
|
620
|
-
<a name='L555'></a><a href='#L555'>555</a>
|
|
621
|
-
<a name='L556'></a><a href='#L556'>556</a>
|
|
622
|
-
<a name='L557'></a><a href='#L557'>557</a>
|
|
623
|
-
<a name='L558'></a><a href='#L558'>558</a>
|
|
624
|
-
<a name='L559'></a><a href='#L559'>559</a>
|
|
625
|
-
<a name='L560'></a><a href='#L560'>560</a>
|
|
626
|
-
<a name='L561'></a><a href='#L561'>561</a>
|
|
627
|
-
<a name='L562'></a><a href='#L562'>562</a>
|
|
628
|
-
<a name='L563'></a><a href='#L563'>563</a>
|
|
629
|
-
<a name='L564'></a><a href='#L564'>564</a>
|
|
630
|
-
<a name='L565'></a><a href='#L565'>565</a>
|
|
631
|
-
<a name='L566'></a><a href='#L566'>566</a>
|
|
632
|
-
<a name='L567'></a><a href='#L567'>567</a>
|
|
633
|
-
<a name='L568'></a><a href='#L568'>568</a>
|
|
634
|
-
<a name='L569'></a><a href='#L569'>569</a>
|
|
635
|
-
<a name='L570'></a><a href='#L570'>570</a>
|
|
636
|
-
<a name='L571'></a><a href='#L571'>571</a>
|
|
637
|
-
<a name='L572'></a><a href='#L572'>572</a>
|
|
638
|
-
<a name='L573'></a><a href='#L573'>573</a>
|
|
639
|
-
<a name='L574'></a><a href='#L574'>574</a>
|
|
640
|
-
<a name='L575'></a><a href='#L575'>575</a>
|
|
641
|
-
<a name='L576'></a><a href='#L576'>576</a>
|
|
642
|
-
<a name='L577'></a><a href='#L577'>577</a>
|
|
643
|
-
<a name='L578'></a><a href='#L578'>578</a>
|
|
644
|
-
<a name='L579'></a><a href='#L579'>579</a>
|
|
645
|
-
<a name='L580'></a><a href='#L580'>580</a>
|
|
646
|
-
<a name='L581'></a><a href='#L581'>581</a>
|
|
647
|
-
<a name='L582'></a><a href='#L582'>582</a>
|
|
648
|
-
<a name='L583'></a><a href='#L583'>583</a>
|
|
649
|
-
<a name='L584'></a><a href='#L584'>584</a>
|
|
650
|
-
<a name='L585'></a><a href='#L585'>585</a>
|
|
651
|
-
<a name='L586'></a><a href='#L586'>586</a>
|
|
652
|
-
<a name='L587'></a><a href='#L587'>587</a>
|
|
653
|
-
<a name='L588'></a><a href='#L588'>588</a>
|
|
654
|
-
<a name='L589'></a><a href='#L589'>589</a>
|
|
655
|
-
<a name='L590'></a><a href='#L590'>590</a>
|
|
656
|
-
<a name='L591'></a><a href='#L591'>591</a>
|
|
657
|
-
<a name='L592'></a><a href='#L592'>592</a>
|
|
658
|
-
<a name='L593'></a><a href='#L593'>593</a>
|
|
659
|
-
<a name='L594'></a><a href='#L594'>594</a>
|
|
660
|
-
<a name='L595'></a><a href='#L595'>595</a>
|
|
661
|
-
<a name='L596'></a><a href='#L596'>596</a>
|
|
662
|
-
<a name='L597'></a><a href='#L597'>597</a>
|
|
663
|
-
<a name='L598'></a><a href='#L598'>598</a>
|
|
664
|
-
<a name='L599'></a><a href='#L599'>599</a>
|
|
665
|
-
<a name='L600'></a><a href='#L600'>600</a>
|
|
666
|
-
<a name='L601'></a><a href='#L601'>601</a>
|
|
667
|
-
<a name='L602'></a><a href='#L602'>602</a>
|
|
668
|
-
<a name='L603'></a><a href='#L603'>603</a>
|
|
669
|
-
<a name='L604'></a><a href='#L604'>604</a>
|
|
670
|
-
<a name='L605'></a><a href='#L605'>605</a>
|
|
671
|
-
<a name='L606'></a><a href='#L606'>606</a>
|
|
672
|
-
<a name='L607'></a><a href='#L607'>607</a>
|
|
673
|
-
<a name='L608'></a><a href='#L608'>608</a>
|
|
674
|
-
<a name='L609'></a><a href='#L609'>609</a>
|
|
675
|
-
<a name='L610'></a><a href='#L610'>610</a>
|
|
676
|
-
<a name='L611'></a><a href='#L611'>611</a>
|
|
677
|
-
<a name='L612'></a><a href='#L612'>612</a>
|
|
678
|
-
<a name='L613'></a><a href='#L613'>613</a>
|
|
679
|
-
<a name='L614'></a><a href='#L614'>614</a>
|
|
680
|
-
<a name='L615'></a><a href='#L615'>615</a>
|
|
681
|
-
<a name='L616'></a><a href='#L616'>616</a>
|
|
682
|
-
<a name='L617'></a><a href='#L617'>617</a>
|
|
683
|
-
<a name='L618'></a><a href='#L618'>618</a>
|
|
684
|
-
<a name='L619'></a><a href='#L619'>619</a>
|
|
685
|
-
<a name='L620'></a><a href='#L620'>620</a>
|
|
686
|
-
<a name='L621'></a><a href='#L621'>621</a>
|
|
687
|
-
<a name='L622'></a><a href='#L622'>622</a>
|
|
688
|
-
<a name='L623'></a><a href='#L623'>623</a>
|
|
689
|
-
<a name='L624'></a><a href='#L624'>624</a>
|
|
690
|
-
<a name='L625'></a><a href='#L625'>625</a>
|
|
691
|
-
<a name='L626'></a><a href='#L626'>626</a>
|
|
692
|
-
<a name='L627'></a><a href='#L627'>627</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
|
|
693
|
-
<span class="cline-any cline-neutral"> </span>
|
|
694
|
-
<span class="cline-any cline-neutral"> </span>
|
|
695
|
-
<span class="cline-any cline-neutral"> </span>
|
|
696
|
-
<span class="cline-any cline-neutral"> </span>
|
|
697
|
-
<span class="cline-any cline-neutral"> </span>
|
|
698
|
-
<span class="cline-any cline-neutral"> </span>
|
|
699
|
-
<span class="cline-any cline-neutral"> </span>
|
|
700
|
-
<span class="cline-any cline-neutral"> </span>
|
|
701
|
-
<span class="cline-any cline-neutral"> </span>
|
|
702
|
-
<span class="cline-any cline-neutral"> </span>
|
|
703
|
-
<span class="cline-any cline-neutral"> </span>
|
|
704
|
-
<span class="cline-any cline-neutral"> </span>
|
|
705
|
-
<span class="cline-any cline-neutral"> </span>
|
|
706
|
-
<span class="cline-any cline-yes">1x</span>
|
|
707
|
-
<span class="cline-any cline-yes">1x</span>
|
|
708
|
-
<span class="cline-any cline-neutral"> </span>
|
|
709
|
-
<span class="cline-any cline-yes">1x</span>
|
|
710
|
-
<span class="cline-any cline-yes">1x</span>
|
|
711
|
-
<span class="cline-any cline-neutral"> </span>
|
|
712
|
-
<span class="cline-any cline-yes">1x</span>
|
|
713
|
-
<span class="cline-any cline-neutral"> </span>
|
|
714
|
-
<span class="cline-any cline-no"> </span>
|
|
715
|
-
<span class="cline-any cline-neutral"> </span>
|
|
716
|
-
<span class="cline-any cline-neutral"> </span>
|
|
717
|
-
<span class="cline-any cline-neutral"> </span>
|
|
718
|
-
<span class="cline-any cline-neutral"> </span>
|
|
719
|
-
<span class="cline-any cline-neutral"> </span>
|
|
720
|
-
<span class="cline-any cline-neutral"> </span>
|
|
721
|
-
<span class="cline-any cline-no"> </span>
|
|
722
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
727
|
-
<span class="cline-any cline-neutral"> </span>
|
|
728
|
-
<span class="cline-any cline-no"> </span>
|
|
729
|
-
<span class="cline-any cline-neutral"> </span>
|
|
730
|
-
<span class="cline-any cline-neutral"> </span>
|
|
731
|
-
<span class="cline-any cline-neutral"> </span>
|
|
732
|
-
<span class="cline-any cline-neutral"> </span>
|
|
733
|
-
<span class="cline-any cline-neutral"> </span>
|
|
734
|
-
<span class="cline-any cline-no"> </span>
|
|
735
|
-
<span class="cline-any cline-neutral"> </span>
|
|
736
|
-
<span class="cline-any cline-neutral"> </span>
|
|
737
|
-
<span class="cline-any cline-neutral"> </span>
|
|
738
|
-
<span class="cline-any cline-neutral"> </span>
|
|
739
|
-
<span class="cline-any cline-neutral"> </span>
|
|
740
|
-
<span class="cline-any cline-neutral"> </span>
|
|
741
|
-
<span class="cline-any cline-no"> </span>
|
|
742
|
-
<span class="cline-any cline-neutral"> </span>
|
|
743
|
-
<span class="cline-any cline-neutral"> </span>
|
|
744
|
-
<span class="cline-any cline-no"> </span>
|
|
745
|
-
<span class="cline-any cline-neutral"> </span>
|
|
746
|
-
<span class="cline-any cline-neutral"> </span>
|
|
747
|
-
<span class="cline-any cline-no"> </span>
|
|
748
|
-
<span class="cline-any cline-neutral"> </span>
|
|
749
|
-
<span class="cline-any cline-neutral"> </span>
|
|
750
|
-
<span class="cline-any cline-no"> </span>
|
|
751
|
-
<span class="cline-any cline-no"> </span>
|
|
752
|
-
<span class="cline-any cline-neutral"> </span>
|
|
753
|
-
<span class="cline-any cline-no"> </span>
|
|
754
|
-
<span class="cline-any cline-no"> </span>
|
|
755
|
-
<span class="cline-any cline-no"> </span>
|
|
756
|
-
<span class="cline-any cline-no"> </span>
|
|
757
|
-
<span class="cline-any cline-no"> </span>
|
|
758
|
-
<span class="cline-any cline-no"> </span>
|
|
759
|
-
<span class="cline-any cline-neutral"> </span>
|
|
760
|
-
<span class="cline-any cline-no"> </span>
|
|
761
|
-
<span class="cline-any cline-neutral"> </span>
|
|
762
|
-
<span class="cline-any cline-neutral"> </span>
|
|
763
|
-
<span class="cline-any cline-no"> </span>
|
|
764
|
-
<span class="cline-any cline-no"> </span>
|
|
765
|
-
<span class="cline-any cline-neutral"> </span>
|
|
766
|
-
<span class="cline-any cline-neutral"> </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-no"> </span>
|
|
773
|
-
<span class="cline-any cline-no"> </span>
|
|
774
|
-
<span class="cline-any cline-no"> </span>
|
|
775
|
-
<span class="cline-any cline-neutral"> </span>
|
|
776
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
781
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-neutral"> </span>
|
|
791
|
-
<span class="cline-any cline-neutral"> </span>
|
|
792
|
-
<span class="cline-any cline-no"> </span>
|
|
793
|
-
<span class="cline-any cline-no"> </span>
|
|
794
|
-
<span class="cline-any cline-no"> </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-no"> </span>
|
|
799
|
-
<span class="cline-any cline-neutral"> </span>
|
|
800
|
-
<span class="cline-any cline-neutral"> </span>
|
|
801
|
-
<span class="cline-any cline-no"> </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-no"> </span>
|
|
815
|
-
<span class="cline-any cline-neutral"> </span>
|
|
816
|
-
<span class="cline-any cline-neutral"> </span>
|
|
817
|
-
<span class="cline-any cline-no"> </span>
|
|
818
|
-
<span class="cline-any cline-no"> </span>
|
|
819
|
-
<span class="cline-any cline-no"> </span>
|
|
820
|
-
<span class="cline-any cline-no"> </span>
|
|
821
|
-
<span class="cline-any cline-neutral"> </span>
|
|
822
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-no"> </span>
|
|
837
|
-
<span class="cline-any cline-neutral"> </span>
|
|
838
|
-
<span class="cline-any cline-neutral"> </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-no"> </span>
|
|
843
|
-
<span class="cline-any cline-neutral"> </span>
|
|
844
|
-
<span class="cline-any cline-neutral"> </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-no"> </span>
|
|
849
|
-
<span class="cline-any cline-no"> </span>
|
|
850
|
-
<span class="cline-any cline-no"> </span>
|
|
851
|
-
<span class="cline-any cline-neutral"> </span>
|
|
852
|
-
<span class="cline-any cline-neutral"> </span>
|
|
853
|
-
<span class="cline-any cline-no"> </span>
|
|
854
|
-
<span class="cline-any cline-no"> </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-neutral"> </span>
|
|
860
|
-
<span class="cline-any cline-neutral"> </span>
|
|
861
|
-
<span class="cline-any cline-no"> </span>
|
|
862
|
-
<span class="cline-any cline-no"> </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-neutral"> </span>
|
|
868
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
875
|
-
<span class="cline-any cline-neutral"> </span>
|
|
876
|
-
<span class="cline-any cline-neutral"> </span>
|
|
877
|
-
<span class="cline-any cline-no"> </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-no"> </span>
|
|
893
|
-
<span class="cline-any cline-no"> </span>
|
|
894
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
899
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
905
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
911
|
-
<span class="cline-any cline-neutral"> </span>
|
|
912
|
-
<span class="cline-any cline-no"> </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-neutral"> </span>
|
|
919
|
-
<span class="cline-any cline-no"> </span>
|
|
920
|
-
<span class="cline-any cline-neutral"> </span>
|
|
921
|
-
<span class="cline-any cline-no"> </span>
|
|
922
|
-
<span class="cline-any cline-no"> </span>
|
|
923
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </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-neutral"> </span>
|
|
935
|
-
<span class="cline-any cline-neutral"> </span>
|
|
936
|
-
<span class="cline-any cline-no"> </span>
|
|
937
|
-
<span class="cline-any cline-no"> </span>
|
|
938
|
-
<span class="cline-any cline-no"> </span>
|
|
939
|
-
<span class="cline-any cline-no"> </span>
|
|
940
|
-
<span class="cline-any cline-neutral"> </span>
|
|
941
|
-
<span class="cline-any cline-neutral"> </span>
|
|
942
|
-
<span class="cline-any cline-no"> </span>
|
|
943
|
-
<span class="cline-any cline-no"> </span>
|
|
944
|
-
<span class="cline-any cline-no"> </span>
|
|
945
|
-
<span class="cline-any cline-no"> </span>
|
|
946
|
-
<span class="cline-any cline-neutral"> </span>
|
|
947
|
-
<span class="cline-any cline-neutral"> </span>
|
|
948
|
-
<span class="cline-any cline-no"> </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-neutral"> </span>
|
|
956
|
-
<span class="cline-any cline-no"> </span>
|
|
957
|
-
<span class="cline-any cline-no"> </span>
|
|
958
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
965
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-no"> </span>
|
|
984
|
-
<span class="cline-any cline-neutral"> </span>
|
|
985
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
991
|
-
<span class="cline-any cline-neutral"> </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-neutral"> </span>
|
|
999
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1000
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-neutral"> </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-no"> </span>
|
|
1018
|
-
<span class="cline-any cline-no"> </span>
|
|
1019
|
-
<span class="cline-any cline-no"> </span>
|
|
1020
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1021
|
-
<span class="cline-any cline-no"> </span>
|
|
1022
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-no"> </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-no"> </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-no"> </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-no"> </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-no"> </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-no"> </span>
|
|
1072
|
-
<span class="cline-any cline-no"> </span>
|
|
1073
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1074
|
-
<span class="cline-any cline-no"> </span>
|
|
1075
|
-
<span class="cline-any cline-no"> </span>
|
|
1076
|
-
<span class="cline-any cline-no"> </span>
|
|
1077
|
-
<span class="cline-any cline-no"> </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-no"> </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-no"> </span>
|
|
1093
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1094
|
-
<span class="cline-any cline-no"> </span>
|
|
1095
|
-
<span class="cline-any cline-no"> </span>
|
|
1096
|
-
<span class="cline-any cline-no"> </span>
|
|
1097
|
-
<span class="cline-any cline-no"> </span>
|
|
1098
|
-
<span class="cline-any cline-no"> </span>
|
|
1099
|
-
<span class="cline-any cline-no"> </span>
|
|
1100
|
-
<span class="cline-any cline-no"> </span>
|
|
1101
|
-
<span class="cline-any cline-no"> </span>
|
|
1102
|
-
<span class="cline-any cline-no"> </span>
|
|
1103
|
-
<span class="cline-any cline-no"> </span>
|
|
1104
|
-
<span class="cline-any cline-no"> </span>
|
|
1105
|
-
<span class="cline-any cline-no"> </span>
|
|
1106
|
-
<span class="cline-any cline-no"> </span>
|
|
1107
|
-
<span class="cline-any cline-no"> </span>
|
|
1108
|
-
<span class="cline-any cline-no"> </span>
|
|
1109
|
-
<span class="cline-any cline-no"> </span>
|
|
1110
|
-
<span class="cline-any cline-no"> </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-no"> </span>
|
|
1115
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1116
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1117
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1118
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1119
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1120
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1121
|
-
<span class="cline-any cline-neutral"> </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-no"> </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-neutral"> </span>
|
|
1134
|
-
<span class="cline-any cline-no"> </span>
|
|
1135
|
-
<span class="cline-any cline-no"> </span>
|
|
1136
|
-
<span class="cline-any cline-no"> </span>
|
|
1137
|
-
<span class="cline-any cline-no"> </span>
|
|
1138
|
-
<span class="cline-any cline-no"> </span>
|
|
1139
|
-
<span class="cline-any cline-no"> </span>
|
|
1140
|
-
<span class="cline-any cline-no"> </span>
|
|
1141
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1142
|
-
<span class="cline-any cline-no"> </span>
|
|
1143
|
-
<span class="cline-any cline-no"> </span>
|
|
1144
|
-
<span class="cline-any cline-no"> </span>
|
|
1145
|
-
<span class="cline-any cline-no"> </span>
|
|
1146
|
-
<span class="cline-any cline-no"> </span>
|
|
1147
|
-
<span class="cline-any cline-no"> </span>
|
|
1148
|
-
<span class="cline-any cline-no"> </span>
|
|
1149
|
-
<span class="cline-any cline-no"> </span>
|
|
1150
|
-
<span class="cline-any cline-no"> </span>
|
|
1151
|
-
<span class="cline-any cline-no"> </span>
|
|
1152
|
-
<span class="cline-any cline-no"> </span>
|
|
1153
|
-
<span class="cline-any cline-no"> </span>
|
|
1154
|
-
<span class="cline-any cline-no"> </span>
|
|
1155
|
-
<span class="cline-any cline-no"> </span>
|
|
1156
|
-
<span class="cline-any cline-no"> </span>
|
|
1157
|
-
<span class="cline-any cline-no"> </span>
|
|
1158
|
-
<span class="cline-any cline-no"> </span>
|
|
1159
|
-
<span class="cline-any cline-no"> </span>
|
|
1160
|
-
<span class="cline-any cline-no"> </span>
|
|
1161
|
-
<span class="cline-any cline-no"> </span>
|
|
1162
|
-
<span class="cline-any cline-no"> </span>
|
|
1163
|
-
<span class="cline-any cline-no"> </span>
|
|
1164
|
-
<span class="cline-any cline-no"> </span>
|
|
1165
|
-
<span class="cline-any cline-no"> </span>
|
|
1166
|
-
<span class="cline-any cline-no"> </span>
|
|
1167
|
-
<span class="cline-any cline-no"> </span>
|
|
1168
|
-
<span class="cline-any cline-no"> </span>
|
|
1169
|
-
<span class="cline-any cline-no"> </span>
|
|
1170
|
-
<span class="cline-any cline-no"> </span>
|
|
1171
|
-
<span class="cline-any cline-no"> </span>
|
|
1172
|
-
<span class="cline-any cline-no"> </span>
|
|
1173
|
-
<span class="cline-any cline-no"> </span>
|
|
1174
|
-
<span class="cline-any cline-no"> </span>
|
|
1175
|
-
<span class="cline-any cline-no"> </span>
|
|
1176
|
-
<span class="cline-any cline-no"> </span>
|
|
1177
|
-
<span class="cline-any cline-no"> </span>
|
|
1178
|
-
<span class="cline-any cline-no"> </span>
|
|
1179
|
-
<span class="cline-any cline-no"> </span>
|
|
1180
|
-
<span class="cline-any cline-no"> </span>
|
|
1181
|
-
<span class="cline-any cline-no"> </span>
|
|
1182
|
-
<span class="cline-any cline-no"> </span>
|
|
1183
|
-
<span class="cline-any cline-no"> </span>
|
|
1184
|
-
<span class="cline-any cline-no"> </span>
|
|
1185
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1186
|
-
<span class="cline-any cline-no"> </span>
|
|
1187
|
-
<span class="cline-any cline-no"> </span>
|
|
1188
|
-
<span class="cline-any cline-no"> </span>
|
|
1189
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1190
|
-
<span class="cline-any cline-no"> </span>
|
|
1191
|
-
<span class="cline-any cline-no"> </span>
|
|
1192
|
-
<span class="cline-any cline-no"> </span>
|
|
1193
|
-
<span class="cline-any cline-no"> </span>
|
|
1194
|
-
<span class="cline-any cline-no"> </span>
|
|
1195
|
-
<span class="cline-any cline-no"> </span>
|
|
1196
|
-
<span class="cline-any cline-no"> </span>
|
|
1197
|
-
<span class="cline-any cline-no"> </span>
|
|
1198
|
-
<span class="cline-any cline-no"> </span>
|
|
1199
|
-
<span class="cline-any cline-no"> </span>
|
|
1200
|
-
<span class="cline-any cline-no"> </span>
|
|
1201
|
-
<span class="cline-any cline-no"> </span>
|
|
1202
|
-
<span class="cline-any cline-no"> </span>
|
|
1203
|
-
<span class="cline-any cline-no"> </span>
|
|
1204
|
-
<span class="cline-any cline-no"> </span>
|
|
1205
|
-
<span class="cline-any cline-no"> </span>
|
|
1206
|
-
<span class="cline-any cline-no"> </span>
|
|
1207
|
-
<span class="cline-any cline-no"> </span>
|
|
1208
|
-
<span class="cline-any cline-no"> </span>
|
|
1209
|
-
<span class="cline-any cline-no"> </span>
|
|
1210
|
-
<span class="cline-any cline-no"> </span>
|
|
1211
|
-
<span class="cline-any cline-no"> </span>
|
|
1212
|
-
<span class="cline-any cline-no"> </span>
|
|
1213
|
-
<span class="cline-any cline-no"> </span>
|
|
1214
|
-
<span class="cline-any cline-no"> </span>
|
|
1215
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1216
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1217
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1218
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1219
|
-
<span class="cline-any cline-no"> </span>
|
|
1220
|
-
<span class="cline-any cline-no"> </span>
|
|
1221
|
-
<span class="cline-any cline-no"> </span>
|
|
1222
|
-
<span class="cline-any cline-no"> </span>
|
|
1223
|
-
<span class="cline-any cline-no"> </span>
|
|
1224
|
-
<span class="cline-any cline-no"> </span>
|
|
1225
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1226
|
-
<span class="cline-any cline-no"> </span>
|
|
1227
|
-
<span class="cline-any cline-no"> </span>
|
|
1228
|
-
<span class="cline-any cline-no"> </span>
|
|
1229
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1230
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1231
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1232
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1233
|
-
<span class="cline-any cline-no"> </span>
|
|
1234
|
-
<span class="cline-any cline-no"> </span>
|
|
1235
|
-
<span class="cline-any cline-no"> </span>
|
|
1236
|
-
<span class="cline-any cline-no"> </span>
|
|
1237
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1238
|
-
<span class="cline-any cline-no"> </span>
|
|
1239
|
-
<span class="cline-any cline-no"> </span>
|
|
1240
|
-
<span class="cline-any cline-no"> </span>
|
|
1241
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1242
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1243
|
-
<span class="cline-any cline-no"> </span>
|
|
1244
|
-
<span class="cline-any cline-no"> </span>
|
|
1245
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1246
|
-
<span class="cline-any cline-no"> </span>
|
|
1247
|
-
<span class="cline-any cline-no"> </span>
|
|
1248
|
-
<span class="cline-any cline-no"> </span>
|
|
1249
|
-
<span class="cline-any cline-no"> </span>
|
|
1250
|
-
<span class="cline-any cline-no"> </span>
|
|
1251
|
-
<span class="cline-any cline-no"> </span>
|
|
1252
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1253
|
-
<span class="cline-any cline-no"> </span>
|
|
1254
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1255
|
-
<span class="cline-any cline-no"> </span>
|
|
1256
|
-
<span class="cline-any cline-no"> </span>
|
|
1257
|
-
<span class="cline-any cline-no"> </span>
|
|
1258
|
-
<span class="cline-any cline-no"> </span>
|
|
1259
|
-
<span class="cline-any cline-no"> </span>
|
|
1260
|
-
<span class="cline-any cline-no"> </span>
|
|
1261
|
-
<span class="cline-any cline-no"> </span>
|
|
1262
|
-
<span class="cline-any cline-no"> </span>
|
|
1263
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1264
|
-
<span class="cline-any cline-no"> </span>
|
|
1265
|
-
<span class="cline-any cline-no"> </span>
|
|
1266
|
-
<span class="cline-any cline-no"> </span>
|
|
1267
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1268
|
-
<span class="cline-any cline-no"> </span>
|
|
1269
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1270
|
-
<span class="cline-any cline-no"> </span>
|
|
1271
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1272
|
-
<span class="cline-any cline-no"> </span>
|
|
1273
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1274
|
-
<span class="cline-any cline-no"> </span>
|
|
1275
|
-
<span class="cline-any cline-no"> </span>
|
|
1276
|
-
<span class="cline-any cline-no"> </span>
|
|
1277
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1278
|
-
<span class="cline-any cline-no"> </span>
|
|
1279
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1280
|
-
<span class="cline-any cline-no"> </span>
|
|
1281
|
-
<span class="cline-any cline-no"> </span>
|
|
1282
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1283
|
-
<span class="cline-any cline-no"> </span>
|
|
1284
|
-
<span class="cline-any cline-no"> </span>
|
|
1285
|
-
<span class="cline-any cline-no"> </span>
|
|
1286
|
-
<span class="cline-any cline-no"> </span>
|
|
1287
|
-
<span class="cline-any cline-no"> </span>
|
|
1288
|
-
<span class="cline-any cline-no"> </span>
|
|
1289
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1290
|
-
<span class="cline-any cline-no"> </span>
|
|
1291
|
-
<span class="cline-any cline-no"> </span>
|
|
1292
|
-
<span class="cline-any cline-no"> </span>
|
|
1293
|
-
<span class="cline-any cline-no"> </span>
|
|
1294
|
-
<span class="cline-any cline-no"> </span>
|
|
1295
|
-
<span class="cline-any cline-no"> </span>
|
|
1296
|
-
<span class="cline-any cline-no"> </span>
|
|
1297
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1298
|
-
<span class="cline-any cline-no"> </span>
|
|
1299
|
-
<span class="cline-any cline-no"> </span>
|
|
1300
|
-
<span class="cline-any cline-no"> </span>
|
|
1301
|
-
<span class="cline-any cline-no"> </span>
|
|
1302
|
-
<span class="cline-any cline-no"> </span>
|
|
1303
|
-
<span class="cline-any cline-no"> </span>
|
|
1304
|
-
<span class="cline-any cline-no"> </span>
|
|
1305
|
-
<span class="cline-any cline-no"> </span>
|
|
1306
|
-
<span class="cline-any cline-no"> </span>
|
|
1307
|
-
<span class="cline-any cline-neutral"> </span>
|
|
1308
|
-
<span class="cline-any cline-no"> </span>
|
|
1309
|
-
<span class="cline-any cline-no"> </span>
|
|
1310
|
-
<span class="cline-any cline-no"> </span>
|
|
1311
|
-
<span class="cline-any cline-no"> </span>
|
|
1312
|
-
<span class="cline-any cline-no"> </span>
|
|
1313
|
-
<span class="cline-any cline-no"> </span>
|
|
1314
|
-
<span class="cline-any cline-no"> </span>
|
|
1315
|
-
<span class="cline-any cline-no"> </span>
|
|
1316
|
-
<span class="cline-any cline-no"> </span>
|
|
1317
|
-
<span class="cline-any cline-no"> </span>
|
|
1318
|
-
<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.
|
|
1319
|
-
*
|
|
1320
|
-
* lock.ts: @switchbot/homebridge-switchbot.
|
|
1321
|
-
*/
|
|
1322
|
-
import type { CharacteristicValue, PlatformAccessory, Service } from 'homebridge'
|
|
1323
|
-
import type { bodyChange, device, lockProServiceData, lockProStatus, lockProWebhookContext, lockServiceData, lockStatus, lockWebhookContext, SwitchBotBLE, SwitchbotDevice, WoSmartLock } from 'node-switchbot'
|
|
1324
|
-
|
|
1325
|
-
import type { SwitchBotPlatform } from '../platform.js'
|
|
1326
|
-
import type { devicesConfig, lockConfig } from '../settings.js'
|
|
1327
|
-
|
|
1328
|
-
/*
|
|
1329
|
-
* For Testing Locally:
|
|
1330
|
-
* import { SwitchBotBLEModel, SwitchBotBLEModelName } from '/Users/Shared/GitHub/OpenWonderLabs/node-switchbot/dist/index.js';
|
|
1331
|
-
*/
|
|
1332
|
-
import { SwitchBotBLEModel, SwitchBotBLEModelName } from 'node-switchbot'
|
|
1333
|
-
import { debounceTime, interval, skipWhile, Subject, take, tap } from 'rxjs'
|
|
1334
|
-
|
|
1335
|
-
import { formatDeviceIdAsMac } from '../utils.js'
|
|
1336
|
-
import { deviceBase } from './device.js'
|
|
1337
|
-
|
|
1338
|
-
export <span class="fstat-no" title="function not covered" ><span class="branch-0 cbranch-no" title="branch not covered" >class Lock extends deviceBase {</span></span>
|
|
1339
|
-
// Services
|
|
1340
|
-
<span class="cstat-no" title="statement not covered" > private LockMechanism: {</span>
|
|
1341
|
-
Name: CharacteristicValue
|
|
1342
|
-
Service: Service
|
|
1343
|
-
LockTargetState: CharacteristicValue
|
|
1344
|
-
LockCurrentState: CharacteristicValue
|
|
1345
|
-
}
|
|
1346
|
-
|
|
1347
|
-
<span class="cstat-no" title="statement not covered" > private Battery: {</span>
|
|
1348
|
-
Name: CharacteristicValue
|
|
1349
|
-
Service: Service
|
|
1350
|
-
BatteryLevel: CharacteristicValue
|
|
1351
|
-
StatusLowBattery: CharacteristicValue
|
|
1352
|
-
}
|
|
1353
|
-
|
|
1354
|
-
<span class="cstat-no" title="statement not covered" > private ContactSensor?: {</span>
|
|
1355
|
-
Name: CharacteristicValue
|
|
1356
|
-
Service: Service
|
|
1357
|
-
ContactSensorState: CharacteristicValue
|
|
1358
|
-
}
|
|
1359
|
-
|
|
1360
|
-
<span class="cstat-no" title="statement not covered" > private Switch?: {</span>
|
|
1361
|
-
Name: CharacteristicValue
|
|
1362
|
-
Service: Service
|
|
1363
|
-
On: CharacteristicValue
|
|
1364
|
-
}
|
|
1365
|
-
|
|
1366
|
-
// OpenAPI
|
|
1367
|
-
<span class="cstat-no" title="statement not covered" > deviceStatus!: lockStatus | lockProStatus</span>
|
|
1368
|
-
|
|
1369
|
-
// Webhook
|
|
1370
|
-
<span class="cstat-no" title="statement not covered" > webhookContext!: lockWebhookContext | lockProWebhookContext</span>
|
|
1371
|
-
|
|
1372
|
-
// BLE
|
|
1373
|
-
<span class="cstat-no" title="statement not covered" > serviceData!: lockServiceData | lockProServiceData</span>
|
|
1374
|
-
|
|
1375
|
-
// Updates
|
|
1376
|
-
<span class="cstat-no" title="statement not covered" > lockUpdateInProgress!: boolean</span>
|
|
1377
|
-
<span class="cstat-no" title="statement not covered" > doLockUpdate!: Subject<void></span>
|
|
1378
|
-
|
|
1379
|
-
<span class="cstat-no" title="statement not covered" > constructor(</span>
|
|
1380
|
-
<span class="cstat-no" title="statement not covered" > readonly platform: SwitchBotPlatform,</span>
|
|
1381
|
-
<span class="cstat-no" title="statement not covered" > accessory: PlatformAccessory,</span>
|
|
1382
|
-
<span class="cstat-no" title="statement not covered" > device: device & devicesConfig,</span>
|
|
1383
|
-
<span class="cstat-no" title="statement not covered" > ) {</span>
|
|
1384
|
-
<span class="cstat-no" title="statement not covered" > super(platform, accessory, device)</span>
|
|
1385
|
-
// Set category
|
|
1386
|
-
<span class="cstat-no" title="statement not covered" > accessory.category = this.hap.Categories.DOOR_LOCK</span>
|
|
1387
|
-
|
|
1388
|
-
// this is subject we use to track when we need to POST changes to the SwitchBot API
|
|
1389
|
-
<span class="cstat-no" title="statement not covered" > this.doLockUpdate = new Subject()</span>
|
|
1390
|
-
<span class="cstat-no" title="statement not covered" > this.lockUpdateInProgress = false</span>
|
|
1391
|
-
|
|
1392
|
-
// Initialize LockMechanism Service
|
|
1393
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.LockMechanism = accessory.context.LockMechanism ?? {}</span>
|
|
1394
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism = {</span>
|
|
1395
|
-
<span class="cstat-no" title="statement not covered" > Name: accessory.displayName,</span>
|
|
1396
|
-
<span class="cstat-no" title="statement not covered" > Service: accessory.getService(this.hap.Service.LockMechanism) ?? accessory.addService(this.hap.Service.LockMechanism) as Service,</span>
|
|
1397
|
-
<span class="cstat-no" title="statement not covered" > LockTargetState: accessory.context.LockTargetState ?? this.hap.Characteristic.LockTargetState.SECURED,</span>
|
|
1398
|
-
<span class="cstat-no" title="statement not covered" > LockCurrentState: accessory.context.LockCurrentState ?? this.hap.Characteristic.LockCurrentState.SECURED,</span>
|
|
1399
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1400
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.LockMechanism = this.LockMechanism as object</span>
|
|
1401
|
-
|
|
1402
|
-
// Initialize LockMechanism Characteristics
|
|
1403
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.Service.setCharacteristic(this.hap.Characteristic.Name, this.LockMechanism.Name).getCharacteristic(this.hap.Characteristic.LockTargetState).onGet(() => {</span>
|
|
1404
|
-
<span class="cstat-no" title="statement not covered" > return this.LockMechanism.LockTargetState</span>
|
|
1405
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.LockTargetStateSet.bind(this))</span>
|
|
1406
|
-
|
|
1407
|
-
// Initialize Battery property
|
|
1408
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.Battery = accessory.context.Battery ?? {}</span>
|
|
1409
|
-
<span class="cstat-no" title="statement not covered" > this.Battery = {</span>
|
|
1410
|
-
<span class="cstat-no" title="statement not covered" > Name: `${accessory.displayName} Battery`,</span>
|
|
1411
|
-
<span class="cstat-no" title="statement not covered" > Service: accessory.getService(this.hap.Service.Battery) ?? accessory.addService(this.hap.Service.Battery) as Service,</span>
|
|
1412
|
-
<span class="cstat-no" title="statement not covered" > BatteryLevel: accessory.context.BatteryLevel ?? 100,</span>
|
|
1413
|
-
<span class="cstat-no" title="statement not covered" > StatusLowBattery: accessory.context.StatusLowBattery ?? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL,</span>
|
|
1414
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1415
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.Battery = this.Battery as object</span>
|
|
1416
|
-
|
|
1417
|
-
// Initialize Battery Characteristics
|
|
1418
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.Service.setCharacteristic(this.hap.Characteristic.Name, this.Battery.Name).setCharacteristic(this.hap.Characteristic.ChargingState, this.hap.Characteristic.ChargingState.NOT_CHARGEABLE).getCharacteristic(this.hap.Characteristic.BatteryLevel).onGet(() => {</span>
|
|
1419
|
-
<span class="cstat-no" title="statement not covered" > return this.Battery.BatteryLevel</span>
|
|
1420
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1421
|
-
|
|
1422
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.Service.getCharacteristic(this.hap.Characteristic.StatusLowBattery).onGet(() => {</span>
|
|
1423
|
-
<span class="cstat-no" title="statement not covered" > return this.Battery.StatusLowBattery</span>
|
|
1424
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1425
|
-
|
|
1426
|
-
// Contact Sensor Service
|
|
1427
|
-
<span class="cstat-no" title="statement not covered" > if ((device as lockConfig).hide_contactsensor) {</span>
|
|
1428
|
-
<span class="cstat-no" title="statement not covered" > if (this.ContactSensor) {</span>
|
|
1429
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Removing Contact Sensor Service')</span>
|
|
1430
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.Service = this.accessory.getService(this.hap.Service.ContactSensor) as Service</span>
|
|
1431
|
-
<span class="cstat-no" title="statement not covered" > accessory.removeService(this.ContactSensor.Service)</span>
|
|
1432
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1433
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1434
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.ContactSensor = accessory.context.ContactSensor ?? {}</span>
|
|
1435
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor = {</span>
|
|
1436
|
-
<span class="cstat-no" title="statement not covered" > Name: `${accessory.displayName} Contact Sensor`,</span>
|
|
1437
|
-
<span class="cstat-no" title="statement not covered" > Service: accessory.getService(this.hap.Service.ContactSensor) ?? this.accessory.addService(this.hap.Service.ContactSensor) as Service,</span>
|
|
1438
|
-
<span class="cstat-no" title="statement not covered" > ContactSensorState: accessory.context.ContactSensorState ?? this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED,</span>
|
|
1439
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1440
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.ContactSensor = this.ContactSensor as object</span>
|
|
1441
|
-
|
|
1442
|
-
// Initialize Contact Sensor Characteristics
|
|
1443
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.Service.setCharacteristic(this.hap.Characteristic.Name, this.ContactSensor.Name).setCharacteristic(this.hap.Characteristic.StatusActive, true).getCharacteristic(this.hap.Characteristic.ContactSensorState).onGet(() => {</span>
|
|
1444
|
-
<span class="cstat-no" title="statement not covered" > return this.ContactSensor!.ContactSensorState</span>
|
|
1445
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1446
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1447
|
-
|
|
1448
|
-
// Initialize Latch Button Service
|
|
1449
|
-
<span class="cstat-no" title="statement not covered" > if ((device as lockConfig).activate_latchbutton === false) {</span>
|
|
1450
|
-
<span class="cstat-no" title="statement not covered" > if (this.Switch) {</span>
|
|
1451
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Removing Latch Button Service')</span>
|
|
1452
|
-
<span class="cstat-no" title="statement not covered" > this.Switch.Service = accessory.getService(this.hap.Service.Switch) as Service</span>
|
|
1453
|
-
<span class="cstat-no" title="statement not covered" > accessory.removeService(this.Switch.Service)</span>
|
|
1454
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1455
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1456
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.Switch = accessory.context.Switch ?? {}</span>
|
|
1457
|
-
<span class="cstat-no" title="statement not covered" > this.Switch = {</span>
|
|
1458
|
-
<span class="cstat-no" title="statement not covered" > Name: `${accessory.displayName} Latch`,</span>
|
|
1459
|
-
<span class="cstat-no" title="statement not covered" > Service: accessory.getService(this.hap.Service.Switch) ?? accessory.addService(this.hap.Service.Switch) as Service,</span>
|
|
1460
|
-
<span class="cstat-no" title="statement not covered" > On: accessory.context.On ?? false,</span>
|
|
1461
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1462
|
-
<span class="cstat-no" title="statement not covered" > accessory.context.Switch = this.Switch as object</span>
|
|
1463
|
-
|
|
1464
|
-
// Initialize Latch Button Characteristics
|
|
1465
|
-
<span class="cstat-no" title="statement not covered" > this.Switch.Service.setCharacteristic(this.hap.Characteristic.Name, this.Switch.Name).getCharacteristic(this.hap.Characteristic.On).onGet(() => {</span>
|
|
1466
|
-
<span class="cstat-no" title="statement not covered" > return this.Switch!.On</span>
|
|
1467
|
-
<span class="cstat-no" title="statement not covered" > }).onSet(this.OnSet.bind(this))</span>
|
|
1468
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1469
|
-
|
|
1470
|
-
// Retrieve initial values and updateHomekit
|
|
1471
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1472
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Retrieve initial values and update Homekit')</span>
|
|
1473
|
-
<span class="cstat-no" title="statement not covered" > this.refreshStatus()</span>
|
|
1474
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1475
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to retrieve initial values and update Homekit, Error: ${e.message ?? e}`)</span>
|
|
1476
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1477
|
-
|
|
1478
|
-
// regisiter webhook event handler if enabled
|
|
1479
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1480
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Registering Webhook Event Handler')</span>
|
|
1481
|
-
<span class="cstat-no" title="statement not covered" > this.registerWebhook()</span>
|
|
1482
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1483
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to registerWebhook, Error: ${e.message ?? e}`)</span>
|
|
1484
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1485
|
-
|
|
1486
|
-
// regisiter platform BLE event handler if enabled
|
|
1487
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1488
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Registering Platform BLE Event Handler')</span>
|
|
1489
|
-
<span class="cstat-no" title="statement not covered" > this.registerPlatformBLE()</span>
|
|
1490
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1491
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to registerPlatformBLE, Error: ${e.message ?? e}`)</span>
|
|
1492
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1493
|
-
|
|
1494
|
-
// Start an update interval
|
|
1495
|
-
<span class="cstat-no" title="statement not covered" > interval(this.deviceRefreshRate * 1000)</span>
|
|
1496
|
-
<span class="cstat-no" title="statement not covered" > .pipe(skipWhile(() => this.lockUpdateInProgress))</span>
|
|
1497
|
-
<span class="cstat-no" title="statement not covered" > .subscribe(async () => {</span>
|
|
1498
|
-
<span class="cstat-no" title="statement not covered" > await this.refreshStatus()</span>
|
|
1499
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1500
|
-
|
|
1501
|
-
// Watch for Lock change events
|
|
1502
|
-
// We put in a debounce of 100ms so we don't make duplicate calls
|
|
1503
|
-
<span class="cstat-no" title="statement not covered" > this.doLockUpdate</span>
|
|
1504
|
-
<span class="cstat-no" title="statement not covered" > .pipe(</span>
|
|
1505
|
-
<span class="cstat-no" title="statement not covered" > tap(() => {</span>
|
|
1506
|
-
<span class="cstat-no" title="statement not covered" > this.lockUpdateInProgress = true</span>
|
|
1507
|
-
<span class="cstat-no" title="statement not covered" > }),</span>
|
|
1508
|
-
<span class="cstat-no" title="statement not covered" > debounceTime(this.devicePushRate * 1000),</span>
|
|
1509
|
-
<span class="cstat-no" title="statement not covered" > )</span>
|
|
1510
|
-
<span class="cstat-no" title="statement not covered" > .subscribe(async () => {</span>
|
|
1511
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1512
|
-
<span class="cstat-no" title="statement not covered" > await this.pushChanges()</span>
|
|
1513
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1514
|
-
<span class="cstat-no" title="statement not covered" > await this.apiError(e)</span>
|
|
1515
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed pushChanges with ${device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)</span>
|
|
1516
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1517
|
-
<span class="cstat-no" title="statement not covered" > this.lockUpdateInProgress = false</span>
|
|
1518
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1519
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1520
|
-
|
|
1521
|
-
<span class="cstat-no" title="statement not covered" > async BLEparseStatus(): Promise<void> {</span>
|
|
1522
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('BLEparseStatus')</span>
|
|
1523
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`(lockState) = BLE:(${this.serviceData.status}), current:(${this.LockMechanism.LockCurrentState})`)</span>
|
|
1524
|
-
|
|
1525
|
-
// LockCurrentState
|
|
1526
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockCurrentState = this.serviceData.status === 'locked'</span>
|
|
1527
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockCurrentState.SECURED</span>
|
|
1528
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockCurrentState.UNSECURED</span>
|
|
1529
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)</span>
|
|
1530
|
-
|
|
1531
|
-
// LockTargetState
|
|
1532
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockTargetState = this.serviceData.status === 'locked'</span>
|
|
1533
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockTargetState.SECURED</span>
|
|
1534
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockTargetState.UNSECURED</span>
|
|
1535
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)</span>
|
|
1536
|
-
|
|
1537
|
-
// Contact Sensor
|
|
1538
|
-
<span class="cstat-no" title="statement not covered" > if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {</span>
|
|
1539
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.ContactSensorState = this.serviceData.door_open</span>
|
|
1540
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.ContactSensorState.CONTACT_NOT_DETECTED</span>
|
|
1541
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED</span>
|
|
1542
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`ContactSensorState: ${this.ContactSensor.ContactSensorState}`)</span>
|
|
1543
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1544
|
-
// Battery Info
|
|
1545
|
-
<span class="cstat-no" title="statement not covered" > if ('battery' in this.serviceData) {</span>
|
|
1546
|
-
// BatteryLevel
|
|
1547
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.BatteryLevel = this.serviceData.battery</span>
|
|
1548
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`BatteryLevel: ${this.Battery.BatteryLevel}`)</span>
|
|
1549
|
-
// StatusLowBattery
|
|
1550
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.StatusLowBattery = this.Battery.BatteryLevel < 10</span>
|
|
1551
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_LOW</span>
|
|
1552
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL</span>
|
|
1553
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`StatusLowBattery: ${this.Battery.StatusLowBattery}`)</span>
|
|
1554
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1555
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1556
|
-
|
|
1557
|
-
<span class="cstat-no" title="statement not covered" > async openAPIparseStatus(): Promise<void> {</span>
|
|
1558
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('openAPIparseStatus')</span>
|
|
1559
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`(lockState) = OpenAPI:(${this.deviceStatus.lockState}), current:(${this.LockMechanism.LockCurrentState})`)</span>
|
|
1560
|
-
|
|
1561
|
-
// LockCurrentState
|
|
1562
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockCurrentState = this.deviceStatus.lockState === 'locked'</span>
|
|
1563
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockCurrentState.SECURED</span>
|
|
1564
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockCurrentState.UNSECURED</span>
|
|
1565
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)</span>
|
|
1566
|
-
|
|
1567
|
-
// LockTargetState
|
|
1568
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockTargetState = this.deviceStatus.lockState === 'locked'</span>
|
|
1569
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockTargetState.SECURED</span>
|
|
1570
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockTargetState.UNSECURED</span>
|
|
1571
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)</span>
|
|
1572
|
-
|
|
1573
|
-
// ContactSensorState
|
|
1574
|
-
<span class="cstat-no" title="statement not covered" > if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {</span>
|
|
1575
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.ContactSensorState = this.deviceStatus.doorState === 'opened'</span>
|
|
1576
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.ContactSensorState.CONTACT_NOT_DETECTED</span>
|
|
1577
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED</span>
|
|
1578
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`ContactSensorState: ${this.ContactSensor.ContactSensorState}`)</span>
|
|
1579
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1580
|
-
|
|
1581
|
-
// BatteryLevel
|
|
1582
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.BatteryLevel = this.deviceStatus.battery</span>
|
|
1583
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`BatteryLevel: ${this.Battery.BatteryLevel}`)</span>
|
|
1584
|
-
|
|
1585
|
-
// StatusLowBattery
|
|
1586
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.StatusLowBattery = this.Battery.BatteryLevel < 10</span>
|
|
1587
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_LOW</span>
|
|
1588
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL</span>
|
|
1589
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`StatusLowBattery: ${this.Battery.StatusLowBattery}`)</span>
|
|
1590
|
-
|
|
1591
|
-
// Firmware Version
|
|
1592
|
-
<span class="cstat-no" title="statement not covered" > if (this.deviceStatus.version) {</span>
|
|
1593
|
-
<span class="cstat-no" title="statement not covered" > const version = this.deviceStatus.version.toString()</span>
|
|
1594
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Firmware Version: ${version.replace(/^V|-.*$/g, '')}`)</span>
|
|
1595
|
-
<span class="cstat-no" title="statement not covered" > const deviceVersion = version.replace(/^V|-.*$/g, '') ?? '0.0.0'</span>
|
|
1596
|
-
<span class="cstat-no" title="statement not covered" > this.accessory</span>
|
|
1597
|
-
<span class="cstat-no" title="statement not covered" > .getService(this.hap.Service.AccessoryInformation)!</span>
|
|
1598
|
-
<span class="cstat-no" title="statement not covered" > .setCharacteristic(this.hap.Characteristic.HardwareRevision, deviceVersion)</span>
|
|
1599
|
-
<span class="cstat-no" title="statement not covered" > .setCharacteristic(this.hap.Characteristic.FirmwareRevision, deviceVersion)</span>
|
|
1600
|
-
<span class="cstat-no" title="statement not covered" > .getCharacteristic(this.hap.Characteristic.FirmwareRevision)</span>
|
|
1601
|
-
<span class="cstat-no" title="statement not covered" > .updateValue(deviceVersion)</span>
|
|
1602
|
-
<span class="cstat-no" title="statement not covered" > this.accessory.context.version = deviceVersion</span>
|
|
1603
|
-
<span class="cstat-no" title="statement not covered" > this.debugSuccessLog(`version: ${this.accessory.context.version}`)</span>
|
|
1604
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1605
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1606
|
-
|
|
1607
|
-
<span class="cstat-no" title="statement not covered" > async parseStatusWebhook(): Promise<void> {</span>
|
|
1608
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('parseStatusWebhook')</span>
|
|
1609
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`(lockState) = Webhook:(${this.webhookContext.lockState}), current:(${this.LockMechanism.LockCurrentState})`)</span>
|
|
1610
|
-
|
|
1611
|
-
// LockCurrentState
|
|
1612
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockCurrentState = this.webhookContext.lockState === 'LOCKED'</span>
|
|
1613
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockCurrentState.SECURED</span>
|
|
1614
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockCurrentState.UNSECURED</span>
|
|
1615
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)</span>
|
|
1616
|
-
|
|
1617
|
-
// LockTargetState
|
|
1618
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockTargetState = this.webhookContext.lockState === 'LOCKED'</span>
|
|
1619
|
-
<span class="cstat-no" title="statement not covered" > ? this.hap.Characteristic.LockTargetState.SECURED</span>
|
|
1620
|
-
<span class="cstat-no" title="statement not covered" > : this.hap.Characteristic.LockTargetState.UNSECURED</span>
|
|
1621
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)</span>
|
|
1622
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1623
|
-
|
|
1624
|
-
/**
|
|
1625
|
-
* Asks the SwitchBot API for the latest device information
|
|
1626
|
-
*/
|
|
1627
|
-
<span class="cstat-no" title="statement not covered" > async refreshStatus(): Promise<void> {</span>
|
|
1628
|
-
<span class="cstat-no" title="statement not covered" > if (!this.device.enableCloudService && this.OpenAPI) {</span>
|
|
1629
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`refreshStatus enableCloudService: ${this.device.enableCloudService}`)</span>
|
|
1630
|
-
<span class="cstat-no" title="statement not covered" > } else if (this.BLE) {</span>
|
|
1631
|
-
<span class="cstat-no" title="statement not covered" > await this.BLERefreshStatus()</span>
|
|
1632
|
-
<span class="cstat-no" title="statement not covered" > } else if (this.OpenAPI && this.platform.config.credentials?.token) {</span>
|
|
1633
|
-
<span class="cstat-no" title="statement not covered" > await this.openAPIRefreshStatus()</span>
|
|
1634
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1635
|
-
<span class="cstat-no" title="statement not covered" > await this.offlineOff()</span>
|
|
1636
|
-
<span class="cstat-no" title="statement not covered" > this.debugWarnLog(`Connection Type: ${this.device.connectionType}, refreshStatus will not happen.`)</span>
|
|
1637
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1638
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1639
|
-
|
|
1640
|
-
<span class="cstat-no" title="statement not covered" > async BLERefreshStatus(): Promise<void> {</span>
|
|
1641
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('BLERefreshStatus')</span>
|
|
1642
|
-
<span class="cstat-no" title="statement not covered" > const switchBotBLE = await this.switchbotBLE()</span>
|
|
1643
|
-
<span class="cstat-no" title="statement not covered" > if (switchBotBLE === undefined) {</span>
|
|
1644
|
-
<span class="cstat-no" title="statement not covered" > await this.BLERefreshConnection(switchBotBLE)</span>
|
|
1645
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1646
|
-
// Start to monitor advertisement packets
|
|
1647
|
-
<span class="cstat-no" title="statement not covered" > (async () => {</span>
|
|
1648
|
-
// Start to monitor advertisement packets
|
|
1649
|
-
<span class="cstat-no" title="statement not covered" > const serviceData = await this.monitorAdvertisementPackets(switchBotBLE) as lockServiceData | lockProServiceData</span>
|
|
1650
|
-
// Update HomeKit
|
|
1651
|
-
<span class="cstat-no" title="statement not covered" > if ((serviceData.model === SwitchBotBLEModel.Lock || SwitchBotBLEModel.LockPro)</span>
|
|
1652
|
-
<span class="cstat-no" title="statement not covered" > && (serviceData.modelName === SwitchBotBLEModelName.Lock || SwitchBotBLEModelName.LockPro)) {</span>
|
|
1653
|
-
<span class="cstat-no" title="statement not covered" > this.serviceData = serviceData</span>
|
|
1654
|
-
<span class="cstat-no" title="statement not covered" > if (serviceData !== undefined || serviceData !== null) {</span>
|
|
1655
|
-
<span class="cstat-no" title="statement not covered" > await this.BLEparseStatus()</span>
|
|
1656
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1657
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1658
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`serviceData is either undefined or null, serviceData: ${JSON.stringify(serviceData)}`)</span>
|
|
1659
|
-
<span class="cstat-no" title="statement not covered" > await this.BLERefreshConnection(switchBotBLE)</span>
|
|
1660
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1661
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1662
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to get serviceData, serviceData: ${JSON.stringify(serviceData)}`)</span>
|
|
1663
|
-
<span class="cstat-no" title="statement not covered" > await this.BLERefreshConnection(switchBotBLE)</span>
|
|
1664
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1665
|
-
<span class="cstat-no" title="statement not covered" > })()</span>
|
|
1666
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1667
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1668
|
-
|
|
1669
|
-
<span class="cstat-no" title="statement not covered" > async registerPlatformBLE(): Promise<void> {</span>
|
|
1670
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('registerPlatformBLE')</span>
|
|
1671
|
-
<span class="cstat-no" title="statement not covered" > if (this.config.options?.BLE && !this.device.disablePlatformBLE) {</span>
|
|
1672
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('is listening to Platform BLE.')</span>
|
|
1673
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1674
|
-
<span class="cstat-no" title="statement not covered" > const formattedDeviceId = formatDeviceIdAsMac(this.device.deviceId)</span>
|
|
1675
|
-
<span class="cstat-no" title="statement not covered" > this.device.bleMac = formattedDeviceId</span>
|
|
1676
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`bleMac: ${this.device.bleMac}`)</span>
|
|
1677
|
-
<span class="cstat-no" title="statement not covered" > this.platform.bleEventHandler[this.device.bleMac] = async (context: lockServiceData | lockProServiceData) => {</span>
|
|
1678
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1679
|
-
<span class="cstat-no" title="statement not covered" > this.serviceData = context</span>
|
|
1680
|
-
<span class="cstat-no" title="statement not covered" > if (context !== undefined || context !== null) {</span>
|
|
1681
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`received BLE: ${JSON.stringify(context)}`)</span>
|
|
1682
|
-
<span class="cstat-no" title="statement not covered" > await this.BLEparseStatus()</span>
|
|
1683
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1684
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1685
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`context is either undefined or null, context: ${JSON.stringify(context)}`)</span>
|
|
1686
|
-
<span class="cstat-no" title="statement not covered" > await this.BLERefreshConnection(context)</span>
|
|
1687
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1688
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1689
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to handle BLE. Received: ${JSON.stringify(context)} Error: ${e.message ?? e}`)</span>
|
|
1690
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1691
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1692
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1693
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to format device ID as MAC, Error: ${error}`)</span>
|
|
1694
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1695
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1696
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('is not listening to Platform BLE')</span>
|
|
1697
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1698
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1699
|
-
|
|
1700
|
-
<span class="cstat-no" title="statement not covered" > async openAPIRefreshStatus(): Promise<void> {</span>
|
|
1701
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('openAPIRefreshStatus')</span>
|
|
1702
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1703
|
-
<span class="cstat-no" title="statement not covered" > const response = await this.deviceRefreshStatus()</span>
|
|
1704
|
-
<span class="cstat-no" title="statement not covered" > const deviceStatus: any = response.body</span>
|
|
1705
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)</span>
|
|
1706
|
-
<span class="cstat-no" title="statement not covered" > if (await this.successfulStatusCodes(deviceStatus)) {</span>
|
|
1707
|
-
<span class="cstat-no" title="statement not covered" > this.debugSuccessLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)</span>
|
|
1708
|
-
<span class="cstat-no" title="statement not covered" > this.deviceStatus = deviceStatus.body</span>
|
|
1709
|
-
<span class="cstat-no" title="statement not covered" > await this.openAPIparseStatus()</span>
|
|
1710
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1711
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1712
|
-
<span class="cstat-no" title="statement not covered" > this.debugWarnLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)</span>
|
|
1713
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1714
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1715
|
-
<span class="cstat-no" title="statement not covered" > await this.apiError(e)</span>
|
|
1716
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed openAPIRefreshStatus with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)</span>
|
|
1717
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1718
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1719
|
-
|
|
1720
|
-
<span class="cstat-no" title="statement not covered" > async registerWebhook() {</span>
|
|
1721
|
-
<span class="cstat-no" title="statement not covered" > if (this.device.webhook) {</span>
|
|
1722
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('is listening webhook.')</span>
|
|
1723
|
-
<span class="cstat-no" title="statement not covered" > this.platform.webhookEventHandler[this.device.deviceId] = async (context: lockWebhookContext | lockProWebhookContext) => {</span>
|
|
1724
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1725
|
-
<span class="cstat-no" title="statement not covered" > this.webhookContext = context</span>
|
|
1726
|
-
<span class="cstat-no" title="statement not covered" > if (context !== undefined || context !== null) {</span>
|
|
1727
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`received Webhook: ${JSON.stringify(context)}`)</span>
|
|
1728
|
-
<span class="cstat-no" title="statement not covered" > await this.parseStatusWebhook()</span>
|
|
1729
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1730
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1731
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`context is either undefined or null, context: ${JSON.stringify(context)}`)</span>
|
|
1732
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1733
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1734
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to handle webhook. Received: ${JSON.stringify(context)} Error: ${e.message ?? e}`)</span>
|
|
1735
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1736
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1737
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1738
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('is not listening webhook.')</span>
|
|
1739
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1740
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1741
|
-
|
|
1742
|
-
/**
|
|
1743
|
-
* Pushes the requested changes to the SwitchBot API
|
|
1744
|
-
* deviceType commandType Command command parameter Description
|
|
1745
|
-
* Lock - "command" "lock" "default" = set to ???? state
|
|
1746
|
-
* Lock - "command" "unlock" "default" = set to ???? state - LockCurrentState
|
|
1747
|
-
*/
|
|
1748
|
-
<span class="cstat-no" title="statement not covered" > async pushChanges(): Promise<void> {</span>
|
|
1749
|
-
<span class="cstat-no" title="statement not covered" > if (!this.device.enableCloudService && this.OpenAPI) {</span>
|
|
1750
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`pushChanges enableCloudService: ${this.device.enableCloudService}`)</span>
|
|
1751
|
-
<span class="cstat-no" title="statement not covered" > } else if (this.BLE) {</span>
|
|
1752
|
-
<span class="cstat-no" title="statement not covered" > await this.BLEpushChanges()</span>
|
|
1753
|
-
<span class="cstat-no" title="statement not covered" > } else if (this.OpenAPI && this.platform.config.credentials?.token) {</span>
|
|
1754
|
-
<span class="cstat-no" title="statement not covered" > await this.openAPIpushChanges()</span>
|
|
1755
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1756
|
-
<span class="cstat-no" title="statement not covered" > await this.offlineOff()</span>
|
|
1757
|
-
<span class="cstat-no" title="statement not covered" > this.debugWarnLog(`Connection Type: ${this.device.connectionType}, pushChanges will not happen.`)</span>
|
|
1758
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1759
|
-
// Refresh the status from the API
|
|
1760
|
-
<span class="cstat-no" title="statement not covered" > interval(15000)</span>
|
|
1761
|
-
<span class="cstat-no" title="statement not covered" > .pipe(skipWhile(() => this.lockUpdateInProgress))</span>
|
|
1762
|
-
<span class="cstat-no" title="statement not covered" > .pipe(take(1))</span>
|
|
1763
|
-
<span class="cstat-no" title="statement not covered" > .subscribe(async () => {</span>
|
|
1764
|
-
<span class="cstat-no" title="statement not covered" > await this.refreshStatus()</span>
|
|
1765
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1766
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1767
|
-
|
|
1768
|
-
<span class="cstat-no" title="statement not covered" > async BLEpushChanges(): Promise<void> {</span>
|
|
1769
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('BLEpushChanges')</span>
|
|
1770
|
-
<span class="cstat-no" title="statement not covered" > if (this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) {</span>
|
|
1771
|
-
<span class="cstat-no" title="statement not covered" > const switchBotBLE = await this.platform.connectBLE(this.accessory, this.device)</span>
|
|
1772
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1773
|
-
<span class="cstat-no" title="statement not covered" > const formattedDeviceId = formatDeviceIdAsMac(this.device.deviceId)</span>
|
|
1774
|
-
<span class="cstat-no" title="statement not covered" > this.device.bleMac = formattedDeviceId</span>
|
|
1775
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`bleMac: ${this.device.bleMac}`)</span>
|
|
1776
|
-
<span class="cstat-no" title="statement not covered" > if (switchBotBLE !== false) {</span>
|
|
1777
|
-
<span class="cstat-no" title="statement not covered" > switchBotBLE</span>
|
|
1778
|
-
<span class="cstat-no" title="statement not covered" > .discover({ model: this.device.bleModel, id: this.device.bleMac })</span>
|
|
1779
|
-
<span class="cstat-no" title="statement not covered" > .then(async (device_list: SwitchbotDevice[]) => {</span>
|
|
1780
|
-
<span class="cstat-no" title="statement not covered" > return await this.retryBLE({</span>
|
|
1781
|
-
<span class="cstat-no" title="statement not covered" > max: this.maxRetryBLE(),</span>
|
|
1782
|
-
<span class="cstat-no" title="statement not covered" > fn: async () => {</span>
|
|
1783
|
-
<span class="cstat-no" title="statement not covered" > if (this.LockMechanism.LockTargetState === this.hap.Characteristic.LockTargetState.SECURED) {</span>
|
|
1784
|
-
<span class="cstat-no" title="statement not covered" > return await (device_list[0] as WoSmartLock).lock()</span>
|
|
1785
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1786
|
-
<span class="cstat-no" title="statement not covered" > return await (device_list[0] as WoSmartLock).unlock()</span>
|
|
1787
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1788
|
-
<span class="cstat-no" title="statement not covered" > },</span>
|
|
1789
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1790
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1791
|
-
<span class="cstat-no" title="statement not covered" > .then(async () => {</span>
|
|
1792
|
-
<span class="cstat-no" title="statement not covered" > this.successLog(`LockTargetState: ${this.LockMechanism.LockTargetState} sent over SwitchBot BLE, sent successfully`)</span>
|
|
1793
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1794
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1795
|
-
<span class="cstat-no" title="statement not covered" > .catch(async (e: any) => {</span>
|
|
1796
|
-
<span class="cstat-no" title="statement not covered" > await this.apiError(e)</span>
|
|
1797
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed BLEpushChanges with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)</span>
|
|
1798
|
-
<span class="cstat-no" title="statement not covered" > await this.BLEPushConnection()</span>
|
|
1799
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1800
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1801
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`wasn't able to establish BLE Connection, node-switchbot: ${JSON.stringify(switchBotBLE)}`)</span>
|
|
1802
|
-
<span class="cstat-no" title="statement not covered" > await this.BLEPushConnection()</span>
|
|
1803
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1804
|
-
<span class="cstat-no" title="statement not covered" > } catch (error) {</span>
|
|
1805
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed to format device ID as MAC, Error: ${error}`)</span>
|
|
1806
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1807
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1808
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`No changes (BLEpushChanges), LockTargetState: ${this.LockMechanism.LockTargetState}, LockCurrentState: ${this.LockMechanism.LockCurrentState}`)</span>
|
|
1809
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1810
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1811
|
-
|
|
1812
|
-
<span class="cstat-no" title="statement not covered" > async openAPIpushChanges(LatchUnlock?: boolean): Promise<void> {</span>
|
|
1813
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('openAPIpushChanges')</span>
|
|
1814
|
-
<span class="cstat-no" title="statement not covered" > if ((this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) || LatchUnlock) {</span>
|
|
1815
|
-
// Determine the command based on the LockTargetState or the forceUnlock parameter
|
|
1816
|
-
<span class="cstat-no" title="statement not covered" > const command = LatchUnlock ? 'unlock' : this.LockMechanism.LockTargetState ? 'lock' : 'unlock'</span>
|
|
1817
|
-
<span class="cstat-no" title="statement not covered" > const bodyChange: bodyChange = {</span>
|
|
1818
|
-
<span class="cstat-no" title="statement not covered" > command: `${command}`,</span>
|
|
1819
|
-
<span class="cstat-no" title="statement not covered" > parameter: 'default',</span>
|
|
1820
|
-
<span class="cstat-no" title="statement not covered" > commandType: 'command',</span>
|
|
1821
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1822
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`SwitchBot OpenAPI bodyChange: ${JSON.stringify(bodyChange)}`)</span>
|
|
1823
|
-
<span class="cstat-no" title="statement not covered" > try {</span>
|
|
1824
|
-
<span class="cstat-no" title="statement not covered" > const response = await this.pushChangeRequest(bodyChange)</span>
|
|
1825
|
-
<span class="cstat-no" title="statement not covered" > const deviceStatus: any = response.body</span>
|
|
1826
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)</span>
|
|
1827
|
-
<span class="cstat-no" title="statement not covered" > if (await this.successfulStatusCodes(deviceStatus)) {</span>
|
|
1828
|
-
<span class="cstat-no" title="statement not covered" > this.debugSuccessLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)</span>
|
|
1829
|
-
<span class="cstat-no" title="statement not covered" > await this.updateHomeKitCharacteristics()</span>
|
|
1830
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1831
|
-
<span class="cstat-no" title="statement not covered" > await this.statusCode(deviceStatus.statusCode)</span>
|
|
1832
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1833
|
-
<span class="cstat-no" title="statement not covered" > } catch (e: any) {</span>
|
|
1834
|
-
<span class="cstat-no" title="statement not covered" > await this.apiError(e)</span>
|
|
1835
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`failed openAPIpushChanges with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)</span>
|
|
1836
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1837
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1838
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`No changes (openAPIpushChanges), LockCurrentState: ${this.LockMechanism.LockCurrentState}, TargetPosition: ${this.LockMechanism.LockTargetState}`)</span>
|
|
1839
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1840
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1841
|
-
|
|
1842
|
-
/**
|
|
1843
|
-
* Handle requests to set the value of the "On" characteristic
|
|
1844
|
-
*/
|
|
1845
|
-
<span class="cstat-no" title="statement not covered" > async LockTargetStateSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1846
|
-
<span class="cstat-no" title="statement not covered" > if (this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) {</span>
|
|
1847
|
-
<span class="cstat-no" title="statement not covered" > this.infoLog(`Set LockTargetState: ${value}`)</span>
|
|
1848
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1849
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`No Changes, LockTargetState: ${value}`)</span>
|
|
1850
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1851
|
-
|
|
1852
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.LockTargetState = value</span>
|
|
1853
|
-
<span class="cstat-no" title="statement not covered" > this.doLockUpdate.next()</span>
|
|
1854
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1855
|
-
|
|
1856
|
-
/**
|
|
1857
|
-
* Handle requests to set the value of the "On" characteristic
|
|
1858
|
-
*/
|
|
1859
|
-
<span class="cstat-no" title="statement not covered" > async OnSet(value: CharacteristicValue): Promise<void> {</span>
|
|
1860
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Latch Button Set On: ${value}`)</span>
|
|
1861
|
-
<span class="cstat-no" title="statement not covered" > if (value) {</span>
|
|
1862
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Attempting to open the latch')</span>
|
|
1863
|
-
|
|
1864
|
-
<span class="cstat-no" title="statement not covered" > this.openAPIpushChanges(value as boolean).then(async () => {</span>
|
|
1865
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Latch opened successfully')</span>
|
|
1866
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`SwitchService is: ${this.Switch?.Service ? 'available' : 'not available'}`)</span>
|
|
1867
|
-
|
|
1868
|
-
// simulate button press to turn the switch back off
|
|
1869
|
-
<span class="cstat-no" title="statement not covered" > if (this.Switch?.Service) {</span>
|
|
1870
|
-
<span class="cstat-no" title="statement not covered" > const SwitchService = this.Switch.Service</span>
|
|
1871
|
-
// Simulate a button press by waiting a short period before turning the switch off
|
|
1872
|
-
<span class="cstat-no" title="statement not covered" > setTimeout(async () => {</span>
|
|
1873
|
-
<span class="cstat-no" title="statement not covered" > SwitchService.getCharacteristic(this.hap.Characteristic.On).updateValue(false)</span>
|
|
1874
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Latch button switched off automatically.')</span>
|
|
1875
|
-
<span class="cstat-no" title="statement not covered" > }, 500) // 500 ms delay</span>
|
|
1876
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1877
|
-
<span class="cstat-no" title="statement not covered" > }).catch(async (e: any) => {</span>
|
|
1878
|
-
// Log the error if the operation failed
|
|
1879
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog(`Error opening latch: ${e.message ?? e}`)</span>
|
|
1880
|
-
// Ensure we turn the switch back off even in case of an error
|
|
1881
|
-
<span class="cstat-no" title="statement not covered" > if (this.Switch?.Service) {</span>
|
|
1882
|
-
<span class="cstat-no" title="statement not covered" > this.Switch.Service.getCharacteristic(this.hap.Characteristic.On).updateValue(false)</span>
|
|
1883
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Latch button switched off after an error.')</span>
|
|
1884
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1885
|
-
<span class="cstat-no" title="statement not covered" > })</span>
|
|
1886
|
-
<span class="cstat-no" title="statement not covered" > } else {</span>
|
|
1887
|
-
<span class="cstat-no" title="statement not covered" > this.debugLog('Switch is off, nothing to do')</span>
|
|
1888
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1889
|
-
|
|
1890
|
-
<span class="cstat-no" title="statement not covered" > this.Switch!.On = value</span>
|
|
1891
|
-
<span class="cstat-no" title="statement not covered" > this.doLockUpdate.next()</span>
|
|
1892
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1893
|
-
|
|
1894
|
-
<span class="cstat-no" title="statement not covered" > async updateHomeKitCharacteristics(): Promise<void> {</span>
|
|
1895
|
-
// LockCurrentState
|
|
1896
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.LockMechanism.Service, this.hap.Characteristic.LockTargetState, this.LockMechanism.LockTargetState, 'LockTargetState')</span>
|
|
1897
|
-
// LockCurrentState
|
|
1898
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.LockMechanism.Service, this.hap.Characteristic.LockCurrentState, this.LockMechanism.LockCurrentState, 'LockCurrentState')</span>
|
|
1899
|
-
// ContactSensorState
|
|
1900
|
-
<span class="cstat-no" title="statement not covered" > if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {</span>
|
|
1901
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.ContactSensor.Service, this.hap.Characteristic.ContactSensorState, this.ContactSensor.ContactSensorState, 'ContactSensorState')</span>
|
|
1902
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1903
|
-
// BatteryLevel
|
|
1904
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.Battery.Service, this.hap.Characteristic.BatteryLevel, this.Battery.BatteryLevel, 'BatteryLevel')</span>
|
|
1905
|
-
// StatusLowBattery
|
|
1906
|
-
<span class="cstat-no" title="statement not covered" > await this.updateCharacteristic(this.Battery.Service, this.hap.Characteristic.StatusLowBattery, this.Battery.StatusLowBattery, 'StatusLowBattery')</span>
|
|
1907
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1908
|
-
|
|
1909
|
-
<span class="cstat-no" title="statement not covered" > async BLEPushConnection() {</span>
|
|
1910
|
-
<span class="cstat-no" title="statement not covered" > if (this.platform.config.credentials?.token && this.device.connectionType === 'BLE/OpenAPI') {</span>
|
|
1911
|
-
<span class="cstat-no" title="statement not covered" > this.warnLog('Using OpenAPI Connection to Push Changes')</span>
|
|
1912
|
-
<span class="cstat-no" title="statement not covered" > await this.openAPIpushChanges()</span>
|
|
1913
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1914
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1915
|
-
|
|
1916
|
-
<span class="cstat-no" title="statement not covered" > async BLERefreshConnection(switchbot: SwitchBotBLE): Promise<void> {</span>
|
|
1917
|
-
<span class="cstat-no" title="statement not covered" > this.errorLog(`wasn't able to establish BLE Connection, node-switchbot: ${switchbot}`)</span>
|
|
1918
|
-
<span class="cstat-no" title="statement not covered" > if (this.platform.config.credentials?.token && this.device.connectionType === 'BLE/OpenAPI') {</span>
|
|
1919
|
-
<span class="cstat-no" title="statement not covered" > this.warnLog('Using OpenAPI Connection to Refresh Status')</span>
|
|
1920
|
-
<span class="cstat-no" title="statement not covered" > await this.openAPIRefreshStatus()</span>
|
|
1921
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1922
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1923
|
-
|
|
1924
|
-
<span class="cstat-no" title="statement not covered" > async offlineOff(): Promise<void> {</span>
|
|
1925
|
-
<span class="cstat-no" title="statement not covered" > if (this.device.offline) {</span>
|
|
1926
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, this.hap.Characteristic.LockTargetState.SECURED)</span>
|
|
1927
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, this.hap.Characteristic.LockCurrentState.SECURED)</span>
|
|
1928
|
-
<span class="cstat-no" title="statement not covered" > if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {</span>
|
|
1929
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.Service.updateCharacteristic(this.hap.Characteristic.ContactSensorState, this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED)</span>
|
|
1930
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1931
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1932
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1933
|
-
|
|
1934
|
-
<span class="cstat-no" title="statement not covered" > async apiError(e: any): Promise<void> {</span>
|
|
1935
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, e)</span>
|
|
1936
|
-
<span class="cstat-no" title="statement not covered" > this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, e)</span>
|
|
1937
|
-
<span class="cstat-no" title="statement not covered" > if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {</span>
|
|
1938
|
-
<span class="cstat-no" title="statement not covered" > this.ContactSensor.Service.updateCharacteristic(this.hap.Characteristic.ContactSensorState, e)</span>
|
|
1939
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1940
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.Service.updateCharacteristic(this.hap.Characteristic.BatteryLevel, e)</span>
|
|
1941
|
-
<span class="cstat-no" title="statement not covered" > this.Battery.Service.updateCharacteristic(this.hap.Characteristic.StatusLowBattery, e)</span>
|
|
1942
|
-
<span class="cstat-no" title="statement not covered" > }</span>
|
|
1943
|
-
<span class="cstat-no" title="statement not covered" >}</span>
|
|
1944
|
-
</pre></td></tr></table></pre>
|
|
1945
|
-
|
|
1946
|
-
<div class='push'></div><!-- for sticky footer -->
|
|
1947
|
-
</div><!-- /wrapper -->
|
|
1948
|
-
<div class='footer quiet pad2 space-top1 center small'>
|
|
1949
|
-
Code coverage generated by
|
|
1950
|
-
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
1951
|
-
at 2025-08-21T05:12:41.588Z
|
|
1952
|
-
</div>
|
|
1953
|
-
<script src="../../prettify.js"></script>
|
|
1954
|
-
<script>
|
|
1955
|
-
window.onload = function () {
|
|
1956
|
-
prettyPrint();
|
|
1957
|
-
};
|
|
1958
|
-
</script>
|
|
1959
|
-
<script src="../../sorter.js"></script>
|
|
1960
|
-
<script src="../../block-navigation.js"></script>
|
|
1961
|
-
</body>
|
|
1962
|
-
</html>
|
|
1963
|
-
|