iobroker.zigbee 1.9.0 → 1.9.3
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/LICENSE +21 -21
- package/README.md +434 -423
- package/admin/adapter-settings.js +244 -244
- package/admin/admin.js +2991 -2991
- package/admin/i18n/de/translations.json +108 -108
- package/admin/i18n/en/translations.json +108 -108
- package/admin/i18n/es/translations.json +102 -102
- package/admin/i18n/fr/translations.json +108 -108
- package/admin/i18n/it/translations.json +102 -102
- package/admin/i18n/nl/translations.json +108 -108
- package/admin/i18n/pl/translations.json +108 -108
- package/admin/i18n/pt/translations.json +102 -102
- package/admin/i18n/ru/translations.json +108 -108
- package/admin/i18n/uk/translations.json +108 -108
- package/admin/i18n/zh-cn/translations.json +102 -102
- package/admin/img/philips_hue_lom001.png +0 -0
- package/admin/index.html +163 -163
- package/admin/index_m.html +1360 -1360
- package/admin/moment.min.js +1 -1
- package/admin/shuffle.min.js +2 -2
- package/admin/tab_m.html +1021 -1021
- package/admin/vis-network.min.css +1 -1
- package/admin/vis-network.min.js +26 -26
- package/admin/words.js +110 -110
- package/docs/de/basedocu.md +19 -19
- package/docs/de/readme.md +126 -126
- package/docs/en/readme.md +128 -128
- package/docs/flashing_via_arduino_(en).md +110 -110
- package/docs/ru/readme.md +28 -28
- package/docs/tutorial/groups-1.png +0 -0
- package/docs/tutorial/groups-2.png +0 -0
- package/docs/tutorial/tab-dev-1.png +0 -0
- package/io-package.json +40 -40
- package/lib/backup.js +171 -171
- package/lib/binding.js +319 -319
- package/lib/colors.js +465 -465
- package/lib/commands.js +4 -2
- package/lib/developer.js +151 -151
- package/lib/devicemgmt.js +374 -393
- package/lib/devices.js +3139 -3139
- package/lib/exclude.js +162 -162
- package/lib/exposes.js +41 -14
- package/lib/groups.js +345 -345
- package/lib/json.js +59 -59
- package/lib/networkmap.js +55 -55
- package/lib/ota.js +198 -198
- package/lib/rgb.js +297 -297
- package/lib/seriallist.js +48 -48
- package/lib/states.js +6420 -6420
- package/lib/statescontroller.js +25 -10
- package/lib/tools.js +54 -54
- package/lib/utils.js +165 -165
- package/lib/zbBaseExtension.js +36 -36
- package/lib/zbDelayedAction.js +144 -144
- package/lib/zbDeviceAvailability.js +319 -319
- package/lib/zbDeviceConfigure.js +148 -151
- package/lib/zbDeviceEvent.js +48 -48
- package/lib/zigbeecontroller.js +1014 -1014
- package/main.js +16 -13
- package/package.json +4 -4
- package/support/docgen.js +93 -93
package/lib/devicemgmt.js
CHANGED
|
@@ -1,393 +1,374 @@
|
|
|
1
|
-
const dmUtils = require('@
|
|
2
|
-
const humanizeDuration = require('humanize-duration');
|
|
3
|
-
|
|
4
|
-
class dmZigbee extends dmUtils.DeviceManagement {
|
|
5
|
-
|
|
6
|
-
async getInstanceInfo() {
|
|
7
|
-
const data = {
|
|
8
|
-
...super.getInstanceInfo(),
|
|
9
|
-
apiVersion: 'v1',
|
|
10
|
-
actions: [
|
|
11
|
-
{
|
|
12
|
-
id: '
|
|
13
|
-
icon: 'fas fa-
|
|
14
|
-
title: '',
|
|
15
|
-
description: {
|
|
16
|
-
en: '
|
|
17
|
-
de: '
|
|
18
|
-
ru: '
|
|
19
|
-
pt: '
|
|
20
|
-
nl: '
|
|
21
|
-
fr: '
|
|
22
|
-
it: '
|
|
23
|
-
es: '
|
|
24
|
-
pl: '
|
|
25
|
-
|
|
26
|
-
uk: '
|
|
27
|
-
},
|
|
28
|
-
handler: this.
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
this.
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
const
|
|
65
|
-
|
|
66
|
-
const
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
await
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
if
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
},
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
type: '
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
label: `
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
},
|
|
230
|
-
|
|
231
|
-
type: '
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
},
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
const
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
async formatDate(time, type) { //'ISO_8601' | 'ISO_8601_local' | 'epoch' | 'relative'
|
|
377
|
-
if (type === 'ISO_8601') return new Date(time).toISOString();
|
|
378
|
-
else if (type === 'ISO_8601_local') return this.toLocalISOString(new Date(time));
|
|
379
|
-
else if (type === 'epoch') return time;
|
|
380
|
-
else { // relative
|
|
381
|
-
const ago = humanizeDuration(Date.now() - time, {language: 'en', largest: 2, round: true}) + ' ago';
|
|
382
|
-
return ago;
|
|
383
|
-
}
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
toLocalISOString(d) {
|
|
387
|
-
const off = d.getTimezoneOffset();
|
|
388
|
-
return new Date(d.getFullYear(), d.getMonth(), d.getDate(), d.getHours(), d.getMinutes() - off, d.getSeconds(), d.getMilliseconds()).toISOString();
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
module.exports = dmZigbee;
|
|
1
|
+
const dmUtils = require('@iobroker/dm-utils');
|
|
2
|
+
const humanizeDuration = require('humanize-duration');
|
|
3
|
+
|
|
4
|
+
class dmZigbee extends dmUtils.DeviceManagement {
|
|
5
|
+
|
|
6
|
+
async getInstanceInfo() {
|
|
7
|
+
const data = {
|
|
8
|
+
...super.getInstanceInfo(),
|
|
9
|
+
apiVersion: 'v1',
|
|
10
|
+
actions: [
|
|
11
|
+
{
|
|
12
|
+
id: 'newDevice',
|
|
13
|
+
icon: 'fas fa-plus',
|
|
14
|
+
title: '',
|
|
15
|
+
description: {
|
|
16
|
+
en: 'Add new device to Zigbee',
|
|
17
|
+
de: 'Neues Gerät zu Zigbee hinzufügen',
|
|
18
|
+
ru: 'Добавить новое устройство в Zigbee',
|
|
19
|
+
pt: 'Adicionar novo dispositivo ao Zigbee',
|
|
20
|
+
nl: 'Voeg nieuw apparaat toe aan Zigbee',
|
|
21
|
+
fr: 'Ajouter un nouvel appareil à Zigbee',
|
|
22
|
+
it: 'Aggiungi nuovo dispositivo a Zigbee',
|
|
23
|
+
es: 'Agregar nuevo dispositivo a Zigbee',
|
|
24
|
+
pl: 'Dodaj nowe urządzenie do Zigbee',
|
|
25
|
+
|
|
26
|
+
uk: 'Додати новий пристрій до Zigbee'
|
|
27
|
+
},
|
|
28
|
+
handler: this.handleNewDevice.bind(this)
|
|
29
|
+
}
|
|
30
|
+
],
|
|
31
|
+
};
|
|
32
|
+
return data;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
async handleRefresh(context) {
|
|
36
|
+
this.adapter.log.info('handleRefresh');
|
|
37
|
+
return { refresh: true };
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async handleNewDevice(context) {
|
|
41
|
+
this.adapter.log.info('handleNewDevice');
|
|
42
|
+
|
|
43
|
+
const res = await this.adapter.zbController.permitJoin(permitTime);
|
|
44
|
+
|
|
45
|
+
const permitTime = this.adapter.config.countDown;
|
|
46
|
+
|
|
47
|
+
const progress = await context.openProgress('Searching...', { label: '0%' });
|
|
48
|
+
await this.delay(500);
|
|
49
|
+
for (let i = 1; i <= permitTime; i += 1) {
|
|
50
|
+
await this.delay(300);
|
|
51
|
+
this.log.info(`Progress at ${i}%`);
|
|
52
|
+
await progress.update({ value: i, label: `${i}%` });
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
await this.delay(1000);
|
|
56
|
+
await progress.close();
|
|
57
|
+
|
|
58
|
+
return { refresh: true };
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
async listDevices() {
|
|
64
|
+
const devices = await this.adapter.getDevicesAsync();
|
|
65
|
+
const arrDevices = [];
|
|
66
|
+
for (const i in devices) {
|
|
67
|
+
const status = {};
|
|
68
|
+
|
|
69
|
+
if (devices[i].common.type == 'group') continue;
|
|
70
|
+
|
|
71
|
+
const available = await this.adapter.getStateAsync(`${devices[i]._id}.available`);
|
|
72
|
+
if(available !== null && available !== undefined) {
|
|
73
|
+
status.connection = available.val ? 'connected' : 'disconnected';
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const link_quality = await this.adapter.getStateAsync(`${devices[i]._id}.link_quality`);
|
|
77
|
+
if(link_quality) {
|
|
78
|
+
status.rssi = link_quality.val;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const battery = await this.adapter.getStateAsync(`${devices[i]._id}.battery`);
|
|
82
|
+
if(battery) {
|
|
83
|
+
status.battery = battery.val;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
let hastDetails = false;
|
|
87
|
+
// Check if device has native.Sender_ID
|
|
88
|
+
if(devices[i].native.id) {
|
|
89
|
+
hastDetails = true;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
const deviceInfo = await this.adapter.zbController.getDevice('0x'+devices[i].native.id);
|
|
93
|
+
|
|
94
|
+
const res = {
|
|
95
|
+
id: devices[i]._id,
|
|
96
|
+
name: devices[i].common.name,
|
|
97
|
+
icon: devices[i].common.icon ? '/adapter/zigbee/' + devices[i].common.icon : null,
|
|
98
|
+
manufacturer: `${deviceInfo._manufacturerName}` ,
|
|
99
|
+
model: `${deviceInfo._modelID}`,
|
|
100
|
+
status: status,
|
|
101
|
+
hasDetails: hastDetails,
|
|
102
|
+
actions: [
|
|
103
|
+
/* {
|
|
104
|
+
id: 'delete',
|
|
105
|
+
icon: 'fa-solid fa-trash-can',
|
|
106
|
+
description: {
|
|
107
|
+
en: 'Delete this device',
|
|
108
|
+
de: 'Gerät löschen',
|
|
109
|
+
ru: 'Удалить это устройство',
|
|
110
|
+
pt: 'Excluir este dispositivo',
|
|
111
|
+
nl: 'Verwijder dit apparaat',
|
|
112
|
+
fr: 'Supprimer cet appareil',
|
|
113
|
+
it: 'Elimina questo dispositivo',
|
|
114
|
+
es: 'Eliminar este dispositivo',
|
|
115
|
+
pl: 'Usuń to urządzenie',
|
|
116
|
+
'zh-cn': '删除此设备',
|
|
117
|
+
uk: 'Видалити цей пристрій'
|
|
118
|
+
},
|
|
119
|
+
handler: this.handleDeleteDevice.bind(this)
|
|
120
|
+
},*/
|
|
121
|
+
{
|
|
122
|
+
id: 'rename',
|
|
123
|
+
icon: 'fa-solid fa-pen',
|
|
124
|
+
description: {
|
|
125
|
+
en: 'Rename this device',
|
|
126
|
+
de: 'Gerät umbenennen',
|
|
127
|
+
ru: 'Переименовать это устройство',
|
|
128
|
+
pt: 'Renomear este dispositivo',
|
|
129
|
+
nl: 'Hernoem dit apparaat',
|
|
130
|
+
fr: 'Renommer cet appareil',
|
|
131
|
+
it: 'Rinomina questo dispositivo',
|
|
132
|
+
es: 'Renombrar este dispositivo',
|
|
133
|
+
pl: 'Zmień nazwę tego urządzenia',
|
|
134
|
+
'zh-cn': '重命名此设备',
|
|
135
|
+
uk: 'Перейменуйте цей пристрій'
|
|
136
|
+
},
|
|
137
|
+
handler: this.handleRenameDevice.bind(this)
|
|
138
|
+
}
|
|
139
|
+
]
|
|
140
|
+
};
|
|
141
|
+
// if id contains gateway remove res.actions
|
|
142
|
+
if(devices[i]._id.includes('gateway')) {
|
|
143
|
+
res.actions = [];
|
|
144
|
+
}
|
|
145
|
+
arrDevices.push(res);
|
|
146
|
+
}
|
|
147
|
+
return arrDevices;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
async getDeviceDetails(id, action, context) {
|
|
151
|
+
this.adapter.log.info('getDeviceDetails');
|
|
152
|
+
const devices = await this.adapter.getDevicesAsync();
|
|
153
|
+
const device = devices.find(d => d._id === id);
|
|
154
|
+
if(!device) {
|
|
155
|
+
return {error: 'Device not found'};
|
|
156
|
+
}
|
|
157
|
+
if(!device.native.id) {
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
const deviceInfo = await this.adapter.zbController.getDevice('0x'+ device.native.id);
|
|
162
|
+
const lastSeen = await this.formatDate(deviceInfo._lastSeen);
|
|
163
|
+
|
|
164
|
+
const items = {};
|
|
165
|
+
|
|
166
|
+
for (const devInfo in deviceInfo._endpoints[0].inputClusters) {
|
|
167
|
+
|
|
168
|
+
const val = deviceInfo._endpoints[0].inputClusters[devInfo];
|
|
169
|
+
const valType = typeof val;
|
|
170
|
+
|
|
171
|
+
if (valType != 'object') {
|
|
172
|
+
const item = {
|
|
173
|
+
['inputCluster'+devInfo]: {
|
|
174
|
+
type: 'staticText',
|
|
175
|
+
text: `inputCluster ${devInfo} : ${val}`,
|
|
176
|
+
newLine: true,
|
|
177
|
+
},
|
|
178
|
+
};
|
|
179
|
+
Object.assign(items,item);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
const data = {
|
|
185
|
+
id: deviceInfo._ieeeAddr,
|
|
186
|
+
schema: {
|
|
187
|
+
type: 'tabs',
|
|
188
|
+
items: {
|
|
189
|
+
_tab_Start: {
|
|
190
|
+
type: 'panel',
|
|
191
|
+
label: 'Main',
|
|
192
|
+
|
|
193
|
+
items: {
|
|
194
|
+
header_Start: {
|
|
195
|
+
type: 'header',
|
|
196
|
+
text: `${device.common.name} ${deviceInfo._ieeeAddr}`,
|
|
197
|
+
size: 3,
|
|
198
|
+
},
|
|
199
|
+
_link: {
|
|
200
|
+
label: `Manufacturer: ${deviceInfo._manufacturerName}`,
|
|
201
|
+
type: 'staticLink',
|
|
202
|
+
href: `https://www.zigbee2mqtt.io/supported-devices/#v=${deviceInfo._manufacturerName}`,
|
|
203
|
+
button: true,
|
|
204
|
+
},
|
|
205
|
+
_link2: {
|
|
206
|
+
label: `Model : ${device.common.type}`,
|
|
207
|
+
type: 'staticLink',
|
|
208
|
+
href: `https://www.zigbee2mqtt.io/devices/${device.common.type}.html`,
|
|
209
|
+
button: true,
|
|
210
|
+
},
|
|
211
|
+
_softwareBuildID: {
|
|
212
|
+
type: 'staticText',
|
|
213
|
+
text: `<b>Software Build Id:</b> ${deviceInfo._softwareBuildID}`,
|
|
214
|
+
style: {
|
|
215
|
+
fontSize: 14
|
|
216
|
+
}
|
|
217
|
+
},
|
|
218
|
+
|
|
219
|
+
_divider2: {
|
|
220
|
+
type: 'divider',
|
|
221
|
+
color: 'primary',
|
|
222
|
+
},
|
|
223
|
+
_interviewCompleted: {
|
|
224
|
+
type: 'checkbox',
|
|
225
|
+
label: `Interview completed`,
|
|
226
|
+
checked: deviceInfo._interviewCompleted == 1 ? 'true' : 'false',
|
|
227
|
+
disabled: 'true',
|
|
228
|
+
newLine: true,
|
|
229
|
+
},
|
|
230
|
+
_configure: {
|
|
231
|
+
type: 'checkbox',
|
|
232
|
+
label: 'is Configured',
|
|
233
|
+
help: 'if it possible',
|
|
234
|
+
checked: deviceInfo.meta.configured == 1 ? 'true' : 'false',
|
|
235
|
+
disabled: 'true',
|
|
236
|
+
},
|
|
237
|
+
_lastSeen: {
|
|
238
|
+
type: 'staticText',
|
|
239
|
+
text: `<b>Last seen:</b> ${lastSeen}`,
|
|
240
|
+
},
|
|
241
|
+
_manufacturerID: {
|
|
242
|
+
type: 'staticText',
|
|
243
|
+
text: `<b>Manufacturer Id:</b> ${deviceInfo._manufacturerID}`,
|
|
244
|
+
newLine: true,
|
|
245
|
+
},
|
|
246
|
+
_network: {
|
|
247
|
+
type: 'staticText',
|
|
248
|
+
text: `<b>Network address:</b> 0x${deviceInfo._networkAddress}`,
|
|
249
|
+
},
|
|
250
|
+
_type: {
|
|
251
|
+
type: 'staticText',
|
|
252
|
+
text: `<b>Device Type:</b> ${deviceInfo._type}`,
|
|
253
|
+
},
|
|
254
|
+
_powered: {
|
|
255
|
+
type: 'staticText',
|
|
256
|
+
text: deviceInfo._powerSource ? `<b>Power:</b> ${deviceInfo._powerSource.toUpperCase()}` : ``,
|
|
257
|
+
},
|
|
258
|
+
_maxListeners: {
|
|
259
|
+
type: 'staticText',
|
|
260
|
+
text: `<b>max Listeners:</b> ${deviceInfo._maxListeners}`,
|
|
261
|
+
},
|
|
262
|
+
},
|
|
263
|
+
},
|
|
264
|
+
_tab_Details: {
|
|
265
|
+
type: 'panel',
|
|
266
|
+
label: 'Details',
|
|
267
|
+
items,
|
|
268
|
+
},
|
|
269
|
+
},
|
|
270
|
+
},
|
|
271
|
+
};
|
|
272
|
+
|
|
273
|
+
return data;
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
async handleDeleteDevice(id, context) {
|
|
277
|
+
const devId = id.replace(/zigbee\.\d\./, '');
|
|
278
|
+
const deviceInfo = await this.adapter.zbController.getDevice('0x'+ devId);
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
const response = await context.showConfirmation({
|
|
282
|
+
en: `Do you really want to delete the device ${deviceInfo._ieeeAddr}?`,
|
|
283
|
+
de: `Möchten Sie das Gerät ${deviceInfo._ieeeAddr} wirklich löschen?`,
|
|
284
|
+
ru: `Вы действительно хотите удалить устройство ${deviceInfo._ieeeAddr}?`,
|
|
285
|
+
pt: `Você realmente deseja excluir o dispositivo ${deviceInfo._ieeeAddr}?`,
|
|
286
|
+
nl: `Weet u zeker dat u het apparaat ${deviceInfo._ieeeAddr} wilt verwijderen?`,
|
|
287
|
+
fr: `Voulez-vous vraiment supprimer l'appareil ${deviceInfo._ieeeAddr} ?`,
|
|
288
|
+
it: `Vuoi davvero eliminare il dispositivo ${deviceInfo._ieeeAddr}?`,
|
|
289
|
+
es: `¿Realmente desea eliminar el dispositivo ${deviceInfo._ieeeAddr}?`,
|
|
290
|
+
pl: `Czy na pewno chcesz usunąć urządzenie ${deviceInfo._ieeeAddr}?`,
|
|
291
|
+
'zh-cn': `您真的要删除设备 ${deviceInfo._ieeeAddr} 吗?`,
|
|
292
|
+
uk: `Ви дійсно бажаєте видалити пристрій ${deviceInfo._ieeeAddr}?`
|
|
293
|
+
});
|
|
294
|
+
|
|
295
|
+
|
|
296
|
+
// delete device
|
|
297
|
+
if(response === false) {
|
|
298
|
+
return {refresh: false};
|
|
299
|
+
}
|
|
300
|
+
const res = await this.adapter.leaveDevice('0x'+ devId);
|
|
301
|
+
|
|
302
|
+
if (res !== null) {
|
|
303
|
+
this.adapter.log.info(`${devId} deleted`);
|
|
304
|
+
return {refresh: true};
|
|
305
|
+
} else {
|
|
306
|
+
this.adapter.log.error(`Can not delete device ${devId}: ${JSON.stringify(res)}`);
|
|
307
|
+
return {refresh: false};
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
async handleRenameDevice(id, context) {
|
|
312
|
+
const result = await context.showForm({
|
|
313
|
+
type : 'panel',
|
|
314
|
+
items: {
|
|
315
|
+
newName: {
|
|
316
|
+
type: 'text',
|
|
317
|
+
trim: false,
|
|
318
|
+
placeholder: '',
|
|
319
|
+
}
|
|
320
|
+
}}, {
|
|
321
|
+
data: {
|
|
322
|
+
newName: ''
|
|
323
|
+
},
|
|
324
|
+
title: {
|
|
325
|
+
en: 'Enter new name',
|
|
326
|
+
de: 'Neuen Namen eingeben',
|
|
327
|
+
ru: 'Введите новое имя',
|
|
328
|
+
pt: 'Digite um novo nome',
|
|
329
|
+
nl: 'Voer een nieuwe naam in',
|
|
330
|
+
fr: 'Entrez un nouveau nom',
|
|
331
|
+
it: 'Inserisci un nuovo nome',
|
|
332
|
+
es: 'Ingrese un nuevo nombre',
|
|
333
|
+
pl: 'Wpisz nowe imię',
|
|
334
|
+
'zh-cn': '输入新名称',
|
|
335
|
+
uk: 'Введіть нове ім\'я'
|
|
336
|
+
}
|
|
337
|
+
});
|
|
338
|
+
if (result == undefined || result.newName == '') {
|
|
339
|
+
return {refresh: false};
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
const obj = {
|
|
343
|
+
common: {
|
|
344
|
+
name: result.newName
|
|
345
|
+
}
|
|
346
|
+
};
|
|
347
|
+
const res = await this.adapter.extendObjectAsync(id, obj);
|
|
348
|
+
this.adapter.log.info(JSON.stringify(res));
|
|
349
|
+
if (res === null) {
|
|
350
|
+
this.adapter.log.warn(`Can not rename device ${context.id}: ${JSON.stringify(res)}`);
|
|
351
|
+
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
return {refresh: true};
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
async formatDate(time, type) { //'ISO_8601' | 'ISO_8601_local' | 'epoch' | 'relative'
|
|
358
|
+
if (type === 'ISO_8601') return new Date(time).toISOString();
|
|
359
|
+
else if (type === 'ISO_8601_local') return this.toLocalISOString(new Date(time));
|
|
360
|
+
else if (type === 'epoch') return time;
|
|
361
|
+
else { // relative
|
|
362
|
+
const ago = humanizeDuration(Date.now() - time, {language: 'en', largest: 2, round: true}) + ' ago';
|
|
363
|
+
return ago;
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
|
|
367
|
+
toLocalISOString(d) {
|
|
368
|
+
const off = d.getTimezoneOffset();
|
|
369
|
+
return new Date(d.getFullYear(), d.getMonth(), d.getDate(), d.getHours(), d.getMinutes() - off, d.getSeconds(), d.getMilliseconds()).toISOString();
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
module.exports = dmZigbee;
|