iobroker.lorawan 1.22.10 → 1.22.12
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/README.md +9 -24
- package/admin/i18n/de/translations.json +2 -0
- package/admin/i18n/en/translations.json +2 -2
- package/admin/i18n/es/translations.json +2 -0
- package/admin/i18n/fr/translations.json +2 -0
- package/admin/i18n/it/translations.json +2 -0
- package/admin/i18n/nl/translations.json +2 -0
- package/admin/i18n/pl/translations.json +2 -0
- package/admin/i18n/pt/translations.json +2 -0
- package/admin/i18n/ru/translations.json +2 -0
- package/admin/i18n/uk/translations.json +2 -0
- package/admin/i18n/zh-cn/translations.json +2 -0
- package/admin/jsonConfig.json +6 -6
- package/io-package.json +31 -31
- package/lib/modules/bridge.js +9 -9
- package/lib/modules/deviceManager/bridgeDevices.js +8 -8
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -24,6 +24,13 @@ For now there is documentation in English here: https://wiki.hafenmeister.de
|
|
|
24
24
|
Placeholder for the next version (at the beginning of the line):
|
|
25
25
|
### **WORK IN PROGRESS**
|
|
26
26
|
-->
|
|
27
|
+
### 1.22.12 (2026-05-09)
|
|
28
|
+
- (copilot) Adapter requires node.js >= 22 now
|
|
29
|
+
* (BenAhrdt) Default Bridge all downlink.control and uplin.decoded to bridge
|
|
30
|
+
|
|
31
|
+
### 1.22.11 (2026-04-20)
|
|
32
|
+
* (BenAhrdt) correct default value for pause (worx)
|
|
33
|
+
|
|
27
34
|
### 1.22.10 (2026-04-20)
|
|
28
35
|
* (BenAhrdt) implements button in card
|
|
29
36
|
|
|
@@ -33,33 +40,11 @@ For now there is documentation in English here: https://wiki.hafenmeister.de
|
|
|
33
40
|
### 1.22.8 (2026-04-20)
|
|
34
41
|
* (BenAhrdt) implements first commands and states of lawn mower
|
|
35
42
|
|
|
36
|
-
### 1.22.7 (2026-04-16)
|
|
37
|
-
* (BenAhrdt) add more device_class entries to assign roles
|
|
38
|
-
|
|
39
|
-
### 1.22.6 (2026-04-10)
|
|
40
|
-
* (BenAhrdt) bugfix cover endposition open
|
|
41
|
-
|
|
42
|
-
### 1.22.5 (2026-04-10)
|
|
43
|
-
* (BenAhrdt) bugfix displaying buttons in dM cards
|
|
44
|
-
|
|
45
|
-
### 1.22.4 (2026-04-10)
|
|
46
|
-
* (BenAhrdt) bugfix lock entity in dM card
|
|
47
|
-
|
|
48
|
-
### 1.22.3 (2026-04-10)
|
|
49
|
-
* (BenAhrdt) add first Test for states of configed devices shown in device Manager cards
|
|
50
|
-
|
|
51
|
-
### 1.22.2 (2026-04-07)
|
|
52
|
-
* (BenAhrdt) remove readOnly flag from jsonEditor
|
|
53
|
-
|
|
54
|
-
### 1.22.1 (2026-04-02)
|
|
55
|
-
* (BenAhrdt) add more roles to toIob devices
|
|
56
|
-
|
|
57
|
-
### 1.22.0 (2026-04-01)
|
|
58
|
-
* (BenAhrdt) new Design in device Manager Cards
|
|
59
|
-
|
|
60
43
|
### Older entries
|
|
61
44
|
[here](OLD_CHANGELOG.md)
|
|
62
45
|
|
|
46
|
+
[Older changelogs can be found there](CHANGELOG_OLD.md)
|
|
47
|
+
|
|
63
48
|
## License
|
|
64
49
|
MIT License
|
|
65
50
|
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "ID für offenen Endschalter",
|
|
169
169
|
"OriginHeader": "Ursprungseinstellungen",
|
|
170
170
|
"OriginInformation": "Legen Sie den Ursprung der erwarteten Daten fest",
|
|
171
|
+
"PauseStateId": "Pause Id",
|
|
172
|
+
"PauseStateNumber": "Pausiert Nummer",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Discovery Zyklus",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "Stellen Sie den Cronjob für das Discovery ein",
|
|
173
175
|
"Rename this device": "Gerät umbenennen",
|
|
@@ -322,10 +322,10 @@
|
|
|
322
322
|
"HomeId": "HomeId",
|
|
323
323
|
"NumberStateId": "Id of State-Number",
|
|
324
324
|
"MowingStateNumber": "Mowing-Number",
|
|
325
|
-
"
|
|
325
|
+
"PauseStateNumber": "Pause-Number",
|
|
326
326
|
"HomeStateNumber": "Home-Number",
|
|
327
327
|
"MowingStateId": "MowingStateId",
|
|
328
|
-
"
|
|
328
|
+
"PauseStateId": "PauseStateId",
|
|
329
329
|
"HomeStateId": "HomeStateId",
|
|
330
330
|
"NumberStateText": "State-Number Id",
|
|
331
331
|
"StatciTextMowerSeparate": "The default values are selected for the worx adapter"
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "ID para interruptor de límite abierto",
|
|
169
169
|
"OriginHeader": "Configuración de origen",
|
|
170
170
|
"OriginInformation": "Establecer el origen de los datos esperados.",
|
|
171
|
+
"PauseStateId": "PausaEstadoId",
|
|
172
|
+
"PauseStateNumber": "Número de pausa",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Descubre el ciclo",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "inserte el cronjob para actualizar el descubrimiento",
|
|
173
175
|
"Rename this device": "Cambiar el nombre de este dispositivo",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "identifiant pour fin de course ouvert",
|
|
169
169
|
"OriginHeader": "Paramètres d'origine",
|
|
170
170
|
"OriginInformation": "Définir l'origine des données attendues",
|
|
171
|
+
"PauseStateId": "PauseStateId",
|
|
172
|
+
"PauseStateNumber": "Numéro de pause",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Découvrir le cycle",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "insérez le cronjob pour rafraîchir la découverte",
|
|
173
175
|
"Rename this device": "Renommer cet appareil",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "id per finecorsa aperto",
|
|
169
169
|
"OriginHeader": "Impostazioni dell'origine",
|
|
170
170
|
"OriginInformation": "Imposta l'origine dei dati attesi",
|
|
171
|
+
"PauseStateId": "PauseStateId",
|
|
172
|
+
"PauseStateNumber": "Numero di pausa",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Scopri Ciclo",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "inserire il cronjob per aggiornare la scoperta",
|
|
173
175
|
"Rename this device": "Rinomina questo dispositivo",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "ID voor open eindschakelaar",
|
|
169
169
|
"OriginHeader": "Oorspronkelijke instellingen",
|
|
170
170
|
"OriginInformation": "Stel de oorsprong van de verwachte gegevens in",
|
|
171
|
+
"PauseStateId": "PauseStateId",
|
|
172
|
+
"PauseStateNumber": "Pauze-nummer",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Ontdek Cyclus",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "plaats de cronjob om de ontdekking te vernieuwen",
|
|
173
175
|
"Rename this device": "Hernoem dit apparaat",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "identyfikator otwartego wyłącznika krańcowego",
|
|
169
169
|
"OriginHeader": "Ustawienia oryginalności",
|
|
170
170
|
"OriginInformation": "Ustaw pochodzenie oczekiwanych danych",
|
|
171
|
+
"PauseStateId": "Identyfikator stanu wstrzymania",
|
|
172
|
+
"PauseStateNumber": "Numer pauzy",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Odkryj cykl",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "wstaw cronjob, aby odświeżyć odkrycie",
|
|
173
175
|
"Rename this device": "Zmień nazwę tego urządzenia",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "id para interruptor de limite aberto",
|
|
169
169
|
"OriginHeader": "Configurações de origem",
|
|
170
170
|
"OriginInformation": "Defina a origem dos dados esperados",
|
|
171
|
+
"PauseStateId": "PauseStateId",
|
|
172
|
+
"PauseStateNumber": "Pausa-Número",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Descubra o Ciclo",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "insira o cronjob para atualizar a descoberta",
|
|
173
175
|
"Rename this device": "Renomear este dispositivo",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "идентификатор концевого выключателя открытия",
|
|
169
169
|
"OriginHeader": "Оригинальные настройки",
|
|
170
170
|
"OriginInformation": "Установите источник ожидаемых данных",
|
|
171
|
+
"PauseStateId": "Паузастатеид",
|
|
172
|
+
"PauseStateNumber": "Пауза-номер",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Откройте для себя цикл",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "вставьте cronjob для обновления открытия",
|
|
173
175
|
"Rename this device": "Переименуйте это устройство",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "ідентифікатор для відкритого кінцевого вимикача",
|
|
169
169
|
"OriginHeader": "Налаштування походження",
|
|
170
170
|
"OriginInformation": "Встановіть джерело очікуваних даних",
|
|
171
|
+
"PauseStateId": "PauseStateId",
|
|
172
|
+
"PauseStateNumber": "Пауза-номер",
|
|
171
173
|
"RefreshDiscoveryCronJob": "Цикл відкриття",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "вставте cronjob для оновлення відкриття",
|
|
173
175
|
"Rename this device": "Перейменуйте цей пристрій",
|
|
@@ -168,6 +168,8 @@
|
|
|
168
168
|
"OpenSignalText": "打开限位开关的 id",
|
|
169
169
|
"OriginHeader": "原始设置",
|
|
170
170
|
"OriginInformation": "设置预期数据的来源",
|
|
171
|
+
"PauseStateId": "暂停状态ID",
|
|
172
|
+
"PauseStateNumber": "暂停号码",
|
|
171
173
|
"RefreshDiscoveryCronJob": "发现周期",
|
|
172
174
|
"RefreshDiscoveryCronJobTooltip": "插入 cronjob 以刷新发现",
|
|
173
175
|
"Rename this device": "重命名该设备",
|
package/admin/jsonConfig.json
CHANGED
|
@@ -2694,10 +2694,10 @@
|
|
|
2694
2694
|
},
|
|
2695
2695
|
{
|
|
2696
2696
|
"type": "number",
|
|
2697
|
-
"label": "
|
|
2698
|
-
"attr": "
|
|
2699
|
-
"tooltip": "
|
|
2700
|
-
"default":
|
|
2697
|
+
"label": "PauseStateNumber",
|
|
2698
|
+
"attr": "PauseStateNumber",
|
|
2699
|
+
"tooltip": "PauseStateNumberTooltip",
|
|
2700
|
+
"default": 34,
|
|
2701
2701
|
"hidden": "data.MowerStateSeparate !== 'number'",
|
|
2702
2702
|
"xs": 12,
|
|
2703
2703
|
"sm": 1,
|
|
@@ -2733,8 +2733,8 @@
|
|
|
2733
2733
|
},
|
|
2734
2734
|
{
|
|
2735
2735
|
"type": "objectId",
|
|
2736
|
-
"attr": "
|
|
2737
|
-
"label": "
|
|
2736
|
+
"attr": "PauseStateId",
|
|
2737
|
+
"label": "PauseStateText",
|
|
2738
2738
|
"customFilter": {"common": { "type": [ "boolean", "mixed" ] } },
|
|
2739
2739
|
"hidden": "data.MowerStateSeparate !== 'separate'",
|
|
2740
2740
|
"xs": 12,
|
package/io-package.json
CHANGED
|
@@ -1,8 +1,34 @@
|
|
|
1
1
|
{
|
|
2
2
|
"common": {
|
|
3
3
|
"name": "lorawan",
|
|
4
|
-
"version": "1.22.
|
|
4
|
+
"version": "1.22.12",
|
|
5
5
|
"news": {
|
|
6
|
+
"1.22.12": {
|
|
7
|
+
"en": "Adapter requires node.js >= 22 now\nDefault Bridge all downlink.control and uplin.decoded to bridge",
|
|
8
|
+
"de": "Adapter benötigt node.js >= 22 jetzt\nDefault Bridge all downlink.control und uplin.decodiert zur Brücke",
|
|
9
|
+
"ru": "Адаптер требует node.js >= 22 сейчас\nDefault Bridge all downlink.control and uplin.decoded to Bridge скачать бесплатно",
|
|
10
|
+
"pt": "Adaptador requer nod.js >= 22 agora\nPonte padrão todos downlink.control e uplin.decoded para ponte",
|
|
11
|
+
"nl": "Voor de adapter zijn node.js < 22 nu nodig\nStandaard brug alle downlink.control en uplin.decodeerd naar brug",
|
|
12
|
+
"fr": "Adaptateur nécessite node.js >= 22 maintenant\nPar défaut Bridge all downlink.control et uplin.decoded to bridge",
|
|
13
|
+
"it": "Adattatore richiede node.js >= 22 ora\nDefault Bridge all downlink.control e uplin.decoded to bridge",
|
|
14
|
+
"es": "Adaptador requiere node.js ю= 22 ahora\nDefault Bridge all downlink.control y uplin.decoded to bridge",
|
|
15
|
+
"pl": "Adapter wymaga node.js > = 22\nDomyślny most wszystko downlink.control i uplin.decoded most",
|
|
16
|
+
"uk": "Адаптер вимагає node.js >= 22 тепер\nJavaScript licenses API Веб-сайт Go1.13.8",
|
|
17
|
+
"zh-cn": "适配器需要节点.js 现在22\n默认桥全部下行链路. control and uplin.decoded to bridge"
|
|
18
|
+
},
|
|
19
|
+
"1.22.11": {
|
|
20
|
+
"en": "correct default value for pause (worx)",
|
|
21
|
+
"de": "korrekter standardwert für pause (worx)",
|
|
22
|
+
"ru": "правильное значение по умолчанию для паузы (worx)",
|
|
23
|
+
"pt": "valor padrão correto para pausa (worx)",
|
|
24
|
+
"nl": "correcte standaard waarde voor pauze (worx)",
|
|
25
|
+
"fr": "corriger la valeur par défaut pour la pause (worx)",
|
|
26
|
+
"it": "corretto valore predefinito per pausa (worx)",
|
|
27
|
+
"es": "valor predeterminado correcto para la pausa (worx)",
|
|
28
|
+
"pl": "poprawna wartość domyślna dla pauzy (worx)",
|
|
29
|
+
"uk": "виправлено значення за замовчуванням для паузи (worx)",
|
|
30
|
+
"zh-cn": "校正暂停( worx) 的默认值"
|
|
31
|
+
},
|
|
6
32
|
"1.22.10": {
|
|
7
33
|
"en": "implements button in card",
|
|
8
34
|
"de": "implementiert knopf in der karte",
|
|
@@ -67,32 +93,6 @@
|
|
|
67
93
|
"pl": "bugfix wyświetlanie przycisków w kartach dM",
|
|
68
94
|
"uk": "кнопки відображення помилок в dM-картах",
|
|
69
95
|
"zh-cn": "在 dM 纸卡中显示按钮"
|
|
70
|
-
},
|
|
71
|
-
"1.22.4": {
|
|
72
|
-
"en": "bugfix lock entity in dM card",
|
|
73
|
-
"de": "bugfix Schloss Entität in dM Karte",
|
|
74
|
-
"ru": "bugfix lock entity в карте dM",
|
|
75
|
-
"pt": "entidade de bloqueio de bugfix no cartão dM",
|
|
76
|
-
"nl": "bugfix slot entiteit in dM-kaart",
|
|
77
|
-
"fr": "bugfix lock entity dans la carte dM",
|
|
78
|
-
"it": "entità di blocco bugfix nella scheda dM",
|
|
79
|
-
"es": "bugfix entidad de bloqueo en tarjeta dM",
|
|
80
|
-
"pl": "element blokujący bugfix w karcie dM",
|
|
81
|
-
"uk": "суб'єкт блокування помилок в картці dM",
|
|
82
|
-
"zh-cn": "dM 卡中的bugfix锁实体"
|
|
83
|
-
},
|
|
84
|
-
"1.22.3": {
|
|
85
|
-
"en": "add first Test for states of configed devices shown in device Manager cards",
|
|
86
|
-
"de": "fügen Sie ersten Test für Zustände von konfiktiven Geräten in Device Manager-Karten",
|
|
87
|
-
"ru": "добавить первый Тест для состояний конфигурированных устройств, показанных в картах диспетчера устройств",
|
|
88
|
-
"pt": "adicionar primeiro Teste para estados de dispositivos configurados mostrados nas placas do Gerenciador de dispositivos",
|
|
89
|
-
"nl": "toe te voegen eerste Test voor toestanden van geconfigureerde apparaten weergegeven in apparaat Manager kaarten",
|
|
90
|
-
"fr": "ajouter le premier test pour les états des périphériques configurés affichés dans les cartes de gestionnaire de périphériques",
|
|
91
|
-
"it": "aggiungere il primo test per gli stati di dispositivi confidificati mostrati nelle schede Gestione dispositivi",
|
|
92
|
-
"es": "añadir el primer Test para estados de dispositivos conectados mostrados en tarjetas de administrador de dispositivos",
|
|
93
|
-
"pl": "dodaj pierwszy test dla stanu podłączonych urządzeń pokazany w kartach menedżera urządzeń",
|
|
94
|
-
"uk": "додати перший тест для станів настрочених пристроїв, відображених в картах диспетчера пристроїв",
|
|
95
|
-
"zh-cn": "添加第一个设备管理卡中显示的配置设备状态测试"
|
|
96
96
|
}
|
|
97
97
|
},
|
|
98
98
|
"titleLang": {
|
|
@@ -445,7 +445,7 @@
|
|
|
445
445
|
"Application": "*",
|
|
446
446
|
"Device": "*",
|
|
447
447
|
"Folder": "uplink.decoded",
|
|
448
|
-
"State": "
|
|
448
|
+
"State": "*",
|
|
449
449
|
"publish": true,
|
|
450
450
|
"subscribe": false,
|
|
451
451
|
"exclude": false
|
|
@@ -453,10 +453,10 @@
|
|
|
453
453
|
{
|
|
454
454
|
"Application": "*",
|
|
455
455
|
"Device": "*",
|
|
456
|
-
"Folder": "
|
|
457
|
-
"State": "
|
|
456
|
+
"Folder": "downlink.control",
|
|
457
|
+
"State": "*",
|
|
458
458
|
"publish": true,
|
|
459
|
-
"subscribe":
|
|
459
|
+
"subscribe": true,
|
|
460
460
|
"exclude": false
|
|
461
461
|
}
|
|
462
462
|
],
|
package/lib/modules/bridge.js
CHANGED
|
@@ -3887,7 +3887,7 @@ class bridgeClass extends EventEmiter {
|
|
|
3887
3887
|
// State (number)
|
|
3888
3888
|
if (config.MowerIds.StateId) {
|
|
3889
3889
|
const MowingStateNumber = config.MowingStateNumber;
|
|
3890
|
-
const
|
|
3890
|
+
const PauseStateNumber = config.PauseStateNumber;
|
|
3891
3891
|
const HomeStateNumber = config.HomeStateNumber;
|
|
3892
3892
|
this.assignIdStructure(
|
|
3893
3893
|
this.PublishedIds,
|
|
@@ -3902,7 +3902,7 @@ class bridgeClass extends EventEmiter {
|
|
|
3902
3902
|
mower: true,
|
|
3903
3903
|
messageAssign: {
|
|
3904
3904
|
[MowingStateNumber]: 'mowing',
|
|
3905
|
-
[
|
|
3905
|
+
[PauseStateNumber]: 'paused',
|
|
3906
3906
|
[HomeStateNumber]: 'docked',
|
|
3907
3907
|
},
|
|
3908
3908
|
},
|
|
@@ -3927,11 +3927,11 @@ class bridgeClass extends EventEmiter {
|
|
|
3927
3927
|
);
|
|
3928
3928
|
}
|
|
3929
3929
|
|
|
3930
|
-
//
|
|
3931
|
-
if (config.MowerIds.
|
|
3930
|
+
// Pause State
|
|
3931
|
+
if (config.MowerIds.PauseStateId) {
|
|
3932
3932
|
this.assignIdStructure(
|
|
3933
3933
|
this.PublishedIds,
|
|
3934
|
-
config.MowerIds.
|
|
3934
|
+
config.MowerIds.PauseStateId,
|
|
3935
3935
|
{
|
|
3936
3936
|
usedDeviceId: deviceIdentifier,
|
|
3937
3937
|
},
|
|
@@ -3988,9 +3988,9 @@ class bridgeClass extends EventEmiter {
|
|
|
3988
3988
|
await this.publishId(config.MowerIds.MowingStateId, undefined, {});
|
|
3989
3989
|
await this.adapter.subscribeForeignStatesAsync(config.MowerIds.MowingStateId);
|
|
3990
3990
|
}
|
|
3991
|
-
if (config.MowerIds.
|
|
3992
|
-
await this.publishId(config.MowerIds.
|
|
3993
|
-
await this.adapter.subscribeForeignStatesAsync(config.MowerIds.
|
|
3991
|
+
if (config.MowerIds.PauseStateId) {
|
|
3992
|
+
await this.publishId(config.MowerIds.PauseStateId, undefined, {});
|
|
3993
|
+
await this.adapter.subscribeForeignStatesAsync(config.MowerIds.PauseStateId);
|
|
3994
3994
|
}
|
|
3995
3995
|
if (config.MowerIds.HomeStateId) {
|
|
3996
3996
|
await this.publishId(config.MowerIds.HomeStateId, undefined, {});
|
|
@@ -4027,7 +4027,7 @@ class bridgeClass extends EventEmiter {
|
|
|
4027
4027
|
}
|
|
4028
4028
|
if (config.MowerStateSeparate === 'seperate') {
|
|
4029
4029
|
MowerIds.MowingStateId = config.MowingStateId;
|
|
4030
|
-
MowerIds.
|
|
4030
|
+
MowerIds.PauseStateId = config.PauseStateId;
|
|
4031
4031
|
MowerIds.HomeStateId = config.HomeStateId;
|
|
4032
4032
|
}
|
|
4033
4033
|
for (const id of Object.values(MowerIds)) {
|
|
@@ -765,14 +765,14 @@ class bridgeDevicesClass {
|
|
|
765
765
|
label: preLabel + label,
|
|
766
766
|
};
|
|
767
767
|
}
|
|
768
|
-
if (discovery.ids.
|
|
768
|
+
if (discovery.ids.PauseStateId) {
|
|
769
769
|
this.adapter.log[this.adapter.logtypes.listDevices]?.(
|
|
770
|
-
`Start building LawnMower stop for Id: ${discovery.ids.
|
|
770
|
+
`Start building LawnMower stop for Id: ${discovery.ids.PauseStateId}`,
|
|
771
771
|
);
|
|
772
|
-
usedId[discovery.ids.
|
|
772
|
+
usedId[discovery.ids.PauseStateId] = true;
|
|
773
773
|
// Start
|
|
774
774
|
card = { label: 'Stop' };
|
|
775
|
-
card = lodash.merge(card, deviceValue.ids[discovery.ids.
|
|
775
|
+
card = lodash.merge(card, deviceValue.ids[discovery.ids.PauseStateId].object.native?.card);
|
|
776
776
|
let preLabel = card.preLabel ?? '';
|
|
777
777
|
let label = '';
|
|
778
778
|
if (card.name) {
|
|
@@ -780,14 +780,14 @@ class bridgeDevicesClass {
|
|
|
780
780
|
} else if (card.label) {
|
|
781
781
|
label = card.label;
|
|
782
782
|
} else {
|
|
783
|
-
label = deviceValue.ids[discovery.ids.
|
|
784
|
-
deviceValue.ids[discovery.ids.
|
|
783
|
+
label = deviceValue.ids[discovery.ids.PauseStateId].object._id.substring(
|
|
784
|
+
deviceValue.ids[discovery.ids.PauseStateId].object._id.lastIndexOf('.') + 1,
|
|
785
785
|
);
|
|
786
786
|
}
|
|
787
|
-
res.customInfo.schema.items[`${discovery.ids.
|
|
787
|
+
res.customInfo.schema.items[`${discovery.ids.PauseStateId}_PauseStateId`] = {
|
|
788
788
|
type: 'state',
|
|
789
789
|
// The full state ID including namespace (foreign = true means it's an absolute ID).
|
|
790
|
-
oid: discovery.ids.
|
|
790
|
+
oid: discovery.ids.PauseStateId,
|
|
791
791
|
foreign: true,
|
|
792
792
|
// Render as an interactive switch control.
|
|
793
793
|
control: 'button',
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "iobroker.lorawan",
|
|
3
|
-
"version": "1.22.
|
|
3
|
+
"version": "1.22.12",
|
|
4
4
|
"description": "converts the desired lora gateway data to a ioBroker structure",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "BenAhrdt",
|
|
@@ -22,13 +22,13 @@
|
|
|
22
22
|
"url": "https://github.com/BenAhrdt/ioBroker.lorawan.git"
|
|
23
23
|
},
|
|
24
24
|
"engines": {
|
|
25
|
-
"node": ">=
|
|
25
|
+
"node": ">= 22"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
28
|
"@iobroker/adapter-core": "^3.3.2",
|
|
29
|
-
"@iobroker/dm-utils": "^3.0.
|
|
29
|
+
"@iobroker/dm-utils": "^3.0.19",
|
|
30
30
|
"easy-crc": "^1.1.0",
|
|
31
|
-
"lodash": "^4.
|
|
31
|
+
"lodash": "^4.18.1",
|
|
32
32
|
"mqtt": "^5.15.1",
|
|
33
33
|
"node-schedule": "^2.1.1"
|
|
34
34
|
},
|
|
@@ -42,7 +42,7 @@
|
|
|
42
42
|
"@iobroker/testing": "^5.2.2",
|
|
43
43
|
"@tsconfig/node20": "^20.1.9",
|
|
44
44
|
"@types/lodash": "^4.17.24",
|
|
45
|
-
"@types/node": "^25.
|
|
45
|
+
"@types/node": "^25.6.0",
|
|
46
46
|
"typescript": "~5.9.3"
|
|
47
47
|
},
|
|
48
48
|
"main": "main.js",
|