@pietrolubini/homebridge-ecoflow 1.7.0-alpha.0 → 1.7.0-alpha.6
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/.prettierrc.json +1 -1
- package/README.md +60 -0
- package/config.schema.json +4 -22
- package/dist/accessories/batteries/delta2/delta2AccessoryBase.js +5 -15
- package/dist/accessories/batteries/delta2/delta2AccessoryBase.js.map +1 -1
- package/dist/accessories/batteries/delta2/services/outletAcService.js +2 -1
- package/dist/accessories/batteries/delta2/services/outletAcService.js.map +1 -1
- package/dist/accessories/batteries/delta2/services/outletCarService.js +1 -1
- package/dist/accessories/batteries/delta2/services/outletCarService.js.map +1 -1
- package/dist/accessories/batteries/delta2/services/outletUsbService.js +1 -1
- package/dist/accessories/batteries/delta2/services/outletUsbService.js.map +1 -1
- package/dist/accessories/batteries/deltapro/deltaProAccessory.js +6 -21
- package/dist/accessories/batteries/deltapro/deltaProAccessory.js.map +1 -1
- package/dist/accessories/batteries/deltapro/services/outletAcService.js +2 -1
- package/dist/accessories/batteries/deltapro/services/outletAcService.js.map +1 -1
- package/dist/accessories/batteries/deltapro/services/outletCarService.js +1 -1
- package/dist/accessories/batteries/deltapro/services/outletCarService.js.map +1 -1
- package/dist/accessories/batteries/deltapro3/deltaPro3Accessory.d.ts +1 -0
- package/dist/accessories/batteries/deltapro3/deltaPro3Accessory.js +7 -5
- package/dist/accessories/batteries/deltapro3/deltaPro3Accessory.js.map +1 -1
- package/dist/accessories/batteries/deltapro3/services/outletAcHvService.js +2 -1
- package/dist/accessories/batteries/deltapro3/services/outletAcHvService.js.map +1 -1
- package/dist/accessories/batteries/deltapro3/services/outletAcLvService.js +2 -1
- package/dist/accessories/batteries/deltapro3/services/outletAcLvService.js.map +1 -1
- package/dist/accessories/batteries/deltapro3/services/outletDc12vService.js +2 -1
- package/dist/accessories/batteries/deltapro3/services/outletDc12vService.js.map +1 -1
- package/dist/accessories/batteries/deltaproultra/deltaProUltraAccessory.js +4 -6
- package/dist/accessories/batteries/deltaproultra/deltaProUltraAccessory.js.map +1 -1
- package/dist/accessories/batteries/deltaproultra/services/outletUsbService.js +2 -1
- package/dist/accessories/batteries/deltaproultra/services/outletUsbService.js.map +1 -1
- package/dist/accessories/ecoFlowAccessoryBase.d.ts +1 -0
- package/dist/accessories/ecoFlowAccessoryBase.js +7 -3
- package/dist/accessories/ecoFlowAccessoryBase.js.map +1 -1
- package/dist/accessories/glacier/glacierAccessory.js +7 -12
- package/dist/accessories/glacier/glacierAccessory.js.map +1 -1
- package/dist/accessories/glacier/services/glacierThermostatFridgeServiceBase.d.ts +0 -1
- package/dist/accessories/glacier/services/glacierThermostatFridgeServiceBase.js +1 -4
- package/dist/accessories/glacier/services/glacierThermostatFridgeServiceBase.js.map +1 -1
- package/dist/accessories/powerocean/powerOceanAccessory.js +3 -0
- package/dist/accessories/powerocean/powerOceanAccessory.js.map +1 -1
- package/dist/accessories/powerstream/powerStreamAccessory.js +2 -4
- package/dist/accessories/powerstream/powerStreamAccessory.js.map +1 -1
- package/dist/accessories/powerstream/services/powerDemandService.js +2 -2
- package/dist/accessories/powerstream/services/powerDemandService.js.map +1 -1
- package/dist/accessories/smartplug/smartPlugAccessory.js +2 -4
- package/dist/accessories/smartplug/smartPlugAccessory.js.map +1 -1
- package/dist/accessories/wave/interfaces/waveHttpApiContracts.d.ts +73 -0
- package/dist/accessories/wave/interfaces/waveHttpApiContracts.js +51 -0
- package/dist/accessories/wave/interfaces/waveHttpApiContracts.js.map +1 -0
- package/dist/accessories/wave/interfaces/waveMqttApiContracts.d.ts +69 -0
- package/dist/accessories/wave/interfaces/waveMqttApiContracts.js +26 -0
- package/dist/accessories/wave/interfaces/waveMqttApiContracts.js.map +1 -0
- package/dist/accessories/wave/services/fanModeService.d.ts +8 -0
- package/dist/accessories/wave/services/fanModeService.js +53 -0
- package/dist/accessories/wave/services/fanModeService.js.map +1 -0
- package/dist/accessories/wave/services/thermostatAirConditionerService.d.ts +13 -0
- package/dist/accessories/wave/services/thermostatAirConditionerService.js +48 -0
- package/dist/accessories/wave/services/thermostatAirConditionerService.js.map +1 -0
- package/dist/accessories/wave/simulations/waveSimulator.d.ts +6 -0
- package/dist/accessories/wave/simulations/waveSimulator.js +72 -0
- package/dist/accessories/wave/simulations/waveSimulator.js.map +1 -0
- package/dist/accessories/wave/waveAccessory.d.ts +31 -0
- package/dist/accessories/wave/waveAccessory.js +192 -0
- package/dist/accessories/wave/waveAccessory.js.map +1 -0
- package/dist/apis/ecoFlowHttpApiManager.js +17 -7
- package/dist/apis/ecoFlowHttpApiManager.js.map +1 -1
- package/dist/apis/interfaces/generalContacts.d.ts +1 -0
- package/dist/apis/interfaces/generalContacts.js +3 -0
- package/dist/apis/interfaces/generalContacts.js.map +1 -0
- package/dist/characteristics/characteristicContracts.d.ts +4 -0
- package/dist/characteristics/characteristicContracts.js +6 -1
- package/dist/characteristics/characteristicContracts.js.map +1 -1
- package/dist/characteristics/characteristicExtensions.d.ts +8 -0
- package/dist/characteristics/characteristicExtensions.js +22 -0
- package/dist/characteristics/characteristicExtensions.js.map +1 -0
- package/dist/characteristics/characteristicExtensions.spec.d.ts +1 -0
- package/dist/characteristics/customCharacteristic.d.ts +1 -0
- package/dist/characteristics/customCharacteristic.js +8 -1
- package/dist/characteristics/customCharacteristic.js.map +1 -1
- package/dist/config.d.ts +2 -1
- package/dist/config.js +1 -0
- package/dist/config.js.map +1 -1
- package/dist/helpers/converter.d.ts +3 -0
- package/dist/helpers/converter.js +13 -0
- package/dist/helpers/converter.js.map +1 -0
- package/dist/helpers/converter.spec.d.ts +1 -0
- package/dist/homebridge-ui/public/index.html +1 -1
- package/dist/homebridge-ui/public/index.js +1 -1
- package/dist/platform.d.ts +2 -2
- package/dist/platform.js +11 -6
- package/dist/platform.js.map +1 -1
- package/dist/services/fanPositionedService.d.ts +14 -0
- package/dist/services/fanPositionedService.js +35 -0
- package/dist/services/fanPositionedService.js.map +1 -0
- package/dist/services/fanPositionedService.spec.d.ts +6 -0
- package/dist/services/fanServiceBase.d.ts +2 -2
- package/dist/services/fanServiceBase.js +27 -9
- package/dist/services/fanServiceBase.js.map +1 -1
- package/dist/services/lightBulbServiceBase.d.ts +2 -2
- package/dist/services/lightBulbServiceBase.js +27 -9
- package/dist/services/lightBulbServiceBase.js.map +1 -1
- package/dist/services/outletBatteryServiceBase.d.ts +2 -1
- package/dist/services/outletBatteryServiceBase.js +2 -2
- package/dist/services/outletBatteryServiceBase.js.map +1 -1
- package/dist/services/outletReadOnlyService.d.ts +0 -1
- package/dist/services/outletReadOnlyService.js +2 -4
- package/dist/services/outletReadOnlyService.js.map +1 -1
- package/dist/services/outletServiceBase.d.ts +4 -2
- package/dist/services/outletServiceBase.js +18 -5
- package/dist/services/outletServiceBase.js.map +1 -1
- package/dist/services/serviceBase.d.ts +2 -1
- package/dist/services/serviceBase.js +11 -4
- package/dist/services/serviceBase.js.map +1 -1
- package/dist/services/switchServiceBase.d.ts +1 -1
- package/dist/services/switchServiceBase.js +13 -4
- package/dist/services/switchServiceBase.js.map +1 -1
- package/dist/services/thermostatAirConditionerServiceBase.d.ts +29 -0
- package/dist/services/thermostatAirConditionerServiceBase.js +142 -0
- package/dist/services/thermostatAirConditionerServiceBase.js.map +1 -0
- package/dist/services/thermostatAirConditionerServiceBase.spec.d.ts +1 -0
- package/dist/services/thermostatFridgeServiceBase.d.ts +6 -5
- package/dist/services/thermostatFridgeServiceBase.js +47 -21
- package/dist/services/thermostatFridgeServiceBase.js.map +1 -1
- package/junit.xml +1105 -859
- package/package.json +4 -3
- package/dist/accessories/batteries/deltapro/services/outletUsbService.d.ts +0 -7
- package/dist/accessories/batteries/deltapro/services/outletUsbService.js +0 -14
- package/dist/accessories/batteries/deltapro/services/outletUsbService.js.map +0 -1
- package/dist/accessories/batteries/deltaproultra/services/outletAcService.d.ts +0 -8
- package/dist/accessories/batteries/deltaproultra/services/outletAcService.js +0 -14
- package/dist/accessories/batteries/deltaproultra/services/outletAcService.js.map +0 -1
- package/dist/accessories/glacier/services/outletBatteryService.d.ts +0 -8
- package/dist/accessories/glacier/services/outletBatteryService.js +0 -14
- package/dist/accessories/glacier/services/outletBatteryService.js.map +0 -1
- /package/dist/accessories/{batteries/deltapro/services/outletUsbService.spec.d.ts → wave/services/fanModeService.spec.d.ts} +0 -0
- /package/dist/accessories/{batteries/deltaproultra/services/outletAcService.spec.d.ts → wave/services/thermostatAirConditionerService.spec.d.ts} +0 -0
- /package/dist/accessories/{glacier/services/outletBatteryService.spec.d.ts → wave/waveAccessory.spec.d.ts} +0 -0
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Converter = void 0;
|
|
4
|
+
class Converter {
|
|
5
|
+
static convertFahrenheitToCelsius(fahrenheit) {
|
|
6
|
+
if (fahrenheit === undefined || fahrenheit === null) {
|
|
7
|
+
return undefined;
|
|
8
|
+
}
|
|
9
|
+
return ((fahrenheit - 32) * 5) / 9;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.Converter = Converter;
|
|
13
|
+
//# sourceMappingURL=converter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"converter.js","sourceRoot":"","sources":["../../src/helpers/converter.ts"],"names":[],"mappings":";;;AAAA,MAAa,SAAS;IACb,MAAM,CAAC,0BAA0B,CAAC,UAAmB;QAC1D,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;YACpD,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,OAAO,CAAC,CAAC,UAAU,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;CACF;AAPD,8BAOC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
(()=>{"use strict";var e={
|
|
1
|
+
(()=>{"use strict";var e={84(e,r,n){Object.defineProperty(r,"__esModule",{value:!0}),r.PluginConfigDevicesRenderer=void 0;const i=n(536);class t extends i.PluginConfigRendererBase{form;$tabs;$tabPanels;_hideDeviceSettingsPerModel;constructor(e){super(e),this.$tabs=$("#devicesTabs"),this.$tabPanels=$("#devicesPanels"),this._hideDeviceSettingsPerModel={"Delta 2":["powerStream","powerOcean","outlet"],"Delta 2 Max":["powerStream","powerOcean","outlet"],"Delta Pro":["powerStream","powerOcean","outlet"],"Delta Pro 3":["powerStream","powerOcean","outlet"],"Delta Pro Ultra":["powerStream","powerOcean","outlet"],Discovery:["battery","powerStream","powerOcean","outlet"],PowerStream:["battery","powerOcean","outlet"],PowerOcean:["battery","powerStream","outlet"],"Smart Plug":["battery","powerStream","powerOcean"],Glacier:["powerStream","powerOcean","outlet"],Wave:["powerStream","powerOcean","outlet"]}}get hideDeviceSettingsPerModel(){return this._hideDeviceSettingsPerModel}render(e){this.renderDevicesSettings({homebridgeProvider:e.homebridgeProvider,configSchema:e.configSchema,configuration:e.configuration,hideDeviceSettingsPerModel:this.hideDeviceSettingsPerModel})}renderDevicesSettings(e,r){$("#devicesLabel").text(e.configSchema.schema.properties.devices.title);const n=!r||r<0?0:r;this.renderDeviceTabs(e,n)}renderDeviceTabs(e,r){this.clearDeviceTabs();const n='\n <li class="nav-item">\n <a class="nav-link {activeClass}" data-toggle="tab" href="#deviceTabPanel{index}" id="deviceTab{index}">{name}</a>\n </li>\n ';e.configuration.devices.forEach((i,t)=>{const o=n.replace(/{activeClass}/g,t===r?"active":"").replace(/{index}/g,t.toString()).replace(/{name}/g,i.name??`Device${t+1}`);this.$tabs.append(o),this.renderDeviceTabPanel(e,i,t,r,this.$tabs.find(`#deviceTab${t}`))}),this.renderAddNewDeviceTab(n,e)}clearDeviceTabs(){this.$tabs.empty(),this.$tabPanels.empty(),this.form?.end()}renderAddNewDeviceTab(e,r){const n=e.replace(/{activeClass}/g,"").replace(/{index}/g,"Add").replace(/{name}/g,"Add Device");this.$tabs.append(n),this.$tabs.find("#deviceTabAdd").on("click",()=>{r.configuration.devices.push(this.getDefaultDeviceConfiguration(r.configSchema)),this.renderDevicesSettings(r,r.configuration.devices.length-1)})}renderDeviceTabPanel(e,r,n,i,t){const o='\n <div class="tab-pane container fade {activeClass} card card-body list-group-item" id="deviceTabPanel{index}">\n <button type="button" class="close pull-right" id="deviceTabPanelClose{index}">\n <span>×</span>\n <span class="sr-only">Close</span>\n </button>\n </div>\n '.replace(/{activeClass}/g,n===i?"in show active":"").replace(/{index}/g,n.toString());this.$tabPanels.append(o);const a=this.$tabPanels.find(`#deviceTabPanel${n}`),s=this.clone(e.configSchema.schema.properties.devices.items),c=s.properties.model;this.renderModelDropDown(t,a,n,e,s,c,r),this.renderRemoveButton(a,n,e),this.renderForm(t,n,i,e,s,r)}renderModelDropDown(e,r,n,i,t,o,a){this.componentRenderer.renderDropDown(r,"model"+n,o,a.model,r=>{a.model=r,this.renderForm(e,n,n,i,t,a)})}renderRemoveButton(e,r,n){e.find(`#deviceTabPanelClose${r}`).on("click",()=>{n.configuration.devices.splice(r,1),this.renderDevicesSettings(n,r-1)})}renderForm(e,r,n,i,t,o){delete(t=this.clone(t)).properties.model,i.hideDeviceSettingsPerModel[o.model].forEach(e=>{delete t.properties[e]}),e.off("click").on("click",()=>{this.form?.end(),this.form=i.homebridgeProvider.createForm({schema:t},o),this.form.onChange(async n=>{const t=i.configuration.devices[r].name;this.applyChanges(i.configuration.devices[r],n,["model"]),await this.updatePluginConfig(i),n.name!==t&&e.text(n.name)})}),r===n&&e.trigger("click")}getDefaultDeviceConfiguration(e){const r={},n=e.schema.properties.devices.items.properties;return Object.keys(n).filter(e=>!!n[e]?.default).forEach(e=>{r[e]=n[e]?.default}),r}applyChanges(e,r,n){Object.assign(e,r);for(const i in e)void 0!==r[i]||n.includes(i)||delete e[i]}}r.PluginConfigDevicesRenderer=t},102(e,r,n){Object.defineProperty(r,"__esModule",{value:!0}),r.PluginConfigNameRenderer=void 0;const i=n(536);class t extends i.PluginConfigRendererBase{render(e){this.componentRenderer.renderTextBox($("#generalSettings"),"name",e.configSchema.schema.properties.name,e.configuration.name,async r=>{e.configuration.name=r,await this.updatePluginConfig(e)})}}r.PluginConfigNameRenderer=t},536(e,r){Object.defineProperty(r,"__esModule",{value:!0}),r.PluginConfigRendererBase=void 0,r.PluginConfigRendererBase=class{componentRenderer;constructor(e){this.componentRenderer=e}async updatePluginConfig(e){const r=this.clone(e.configuration);delete r.platform,await e.homebridgeProvider.updatePluginConfig([r])}clone(e){return JSON.parse(JSON.stringify(e))}}},653(e,r){Object.defineProperty(r,"__esModule",{value:!0}),r.PluginConfigRenderer=void 0,r.PluginConfigRenderer=class{renderers;constructor(e){this.renderers=e}render(e){void 0===e.configuration&&(e.configuration={name:void 0,devices:[]}),this.renderers.forEach(r=>r.render(e))}}},999(e,r){Object.defineProperty(r,"__esModule",{value:!0}),r.ComponentRenderer=void 0,r.ComponentRenderer=class{renderTextBox(e,r,n,i,t){const o='\n <div class="form-group">\n <label for="device{id}" class="{requiredClass}">{title}</label>\n <input type="text" class="form-control" id="device{id}" placeholder="{description}" required="{required}" />\n </div>'.replace(/{id}/g,r).replace(/{title}/g,n.title).replace(/{description}/g,n.description??"").replace(/{requiredClass}/g,n.required?"required-label":"").replace(/{required}/g,(n.required??!1).toString());e.append(o);const a=e.find(`#device${r}`);a.val(i),a.on("change",()=>t(a.val()?.toString()||""))}renderDropDown(e,r,n,i,t){const o='\n <div class="form-group">\n <label for="device{id}" class="{requiredClass}">{title}</label>\n <select class="form-control" id="device{id}" required="{required}"></select>\n </div>'.replace(/{id}/g,r).replace(/{title}/g,n.title).replace(/{requiredClass}/g,n.required?"required-label":"").replace(/{required}/g,(n.required??!1).toString());e.append(o);const a=e.find(`#device${r}`);n.enum.forEach(e=>{const r=$("<option>").val(e).text(e);a.append(r)}),a.val(i),a.on("change",()=>t(a.val()?.toString()||""))}}}},r={};function n(i){var t=r[i];if(void 0!==t)return t.exports;var o=r[i]={exports:{}};return e[i](o,o.exports,n),o.exports}(()=>{const e=n(999),r=n(84),i=n(102),t=n(653);window.renderEcoFlowPluginConfig=async function(n){const o=await n.getPluginConfig(),a=await n.getPluginConfigSchema(),s=o[0],c=new e.ComponentRenderer;new t.PluginConfigRenderer([new i.PluginConfigNameRenderer(c),new r.PluginConfigDevicesRenderer(c)]).render({homebridgeProvider:n,configuration:s,configSchema:a})}})()})();
|
package/dist/platform.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { API, Characteristic, DynamicPlatformPlugin,
|
|
1
|
+
import { API, Characteristic, DynamicPlatformPlugin, Logging, PlatformAccessory, PlatformConfig, Service } from 'homebridge';
|
|
2
2
|
import { CustomCharacteristics } from '@ecoflow/characteristics/customCharacteristic';
|
|
3
3
|
/**
|
|
4
4
|
* HomebridgePlatform
|
|
@@ -18,7 +18,7 @@ export declare class EcoFlowHomebridgePlatform implements DynamicPlatformPlugin
|
|
|
18
18
|
private readonly mqttApiManager;
|
|
19
19
|
private readonly batteryStatusProvider;
|
|
20
20
|
constructor(commonLog: Logging, config: PlatformConfig, api: API);
|
|
21
|
-
static
|
|
21
|
+
static InitCharacteristics(api: API): void;
|
|
22
22
|
/**
|
|
23
23
|
* This function is invoked when homebridge restores cached accessories from disk at startup.
|
|
24
24
|
* It should be used to set up event handlers for characteristics and update respective values.
|
package/dist/platform.js
CHANGED
|
@@ -12,8 +12,11 @@ const powerStreamAccessory_1 = require("@ecoflow/accessories/powerstream/powerSt
|
|
|
12
12
|
const powerStreamSimulator_1 = require("@ecoflow/accessories/powerstream/simulations/powerStreamSimulator");
|
|
13
13
|
const smartPlugSimulator_1 = require("@ecoflow/accessories/smartplug/simulations/smartPlugSimulator");
|
|
14
14
|
const smartPlugAccessory_1 = require("@ecoflow/accessories/smartplug/smartPlugAccessory");
|
|
15
|
+
const waveSimulator_1 = require("@ecoflow/accessories/wave/simulations/waveSimulator");
|
|
16
|
+
const waveAccessory_1 = require("@ecoflow/accessories/wave/waveAccessory");
|
|
15
17
|
const ecoFlowHttpApiManager_1 = require("@ecoflow/apis/ecoFlowHttpApiManager");
|
|
16
18
|
const ecoFlowMqttApiManager_1 = require("@ecoflow/apis/ecoFlowMqttApiManager");
|
|
19
|
+
const characteristicExtensions_1 = require("@ecoflow/characteristics/characteristicExtensions");
|
|
17
20
|
const customCharacteristic_1 = require("@ecoflow/characteristics/customCharacteristic");
|
|
18
21
|
const config_1 = require("@ecoflow/config");
|
|
19
22
|
const batteryStatusProvider_1 = require("@ecoflow/helpers/batteryStatusProvider");
|
|
@@ -36,7 +39,7 @@ class EcoFlowHomebridgePlatform {
|
|
|
36
39
|
this.commonLog = commonLog;
|
|
37
40
|
this.config = config;
|
|
38
41
|
this.api = api;
|
|
39
|
-
EcoFlowHomebridgePlatform.
|
|
42
|
+
EcoFlowHomebridgePlatform.InitCharacteristics(api);
|
|
40
43
|
this.ecoFlowConfig = this.config;
|
|
41
44
|
this.Service = api.hap.Service;
|
|
42
45
|
this.Characteristic = {
|
|
@@ -57,11 +60,9 @@ class EcoFlowHomebridgePlatform {
|
|
|
57
60
|
this.registerDevices();
|
|
58
61
|
});
|
|
59
62
|
}
|
|
60
|
-
static
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
customCharacteristic_1.CustomCharacteristics.PowerConsumption.OutputVoltage = (0, customCharacteristic_1.OutputVoltageFactory)(hap);
|
|
64
|
-
customCharacteristic_1.CustomCharacteristics.PowerConsumption.OutputCurrent = (0, customCharacteristic_1.OutputCurrentFactory)(hap);
|
|
63
|
+
static InitCharacteristics(api) {
|
|
64
|
+
(0, customCharacteristic_1.InitCustomCharacteristics)(api.hap);
|
|
65
|
+
(0, characteristicExtensions_1.InitCharacteristicExtensions)(api);
|
|
65
66
|
}
|
|
66
67
|
/**
|
|
67
68
|
* This function is invoked when homebridge restores cached accessories from disk at startup.
|
|
@@ -209,6 +210,10 @@ class EcoFlowHomebridgePlatform {
|
|
|
209
210
|
EcoFlowAccessoryType = smartPlugAccessory_1.SmartPlugAccessory;
|
|
210
211
|
EcoFlowAccessorySimulatorType = smartPlugSimulator_1.SmartPlugSimulator;
|
|
211
212
|
break;
|
|
213
|
+
case config_1.DeviceModel.Wave:
|
|
214
|
+
EcoFlowAccessoryType = waveAccessory_1.WaveAccessory;
|
|
215
|
+
EcoFlowAccessorySimulatorType = waveSimulator_1.WaveSimulator;
|
|
216
|
+
break;
|
|
212
217
|
default:
|
|
213
218
|
log.warn(`"${config.model}" is not supported. Ignoring the device`);
|
|
214
219
|
}
|
package/dist/platform.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"platform.js","sourceRoot":"","sources":["../src/platform.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"platform.js","sourceRoot":"","sources":["../src/platform.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { EcoFlowAccessoryBase } from '@ecoflow/accessories/ecoFlowAccessoryBase';
|
|
2
|
+
import { Enum } from '@ecoflow/apis/interfaces/generalContacts';
|
|
3
|
+
import { FanServiceBase } from '@ecoflow/services/fanServiceBase';
|
|
4
|
+
export declare abstract class FanPositionedServiceBase<TPositionType, TPositionTypeObj extends Enum> extends FanServiceBase {
|
|
5
|
+
private readonly positionLength;
|
|
6
|
+
private readonly positionValues;
|
|
7
|
+
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, serviceSubType: string, positionTypeObj: TPositionTypeObj);
|
|
8
|
+
updatePositionedRotationSpeed(value: TPositionType): void;
|
|
9
|
+
updateRotationSpeed(value: number): void;
|
|
10
|
+
protected processOnSetRotationSpeed(value: number, revert: () => void): Promise<void>;
|
|
11
|
+
protected abstract processOnSetPositionedRotationSpeed(value: TPositionType, revert: () => void): Promise<void>;
|
|
12
|
+
private covertToPositionedValue;
|
|
13
|
+
private covertFromPositionedValue;
|
|
14
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FanPositionedServiceBase = void 0;
|
|
4
|
+
const fanServiceBase_1 = require("@ecoflow/services/fanServiceBase");
|
|
5
|
+
class FanPositionedServiceBase extends fanServiceBase_1.FanServiceBase {
|
|
6
|
+
positionLength;
|
|
7
|
+
positionValues;
|
|
8
|
+
constructor(ecoFlowAccessory, serviceSubType, positionTypeObj) {
|
|
9
|
+
super(ecoFlowAccessory, 100, serviceSubType);
|
|
10
|
+
this.positionValues = Object.values(positionTypeObj)
|
|
11
|
+
.filter(v => typeof v === 'number')
|
|
12
|
+
.map(v => v);
|
|
13
|
+
this.positionLength = 100 / this.positionValues.length;
|
|
14
|
+
}
|
|
15
|
+
updatePositionedRotationSpeed(value) {
|
|
16
|
+
super.updateRotationSpeed(this.covertFromPositionedValue(value));
|
|
17
|
+
}
|
|
18
|
+
updateRotationSpeed(value) {
|
|
19
|
+
super.updateRotationSpeed(this.covertFromPositionedValue(this.covertToPositionedValue(value)));
|
|
20
|
+
}
|
|
21
|
+
async processOnSetRotationSpeed(value, revert) {
|
|
22
|
+
const positionedValue = this.covertToPositionedValue(value);
|
|
23
|
+
await this.processOnSetPositionedRotationSpeed(positionedValue, revert);
|
|
24
|
+
}
|
|
25
|
+
covertToPositionedValue(value) {
|
|
26
|
+
const pos = Math.floor(value / this.positionLength);
|
|
27
|
+
return this.positionValues[Math.max(0, pos - 1)];
|
|
28
|
+
}
|
|
29
|
+
covertFromPositionedValue(value) {
|
|
30
|
+
const pos = value;
|
|
31
|
+
return Math.round((pos + 1) * this.positionLength);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.FanPositionedServiceBase = FanPositionedServiceBase;
|
|
35
|
+
//# sourceMappingURL=fanPositionedService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fanPositionedService.js","sourceRoot":"","sources":["../../src/services/fanPositionedService.ts"],"names":[],"mappings":";;;AAEA,qEAAkE;AAElE,MAAsB,wBAAuE,SAAQ,+BAAc;IAChG,cAAc,CAAS;IACvB,cAAc,CAAkB;IACjD,YAAY,gBAAsC,EAAE,cAAsB,EAAE,eAAiC;QAC3G,KAAK,CAAC,gBAAgB,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;QAC7C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC;aACjD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC;aAClC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAkB,CAAC,CAAC;QAChC,IAAI,CAAC,cAAc,GAAG,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;IACzD,CAAC;IAEM,6BAA6B,CAAC,KAAoB;QACvD,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,CAAC;IACnE,CAAC;IAEM,mBAAmB,CAAC,KAAa;QACtC,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACjG,CAAC;IAEkB,KAAK,CAAC,yBAAyB,CAAC,KAAa,EAAE,MAAkB;QAClF,MAAM,eAAe,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAC5D,MAAM,IAAI,CAAC,mCAAmC,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;IAC1E,CAAC;IAIO,uBAAuB,CAAC,KAAa;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IAEO,yBAAyB,CAAC,KAAoB;QACpD,MAAM,GAAG,GAAG,KAA0B,CAAC;QACvC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IACrD,CAAC;CACF;AAnCD,4DAmCC"}
|
|
@@ -13,6 +13,6 @@ export declare abstract class FanServiceBase extends ServiceBase {
|
|
|
13
13
|
updateState(state: boolean): void;
|
|
14
14
|
updateRotationSpeed(value: number): void;
|
|
15
15
|
protected setRotationSpeed(value: number): void;
|
|
16
|
-
protected
|
|
17
|
-
protected
|
|
16
|
+
protected processOnSetOn(value: boolean, revert: () => void): Promise<void>;
|
|
17
|
+
protected processOnSetRotationSpeed(value: number, revert: () => void): Promise<void>;
|
|
18
18
|
}
|
|
@@ -17,18 +17,26 @@ class FanServiceBase extends serviceBase_1.ServiceBase {
|
|
|
17
17
|
addCharacteristics() {
|
|
18
18
|
const onCharacteristic = this.addCharacteristic(this.platform.Characteristic.On)
|
|
19
19
|
.onGet(() => this.processOnGet(this.state))
|
|
20
|
-
.onSet(value =>
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
.onSet(value => {
|
|
21
|
+
this.processOnSetVerify(this.platform.Characteristic.On.name);
|
|
22
|
+
const revert = () => this.updateState(!value);
|
|
23
|
+
this.processOnSet(async () => {
|
|
24
|
+
this.state = value;
|
|
25
|
+
await this.processOnSetOn(this.state, revert);
|
|
26
|
+
}, revert);
|
|
27
|
+
});
|
|
24
28
|
this.rotationSpeedCharacteristic = this.addCharacteristic(this.platform.Characteristic.RotationSpeed)
|
|
25
29
|
.onGet(() => this.processOnGet(this.rotationSpeedPercents))
|
|
26
|
-
.onSet(percents =>
|
|
27
|
-
this.
|
|
30
|
+
.onSet(percents => {
|
|
31
|
+
this.processOnSetVerify(this.platform.Characteristic.RotationSpeed.name);
|
|
28
32
|
const prevRotationSpeed = this.rotationSpeed;
|
|
29
|
-
|
|
30
|
-
this.
|
|
31
|
-
|
|
33
|
+
const revert = () => this.updateRotationSpeed(prevRotationSpeed);
|
|
34
|
+
this.processOnSet(async () => {
|
|
35
|
+
this.rotationSpeedPercents = percents;
|
|
36
|
+
this.rotationSpeed = this.covertPercentsToValue(this.rotationSpeedPercents, this.maxRotationSpeed);
|
|
37
|
+
await this.processOnSetRotationSpeed(this.rotationSpeed, revert);
|
|
38
|
+
}, revert);
|
|
39
|
+
});
|
|
32
40
|
return [onCharacteristic, this.rotationSpeedCharacteristic];
|
|
33
41
|
}
|
|
34
42
|
updateState(state) {
|
|
@@ -43,6 +51,16 @@ class FanServiceBase extends serviceBase_1.ServiceBase {
|
|
|
43
51
|
setRotationSpeed(value) {
|
|
44
52
|
this.rotationSpeedCharacteristic?.setValue(value);
|
|
45
53
|
}
|
|
54
|
+
/* istanbul ignore next */
|
|
55
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
56
|
+
processOnSetOn(value, revert) {
|
|
57
|
+
return Promise.resolve();
|
|
58
|
+
}
|
|
59
|
+
/* istanbul ignore next */
|
|
60
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
61
|
+
processOnSetRotationSpeed(value, revert) {
|
|
62
|
+
return Promise.resolve();
|
|
63
|
+
}
|
|
46
64
|
}
|
|
47
65
|
exports.FanServiceBase = FanServiceBase;
|
|
48
66
|
//# sourceMappingURL=fanServiceBase.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fanServiceBase.js","sourceRoot":"","sources":["../../src/services/fanServiceBase.ts"],"names":[],"mappings":";;;AACA,+DAA4D;AAG5D,MAAsB,cAAe,SAAQ,yBAAW;IAOjC;IACF;IAPX,KAAK,GAAY,KAAK,CAAC;IACvB,qBAAqB,GAAW,CAAC,CAAC;IAClC,aAAa,GAAG,CAAC,CAAC;IAClB,2BAA2B,GAA0B,IAAI,CAAC;IAElE,YACqB,gBAAsC,EACxC,gBAAwB,EACzC,cAAsB;QAEtB,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,gBAAgB,EAAE,cAAc,CAAC,CAAC;QAJ5D,qBAAgB,GAAhB,gBAAgB,CAAsB;QACxC,qBAAgB,GAAhB,gBAAgB,CAAQ;IAI3C,CAAC;IAEkB,kBAAkB;QACnC,MAAM,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;aAC7E,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC1C,KAAK,CAAC,KAAK,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"fanServiceBase.js","sourceRoot":"","sources":["../../src/services/fanServiceBase.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,6 +13,6 @@ export declare abstract class LightBulbServiceBase extends ServiceBase {
|
|
|
13
13
|
updateState(state: boolean): void;
|
|
14
14
|
updateBrightness(value: number): void;
|
|
15
15
|
protected setBrightness(value: number): void;
|
|
16
|
-
protected
|
|
17
|
-
protected
|
|
16
|
+
protected processOnSetOn(value: boolean, revert: () => void): Promise<void>;
|
|
17
|
+
protected processOnSetBrightness(value: number, revert: () => void): Promise<void>;
|
|
18
18
|
}
|
|
@@ -17,18 +17,26 @@ class LightBulbServiceBase extends serviceBase_1.ServiceBase {
|
|
|
17
17
|
addCharacteristics() {
|
|
18
18
|
const onCharacteristic = this.addCharacteristic(this.platform.Characteristic.On)
|
|
19
19
|
.onGet(() => this.processOnGet(this.state))
|
|
20
|
-
.onSet(value =>
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
|
|
20
|
+
.onSet(value => {
|
|
21
|
+
this.processOnSetVerify(this.platform.Characteristic.On.name);
|
|
22
|
+
const revert = () => this.updateState(!value);
|
|
23
|
+
this.processOnSet(async () => {
|
|
24
|
+
this.state = value;
|
|
25
|
+
await this.processOnSetOn(this.state, revert);
|
|
26
|
+
}, revert);
|
|
27
|
+
});
|
|
24
28
|
this.brightnessCharacteristic = this.addCharacteristic(this.platform.Characteristic.Brightness)
|
|
25
29
|
.onGet(() => this.processOnGet(this.brightnessPercents))
|
|
26
|
-
.onSet(percents =>
|
|
27
|
-
this.
|
|
30
|
+
.onSet(percents => {
|
|
31
|
+
this.processOnSetVerify(this.platform.Characteristic.Brightness.name);
|
|
28
32
|
const prevBrightness = this.brightness;
|
|
29
|
-
|
|
30
|
-
this.
|
|
31
|
-
|
|
33
|
+
const revert = () => this.updateBrightness(prevBrightness);
|
|
34
|
+
this.processOnSet(async () => {
|
|
35
|
+
this.brightnessPercents = percents;
|
|
36
|
+
this.brightness = this.covertPercentsToValue(this.brightnessPercents, this.maxBrightness);
|
|
37
|
+
await this.processOnSetBrightness(this.brightness, revert);
|
|
38
|
+
}, revert);
|
|
39
|
+
});
|
|
32
40
|
return [onCharacteristic, this.brightnessCharacteristic];
|
|
33
41
|
}
|
|
34
42
|
updateState(state) {
|
|
@@ -43,6 +51,16 @@ class LightBulbServiceBase extends serviceBase_1.ServiceBase {
|
|
|
43
51
|
setBrightness(value) {
|
|
44
52
|
this.brightnessCharacteristic?.setValue(value);
|
|
45
53
|
}
|
|
54
|
+
/* istanbul ignore next */
|
|
55
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
56
|
+
processOnSetOn(value, revert) {
|
|
57
|
+
return Promise.resolve();
|
|
58
|
+
}
|
|
59
|
+
/* istanbul ignore next */
|
|
60
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
61
|
+
processOnSetBrightness(value, revert) {
|
|
62
|
+
return Promise.resolve();
|
|
63
|
+
}
|
|
46
64
|
}
|
|
47
65
|
exports.LightBulbServiceBase = LightBulbServiceBase;
|
|
48
66
|
//# sourceMappingURL=lightBulbServiceBase.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lightBulbServiceBase.js","sourceRoot":"","sources":["../../src/services/lightBulbServiceBase.ts"],"names":[],"mappings":";;;AACA,+DAA4D;AAG5D,MAAsB,oBAAqB,SAAQ,yBAAW;IAOvC;IACF;IAPX,KAAK,GAAY,KAAK,CAAC;IACvB,kBAAkB,GAAW,CAAC,CAAC;IAC/B,UAAU,GAAW,CAAC,CAAC;IACvB,wBAAwB,GAA0B,IAAI,CAAC;IAE/D,YACqB,gBAAsC,EACxC,aAAqB,EACtC,cAAsB;QAEtB,KAAK,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,EAAE,gBAAgB,EAAE,cAAc,CAAC,CAAC;QAJlE,qBAAgB,GAAhB,gBAAgB,CAAsB;QACxC,kBAAa,GAAb,aAAa,CAAQ;IAIxC,CAAC;IAEkB,kBAAkB;QACnC,MAAM,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;aAC7E,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC1C,KAAK,CAAC,KAAK,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"lightBulbServiceBase.js","sourceRoot":"","sources":["../../src/services/lightBulbServiceBase.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { EcoFlowAccessoryBase } from '@ecoflow/accessories/ecoFlowAccessoryBase';
|
|
2
|
+
import { CharacteristicPermsType } from '@ecoflow/characteristics/characteristicContracts';
|
|
2
3
|
import { AdditionalBatteryCharacteristicType as BatteryCharacteristicType } from '@ecoflow/config';
|
|
3
4
|
import { BatteryStatusProvider } from '@ecoflow/helpers/batteryStatusProvider';
|
|
4
5
|
import { OutletServiceBase } from '@ecoflow/services/outletServiceBase';
|
|
5
6
|
import { Characteristic } from 'homebridge';
|
|
6
7
|
export declare abstract class OutletBatteryServiceBase extends OutletServiceBase {
|
|
7
8
|
private readonly batteryStatusProvider;
|
|
8
|
-
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, batteryStatusProvider: BatteryStatusProvider, serviceSubType: string, additionalCharacteristics?: BatteryCharacteristicType[]);
|
|
9
|
+
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, batteryStatusProvider: BatteryStatusProvider, serviceSubType: string, onCharacteristicPermsType: CharacteristicPermsType, additionalCharacteristics?: BatteryCharacteristicType[]);
|
|
9
10
|
updateInputConsumption(watt: number): void;
|
|
10
11
|
updateBatteryLevel(batteryLevel: number, dischargeLimit: number): void;
|
|
11
12
|
updateChargingState(isCharging: boolean): void;
|
|
@@ -5,8 +5,8 @@ const config_1 = require("@ecoflow/config");
|
|
|
5
5
|
const outletServiceBase_1 = require("@ecoflow/services/outletServiceBase");
|
|
6
6
|
class OutletBatteryServiceBase extends outletServiceBase_1.OutletServiceBase {
|
|
7
7
|
batteryStatusProvider;
|
|
8
|
-
constructor(ecoFlowAccessory, batteryStatusProvider, serviceSubType, additionalCharacteristics) {
|
|
9
|
-
super(ecoFlowAccessory, additionalCharacteristics, serviceSubType);
|
|
8
|
+
constructor(ecoFlowAccessory, batteryStatusProvider, serviceSubType, onCharacteristicPermsType, additionalCharacteristics) {
|
|
9
|
+
super(ecoFlowAccessory, additionalCharacteristics, serviceSubType, onCharacteristicPermsType);
|
|
10
10
|
this.batteryStatusProvider = batteryStatusProvider;
|
|
11
11
|
}
|
|
12
12
|
updateInputConsumption(watt) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outletBatteryServiceBase.js","sourceRoot":"","sources":["../../src/services/outletBatteryServiceBase.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"outletBatteryServiceBase.js","sourceRoot":"","sources":["../../src/services/outletBatteryServiceBase.ts"],"names":[],"mappings":";;;AAEA,4CAGyB;AAEzB,2EAAwE;AAGxE,MAAsB,wBAAyB,SAAQ,qCAAiB;IAGnD;IAFnB,YACE,gBAAsC,EACrB,qBAA4C,EAC7D,cAAsB,EACtB,yBAAkD,EAClD,yBAAuD;QAEvD,KAAK,CAAC,gBAAgB,EAAE,yBAAyB,EAAE,cAAc,EAAE,yBAAyB,CAAC,CAAC;QAL7E,0BAAqB,GAArB,qBAAqB,CAAuB;IAM/D,CAAC;IAEM,sBAAsB,CAAC,IAAY;QACxC,IAAI,CAAC,0BAA0B,CAC7B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC,qBAAqB,EACnE,sBAAsB,EACtB,GAAG,EAAE,CAAC,IAAI,EACV,kDAA+B,CAAC,uBAAuB,CACxD,CAAC;IACJ,CAAC;IAEM,kBAAkB,CAAC,YAAoB,EAAE,cAAsB;QACpE,IAAI,CAAC,0BAA0B,CAC7B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,YAAY,EACzC,kBAAkB,EAClB,GAAG,EAAE,CAAC,YAAY,EAClB,kDAA+B,CAAC,YAAY,CAC7C,CAAC;QACF,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;IAC5D,CAAC;IAEM,mBAAmB,CAAC,UAAmB;QAC5C,IAAI,CAAC,0BAA0B,CAC7B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,EAC1C,eAAe,EACf,GAAG,EAAE,CAAC,UAAU,EAChB,kDAA+B,CAAC,aAAa,CAC9C,CAAC;IACJ,CAAC;IAEkB,kBAAkB;QACnC,MAAM,eAAe,GAAG,KAAK,CAAC,kBAAkB,EAAE,CAAC;QACnD,MAAM,yBAAyB,GAAG;YAChC,IAAI,CAAC,0BAA0B,CAC7B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC,qBAAqB,EACnE,kDAA+B,CAAC,uBAAuB,CACxD;YACD,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,YAAY,EAAE,kDAA+B,CAAC,YAAY,CAAC;YACxH,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,EAAE,kDAA+B,CAAC,aAAa,CAAC;YAC1H,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,EAAE,kDAA+B,CAAC,gBAAgB,CAAC;SACjI,CAAC;QAEF,OAAO,CAAC,GAAG,eAAe,EAAE,GAAG,yBAAyB,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC;IAC9G,CAAC;IAEO,sBAAsB,CAAC,YAAoB,EAAE,cAAsB;QACzE,IAAI,CAAC,0BAA0B,CAC7B,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,EAC7C,kBAAkB,EAClB,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,YAAY,EAAE,cAAc,CAAC,EAChH,kDAA+B,CAAC,gBAAgB,CACjD,CAAC;IACJ,CAAC;CACF;AA9DD,4DA8DC"}
|
|
@@ -4,5 +4,4 @@ import { BatteryStatusProvider } from '@ecoflow/helpers/batteryStatusProvider';
|
|
|
4
4
|
import { OutletBatteryServiceBase } from '@ecoflow/services/outletBatteryServiceBase';
|
|
5
5
|
export declare class OutletReadOnlyService extends OutletBatteryServiceBase {
|
|
6
6
|
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, batteryStatusProvider: BatteryStatusProvider, serviceSubType: string, additionalCharacteristics?: CharacteristicType[]);
|
|
7
|
-
protected processOnSetOn(): Promise<void>;
|
|
8
7
|
}
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.OutletReadOnlyService = void 0;
|
|
4
|
+
const characteristicContracts_1 = require("@ecoflow/characteristics/characteristicContracts");
|
|
4
5
|
const outletBatteryServiceBase_1 = require("@ecoflow/services/outletBatteryServiceBase");
|
|
5
6
|
class OutletReadOnlyService extends outletBatteryServiceBase_1.OutletBatteryServiceBase {
|
|
6
7
|
constructor(ecoFlowAccessory, batteryStatusProvider, serviceSubType, additionalCharacteristics) {
|
|
7
|
-
super(ecoFlowAccessory, batteryStatusProvider, serviceSubType, additionalCharacteristics);
|
|
8
|
-
}
|
|
9
|
-
processOnSetOn() {
|
|
10
|
-
throw new this.platform.api.hap.HapStatusError(-70404 /* this.platform.api.hap.HAPStatus.READ_ONLY_CHARACTERISTIC */);
|
|
8
|
+
super(ecoFlowAccessory, batteryStatusProvider, serviceSubType, characteristicContracts_1.CharacteristicPermsType.READ_ONLY, additionalCharacteristics);
|
|
11
9
|
}
|
|
12
10
|
}
|
|
13
11
|
exports.OutletReadOnlyService = OutletReadOnlyService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outletReadOnlyService.js","sourceRoot":"","sources":["../../src/services/outletReadOnlyService.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"outletReadOnlyService.js","sourceRoot":"","sources":["../../src/services/outletReadOnlyService.ts"],"names":[],"mappings":";;;AACA,8FAA2F;AAG3F,yFAAsF;AAEtF,MAAa,qBAAsB,SAAQ,mDAAwB;IACjE,YACE,gBAAsC,EACtC,qBAA4C,EAC5C,cAAsB,EACtB,yBAAgD;QAEhD,KAAK,CAAC,gBAAgB,EAAE,qBAAqB,EAAE,cAAc,EAAE,iDAAuB,CAAC,SAAS,EAAE,yBAAyB,CAAC,CAAC;IAC/H,CAAC;CACF;AATD,sDASC"}
|
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
import { EcoFlowAccessoryBase } from '@ecoflow/accessories/ecoFlowAccessoryBase';
|
|
2
|
+
import { CharacteristicPermsType } from '@ecoflow/characteristics/characteristicContracts';
|
|
2
3
|
import { ServiceBase } from '@ecoflow/services/serviceBase';
|
|
3
4
|
import { Characteristic, CharacteristicValue, WithUUID } from 'homebridge';
|
|
4
5
|
export declare abstract class OutletServiceBase extends ServiceBase {
|
|
5
6
|
private readonly additionalCharacteristics?;
|
|
7
|
+
private readonly onCharacteristicPermsType;
|
|
6
8
|
private state;
|
|
7
|
-
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, additionalCharacteristics?: string[] | undefined, serviceSubType?: string);
|
|
9
|
+
constructor(ecoFlowAccessory: EcoFlowAccessoryBase, additionalCharacteristics?: string[] | undefined, serviceSubType?: string, onCharacteristicPermsType?: CharacteristicPermsType);
|
|
8
10
|
updateState(state: boolean): void;
|
|
9
11
|
updateOutputConsumption(watt: number): void;
|
|
10
12
|
updateOutputVoltage(volt: number): void;
|
|
11
13
|
updateOutputCurrent(ampere: number): void;
|
|
12
14
|
protected addCharacteristics(): Characteristic[];
|
|
13
|
-
protected
|
|
15
|
+
protected processOnSetOn(value: boolean, revert: () => void): Promise<void>;
|
|
14
16
|
protected tryAddCustomCharacteristic(characteristic: WithUUID<{
|
|
15
17
|
new (): Characteristic;
|
|
16
18
|
}>, characteristicType: string): Characteristic | null;
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.OutletServiceBase = void 0;
|
|
4
|
+
const characteristicContracts_1 = require("@ecoflow/characteristics/characteristicContracts");
|
|
4
5
|
const config_1 = require("@ecoflow/config");
|
|
5
6
|
const serviceBase_1 = require("@ecoflow/services/serviceBase");
|
|
6
7
|
class OutletServiceBase extends serviceBase_1.ServiceBase {
|
|
7
8
|
additionalCharacteristics;
|
|
9
|
+
onCharacteristicPermsType;
|
|
8
10
|
state = false;
|
|
9
|
-
constructor(ecoFlowAccessory, additionalCharacteristics, serviceSubType) {
|
|
11
|
+
constructor(ecoFlowAccessory, additionalCharacteristics, serviceSubType, onCharacteristicPermsType = characteristicContracts_1.CharacteristicPermsType.DEFAULT) {
|
|
10
12
|
super(ecoFlowAccessory.platform.Service.Outlet, ecoFlowAccessory, serviceSubType);
|
|
11
13
|
this.additionalCharacteristics = additionalCharacteristics;
|
|
14
|
+
this.onCharacteristicPermsType = onCharacteristicPermsType;
|
|
12
15
|
}
|
|
13
16
|
updateState(state) {
|
|
14
17
|
this.state = state;
|
|
@@ -26,11 +29,16 @@ class OutletServiceBase extends serviceBase_1.ServiceBase {
|
|
|
26
29
|
}
|
|
27
30
|
addCharacteristics() {
|
|
28
31
|
const onCharacteristic = this.addCharacteristic(this.platform.Characteristic.On)
|
|
32
|
+
.setPropsPerms(this.onCharacteristicPermsType)
|
|
29
33
|
.onGet(() => this.processOnGet(this.state))
|
|
30
|
-
.onSet((value) =>
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
+
.onSet((value) => {
|
|
35
|
+
this.processOnSetVerify(this.platform.Characteristic.On.name);
|
|
36
|
+
const revert = () => this.updateState(!value);
|
|
37
|
+
this.processOnSet(async () => {
|
|
38
|
+
this.state = value;
|
|
39
|
+
await this.processOnSetOn(this.state, revert);
|
|
40
|
+
}, revert);
|
|
41
|
+
});
|
|
34
42
|
const characteristics = [
|
|
35
43
|
this.addCharacteristic(this.platform.Characteristic.OutletInUse),
|
|
36
44
|
onCharacteristic,
|
|
@@ -41,6 +49,11 @@ class OutletServiceBase extends serviceBase_1.ServiceBase {
|
|
|
41
49
|
this.service.setCharacteristic(this.platform.Characteristic.Name, this.serviceName);
|
|
42
50
|
return characteristics.filter(characteristic => characteristic !== null);
|
|
43
51
|
}
|
|
52
|
+
/* istanbul ignore next */
|
|
53
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
54
|
+
processOnSetOn(value, revert) {
|
|
55
|
+
return Promise.resolve();
|
|
56
|
+
}
|
|
44
57
|
tryAddCustomCharacteristic(characteristic, characteristicType) {
|
|
45
58
|
if (this.additionalCharacteristics?.includes(characteristicType)) {
|
|
46
59
|
return this.addCharacteristic(characteristic);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outletServiceBase.js","sourceRoot":"","sources":["../../src/services/outletServiceBase.ts"],"names":[],"mappings":";;;AACA,4CAAiG;AACjG,+DAA4D;AAG5D,MAAsB,iBAAkB,SAAQ,yBAAW;IAKtC;
|
|
1
|
+
{"version":3,"file":"outletServiceBase.js","sourceRoot":"","sources":["../../src/services/outletServiceBase.ts"],"names":[],"mappings":"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"}
|
|
@@ -32,7 +32,8 @@ export declare abstract class ServiceBase {
|
|
|
32
32
|
protected covertValueToPercents(value: number, maxValue: number): number;
|
|
33
33
|
protected onDisabled(): void;
|
|
34
34
|
protected processOnGet<TValue>(value: TValue): TValue;
|
|
35
|
-
protected
|
|
35
|
+
protected processOnSetVerify(name: string): void;
|
|
36
|
+
protected processOnSet(process: () => Promise<void>, revert: () => void): Promise<void>;
|
|
36
37
|
private checkIsReachable;
|
|
37
38
|
private checkIsEnabled;
|
|
38
39
|
}
|
|
@@ -60,8 +60,7 @@ class ServiceBase {
|
|
|
60
60
|
return this.service.getCharacteristic(characteristic);
|
|
61
61
|
}
|
|
62
62
|
getOrAddService(service, displayName) {
|
|
63
|
-
const result = this.ecoFlowAccessory.accessory.getService(service) ||
|
|
64
|
-
this.ecoFlowAccessory.accessory.addService(service, displayName, service.UUID);
|
|
63
|
+
const result = this.ecoFlowAccessory.accessory.getService(service) || this.ecoFlowAccessory.accessory.addService(service, displayName, service.UUID);
|
|
65
64
|
result.displayName = displayName ?? result.displayName;
|
|
66
65
|
return result;
|
|
67
66
|
}
|
|
@@ -86,10 +85,18 @@ class ServiceBase {
|
|
|
86
85
|
this.checkIsReachable();
|
|
87
86
|
return value;
|
|
88
87
|
}
|
|
89
|
-
|
|
88
|
+
processOnSetVerify(name) {
|
|
90
89
|
this.checkIsReachable();
|
|
91
90
|
this.checkIsEnabled(name);
|
|
92
|
-
|
|
91
|
+
}
|
|
92
|
+
async processOnSet(process, revert) {
|
|
93
|
+
try {
|
|
94
|
+
await process();
|
|
95
|
+
}
|
|
96
|
+
catch (error) {
|
|
97
|
+
this.log.warn('Failed to process onSet. Reverting value...', error);
|
|
98
|
+
setTimeout(() => revert(), 300);
|
|
99
|
+
}
|
|
93
100
|
}
|
|
94
101
|
checkIsReachable() {
|
|
95
102
|
if (!this.isReachable) {
|