@uboness/homebridge-mqtt 0.1.2 → 0.2.0
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/CHANGELOG.md +13 -0
- package/dist/Mqtt.d.ts +4 -1
- package/dist/Mqtt.d.ts.map +1 -1
- package/dist/Mqtt.js +4 -4
- package/dist/Mqtt.js.map +1 -1
- package/dist/MqttDevice.d.ts +2 -1
- package/dist/MqttDevice.d.ts.map +1 -1
- package/dist/MqttDevice.js +9 -4
- package/dist/MqttDevice.js.map +1 -1
- package/dist/MqttPlatform.js +5 -5
- package/dist/MqttPlatform.js.map +1 -1
- package/dist/service/HeaterCooler.d.ts +12 -0
- package/dist/service/HeaterCooler.d.ts.map +1 -0
- package/dist/service/HeaterCooler.js +62 -0
- package/dist/service/HeaterCooler.js.map +1 -0
- package/dist/service/Lightbulb.d.ts +2 -2
- package/dist/service/Lightbulb.d.ts.map +1 -1
- package/dist/service/Lightbulb.js +51 -8
- package/dist/service/Lightbulb.js.map +1 -1
- package/dist/service/WindowCovering.d.ts +1 -1
- package/dist/service/WindowCovering.d.ts.map +1 -1
- package/dist/service/WindowCovering.js +15 -6
- package/dist/service/WindowCovering.js.map +1 -1
- package/dist/service/WindowCoveringMomentary.d.ts +13 -0
- package/dist/service/WindowCoveringMomentary.d.ts.map +1 -0
- package/dist/service/WindowCoveringMomentary.js +54 -0
- package/dist/service/WindowCoveringMomentary.js.map +1 -0
- package/dist/service/WindowCoveringTernary.d.ts +13 -0
- package/dist/service/WindowCoveringTernary.d.ts.map +1 -0
- package/dist/service/WindowCoveringTernary.js +74 -0
- package/dist/service/WindowCoveringTernary.js.map +1 -0
- package/dist/service/characteristic/active.d.ts +3 -3
- package/dist/service/characteristic/active.js +1 -1
- package/dist/service/characteristic/archetype/BooleanValue.js +1 -1
- package/dist/service/characteristic/archetype/Converter.d.ts +6 -4
- package/dist/service/characteristic/archetype/Converter.d.ts.map +1 -1
- package/dist/service/characteristic/archetype/Converter.js +52 -3
- package/dist/service/characteristic/archetype/Converter.js.map +1 -1
- package/dist/service/characteristic/archetype/NumericValue.d.ts.map +1 -1
- package/dist/service/characteristic/archetype/NumericValue.js +9 -3
- package/dist/service/characteristic/archetype/NumericValue.js.map +1 -1
- package/dist/service/characteristic/archetype/Signal.d.ts +16 -0
- package/dist/service/characteristic/archetype/Signal.d.ts.map +1 -0
- package/dist/service/characteristic/archetype/Signal.js +35 -0
- package/dist/service/characteristic/archetype/Signal.js.map +1 -0
- package/dist/service/characteristic/archetype/{OneZeroValue.d.ts → ZeroOneValue.d.ts} +2 -2
- package/dist/service/characteristic/archetype/{OneZeroValue.d.ts.map → ZeroOneValue.d.ts.map} +1 -1
- package/dist/service/characteristic/archetype/{OneZeroValue.js → ZeroOneValue.js} +18 -9
- package/dist/service/characteristic/archetype/{OneZeroValue.js.map → ZeroOneValue.js.map} +1 -1
- package/dist/service/characteristic/archetype/common.d.ts +2 -3
- package/dist/service/characteristic/archetype/common.d.ts.map +1 -1
- package/dist/service/characteristic/archetype/common.js +1 -5
- package/dist/service/characteristic/archetype/common.js.map +1 -1
- package/dist/service/characteristic/archetype/index.d.ts +7 -6
- package/dist/service/characteristic/archetype/index.d.ts.map +1 -1
- package/dist/service/characteristic/archetype/index.js +7 -6
- package/dist/service/characteristic/archetype/index.js.map +1 -1
- package/dist/service/characteristic/carbonDioxideDetected.d.ts +3 -3
- package/dist/service/characteristic/carbonDioxideDetected.js +1 -1
- package/dist/service/characteristic/carbonMonoxideDetected.d.ts +3 -3
- package/dist/service/characteristic/carbonMonoxideDetected.js +1 -1
- package/dist/service/characteristic/chargingState.d.ts +3 -3
- package/dist/service/characteristic/chargingState.js +1 -1
- package/dist/service/characteristic/closeSignal.d.ts +9 -0
- package/dist/service/characteristic/closeSignal.d.ts.map +1 -0
- package/dist/service/characteristic/closeSignal.js +9 -0
- package/dist/service/characteristic/closeSignal.js.map +1 -0
- package/dist/service/characteristic/contactSensorState.d.ts +3 -3
- package/dist/service/characteristic/contactSensorState.js +1 -1
- package/dist/service/characteristic/currentHeaterCoolerState.d.ts +8 -0
- package/dist/service/characteristic/currentHeaterCoolerState.d.ts.map +1 -0
- package/dist/service/characteristic/currentHeaterCoolerState.js +12 -0
- package/dist/service/characteristic/currentHeaterCoolerState.js.map +1 -0
- package/dist/service/characteristic/index.d.ts +8 -3
- package/dist/service/characteristic/index.d.ts.map +1 -1
- package/dist/service/characteristic/index.js +8 -3
- package/dist/service/characteristic/index.js.map +1 -1
- package/dist/service/characteristic/leakDetected.d.ts +3 -3
- package/dist/service/characteristic/leakDetected.d.ts.map +1 -1
- package/dist/service/characteristic/leakDetected.js +2 -2
- package/dist/service/characteristic/leakDetected.js.map +1 -1
- package/dist/service/characteristic/lockPhysicalControls.d.ts +3 -3
- package/dist/service/characteristic/lockPhysicalControls.d.ts.map +1 -1
- package/dist/service/characteristic/lockPhysicalControls.js +2 -2
- package/dist/service/characteristic/lockPhysicalControls.js.map +1 -1
- package/dist/service/characteristic/lockTargetState.d.ts +3 -3
- package/dist/service/characteristic/lockTargetState.d.ts.map +1 -1
- package/dist/service/characteristic/lockTargetState.js +2 -2
- package/dist/service/characteristic/lockTargetState.js.map +1 -1
- package/dist/service/characteristic/momentaryOn.d.ts +1 -1
- package/dist/service/characteristic/momentaryOn.d.ts.map +1 -1
- package/dist/service/characteristic/momentaryOn.js +8 -7
- package/dist/service/characteristic/momentaryOn.js.map +1 -1
- package/dist/service/characteristic/occupancyDetected.d.ts +3 -3
- package/dist/service/characteristic/occupancyDetected.d.ts.map +1 -1
- package/dist/service/characteristic/occupancyDetected.js +2 -2
- package/dist/service/characteristic/occupancyDetected.js.map +1 -1
- package/dist/service/characteristic/openSignal.d.ts +9 -0
- package/dist/service/characteristic/openSignal.d.ts.map +1 -0
- package/dist/service/characteristic/openSignal.js +9 -0
- package/dist/service/characteristic/openSignal.js.map +1 -0
- package/dist/service/characteristic/positionState.d.ts +2 -2
- package/dist/service/characteristic/positionState.d.ts.map +1 -1
- package/dist/service/characteristic/positionState.js +2 -2
- package/dist/service/characteristic/positionState.js.map +1 -1
- package/dist/service/characteristic/rotationDirection.d.ts +3 -3
- package/dist/service/characteristic/rotationDirection.d.ts.map +1 -1
- package/dist/service/characteristic/rotationDirection.js +2 -2
- package/dist/service/characteristic/rotationDirection.js.map +1 -1
- package/dist/service/characteristic/rotationSpeed.d.ts +7 -2
- package/dist/service/characteristic/rotationSpeed.d.ts.map +1 -1
- package/dist/service/characteristic/rotationSpeed.js +52 -27
- package/dist/service/characteristic/rotationSpeed.js.map +1 -1
- package/dist/service/characteristic/smokeDetected.d.ts +3 -3
- package/dist/service/characteristic/smokeDetected.d.ts.map +1 -1
- package/dist/service/characteristic/smokeDetected.js +2 -2
- package/dist/service/characteristic/smokeDetected.js.map +1 -1
- package/dist/service/characteristic/statusFault.d.ts +3 -3
- package/dist/service/characteristic/statusFault.d.ts.map +1 -1
- package/dist/service/characteristic/statusFault.js +2 -2
- package/dist/service/characteristic/statusFault.js.map +1 -1
- package/dist/service/characteristic/statusLowBattery.d.ts +3 -3
- package/dist/service/characteristic/statusLowBattery.d.ts.map +1 -1
- package/dist/service/characteristic/statusLowBattery.js +2 -2
- package/dist/service/characteristic/statusLowBattery.js.map +1 -1
- package/dist/service/characteristic/statusTampered.d.ts +3 -3
- package/dist/service/characteristic/statusTampered.d.ts.map +1 -1
- package/dist/service/characteristic/statusTampered.js +2 -2
- package/dist/service/characteristic/statusTampered.js.map +1 -1
- package/dist/service/characteristic/swingMode.d.ts +3 -3
- package/dist/service/characteristic/swingMode.d.ts.map +1 -1
- package/dist/service/characteristic/swingMode.js +2 -2
- package/dist/service/characteristic/swingMode.js.map +1 -1
- package/dist/service/characteristic/targetFanState.d.ts +3 -3
- package/dist/service/characteristic/targetFanState.d.ts.map +1 -1
- package/dist/service/characteristic/targetFanState.js +2 -2
- package/dist/service/characteristic/targetFanState.js.map +1 -1
- package/dist/service/characteristic/targetHeaterCoolerState.d.ts +8 -0
- package/dist/service/characteristic/targetHeaterCoolerState.d.ts.map +1 -0
- package/dist/service/characteristic/targetHeaterCoolerState.js +11 -0
- package/dist/service/characteristic/targetHeaterCoolerState.js.map +1 -0
- package/dist/service/characteristic/temperatureDisplayUnits.d.ts +3 -3
- package/dist/service/characteristic/temperatureDisplayUnits.d.ts.map +1 -1
- package/dist/service/characteristic/temperatureDisplayUnits.js +2 -2
- package/dist/service/characteristic/temperatureDisplayUnits.js.map +1 -1
- package/dist/service/characteristic/ternaryState.d.ts +23 -0
- package/dist/service/characteristic/ternaryState.d.ts.map +1 -0
- package/dist/service/characteristic/ternaryState.js +81 -0
- package/dist/service/characteristic/ternaryState.js.map +1 -0
- package/dist/service/index.d.ts.map +1 -1
- package/dist/service/index.js +7 -1
- package/dist/service/index.js.map +1 -1
- package/package.json +1 -1
- package/tsconfig.json +2 -1
|
@@ -2,32 +2,33 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.momentaryOn = void 0;
|
|
4
4
|
const common_js_1 = require("../../common.js");
|
|
5
|
-
const
|
|
5
|
+
const archetype_1 = require("./archetype");
|
|
6
|
+
const isWrite = (config) => 'set' in config;
|
|
6
7
|
const isRead = (config) => 'get' in config;
|
|
7
8
|
const momentaryOn = async (platform, mqtt, accessory, service, config, ctx) => {
|
|
8
9
|
var _a, _b;
|
|
9
|
-
const [setTopic, setJson, fullSetTopic] = (0,
|
|
10
|
-
const [getTopic, getJson, fullGetTopic] = isRead(config) ? (0,
|
|
10
|
+
const [setTopic, setJson, fullSetTopic] = isWrite(config) ? (0, archetype_1.parseTopic)(config.set, ctx) : [undefined, undefined, undefined];
|
|
11
|
+
const [getTopic, getJson, fullGetTopic] = isRead(config) ? (0, archetype_1.parseTopic)(config.get, ctx) : [undefined, undefined, undefined];
|
|
11
12
|
const publishedValue = (_a = setJson === null || setJson === void 0 ? void 0 : setJson.stringify(config.value)) !== null && _a !== void 0 ? _a : `${config.value}`;
|
|
12
13
|
const on = ((_b = service.getCharacteristic(platform.Characteristic.On)) !== null && _b !== void 0 ? _b : service.addCharacteristic(platform.Characteristic.On))
|
|
13
14
|
.onSet((value, ctx) => {
|
|
14
15
|
if (value) {
|
|
15
16
|
(0, common_js_1.nextTick)(() => on.updateValue(false));
|
|
16
|
-
if (!(ctx === null || ctx === void 0 ? void 0 : ctx.fromMqtt)) {
|
|
17
|
+
if (!(ctx === null || ctx === void 0 ? void 0 : ctx.fromMqtt) && setTopic) {
|
|
17
18
|
platform.logger.debug(`Publishing [${mqtt.id}][${accessory.displayName}][${service.displayName}][momentaryOn][${config.value}] value [${publishedValue}] to topic [${fullSetTopic}]`);
|
|
18
|
-
mqtt.publish(setTopic, publishedValue);
|
|
19
|
+
mqtt.publish(setTopic, publishedValue, { retain: false });
|
|
19
20
|
}
|
|
20
21
|
}
|
|
21
22
|
});
|
|
22
23
|
const detachable = !getTopic ? common_js_1.Detachable.NOOP : await mqtt.subscribe(getTopic, value => {
|
|
23
|
-
const mqttValue = !getJson ? (0,
|
|
24
|
+
const mqttValue = !getJson ? (0, archetype_1.parseMqttValue)(value) : getJson.parse(value);
|
|
24
25
|
const match = `${mqttValue}` === `${config.value}`;
|
|
25
26
|
if (match) {
|
|
26
27
|
platform.logger.debug(`Setting [${mqtt.id}][${accessory.displayName}][${service.displayName}][stickyOn][${config.value}] to [true] with MQTT value [${mqttValue}] from topic [${fullGetTopic}]`);
|
|
27
28
|
on.setValue(true, { fromMqtt: true });
|
|
28
29
|
}
|
|
29
30
|
});
|
|
30
|
-
return
|
|
31
|
+
return archetype_1.DetachableCharacteristic.mixin(on, detachable);
|
|
31
32
|
};
|
|
32
33
|
exports.momentaryOn = momentaryOn;
|
|
33
34
|
//# sourceMappingURL=momentaryOn.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"momentaryOn.js","sourceRoot":"","sources":["../../../src/service/characteristic/momentaryOn.ts"],"names":[],"mappings":";;;AAAA,+CAAuD;AACvD,
|
|
1
|
+
{"version":3,"file":"momentaryOn.js","sourceRoot":"","sources":["../../../src/service/characteristic/momentaryOn.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type OccupancyDetected = {
|
|
3
|
-
occupancyDetected:
|
|
3
|
+
occupancyDetected: ZeroOneValue.ReadOnlyConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const occupancyDetected: import("
|
|
5
|
+
export declare const occupancyDetected: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=occupancyDetected.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"occupancyDetected.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/occupancyDetected.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"occupancyDetected.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/occupancyDetected.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,iBAAiB,GAAG;IAC5B,iBAAiB,EAAE,YAAY,CAAC,cAAc,CAAA;CACjD,CAAA;AAED,eAAO,MAAM,iBAAiB,mLAAoG,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.occupancyDetected = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.occupancyDetected =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.occupancyDetected = archetype_1.ZeroOneValue.readOnly('occupancyDetected', platform => platform.Characteristic.OccupancyDetected);
|
|
6
6
|
//# sourceMappingURL=occupancyDetected.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"occupancyDetected.js","sourceRoot":"","sources":["../../../src/service/characteristic/occupancyDetected.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"occupancyDetected.js","sourceRoot":"","sources":["../../../src/service/characteristic/occupancyDetected.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,iBAAiB,GAAG,wBAAY,CAAC,QAAQ,CAAC,mBAAmB,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openSignal.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/openSignal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,MAAM,MAAM,UAAU,GAAG;IACrB,IAAI,EAAE,MAAM,CAAC,MAAM,CAAA;CACtB,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,UAAU,6DAAoC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.openSignal = void 0;
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
/**
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
exports.openSignal = archetype_1.Signal.configurator('openSignal');
|
|
9
|
+
//# sourceMappingURL=openSignal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openSignal.js","sourceRoot":"","sources":["../../../src/service/characteristic/openSignal.ts"],"names":[],"mappings":";;;AAAA,2CAAqC;AAMrC;;GAEG;AACU,QAAA,UAAU,GAAG,kBAAM,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { EnumValue } from './archetype
|
|
1
|
+
import { EnumValue } from './archetype';
|
|
2
2
|
declare const values: EnumValue.ValuesResolver;
|
|
3
3
|
export type PositionState = {
|
|
4
4
|
positionState: EnumValue.ReadOnlyConfig<typeof values>;
|
|
5
5
|
};
|
|
6
|
-
export declare const positionState: import("
|
|
6
|
+
export declare const positionState: import(".").CharacteristicConfigurator<EnumValue.ReadOnlyConfig<EnumValue.ValuesResolver>>;
|
|
7
7
|
export {};
|
|
8
8
|
//# sourceMappingURL=positionState.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"positionState.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/positionState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"positionState.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/positionState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,QAAA,MAAM,MAAM,EAAE,SAAS,CAAC,cAItB,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG;IACxB,aAAa,EAAE,SAAS,CAAC,cAAc,CAAC,OAAO,MAAM,CAAC,CAAA;CACzD,CAAA;AAED,eAAO,MAAM,aAAa,4FAAiG,CAAC"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.positionState = void 0;
|
|
4
|
-
const
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
5
|
const values = platform => ({
|
|
6
6
|
closing: platform.Characteristic.PositionState.DECREASING,
|
|
7
7
|
opening: platform.Characteristic.PositionState.INCREASING,
|
|
8
8
|
stopped: platform.Characteristic.PositionState.STOPPED
|
|
9
9
|
});
|
|
10
|
-
exports.positionState =
|
|
10
|
+
exports.positionState = archetype_1.EnumValue.readOnly('positionState', values, platform => platform.Characteristic.PositionState);
|
|
11
11
|
//# sourceMappingURL=positionState.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"positionState.js","sourceRoot":"","sources":["../../../src/service/characteristic/positionState.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"positionState.js","sourceRoot":"","sources":["../../../src/service/characteristic/positionState.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AAExC,MAAM,MAAM,GAA6B,QAAQ,CAAC,EAAE,CAAC,CAAC;IAClD,OAAO,EAAE,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,UAAU;IACzD,OAAO,EAAE,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,UAAU;IACzD,OAAO,EAAE,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,OAAO;CACzD,CAAC,CAAC;AAMU,QAAA,aAAa,GAAG,qBAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type RotationDirection = {
|
|
3
|
-
rotationDirection:
|
|
3
|
+
rotationDirection: ZeroOneValue.ReadWriteConfig<'counter-clockwise', 'clockwise'>;
|
|
4
4
|
};
|
|
5
|
-
export declare const rotationDirection: import("
|
|
5
|
+
export declare const rotationDirection: import(".").CharacteristicConfigurator<ZeroOneValue.ReadWriteConfig<"counter-clockwise", "clockwise"> | ZeroOneValue.ReadOnlyConfig<"counter-clockwise", "clockwise"> | ZeroOneValue.WriteOnlyConfig<"counter-clockwise", "clockwise">>;
|
|
6
6
|
//# sourceMappingURL=rotationDirection.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rotationDirection.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/rotationDirection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"rotationDirection.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/rotationDirection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,iBAAiB,GAAG;IAC5B,iBAAiB,EAAE,YAAY,CAAC,eAAe,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAA;CACpF,CAAA;AAED,eAAO,MAAM,iBAAiB,yOAG5B,CAAC"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.rotationDirection = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.rotationDirection =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.rotationDirection = archetype_1.ZeroOneValue.readWrite('rotationDirection', platform => platform.Characteristic.RotationDirection, {
|
|
6
6
|
onKey: 'counter-clockwise',
|
|
7
7
|
offKey: 'clockwise'
|
|
8
8
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rotationDirection.js","sourceRoot":"","sources":["../../../src/service/characteristic/rotationDirection.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"rotationDirection.js","sourceRoot":"","sources":["../../../src/service/characteristic/rotationDirection.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,iBAAiB,GAAG,wBAAY,CAAC,SAAS,CAAmC,mBAAmB,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,iBAAiB,EAAE;IAClK,KAAK,EAAE,mBAAmB;IAC1B,MAAM,EAAE,WAAW;CACtB,CAAC,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Converter } from './archetype
|
|
1
|
+
import { Converter } from './archetype';
|
|
2
2
|
import { CharacteristicConfigurator } from './index.js';
|
|
3
3
|
/**
|
|
4
4
|
* This is a special "extended" percent type characteristic. The converter can be a normal Converter.Percent.Type, but
|
|
@@ -17,7 +17,12 @@ export type RotationSpeed = {
|
|
|
17
17
|
export type RotationSpeedConfig = {
|
|
18
18
|
get: string;
|
|
19
19
|
set: string;
|
|
20
|
-
converter?: Converter.Percent.Type | number |
|
|
20
|
+
converter?: Converter.Percent.Type | Array<string | number> | ObjectConverter;
|
|
21
21
|
};
|
|
22
22
|
export declare const rotationSpeed: CharacteristicConfigurator<RotationSpeedConfig>;
|
|
23
|
+
type ObjectConverter = {
|
|
24
|
+
disableOff: boolean;
|
|
25
|
+
values: Array<string | number>;
|
|
26
|
+
};
|
|
27
|
+
export {};
|
|
23
28
|
//# sourceMappingURL=rotationSpeed.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rotationSpeed.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/rotationSpeed.ts"],"names":[],"mappings":"AAGA,OAAO,EAEH,SAAS,EAIZ,MAAM,
|
|
1
|
+
{"version":3,"file":"rotationSpeed.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/rotationSpeed.ts"],"names":[],"mappings":"AAGA,OAAO,EAEH,SAAS,EAIZ,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,0BAA0B,EAAE,MAAM,YAAY,CAAC;AAExD;;;;;;;;;;GAUG;AAEH,MAAM,MAAM,aAAa,GAAG;IACxB,aAAa,EAAE,mBAAmB,CAAA;CACrC,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG;IAC9B,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IAOZ,SAAS,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,eAAe,CAAA;CAChF,CAAA;AAED,eAAO,MAAM,aAAa,EAAE,0BAA0B,CAAC,mBAAmB,CAsDzE,CAAC;AAuEF,KAAK,eAAe,GAAG;IACnB,UAAU,EAAE,OAAO,CAAC;IACpB,MAAM,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAA;CACjC,CAAA"}
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.rotationSpeed = void 0;
|
|
4
4
|
const common_js_1 = require("../../common.js");
|
|
5
|
-
const
|
|
5
|
+
const archetype_1 = require("./archetype");
|
|
6
6
|
const rotationSpeed = async (platform, mqtt, accessory, service, config, serviceCtx) => {
|
|
7
7
|
var _a;
|
|
8
|
-
const [setTopic, setJson, fullSetTopic] = (0,
|
|
9
|
-
const [getTopic, getJson, fullGetTopic] = (0,
|
|
10
|
-
const { props, converter } = resolveConverter(platform, `${mqtt.id}:${accessory.displayName}:${service.name}`, config.converter);
|
|
8
|
+
const [setTopic, setJson, fullSetTopic] = (0, archetype_1.parseTopic)(config.set, serviceCtx);
|
|
9
|
+
const [getTopic, getJson, fullGetTopic] = (0, archetype_1.parseTopic)(config.get, serviceCtx);
|
|
10
|
+
const { props, converter, quantize } = resolveConverter(platform, `${mqtt.id}:${accessory.displayName}:${service.name}`, config.converter);
|
|
11
11
|
if (!converter) {
|
|
12
12
|
platform.logger.error(`Unknown 'rotationSpeed' converter [${JSON.stringify(config.converter)}] set for service [${mqtt.id}:${accessory.displayName}:${service.name}]`);
|
|
13
13
|
}
|
|
@@ -17,7 +17,15 @@ const rotationSpeed = async (platform, mqtt, accessory, service, config, service
|
|
|
17
17
|
var _a;
|
|
18
18
|
serviceCtx.emitter.emit('rotationSpeed.set', value, ctx);
|
|
19
19
|
if (!(ctx === null || ctx === void 0 ? void 0 : ctx.fromMqtt) && converter) {
|
|
20
|
+
const quantized = quantize(value);
|
|
21
|
+
if (quantized !== value) {
|
|
22
|
+
setTimeout(() => { speed.setValue(quantized); }, 300);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
20
25
|
const mqttValue = converter.fromHap(value);
|
|
26
|
+
if (mqttValue === undefined) {
|
|
27
|
+
throw new platform.api.hap.HapStatusError(-70410 /* platform.api.hap.HAPStatus.INVALID_VALUE_IN_REQUEST */);
|
|
28
|
+
}
|
|
21
29
|
const publishedValue = (_a = setJson === null || setJson === void 0 ? void 0 : setJson.stringify(mqttValue)) !== null && _a !== void 0 ? _a : mqttValue;
|
|
22
30
|
platform.logger.debug(`Publishing [${mqtt.id}][${accessory.displayName}][${service.displayName}][rotationSpeed] value [${publishedValue}] to topic [${fullSetTopic}]`);
|
|
23
31
|
mqtt.publish(setTopic, publishedValue);
|
|
@@ -26,7 +34,7 @@ const rotationSpeed = async (platform, mqtt, accessory, service, config, service
|
|
|
26
34
|
const detachable = await mqtt.subscribe(getTopic, value => {
|
|
27
35
|
var _a;
|
|
28
36
|
if (converter) {
|
|
29
|
-
const mqttValue = (_a = getJson === null || getJson === void 0 ? void 0 : getJson.parse(value)) !== null && _a !== void 0 ? _a : (0,
|
|
37
|
+
const mqttValue = (_a = getJson === null || getJson === void 0 ? void 0 : getJson.parse(value)) !== null && _a !== void 0 ? _a : (0, archetype_1.parseMqttValue)(value);
|
|
30
38
|
const hapValue = converter.toHap(mqttValue);
|
|
31
39
|
if (hapValue === null) {
|
|
32
40
|
platform.logger.error(`Cannot update value from topic [${fullGetTopic}] for [${mqtt.id}][${accessory.displayName}][${service.displayName}][rotationSpeed]. Unknown value [${mqttValue}]`);
|
|
@@ -43,52 +51,69 @@ const rotationSpeed = async (platform, mqtt, accessory, service, config, service
|
|
|
43
51
|
serviceCtx.emitter.on(eventName, handler);
|
|
44
52
|
return { detach: () => serviceCtx.emitter.off(eventName, handler) };
|
|
45
53
|
};
|
|
46
|
-
return
|
|
54
|
+
return archetype_1.DetachableCharacteristic.mixin(speed, detachable, onEvent);
|
|
47
55
|
};
|
|
48
56
|
exports.rotationSpeed = rotationSpeed;
|
|
49
57
|
function resolveConverter(platform, id, type = 'homekit') {
|
|
50
|
-
if (type === 'homekit' || type === 'decimal' ||
|
|
58
|
+
if (type === 'homekit' || type === 'decimal' || archetype_1.Converter.Percent.isScaleType(type)) {
|
|
51
59
|
return {
|
|
52
60
|
props: {
|
|
53
61
|
minStep: 1,
|
|
54
62
|
minValue: 0,
|
|
55
63
|
maxValue: 100
|
|
56
64
|
},
|
|
57
|
-
|
|
65
|
+
quantize: (value) => value,
|
|
66
|
+
converter: archetype_1.Converter.Percent.resolve(type)
|
|
58
67
|
};
|
|
59
68
|
}
|
|
60
|
-
if ((
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
minStep: Math.round(100 / type),
|
|
65
|
-
minValue: 0,
|
|
66
|
-
maxValue: 100
|
|
67
|
-
},
|
|
68
|
-
converter: {
|
|
69
|
-
toHap: (value) => Math.round(value * jump),
|
|
70
|
-
fromHap: (value) => Math.round(value / jump)
|
|
71
|
-
}
|
|
69
|
+
if (!isObjectConverter(type)) {
|
|
70
|
+
type = {
|
|
71
|
+
disableOff: false,
|
|
72
|
+
values: type
|
|
72
73
|
};
|
|
73
74
|
}
|
|
74
|
-
const jump = 100 / type.length;
|
|
75
|
+
const jump = Math.floor(type.disableOff ? (100 / (type.values.length)) : (100 / (type.values.length - 1)));
|
|
76
|
+
const mqttValues = type.values;
|
|
77
|
+
const hapValues = [];
|
|
78
|
+
mqttValues.forEach((mqttValue, i) => {
|
|
79
|
+
const multiplier = type.disableOff ? i + 1 : i;
|
|
80
|
+
const hapValue = multiplier * jump;
|
|
81
|
+
hapValues.push(i === mqttValues.length - 1 ? 100 : hapValue);
|
|
82
|
+
});
|
|
83
|
+
const quantize = (value) => {
|
|
84
|
+
const adjusted = Math.round(value / jump) * jump;
|
|
85
|
+
if (adjusted === 0 && type.disableOff) {
|
|
86
|
+
return hapValues[0];
|
|
87
|
+
}
|
|
88
|
+
return adjusted;
|
|
89
|
+
};
|
|
75
90
|
return {
|
|
76
91
|
props: {
|
|
77
|
-
minStep:
|
|
92
|
+
minStep: 1,
|
|
78
93
|
minValue: 0,
|
|
79
94
|
maxValue: 100
|
|
80
95
|
},
|
|
96
|
+
quantize,
|
|
81
97
|
converter: {
|
|
82
98
|
toHap: (value) => {
|
|
83
|
-
const
|
|
84
|
-
if (
|
|
99
|
+
const index = mqttValues.indexOf(value);
|
|
100
|
+
if (index < 0) {
|
|
85
101
|
platform.logger.error(`Could not resolve fan speed level of [${id}]. Unknown speed [${value}]`);
|
|
86
|
-
return
|
|
102
|
+
return null;
|
|
87
103
|
}
|
|
88
|
-
return
|
|
104
|
+
return hapValues[index];
|
|
89
105
|
},
|
|
90
|
-
fromHap: (
|
|
106
|
+
fromHap: (quantized) => {
|
|
107
|
+
if (quantized === 100) {
|
|
108
|
+
return mqttValues[mqttValues.length - 1];
|
|
109
|
+
}
|
|
110
|
+
const valueIndex = Math.round(quantized / jump);
|
|
111
|
+
return mqttValues[type.disableOff ? valueIndex - 1 : valueIndex];
|
|
112
|
+
}
|
|
91
113
|
}
|
|
92
114
|
};
|
|
93
115
|
}
|
|
116
|
+
const isObjectConverter = (value) => {
|
|
117
|
+
return (0, common_js_1.isObject)(value) && 'disableOff' in value;
|
|
118
|
+
};
|
|
94
119
|
//# sourceMappingURL=rotationSpeed.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rotationSpeed.js","sourceRoot":"","sources":["../../../src/service/characteristic/rotationSpeed.ts"],"names":[],"mappings":";;;AACA,+CAAqD;AAErD,
|
|
1
|
+
{"version":3,"file":"rotationSpeed.js","sourceRoot":"","sources":["../../../src/service/characteristic/rotationSpeed.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type SmokeDetected = {
|
|
3
|
-
smokeDetected:
|
|
3
|
+
smokeDetected: ZeroOneValue.ReadOnlyConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const smokeDetected: import("
|
|
5
|
+
export declare const smokeDetected: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=smokeDetected.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"smokeDetected.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/smokeDetected.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"smokeDetected.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/smokeDetected.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,aAAa,GAAG;IACxB,aAAa,EAAE,YAAY,CAAC,cAAc,CAAA;CAC7C,CAAA;AAED,eAAO,MAAM,aAAa,mLAA4F,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.smokeDetected = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.smokeDetected =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.smokeDetected = archetype_1.ZeroOneValue.readOnly('smokeDetected', platform => platform.Characteristic.SmokeDetected);
|
|
6
6
|
//# sourceMappingURL=smokeDetected.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"smokeDetected.js","sourceRoot":"","sources":["../../../src/service/characteristic/smokeDetected.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"smokeDetected.js","sourceRoot":"","sources":["../../../src/service/characteristic/smokeDetected.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,aAAa,GAAG,wBAAY,CAAC,QAAQ,CAAC,eAAe,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type StatusFault = {
|
|
3
|
-
statusFault:
|
|
3
|
+
statusFault: ZeroOneValue.ReadOnlyConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const statusFault: import(".").CharacteristicConfigurator<
|
|
5
|
+
export declare const statusFault: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=statusFault.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusFault.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusFault.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"statusFault.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusFault.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,WAAW,GAAG;IACtB,WAAW,EAAE,YAAY,CAAC,cAAc,CAAA;CAC3C,CAAA;AAED,eAAO,MAAM,WAAW,mLAAwF,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.statusFault = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.statusFault =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.statusFault = archetype_1.ZeroOneValue.readOnly('statusFault', platform => platform.Characteristic.StatusFault);
|
|
6
6
|
//# sourceMappingURL=statusFault.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusFault.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusFault.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"statusFault.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusFault.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,WAAW,GAAG,wBAAY,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type StatusLowBattery = {
|
|
3
|
-
statusLowBattery:
|
|
3
|
+
statusLowBattery: ZeroOneValue.ReadOnlyConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const statusLowBattery: import(".").CharacteristicConfigurator<
|
|
5
|
+
export declare const statusLowBattery: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=statusLowBattery.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusLowBattery.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusLowBattery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"statusLowBattery.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusLowBattery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,gBAAgB,EAAE,YAAY,CAAC,cAAc,CAAA;CAChD,CAAA;AAED,eAAO,MAAM,gBAAgB,mLAAkG,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.statusLowBattery = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.statusLowBattery =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.statusLowBattery = archetype_1.ZeroOneValue.readOnly('statusLowBattery', platform => platform.Characteristic.StatusLowBattery);
|
|
6
6
|
//# sourceMappingURL=statusLowBattery.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusLowBattery.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusLowBattery.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"statusLowBattery.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusLowBattery.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,gBAAgB,GAAG,wBAAY,CAAC,QAAQ,CAAC,kBAAkB,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type StatusTampered = {
|
|
3
|
-
statusTampered:
|
|
3
|
+
statusTampered: ZeroOneValue.ReadOnlyConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const statusTampered: import(".").CharacteristicConfigurator<
|
|
5
|
+
export declare const statusTampered: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=statusTampered.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusTampered.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusTampered.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"statusTampered.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/statusTampered.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,cAAc,GAAG;IACzB,cAAc,EAAE,YAAY,CAAC,cAAc,CAAC;CAC/C,CAAA;AAED,eAAO,MAAM,cAAc,mLAA8F,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.statusTampered = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.statusTampered =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.statusTampered = archetype_1.ZeroOneValue.readOnly('statusTampered', platform => platform.Characteristic.StatusTampered);
|
|
6
6
|
//# sourceMappingURL=statusTampered.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"statusTampered.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusTampered.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"statusTampered.js","sourceRoot":"","sources":["../../../src/service/characteristic/statusTampered.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,cAAc,GAAG,wBAAY,CAAC,QAAQ,CAAC,gBAAgB,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type SwingMode = {
|
|
3
|
-
swingMode:
|
|
3
|
+
swingMode: ZeroOneValue.ReadWriteConfig;
|
|
4
4
|
};
|
|
5
|
-
export declare const swingMode: import(".").CharacteristicConfigurator<
|
|
5
|
+
export declare const swingMode: import(".").CharacteristicConfigurator<ZeroOneValue.ReadOnlyConfig<string, string> | ZeroOneValue.WriteOnlyConfig<string, string> | ZeroOneValue.ReadWriteConfig<string, string>>;
|
|
6
6
|
//# sourceMappingURL=swingMode.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"swingMode.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/swingMode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"swingMode.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/swingMode.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,SAAS,GAAG;IACpB,SAAS,EAAE,YAAY,CAAC,eAAe,CAAA;CAC1C,CAAA;AAED,eAAO,MAAM,SAAS,mLAAqF,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.swingMode = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.swingMode =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.swingMode = archetype_1.ZeroOneValue.readWrite('swingMode', platform => platform.Characteristic.SwingMode);
|
|
6
6
|
//# sourceMappingURL=swingMode.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"swingMode.js","sourceRoot":"","sources":["../../../src/service/characteristic/swingMode.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"swingMode.js","sourceRoot":"","sources":["../../../src/service/characteristic/swingMode.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,SAAS,GAAG,wBAAY,CAAC,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ZeroOneValue } from './archetype';
|
|
2
2
|
export type TargetFanState = {
|
|
3
|
-
targetFanState:
|
|
3
|
+
targetFanState: ZeroOneValue.ReadWriteConfig<'auto', 'manual'>;
|
|
4
4
|
};
|
|
5
|
-
export declare const targetFanState: import("
|
|
5
|
+
export declare const targetFanState: import(".").CharacteristicConfigurator<ZeroOneValue.ReadWriteConfig<"auto", "manual"> | ZeroOneValue.ReadOnlyConfig<"auto", "manual"> | ZeroOneValue.WriteOnlyConfig<"auto", "manual">>;
|
|
6
6
|
//# sourceMappingURL=targetFanState.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"targetFanState.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/targetFanState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"targetFanState.d.ts","sourceRoot":"","sources":["../../../src/service/characteristic/targetFanState.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,cAAc,GAAG;IACzB,cAAc,EAAE,YAAY,CAAC,eAAe,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;CACjE,CAAA;AAED,eAAO,MAAM,cAAc,yLAGzB,CAAC"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.targetFanState = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.targetFanState =
|
|
4
|
+
const archetype_1 = require("./archetype");
|
|
5
|
+
exports.targetFanState = archetype_1.ZeroOneValue.readWrite('targetFanState', platform => platform.Characteristic.TargetFanState, {
|
|
6
6
|
onKey: 'auto',
|
|
7
7
|
offKey: 'manual'
|
|
8
8
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"targetFanState.js","sourceRoot":"","sources":["../../../src/service/characteristic/targetFanState.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"targetFanState.js","sourceRoot":"","sources":["../../../src/service/characteristic/targetFanState.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAM9B,QAAA,cAAc,GAAG,wBAAY,CAAC,SAAS,CAAmB,gBAAgB,EAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,cAAc,EAAE;IACzI,KAAK,EAAE,MAAM;IACb,MAAM,EAAE,QAAQ;CACnB,CAAC,CAAC"}
|