Ist so etwas interessant?
NEWS
Best posts made by MCU
-
Windows 10 / 11 Notifications aus ioBroker erstellen
Mit diesem Programm kann man aus ioBroker Notifications mit unterschiedlichen Ausprägungen erstellen. Diese werden als Benachrichtungs-Popup in Windows gezeigt.
https://mcuiobroker.gitbook.io/iobroker-tipps/tipps/allgemein/microsoft-windows/burnttoast
Da noch TEST-Version , Bitte um Rückmeldung, ob alles funktioniert, Windows 11?
EDIT
22.09.2023 11:10- Neue
iobroker.zip
in github (Problem iobroker-IP-Adresse fehlte um Daten senden zu können) - iobroker Script in Doku aktualisiert
22.09.2023 20:40
- Neue
iobroker.zip
in github (Zusatzprogramm Windows PC-Daten holen ergänzt) - iobroker Script in Doku aktualisiert mit pcDataActive-Option -> true neue Funktion unter
0_userdata.0.windowsPC
Man kann sich alle wichtigen Daten vom PC holen und selbst verarbeiten. Falls jemand bestimmte als sinnvolle Daten erachtet, kann man evtl auch ein Unterverzeichnis mit allen "Wichtigen Daten" einrichten
- Neue
-
RE: jarvis v2.2.0 - just another remarkable vis
Rainbow-Text Effekt nur für Anzeigevarianten:
{"open":"geöffnet","closed":"<span class='rainbow-text' >geschlossen</span>"}
Einträge für Styles Pro:
Ergebnis:
Pulsierendes Rechteck in rot:
NUR für Anzeigevarianten möglich:
{"true":"<span class='impuls'>an</span>"}
Ergebnis:
-
HowTo: Zusatz-Programme fuer jarvis v3
CSSThemes v1.0.8
(Stand 06.02.2022)Hiermit legt man ein ioBroker-Struktur an, mit der man eigene Themes für jarvis v3 definieren kann und auch untereinander austauschen kann.
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-effektprogramme/cssthemesCSSEffects v1.0.5
(Stand 06.02.2022)Man kann mit dem Programm eine ioBroker-Struktur für Elemente aus dem jarvis-Layout erstellen.
Damit ist es dann einfach möglich, Elemente (Seiten, TABs, Widgets, States(StateList) auszublenden und einen Hintergrund zu definieren, oder man möchte einen Effekt (blink, bubble, border, animation) auf das Element legen.
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-effektprogramme/csseffectsaddDevice v1.0.0
(Stand 16.02.2022)Mit dem Programm kann man Devices in jarvis anlegen, falls es im Importer von jarvis den Adapter nicht geben sollte.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/adddevicesetDropDown v1.0.0
(Stand 03.03.2022)
Mit diesem Programm kann man in einen oder mehreren Devices eine DropDownListe ersetzen.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/setdropdownsetDefaultPosition v1.0.0
(Stand 14.03.2022)
Mit diesem Programm kann man die DefaultPosition von einem ausgewählten MAP-Widget anpassen. Weiterhin kann man auch bis zu 4 Positionen folgen.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/setdefaultpositiongetRestore v1.0.0 (Test)
(Stand 16.03.2022)
Mit diesem Programm kann man die jarvis-DPs aus einer Komplettsicherung von backitup herausfiltern und dann aus den Extra-DPs in die ORIG-DPs kopieren.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/getrestore-aus-backup.jsonBlindLevelButtons v1.0.0 (Test)
(Stand 19.03.2022)
Mit diesem Programm kann man die BlindLevelAction als 3 einzelne Buttons nutzen.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./blindlevelbuttonsBlindLevelUpDown v1.0.0
(Stand 09.05.2022)
Mit diesem Programm kann man die BlindLevelAction als 2 Taster nutzen.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./blindlevelupdowndevExpressionCopy v1.0.0 TEST
(Stand: 17.05.2022)
Mit diesem Programm kann man von einem Device (deviceId) (Quelle) die Ausprägungen (Parameter-Einstellungen) der devStates für ein oder mehrere copyArray device(s) (Ziele) kopieren. Einschränkungen auf unterschiedlichen Ebenen (devState, devState-Parameter( Icon, Icon-Stil, usw. )) sind möglich.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/devexpressioncopycopyDeskToSmart v1.0.0 TEST
(Stand: 18.05.2022)
Mit diesem Programm kann man das Desktop-Layout zum SmartPhone-Layout kopieren und das SmartPhone-Layout aktivieren und deaktivieren.
Beschreibung in der Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/copydesktosmartcheckDeviceName function
(Stand: 19.05.2022)
Mit diesem Programm kann man die Namen der Geräte in jarvis mit denen in ioBroker vergleichen und anzeigen lassen.
Beschreibung in der Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/system-effektprog./v3-systemprogramme/checkdevicenamegetInfosFromAdapter function
(Stand 25.05.2022)
Mit dieser Funktion kann man Infos zum Adapter auslesen und bei ('*') werden alle Adapter mit den scheduled Werten angezeigt.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/tipps/scripte-blockly-javascript/javascript/getinfosfromadaptergetInstanceConfig v1.0.0 TEST
(Stand 28.05.2022)
Mit dem Programm kann man aus einer Backitup-Datei die Config zu einer Instanz von einem Adapter auslesen lassen und als Datei abspeichern.
Beschreibung siehe Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/tipps/scripte-blockly-javascript/javascript/getinstanceconfigcreateDPsFromJSON function
(Stand 01.06.2022)
Mit dieser Funktion kann man aus dem JSON die Daten sich eine ioBroker-DP-Struktur erzeugen lassen. Weiterhin ist eine Aktualisierung der Werte vorhanden (on(jsonDP,....)).
Beschreibung in der Doku:
https://mcuiobroker.gitbook.io/jarvis-infos/tipps/scripte-blockly-javascript/javascript/createdpsfromjson -
RE: TR-064 Fritzbox Anrufbeantworter
@jojo58
Auf httpGet angepasst.
Standard Pfad für Objekte auf0_userdata.0
geändert!/* Kurzbeschreibung Mit diesem Skript können die Anrufbeantworterdaten der Anrufer aus der Fritzbox ausgelesen werden. Die Informationen werden in einer JSON Struktur zur Verfügung gestellt. Vorhande Einträge (Indexnummern) auf dem Anrufbeantworter werden ebenfalls in einer JSON Struktur zur verfügung gestellt werden und einzelne Nachrichten auf dem Anrufbeantworter können auf Basis der Indexnummer gelöscht werden. {1} Einschränkungen: - aktuell keine {1} {1} 2020-09-03: Initiale Version um Informationen aus der Fritzbox über die API auszulesen https://avm.de/service/schnittstellen/?spm=a2c6h.14275010.0.0.202628cfwq7844 https://forum.iobroker.net/topic/14288/tr-064-fritzbox-anrufbeantworter/21 https://developer.aliyun.com/mirror/npm/package/iobroker.tr-064 {1} {1} 2020-09-09: Mit der Funktion Fritzbox_Anrufbeantworter_GetMessageList() werden die auf dem Fritzbox hinterlegten Anrufe auf dem Anrufbeantworter ausgelesen. Getestet mit Fritzbox 7530 SW 7.20, Fritzbox 6590 SW 7.20 {1} 2020-09-12: - Konstante NewIndex_Anrufbeantworter eingeführt welche die ID des Anrufbeatworters in der Fritzbox entspricht - Mit dem Skript aus https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5 wird ermittelt ob der Anrufer auf den Anrufbeantworter gesprochen hat und es werden die Daten aus der Fritzbox ausgelesen - Datenpunkt (Button) eingefügt um manuell das Auslesen der Daten aus dem Anrufbeantworter zu triggern - Im Datenpunkt DP_Fritzbox_AnrufbeantworterDeleteMessage wird der Index der Nachricht auf dem Anrufbeantworter eingetragen welcher gelöscht werden soll {1} 2020-09-13: - Im Datenpunkt DP_Fritzbox_AnrufbeantworterIndexMessage_json wird ein JSON String für das Widget "materialdesign - Select" erzeugt, welches die Index Einträge der Anrufereinträge auf dem Anrufbeantworter enthält 2020-09-22: - Wenn keine Nachricht auf dem AB vorhanden ist, wird in den Datenpunkt DP_Fritzbox_AnrufbeantworterIndexMessage_json ein Eintrag hinzugefügt, dass keine Nachricht vorhanden ist. 2024-05-28: - request durch httpGet ersetzt (@MCU) - Pfad DP_FritzBox_anrufbeantworter gesetzt, leichter änderbar - Standard auf 0_userdata.0 geändert */ const debug = false; const NewIndex_Anrufbeantworter = 0; //ID des Anrufbeantworters in der Fritzbox. Der erste Anrufbeantworter hat die ID 0 const DP_Fritzbox_Anrufbeantworter = "0_userdata.0.Telefon.Anrufbeantworter" const DP_Fritzbox_AnrufbeantworterDaten_json = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterDaten_json"; const DP_Fritzbox_AnrufbeantworterDatenAktualisieren = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterDatenAktualisieren"; const DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten"; const DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterAnzahlNeueNachrichten" const DP_Fritzbox_AnrufbeantworterDeleteMessage = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterDeleteMessage"; const DP_Fritzbox_AnrufbeantworterIndexMessage_json = DP_Fritzbox_Anrufbeantworter + ".Fritzbox_AnrufbeantworterIndexMessage_json"; createState(DP_Fritzbox_AnrufbeantworterDaten_json, '{}', {name: 'JSON Struktur mit den Daten vom Anrufbeantworter aus der FritzBox', unit: '', type: 'string', role: 'value', def: '{}'}); createState(DP_Fritzbox_AnrufbeantworterDatenAktualisieren, false,{name: 'Manueller Trigger um die Daten aus dem Anrufbeantworter auszulesen', unit: '', read: true, write: true, type: 'boolean', role: 'button', def: false}); createState(DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten, 0, {name: 'Gesamtanzahl der Nachrichten auf dem Anrufbeantworter', unit: '', type: 'number', role: 'value', def: 0}); createState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten, 0, {name: 'Anzahl der neuen Nachrichten auf dem Anrufbeantworter', unit: '', type: 'number', role: 'value', def: 0}); createState(DP_Fritzbox_AnrufbeantworterDeleteMessage, '', {name: 'Zum loeschen ausgewaehlter Eintrag vom Anrufbeantworter', unit: '', read: true, write: true, type: 'string', role: 'value', def: ''}); createState(DP_Fritzbox_AnrufbeantworterIndexMessage_json, '', {name: 'JSON Struktur mit den Anrufbeantworter Index Eintraegen um sie in einem Select Widget darstellen zu koennen', unit: '', read: true, write: true, type: 'string', role: 'value', def: ''}); //Funktion Fritzbox_Anrufbeantworter_DeleteMessage() löscht die Nachricht welche als Index übergeben wird und liest danach erneut alle Anrufe vom Anrufbeantworter wieder aus function Fritzbox_Anrufbeantworter_DeleteMessage(NewMessageIndex){ var befehl_DeleteMessage = '{"service": "urn:dslforum-org:service:X_AVM-DE_TAM:1","action": "DeleteMessage","params": {"NewIndex": "'+ NewIndex_Anrufbeantworter + '", "NewMessageIndex": "' + NewMessageIndex + '" }}'; setState("tr-064.0.states.command","{}"); setState("tr-064.0.states.command",befehl_DeleteMessage); //Befehl zum loeschen einer Nachricht im Anrufbeantworter if(debug) console.log("Antwort auf command im State tr-064.0.states.commandResult: " + getState("tr-064.0.states.commandResult").val); Fritzbox_Anrufbeantworter_GetMessageList(); } on({id:DP_Fritzbox_AnrufbeantworterDeleteMessage, change: 'any'}, function(obj) { if(debug) console.log("Es wird der Eintrag auf dem Anrufebeantworter mit dem Index: " + getState(DP_Fritzbox_AnrufbeantworterDeleteMessage).val + "gelöscht"); Fritzbox_Anrufbeantworter_DeleteMessage(getState(DP_Fritzbox_AnrufbeantworterDeleteMessage).val); }); var AB_Index_DeleteMessageIndex = {}; AB_Index_DeleteMessageIndex.sendTo = function(text, subText = '', value = '', icon = '', iconColor = '') { let json = getState(DP_Fritzbox_AnrufbeantworterIndexMessage_json).val; if (json) { try { json = JSON.parse(json); } catch (e) { json = []; console.warn('Wert ist kein JSON string! Wert wird ersetzt!'); } } else { json = []; } json.push( { text: text, subText: subText, value: value, icon: icon, iconColor: iconColor, } ) setState(DP_Fritzbox_AnrufbeantworterIndexMessage_json, JSON.stringify(json), true); } // Funktion Fritzbox_Anrufbeantworter_GetMessageList() liest aus der Fritzbox die hinterlegten Informationen zu den Anrufen auf dem // Anrufbeantworter aus. Ergebnis als JSON in einen Datenpunkt gespeichert, damit es in VIS einfach dargestellt werden kann. Es werden // in Datenpunkten gespeichert wieviele Anrufe im Anrufbeantworter insgesamt vorliegen und wieviele neue Nachrichten vorhanden sind function Fritzbox_Anrufbeantworter_GetMessageList(){ //Skript zum parsen von XML zu JSON: https://forum.iobroker.net/topic/623/gel%C3%B6st-xml-daten-einer-url-weiterverarbeiten/19 //Damit das xml geparsed werden kann muss in der Javascript Instanz unter "Zusätzliche NPM Module" noch "xml2js" (mit Enter bestätigen) eintragen werden var parseString = require('xml2js').parseString; //var request = require('request'); var Result_Fritzbox_HyperlinkXmlTAM; var Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn = 0; var Fritzbox_AnrufbeantworterDaten_json = ""; var befehl_GetMessageList = '{"service": "urn:dslforum-org:service:X_AVM-DE_TAM:1","action": "GetMessageList","params": {"NewIndex ": "' + NewIndex_Anrufbeantworter + '"}}'; setState("tr-064.0.states.command","{}"); setState("tr-064.0.states.command",befehl_GetMessageList); //Befehl zum auslesen der Anrufbeantworterdaten in Datenpunkt schreiben if(debug) console.log("Antwort auf command im State tr-064.0.states.commandResult: " + getState("tr-064.0.states.commandResult").val); setState(DP_Fritzbox_AnrufbeantworterIndexMessage_json,""); //Setzt den aktuellen Inhalt vom Datenpunkt zurück, damit im Verlauf die Index Nummer von den Anrufen neu geschrieben werden können //Das Ergebnis im Datenpunkt commandResult ist ein Link auf ein XML welches die Informationen zu den Anrufen auf dem //Anrufbeantworter enthält. Das Ergebnis hat folgendes Format: {"NewURL":"http://192.168.178.1:49000/tamcalllist.lua?sid=2a4abe5e5ad61b64&tamindex=0"} //Aus diesem String wird mittels substring der eigentliche Link extrahiert Result_Fritzbox_HyperlinkXmlTAM = getState("tr-064.0.states.commandResult").val; Result_Fritzbox_HyperlinkXmlTAM = Result_Fritzbox_HyperlinkXmlTAM.substring(11, getState("tr-064.0.states.commandResult").val.length -2); //die reine URL wird extrahiert if(debug) console.log("Extrahierter Hyperlink aus commandresult. CommandResult: " + getState("tr-064.0.states.commandResult").val + " und der extrahierte Link: " + Result_Fritzbox_HyperlinkXmlTAM); //Das XML File wird geparst und in eine JSON Struktur umgewandelt httpGet(Result_Fritzbox_HyperlinkXmlTAM, function(error, response){ //request(Result_Fritzbox_HyperlinkXmlTAM, function (error, response, body) { if (!error && response.statusCode == 200) { const body = response.data; if(debug) console.log("Body: " + body); //Aus dem xml String wird der Wert nach tam calls: extrahiert welcher die Anzahl der Anrufe auf dem Anrufbeantworter angibt //Beispiel: ... <!-- tam calls:0 --> </Root> ... //https://regex101.com/ //https://regex101.com/r/Q74grJ/1 const regex = /<!-- tam calls:[\s\S]*?(\d+)/igm; const matches = regex.exec(body); const FB_xml_TamCalls = parseInt(matches[1]); if(debug) console.log("FB_xml_TamCalls aus XML extrahiert: "+ FB_xml_TamCalls); setState(DP_Fritzbox_AnrufbeantworterGesamtAnzahlNachrichten, FB_xml_TamCalls); parseString(body, { explicitArray: true, // Always put child nodes in an array if true; otherwise an array is created only if there is more than one. mergeAttrs: true //Merge attributes and child elements as properties of the parent, instead of keying attributes off a child attribute object. This option is ignored if ignoreAttrs is true. }, function (err, result) { if (err) { log("Fehler: " + err); } else { if(debug) console.log("Result Umwandlung xml in JSON: " + JSON.stringify(result)); //Abhaengig von der Anzahl der Anruf auf dem Anrufbeantworter erfolgt die weitere Verarbeitung der Daten if(FB_xml_TamCalls == 0){ //Wenn keine Nachrichten auf dem Anrufbeantworter in der Fritzbox vorliegen //JSON String aus der Fritzbox wenn keine Nachricht auf dem AB ist //JSON: {"Root":"\n\n\n\n"} Fritzbox_AnrufbeantworterDaten_json = '[{"Index":["---"],"Tam":["---"],"Called":["---"],"Date":["---"],"Duration":["---"],"Inbook":["---"],"Name":["---"],"New":["---"],"Number":["---"],"Path":["---"]}]'; setState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten,0); //Anzahl der neuen Nachrichten auf 0 setzen setState(DP_Fritzbox_AnrufbeantworterDaten_json,Fritzbox_AnrufbeantworterDaten_json); setTimeout(function(){ AB_Index_DeleteMessageIndex.sendTo("Keine Nachricht vorhanden","","","phone-message-outline","red"); },500); } else{ //Mindestens eine Nachricht ist auf dem Anrufbeantworter in der Fritzbox vorhanden //JSON String wenn eine Nachricht auf dem Anrufbeantworter ist //JSON: {"Root":{"Message":[{"Index":["0"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:17"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["1"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}} //JSON String wenn zwei Nachrichten auf dem Anrufbeantworter sind //JSON: {"Root":{"Message":[{"Index":["1"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:30"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["1"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.001"]},{"Index":["0"],"Tam":["0"],"Called":["0123456789"],"Date":["09.09.20 21:17"],"Duration":["0:01"],"Inbook":["0"],"Name":["Feuersturm"],"New":["0"],"Number":["0987654321"],"Path":["/download.lua?path=/data/tam/rec/rec.0.000"]}]}} Fritzbox_AnrufbeantworterDaten_json = JSON.stringify(result); Fritzbox_AnrufbeantworterDaten_json = Fritzbox_AnrufbeantworterDaten_json.substring(19,JSON.stringify(result).length - 2); setState(DP_Fritzbox_AnrufbeantworterDaten_json,Fritzbox_AnrufbeantworterDaten_json); if(debug) console.log("result.Root.Message.length: " + JSON.stringify(result.Root.Message.length)); for (let i = 0; i < JSON.stringify(result.Root.Message.length); i++) { let MessageIndexValue = JSON.stringify(result.Root.Message[i].Index); MessageIndexValue = MessageIndexValue.substring(2,MessageIndexValue.length - 2); if(debug) console.log("Nachricht neu [i]: [" + i + "]" + JSON.stringify(result.Root.Message[i].New) + " mit Index: " + JSON.stringify(result.Root.Message[i].Index) + " und gekürzt: " + MessageIndexValue); setTimeout(function(){ AB_Index_DeleteMessageIndex.sendTo("AB Index","",MessageIndexValue,"phone-message-outline","red"); },i*500); if( JSON.stringify(result.Root.Message[i].New) === '["1"]') { Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn = Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn + 1; } } if(debug) console.log("Anzahl Neuer Nachrichten auf dem AB: " + Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn); setState(DP_Fritzbox_AnrufbeantworterAnzahlNeueNachrichten,Fritzbox_AnrufbeantworterAnzahlNeueNachrichtenn); } } }); } else { log(error); } }); } //Über Datenpunkt kann manuell das Auslesen der Daten aus dem Anrufbeantworter getriggert werden on({id:DP_Fritzbox_AnrufbeantworterDatenAktualisieren, change: 'any'}, function(obj) { Fritzbox_Anrufbeantworter_GetMessageList(); }); //------------------------- Anrufername oder Telefonnummer ermitteln ----------- //Quelle: https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5 /* Steht der Anrufer in Adressbuch wird Vorname und Name ausgegeben, sonst die Telefonnummer {1} */ function telefonname () { var tokens = getState("tr-064.0.callmonitor.inbound.callerName").val.split(","); var answer = ''; var vorname = tokens[1]; var famname = tokens[0]; if (famname === undefined) famname = ''; if (vorname === undefined) vorname = ''; if (vorname !== '' || famname !== '') answer = vorname + ' ' + famname; else answer = getState("tr-064.0.callmonitor.inbound.caller").val; return answer; } /* ---------------------------- Anruf beendet ------------------------------------- Quelle: https://forum.iobroker.net/topic/15533/tr-64-erkennen-ob-ein-aufruf-auf-ab-gesprochen-wurde/5 Es werden die Anzahl der Anrufe auf Anrufbeantworter und eine Liste von Namen mitgeführt, die Nachrichten hinterlassen haben. Es werden dazu 'callmonitor.lastCall.type' und 'tr-064.0.callmonitor.lastCall.extension' ausgewertet. {1} Mangels Dok wurde durch Ausprobieren ermittelt, dass {1} - type === missed : es wurde aufgelegt und nicht gesprochen. - type === disconnect && extension !== 40: Gespräch wurde geführt und dann aufgelegt - type === disconnect && extension === 40: Nachricht auf AB {1} bedeuten könnte. */ on({id:"tr-064.0.callmonitor.toPauseState", change: 'ne'}, function(obj) { setTimeout( function() { if (getState('tr-064.0.callmonitor.toPauseState').val === 'end') { var name = telefonname(); if (getState("tr-064.0.callmonitor.lastCall.type").val === 'missed') { log(name + " hat aufgelegt und keine Nachricht hinterlassen");} if (getState("tr-064.0.callmonitor.lastCall.type").val === 'disconnect') { if (getState('tr-064.0.callmonitor.lastCall.extension').val == 40) { if(debug) console.log(name + " hat auf den Anrufbeantworter gesprochen. Daten werden aus der Fritzbox ausgelesen..."); Fritzbox_Anrufbeantworter_GetMessageList(); //Es werden die Informationen aus dem Anrufbeantworter in der Fritzbox ausgelesen } else { log("Der Anruf von " + telefonname() + " hat " + getState("tr-064.0.callmonitor.lastCall.duration").val + " sec gedauert"); } } } }, 3000); });
-
RE: jarvis v3.1.x - just another remarkable vis
@darkdevil
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis-v3/besonderheiten-v3/scripts-3.1.x-pro/tab/changetablabel
Auch möglich, gewünscht?
in v1.0.1 angepasst.Auch möglich mit Icon
-
RE: [Javascript] für Warnungen von Lebensmittelwarnung
/*VIS Lebensmittelwarnungen {1} Bringt einen RSS-Feed als Tabelle in ioBroker setzt die Library xml2js voraus (in Javascript Einstellungen zufügen) {1} {1} erstellt: 11.05.2017 von Torsten (auf Basis von Bluefox Code und Pix) Script angepasst : 28.10.2019 von Oliver https://forum.iobroker.net/post/319584 {1} */ var idFeedTabelle = '0_userdata.0.Eigene_Datenpunkte.VIS.Lebensmittelwarnung.Alle.RSS-Feed_Tabelle'; var forceCreation = false; createState(idFeedTabelle, '', forceCreation, { write: true, read: true, name: 'RSS Feed Lebensmittelwarnung Tabelle', type: 'string', desc: 'Lebensmittelwarnung RSS Feed als HTML Tabelle', role: 'html' }); var link = 'https://www.lebensmittelwarnung.de/bvl-lmw-de/opensaga/feed/alle/nordrhein_westfalen.rss'; var quer = false ; function RSS_einlesen () { var parseString = require('xml2js').parseString; //var request = require('request'); httpGet(link, function (error, response) { if (!error && response.statusCode == 200) { parseString(response.data, { explicitArray: false, mergeAttrs: true }, function (err, result) { //log(JSON.stringify(result, null, 2)); if (err) { log("Fehler: " + err, 'error'); } else { var tabelle; if (quer) { // Titel links, Inhalt rechts tabelle ='<table class="rss_feed"><thead><tr><th>Titel</th><th>Produktwarnungen</th></tr></thead><tbody>'; for (var i = 0; i <result.rss.channel.item.length; i++) { tabelle += '<tr><td>' + result.rss.channel.item[i].title + '</td><td>' + result.rss.channel.item[i].description + '----------------------------------------------------------------------------------------------------------------------------------------------------------------------------</td></tr>'; } } else { // Titel oben, INhalt darunter (wie in der Zeitung) tabelle ='<table class="rss_feed"><thead><tr><th>Produktwarnungen</th><tr><tr></tr></thead><tbody>'; for (var j = 0; j <result.rss.channel.item.length; j++) { //Datum auf dt. Wochentage patchen result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Mon', 'Mo'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Tue', 'Di'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Wed', 'Mi'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Thu', 'Do'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Fri', 'Fr'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Sat', 'Sa'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Sun', 'So'); //Datum auf dt. Monate patchen result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Mar', 'März'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('May', 'Mai'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Oct', 'Okt'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('Dec', 'Dez'); result.rss.channel.item[j].pubDate = result.rss.channel.item[j].pubDate.replace('+0000', ''); tabelle += '<tr><td>' + result.rss.channel.item[j].title + '</td></tr><tr><td>' + result.rss.channel.item[j].description + '</td></tr><tr><td>' + result.rss.channel.item[j].pubDate + '</td></tr><tr><td>----------------------------------------------------------------------------------------------------------------------------------------------------------------------------</td></tr>'; } } tabelle += '</tbody></table>'; setState(idFeedTabelle, tabelle); } }); } else { log(error, 'error'); } }); // Ende request log('RSS-Feed ' + link + ' eingelesen'); } schedule("*/10 * * * *", RSS_einlesen); // alle 10 Minuten RSS_einlesen();
-
RE: [gelöst] Skript auf AXIOS/httpGet umbauen
@djmarc75 Wenn du Blockly nutzt kannst du auch direkt den Block verwenden?
-
RE: jarvis v2.2.0 - just another remarkable vis
@stony2k
Nein. Musst du noch selber in ioBroker machen. Soll mit einer der nächsten Versionen kommen. (Ist ein Wunsch von vielen und auch als Issue eingetragen)
Laut zefau behoben eintragen in Datenpunkt Eigenschaft:https://github.com/Zefau/ioBroker.jarvis/issues/416
https://github.com/Zefau/ioBroker.jarvis/issues/312
{"value":"val => parseFloat(val).toFixed(2)"}
Latest posts made by MCU
-
RE: Shelly Dimmer 2 einschalten & dimmen
@cookiemonster1706
javascriptconst dimmerDP = "dein.dimmer.datenpunkt"; // Dimmer-Datenpunkt const switchDP = "dein.schalter.datenpunkt"; // ON/OFF-Datenpunkt on({ id: dimmerDP, change: "any" }, function (obj) { const dimmerValue = obj.state.val; if (dimmerValue > 0) { setState(switchDP, true); // Einschalten, wenn Dimmer-Wert > 0 } else { setState(switchDP, false); // Ausschalten, wenn Dimmer-Wert = 0 } });
MQTT
{ "turn": "on", // "on" oder "off" "brightness": 50 // Wert für Dimmen (0-100) }
HTTP
http://<Shelly-IP>/light/0?turn=on&brightness=50
-
RE: HowTo: Zusatz-Programme fuer jarvis v3
@der-eine Problem nicht, aber du kannst sie rausnehmen.
Einfach ein // davor setzen // console.warn(...
-
RE: HowTo: Zusatz-Programme fuer jarvis v3
@der-eine Die Anzeigevariante muss identisch mit den States im Objekt von iobroker sein.
{"":"Id auswählen", "G23562346":"Kueche", "g3487634578":"Wohnzimmer"}
-
RE: jarvis v3.2.x - just another remarkable vis
@der-eine Könnte man auch dafür nutzen, nur dann würde man keine "gehört"-Json einsetzen.
Kann man machen, gib mir mal eine Liste der Radioprogramme, die vorkommen sollen.Könnte man auch für Youtube-Videos usw nutzen.
-
RE: HowTo: Zusatz-Programme fuer jarvis v3
@der-eine Die states vom DP müssen in die Anzeigevariante eingetragen werden.
-
RE: HowTo: Zusatz-Programme fuer jarvis v3
@der-eine „Pippi Langstrumpf“ und „Wir Kinder aus Bullerbü“. - Hab ich ergänzt.
Wie hättest Du dir vorgestellt, wie man die Alexa zur Wiedergabe auswählt?
Man muss die AlexaID zurückgeben, oder die States vom DP nutzen.
worauf ich achten muss, wenn ich die Cover selbst heraussuchen möchte
Wie beschrieben, kann man grundsätzlich jeden http(s)-Link hinzufügen, den man dort sehen möchte. Es wird nur bei den gehörten Epsioden das zugehörige Image genutzt. Dies wird von Amazon in den Alexa-Objekten mitgegeben.
-
RE: Name aus Fritz Telefonbuch auslesen
@berges01 Auslesen vom Telefonbuch mit tr-064-Command
tr-064.0.states.command
mit den Einträgen
/* GetPhonebookList -> Index Phonebooks */ { "service": "urn:dslforum-org:service:X_AVM-DE_OnTel:1", "action": "GetPhonebookList", "params": {} } /* GetPhonebook mit Indexzahl */ { "service": "urn:dslforum-org:service:X_AVM-DE_OnTel:1", "action": "GetPhonebook", "params": { "NewPhonebookID": 0 } } /* GetPhonebookEntry PhonebookID + EntryID */ { "service": "urn:dslforum-org:service:X_AVM-DE_OnTel:1", "action": "GetPhonebookEntry", "params": { "NewPhonebookID": 0, "NewPhonebookEntryID": 0 } } /* GetPhonebookEntryUID */ { "service": "urn:dslforum-org:service:X_AVM-DE_OnTel:1", "action": "GetPhonebookEntryUID", "params": { "NewPhonebookID": 1, "NewPhonebookEntryUniqueID": 86 } } { "service": "urn:dslforum-org:service:X_AVM-DE_OnTel:1", "action": "GetPhonebookEntryUID", "params": { "NewPhonebookID": 1, "NewPhonebookEntryUniqueID": 80 } }
-
RE: Name aus Fritz Telefonbuch auslesen
@berges01 Kein Problem, wollte nur wissen was man an Jarvis verbessern kann bzw. sollte.
Dieser Teil kann man mit Jarvis nicht erstellen.
Für einige wäre das Design auch schon ziemlich "überladen", aber das ist Geschmackssache.