Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Yahka Rolläden mit KNX

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Yahka Rolläden mit KNX

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      Matze1708 last edited by

      Ich finde nur unter Aufzählung enum.rooms

      1 Reply Last reply Reply Quote 0
      • Dutchman
        Dutchman Developer Most Active Administrators last edited by

        @Matze1708:

        Ich finde nur unter Aufzählung enum.rooms `

        dan den enum manuell erstellen:

        979_enum_functions.jpg

        1 Reply Last reply Reply Quote 0
        • M
          Matze1708 last edited by

          das habe ich. und wie kommen die States aus KNX dort hin?

          1 Reply Last reply Reply Quote 0
          • Dutchman
            Dutchman Developer Most Active Administrators last edited by

            @Matze1708:

            das habe ich. und wie kommen die States aus KNX dort hin? `

            • function rolladen erstellt ?

            • meine screenshots gesehen in diesem post: http://forum.iobroker.net/viewtopic.php … 405#p94365 ? 🙂

            ~Dutch

            1 Reply Last reply Reply Quote 0
            • Dutchman
              Dutchman Developer Most Active Administrators last edited by

              Hey @Matze1708,

              Hat es geklappt ? Ich habe das script jetzt erweitert damit er alle states erstellt und den jetzigen wert syncronisiert.

              Jetzt fehlt in grundegenommen nur noch die function um die wert zum updaten wen sich was aendert.

              das resultat sollte sein das bei dir bei den objecten unter javascript ein ordner erstellt wird "rolladen_reversed_values" mit darin al deine KNX geraete die du an die enum.function rolladen verknuepft hast

              `// Read all enums related to enum.functions
              functions = getEnums('functions');
              
              // Loop on all values and store members of function "rolladen" to variable
              for (var i in functions){
                  if (functions[i].name == 'rolladen'){
                      var rolladen = functions[i].members;
                      }
                  }
              
              //Seperate values in variable "rolladen" to seperate devices
              //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
              str = " ' " + rolladen + " ' ";
              var str_array = str.split(',');
              for(i = 0; i < str_array.length; i++) {
                  str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
              
              	try{
              
                      //retrieve device name for all found devices
                      var objname = getObject(str_array[i]).common.name;
                      var objvalue = getState(str_array[i]).val;
                      var revName = getObject(str_array[i]).common.name + '_reversed';
              
                      //Check if object already exist, otherwise create and sync current value
              		if (typeof(getIdByName(revName)) === 'undefined') {
              
                      createState("rolladen_reversed_values." + objname, objvalue, {
                          name: revName,
                          read: true,
                          write: true,
                          min: 0,
                          max: 100,
                          type: 'number',
                          role: 'level.hight',
                          unit: "%",
                          linkorigin: str_array[i]
                          });
                      }
                      }   catch(e){}   
              
              }` [/i][/i][/i][/i][/i][/i][/i][/i]
              
              1 Reply Last reply Reply Quote 0
              • Dutchman
                Dutchman Developer Most Active Administrators last edited by

                Geschafft ! :mrgreen: :mrgreen: :mrgreen:

                Erhoffe mir das du was dran hast, wen nicht war es fuer mich auf jedenfall eine super gelegenheit einige sachen im javascript zu entdecken die ich noch nicht wusste und bereits seit langen auf meiner to-do stand 8-)

                Also mein script setzt voraus das alle deine KNX werte der rollaeden in die enum.functions.rolladen aufgenommen sind

                Dan sorgt das script fuer:

                • anlegen aller states inter javascript.rolladen_reversed_values

                • wen ein wert sich dort aendert, wird automatisch der wert in der source (KNX bei dir) geaendert, hierbei rechnet er um

                • wen ein wert sich in de KNX objecten aendert, wird automatisch der wert in der reverse geaendert, hierbei rechnet er auch um

                das ergebnis sollte also sein das:

                • du deine rollaeden mit den reverse werten in yahka integrierst

                • jede aenderung da umgerechnet wird und auf KNX gebracht

                • andersum genauso, aendert sich was in KNX durch grund x wird der wert den yahka benutzt geaenert.

                hier mal eine kleine vid in gif dieser function

                979_reverse.gif

                Beim ersten start meldet er dir in der consoe welche objecte erstellt wurden: "New object " xxx " created within " xxx "".

                Das schalten selben zeigt er nur wen dein loglevel auf debug steht, dan verraeht er auch was empfangen wurden + die umrechnung

                value change based on Yahka trigger, received value = 20 ,calculated to = 80
                value change based on KNX trigger, received value = 10 ,calculated to = 90
                
                

                Und hier das script

                `//******************************************
                //*****************Dutchman*****************
                //*revert values to use KNX shutters with yahka*
                //*******************V 0.6****************** 
                //******************************************
                //******************************************
                
                // Read all enums related to enum.functions
                functions = getEnums('functions');
                
                // Loop on all values and store members of function "rolladen" to variable
                for (var i in functions){
                    if (functions[i].name == 'rolladen'){
                        var rolladen = functions[i].members;
                
                    }
                
                }
                
                //Seperate values in variable "rolladen" to seperate devices
                //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
                str = " ' " + rolladen + " ' ";
                var str_array = str.split(',');
                for(i = 0; i < str_array.length; i++) {
                    str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
                
                	try{
                
                        //retrieve device name for all found devices
                        var objname = getObject(str_array[i]).common.name;
                        var objvalue = 100 - getState(str_array[i]).val;
                        var revName = getObject(str_array[i]).common.name + '_reversed';
                
                        //Check if object already exist, otherwise create and sync current value
                		if (typeof(getIdByName(revName)) === 'undefined') {
                
                            createState("rolladen_reversed_values." + objname, objvalue, {
                                name: revName,
                                read: true,
                                write: true,
                                min: 0,
                                max: 100,
                                type: 'number',
                                role: 'level.hight',
                                unit: "%",
                                linkorigin: str_array[i]
                
                            });
                
                            log('New object  "' + revName + '"  created within "rolladen_reversed_values"');
                
                		}
                
                	}   catch(e){}   
                
                }
                
                // Trigger on value change in reverse values and syncronise to origin
                on({id: /^javascript.1.rolladen_reversed_values\./, change: "ne"}, function (obj) {
                
                    //reverse value from Yahka to KNX logic
                    var newvalue = 100 - obj.state.val;
                
                    //verify is calculated value is different, if yes update Yahka value to reversed object otherwise do nothing
                    if (newvalue !== getState(obj.common.linkorigin).val){
                        setState (obj.common.linkorigin, newvalue);
                        console.debug('value change based on Yahka trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                
                    }
                
                });
                
                // Trigger on value change in origin values and syncronise to reverse values
                on({enumName: 'rolladen', change: "ne"}, function (obj) {
                
                    //reverse value from KNX to Yahka logic
                    var newvalue = 100 - obj.state.val;
                
                    //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                    if (newvalue !== getState("rolladen_reversed_values." + obj.common.name).val){
                        setState("rolladen_reversed_values." + obj.common.name, newvalue, true);
                        console.debug('value change based on KNX trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                
                    }
                
                });` [/i][/i][/i][/i][/i][/i][/i][/i]
                
                1 Reply Last reply Reply Quote 0
                • M
                  Matze1708 last edited by

                  Sau stark!

                  Ich versuche es mal morgen einzubauen.

                  Ich gebe info.

                  Einbinden muss ich aber immer die JavaScript objecte oder?

                  1 Reply Last reply Reply Quote 0
                  • Dutchman
                    Dutchman Developer Most Active Administrators last edited by

                    @Matze1708:

                    Einbinden muss ich aber immer die JavaScript objecte oder? `

                    Im yahka? Jup

                    –-----------------------

                    Send from mobile device

                    1 Reply Last reply Reply Quote 0
                    • M
                      Matze1708 last edited by

                      Hallo,

                      das hier ist meine Ausgabe im Log:

                      Drücke Strg+A und danach Strg+C, um den Inhalt in die Zwischenablage zu kopieren. Klicke irgendwo, um das Fenster zu schliessen.
                      javascript.0	2017-11-07 17:41:21.609	info	script.js.Rolläden.Schlaf2_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:21.607	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:21.441	info	Start javascript script.js.Rolläden.Schlaf2_Status
                      javascript.0	2017-11-07 17:41:21.438	info	script.js.Rolläden.Schlaf1_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:21.436	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:21.270	info	Start javascript script.js.Rolläden.Schlaf1_Pos
                      javascript.0	2017-11-07 17:41:21.268	info	script.js.Rolläden.Kind_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:21.266	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:21.098	info	Start javascript script.js.Rolläden.Kind_Pos
                      javascript.0	2017-11-07 17:41:21.096	info	script.js.Rolläden.Kind_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:21.093	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.927	info	Start javascript script.js.Rolläden.Kind_Status
                      javascript.0	2017-11-07 17:41:20.924	info	script.js.Rolläden.Schlaf2_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.921	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.757	info	Start javascript script.js.Rolläden.Schlaf2_Pos
                      javascript.0	2017-11-07 17:41:20.754	info	script.js.Rolläden.Schlaf1_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.752	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.590	info	Start javascript script.js.Rolläden.Schlaf1_Status
                      javascript.0	2017-11-07 17:41:20.588	info	script.js.Rolläden.Büro_OG_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.586	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.424	info	Start javascript script.js.Rolläden.Büro_OG_Status
                      javascript.0	2017-11-07 17:41:20.422	info	script.js.Rolläden.Büro_OG_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.419	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.251	info	Start javascript script.js.Rolläden.Büro_OG_Pos
                      javascript.0	2017-11-07 17:41:20.249	info	script.js.Rolläden.Essen_Pos(4): registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.246	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:20.085	info	Start javascript script.js.Rolläden.Essen_Pos(4)
                      javascript.0	2017-11-07 17:41:20.082	info	script.js.Rolläden.Gaderobe_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:20.079	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.919	info	Start javascript script.js.Rolläden.Gaderobe_Pos
                      javascript.0	2017-11-07 17:41:19.917	info	script.js.Rolläden.WZ_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.915	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.754	info	Start javascript script.js.Rolläden.WZ_Pos
                      javascript.0	2017-11-07 17:41:19.751	info	script.js.Rolläden.Gaderobe_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.749	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.592	info	Start javascript script.js.Rolläden.Gaderobe_Status
                      javascript.0	2017-11-07 17:41:19.590	info	script.js.Rolläden.WZ_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.587	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.395	info	Start javascript script.js.Rolläden.WZ_Status
                      javascript.0	2017-11-07 17:41:19.394	info	script.js.Rolläden.WZ_Tür_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.391	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.231	info	Start javascript script.js.Rolläden.WZ_Tür_Status
                      javascript.0	2017-11-07 17:41:19.229	info	script.js.Rolläden.WZ_Tür_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.226	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:19.071	info	Start javascript script.js.Rolläden.WZ_Tür_Pos
                      javascript.0	2017-11-07 17:41:19.069	info	script.js.Rolläden.Essen_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:19.067	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:18.914	info	Start javascript script.js.Rolläden.Essen_Status
                      javascript.0	2017-11-07 17:41:18.912	info	script.js.Rolläden.Küche_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:18.909	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:18.750	info	Start javascript script.js.Rolläden.Küche_Status
                      javascript.0	2017-11-07 17:41:18.748	info	script.js.Rolläden.Küche_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 17:41:18.739	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 17:41:18.563	info	Start javascript script.js.Rolläden.Küche_Pos
                      javascript.0	2017-11-07 17:41:18.460	info	received all objects
                      javascript.0	2017-11-07 17:41:17.712	info	received all states
                      javascript.0	2017-11-07 17:41:17.071	info	requesting all objects
                      javascript.0	2017-11-07 17:41:17.067	info	requesting all states
                      javascript.0	2017-11-07 17:41:17.054	info	starting. Version 3.2.6 in /opt/iobroker/node_modules/iobroker.javascript, node: v6.11.1
                      javascript.0	2017-11-07 17:41:16.987	info	States connected to redis 127.0.0.1:6379
                      host.ioBroker-RasPi	2017-11-07 17:41:14.245	info	instance system.adapter.javascript.0 started with pid 28595
                      yahka.0	2017-11-07 17:41:11.710	info	objectChange system.adapter.javascript.0 {'_id':'system.adapter.javascript.0','type':'instance','common':{'name':'javascript','version':'3.2.6','title':'Javascript/Blockly Script Engine','titleLang':{'en':'Javascript/Blockly Script Engine','de':'Javascript/Blockly Skriptausführung','ru':'Javascript/Blockly Скрипты'},'authors':['bluefox ','hobbyquaker '],'news':{'3.3.5':{'en':'add the genitive month for formatDate','de':'Genitiv Monat für formatDate hinzugefügt','ru':'Добавлены месяцы в дательном падеже для formatDate'},'3.3.4':{'en':'Catch error by request if host unavailable','de':'Fange den Fehler ab, falls URL nicht online','ru':'Ловятся ошибки request, если адрес не доступен'},'3.3.3':{'en':'Fix stopScript','de':'Korrigiere stopScript','ru':'Исправлен stopScript'},'3.3.2':{'en':'Support of system coordinates','de':'Unterstützung von Systemkoordinaten','ru':'Поддержка системных настроек для координат'},'3.3.1':{'en':'fix error if no scripts exists','de':'Korrigiere das Problem, falls keine Skripte existieren','ru':'Исправлена ошибка, если нет никаких скриптов'},'3.3.0':{'en':'all callbacks in try/catch','de':'Alle Callbacks in try/catch','ru':'Все callbacks в try/catch'},'3.2.8':{'en':'Translations','de':'Übersetzungen','ru':'Перевод'},'3.2.7':{'en':'allow creation of states for other javascript instances','de':'Erlaube States-Erzeugung für andere Javascirpt-Instanzen','ru':'Можно создавать переменные для других Javascirpt экземпляров'},'3.2.6':{'en':'Fix import of scripts\nAsk to save before start the script','de':'Korrigiere Skriptimport\nFrage um Speichern bevor Skriptstart','ru':'Исправлен импорт скриптов\nСохранение скриптов прежде, чем запустить их'},'3.2.5':{'en':'Extend compareTime function with astro features','de':'Erweitere compareTime Funktion mit astro Möglichkeiten','ru':'Функция compareTime расширена astro возможностями'},'3.2.4':{'en':'fix stopScript','de':'Korrigiere stopScript','ru':'Исправлен stopScript'},'3.2.3':{'en':'Try to fix error with sayit','de':'Try to fix error with sayit','ru':'Try to fix error with sayit'},'3.2.2':{'en':'Allow with stopScript() to stop itself','de':'Ermögliche mit stopScript() sich anzuhalten','ru':'Позволяет при помощи stopScript() остановить сам скрипт'},'3.2.1':{'en':'Fix error with subscribe for only required states','de':'Korrigiere den Fahler mit dem Subscribe nur für benötigten States','ru':'Исправлена ошибка в подписвании только на необходимые объекты'},'3.2.0':{'en':'Fix error with of blocks in adapters\nSupport of subscribe for only required states','de':'Korrigiere den Fahler mit Blöcken in Adaptern\nUnterstützung von Subscribe nur für benötigten States','ru':'Исправлена ошибка в блоках при драйверах\nПоддержка режима, что подписваются только на необходимые объекты'},'3.1.0':{'en':'Support of blocks in adapters\nMove sendTo blocks into adapters','de':'Unterstützung von Blöcken in Adaptern\nVerschiebe sendTo Blöcke in Adaptern','ru':'Поддержка блоков в драйверах\nБлоки sendTo передвинуты в драйвера'},'3.0.10':{'en':'New blocks: compare time, write state\nDocumentation','de':'Neue Blöcke: Zeitvergleich, Zustand schreiben\nDokumentation ','ru':'Новые блоки: сравнение времени, запись в состояние\nДокументация'},'3.0.9':{'en':'Bugfixing of blockly','de':'Fehler korrigiert in Blockly','ru':'Исправлены ошибки в Blockly'},'3.0.7':{'en':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare','de':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare','ru':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare'},'3.0.6':{'en':'add extendObject function\nadd custom sendTo block\nadd multiple trigger block','de':'Neue Funktion: extendObject\nNeuer Block: custom sendTo\nNeuer Block: multiple trigger','ru':'Добавлена функция extendObject\nДобавлен блок: custom sendTo\nДобавлен блок: multiple trigger'},'3.0.5':{'en':'Fix sendTo blocks','de':'Repariere sendTo Blöcke','ru':'Исправлены sendTo блоки'},'3.0.4':{'en':'Support of convert day of week into text in blockly','de':'Unterstützung von der Konvertierung des Wochentages in Text','ru':'Поддержка конвертирования дня недели в текст в blockly'},'3.0.3':{'en':'Fixed the convert date block','de':'Block für Datumkonevrtirung ist geändert','ru':'Поправлен блок конвертирования даты'},'3.0.2':{'en':'Change name of sandbox debug variable','de':'Ändere Name von Sandbox-Debug','ru':'Изменено имя Sandbox debug переменной'},'3.0.1':{'en':'Fix disabling of script','de':'Fix Deaktivierung vom Skript','ru':'Исправлена деактивация скрипта'},'3.0.0':{'en':'Beta Release with Blockly','de':'Beta Release mit Blockly','ru':'Бета релих с Blockly'},'2.3.4':{'en':'fix sayIt Block','de':'Repariere sayIt Block','ru':'Исправлен sayIt блок'},'2.3.3':{'en':'add more blockly modules\nadd debug mode and verbose mode','de':'add more blockly modules\nadd debug mode and verbose mode','ru':'add more blockly modules\nadd debug mode and verbose mode'},'2.3.1':{'en':'blockly support','de':'blockly support','ru':'blockly support'},'2.3.0':{'en':'export/import of scripts','de':'export/import of scripts','ru':'export/import of scripts'},'2.2.1':{'en':'fix delete state','de':'fix delete state','ru':'fix delete state'},'2.2.0':{'en':'adapter is compatible with redis','de':'adapter is compatible with redis','ru':'adapter is compatible with redis'},'2.1.9':{'en':'add for script onStop handler','de':'add for script onStop handler','ru':'add for script onStop handler'},'2.1.8':{'en':'do not show error if regexp ID','de':'do not show error if regexp ID','ru':'do not show error if regexp ID'},'2.1.7':{'en':'keep configured libraries by upgrade','de':'keep configured libraries by upgrade','ru':'keep configured libraries by upgrade'},'2.1.4':{'en':'catch an error if some system object changed, e.g. _design/history','de':'catch an error if some system object changed, e.g. _design/history','ru':'catch an error if some system object changed, e.g. _design/history'},'2.1.3':{'en':'fix warning with wrong types one more time','de':'fix warning with wrong types one more time','ru':'fix warning with wrong types one more time'},'2.1.2':{'en':'fix warning with wrong types','de':'fix warning with wrong types','ru':'fix warning with wrong types'}},'desc':'Javascript/Coffeescript Script Engine','platform':'Javascript/Node.js','mode':'daemon','loglevel':'info','icon':'js.jpeg','extIcon':'https://raw.githubusercontent.com/ioBroker/ioBroker.javascript/master/admin/js.jpeg','keywords':['js','javascript','coffeescript','rules','automate','scriptengine'],'readme':'https://github.com/iobroker/ioBroker.javascript/blob/master/README.md','license':'MIT','engineTypes':['Blockly','Javascript/js','Coffeescript/coffee'],'adminTab':{'singleton':true,'name':'Scripts'},'type':'script','installedVersion':'3.2.6','enabled':true,'host':'ioBroker-RasPi'},'native':{'latitude':'','longitude':'','enableSetObject':false,'libraries':'','subscribe':false,'useSystemGPS':true}}
                      host.ioBroker-RasPi	2017-11-07 17:41:11.725	info	instance system.adapter.javascript.0 terminated with code 0 (OK)
                      host.ioBroker-RasPi	2017-11-07 17:41:11.679	info	stopInstance system.adapter.javascript.0 killing pid 810
                      host.ioBroker-RasPi	2017-11-07 17:41:11.678	info	stopInstance system.adapter.javascript.0
                      javascript.0	2017-11-07 17:41:11.686	info	terminating
                      host.ioBroker-RasPi	2017-11-07 17:41:11.667	info	object change system.adapter.javascript.0
                      javascript.0	2017-11-07 17:41:05.743	info	Stop script script.js.global.Skript1
                      
                      

                      geändert: Code in Code-Tags; Homoran (Mod)

                      1 Reply Last reply Reply Quote 0
                      • Dutchman
                        Dutchman Developer Most Active Administrators last edited by

                        @Matze1708:

                        Sau stark!

                        Ich versuche es mal morgen einzubauen.

                        Ich gebe info.

                        Einbinden muss ich aber immer die JavaScript objecte oder? `

                        fuer mal bitten diesen code aus, was sagt dein log:

                        `// Read all enums related to enum.functions
                        functions = getEnums('functions');
                        
                        // Loop on all values and store members of function "rolladen" to variable
                        for (var i in functions){
                            if (functions[i].name == 'rolladen'){
                                var rolladen = functions[i].members;
                        
                        	log(rolladen)
                        
                            }
                        
                        }` [/i][/i]
                        
                        1 Reply Last reply Reply Quote 0
                        • M
                          Matze1708 last edited by

                          wenn ich es global ausführe kommt ziemlich das gleiche wie eben.

                          wenn ich es nicht global ausführe kommt das hier

                          ` > javascript.0 2017-11-07 18:01:59.633 warn unsubscribe: empty name

                          javascript.0 2017-11-07 18:01:59.630 info Stop script script.js.Rolläden.Skript1

                          javascript.0 2017-11-07 18:01:54.337 info script.js.Rolläden.Skript1: registered 2 subscriptions and 0 schedules

                          javascript.0 2017-11-07 18:01:54.335 warn Object "' undefined '" does not exist

                          javascript.0 2017-11-07 18:01:54.165 info Start javascript script.js.Rolläden.Skript1 `

                          1 Reply Last reply Reply Quote 0
                          • M
                            Matze1708 last edited by

                            Anbei 2 Bilder von dem enum
                            2486_bildschirmfoto_2017-11-07_um_18.04.00.png
                            2486_bildschirmfoto_2017-11-07_um_18.03.51.png

                            1 Reply Last reply Reply Quote 0
                            • Dutchman
                              Dutchman Developer Most Active Administrators last edited by

                              Führe Mal bitte den code aus 2 Post zurück

                              –-----------------------

                              Send from mobile device

                              1 Reply Last reply Reply Quote 0
                              • M
                                Matze1708 last edited by

                                javascript.0	2017-11-07 18:16:41.242	info	script.js.Rolläden.Schlaf2_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.241	info	script.js.Rolläden.Schlaf2_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.241	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.241	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.241	info	Start javascript script.js.Rolläden.Schlaf2_Status
                                javascript.0	2017-11-07 18:16:41.240	info	script.js.Rolläden.Schlaf1_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.240	info	script.js.Rolläden.Schlaf1_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.240	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.240	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.239	info	Start javascript script.js.Rolläden.Schlaf1_Pos
                                javascript.0	2017-11-07 18:16:41.239	info	script.js.Rolläden.Kind_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.239	info	script.js.Rolläden.Kind_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.239	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.238	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.238	info	Start javascript script.js.Rolläden.Kind_Pos
                                javascript.0	2017-11-07 18:16:41.238	info	script.js.Rolläden.Kind_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.237	info	script.js.Rolläden.Kind_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.237	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.236	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.235	info	Start javascript script.js.Rolläden.Kind_Status
                                javascript.0	2017-11-07 18:16:41.235	info	script.js.Rolläden.Schlaf2_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.235	info	script.js.Rolläden.Schlaf2_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.235	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.234	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.234	info	Start javascript script.js.Rolläden.Schlaf2_Pos
                                javascript.0	2017-11-07 18:16:41.234	info	script.js.Rolläden.Schlaf1_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.234	info	script.js.Rolläden.Schlaf1_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.233	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.233	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.233	info	Start javascript script.js.Rolläden.Schlaf1_Status
                                javascript.0	2017-11-07 18:16:41.232	info	script.js.Rolläden.Büro_OG_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.232	info	script.js.Rolläden.Büro_OG_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.232	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.231	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.231	info	Start javascript script.js.Rolläden.Büro_OG_Status
                                javascript.0	2017-11-07 18:16:41.231	info	script.js.Rolläden.Büro_OG_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.230	info	script.js.Rolläden.Büro_OG_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.228	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.228	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.227	info	Start javascript script.js.Rolläden.Büro_OG_Pos
                                javascript.0	2017-11-07 18:16:41.227	info	script.js.Rolläden.Essen_Pos(4): registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.227	info	script.js.Rolläden.Essen_Pos(4): ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.226	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.226	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.226	info	Start javascript script.js.Rolläden.Essen_Pos(4)
                                javascript.0	2017-11-07 18:16:41.225	info	script.js.Rolläden.Gaderobe_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.225	info	script.js.Rolläden.Gaderobe_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.225	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.224	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.224	info	Start javascript script.js.Rolläden.Gaderobe_Pos
                                javascript.0	2017-11-07 18:16:41.218	info	script.js.Rolläden.WZ_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.218	info	script.js.Rolläden.WZ_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.217	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.216	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.216	info	Start javascript script.js.Rolläden.WZ_Pos
                                javascript.0	2017-11-07 18:16:41.215	info	script.js.Rolläden.Gaderobe_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.215	info	script.js.Rolläden.Gaderobe_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.215	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.214	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.214	info	Start javascript script.js.Rolläden.Gaderobe_Status
                                javascript.0	2017-11-07 18:16:41.213	info	script.js.Rolläden.WZ_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.213	info	script.js.Rolläden.WZ_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.212	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.212	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.211	info	Start javascript script.js.Rolläden.WZ_Status
                                javascript.0	2017-11-07 18:16:41.211	info	script.js.Rolläden.WZ_Tür_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.210	info	script.js.Rolläden.WZ_Tür_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.199	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.199	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.199	info	Start javascript script.js.Rolläden.WZ_Tür_Status
                                javascript.0	2017-11-07 18:16:41.198	info	script.js.Rolläden.WZ_Tür_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.198	info	script.js.Rolläden.WZ_Tür_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.198	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.198	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.197	info	Start javascript script.js.Rolläden.WZ_Tür_Pos
                                javascript.0	2017-11-07 18:16:41.197	info	script.js.Rolläden.Essen_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.197	info	script.js.Rolläden.Essen_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.196	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.195	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.195	info	Start javascript script.js.Rolläden.Essen_Status
                                javascript.0	2017-11-07 18:16:41.194	info	script.js.Rolläden.Küche_Status: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.192	info	script.js.Rolläden.Küche_Status: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.191	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.191	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.191	info	Start javascript script.js.Rolläden.Küche_Status
                                javascript.0	2017-11-07 18:16:41.190	info	script.js.Rolläden.Küche_Pos: registered 4 subscriptions and 0 schedules
                                javascript.0	2017-11-07 18:16:41.190	info	script.js.Rolläden.Küche_Pos: ObjectId = ' undefined ', Wert = null
                                javascript.0	2017-11-07 18:16:41.190	warn	State '' undefined '' not found
                                javascript.0	2017-11-07 18:16:41.190	warn	Object '' undefined '' does not exist
                                javascript.0	2017-11-07 18:16:41.189	info	Start javascript script.js.Rolläden.Küche_Pos
                                javascript.0	2017-11-07 18:16:37.949	info	Start javascript script.js.Rolläden.Küche_Pos
                                javascript.0	2017-11-07 18:16:37.882	info	received all objects
                                javascript.0	2017-11-07 18:16:37.219	info	received all states
                                javascript.0	2017-11-07 18:16:36.445	info	requesting all objects
                                javascript.0	2017-11-07 18:16:36.442	info	requesting all states
                                javascript.0	2017-11-07 18:16:36.428	info	starting. Version 3.2.6 in /opt/iobroker/node_modules/iobroker.javascript, node: v6.11.1
                                javascript.0	2017-11-07 18:16:36.361	info	States connected to redis 127.0.0.1:6379
                                

                                geändert: Code in Code-tags; Homoran (Mod)

                                1 Reply Last reply Reply Quote 0
                                • Dutchman
                                  Dutchman Developer Most Active Administrators last edited by

                                  -Javascript Adapter neu gestartet nachdem du die enum erstellt und gefüllt hast?

                                  –-----------------------

                                  Send from mobile device

                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    Matze1708 last edited by

                                    Nein…. sorry....

                                    ABER.... auch nach java adapter neustart, ändert sich nichts am LOG.

                                    1 Reply Last reply Reply Quote 0
                                    • Dutchman
                                      Dutchman Developer Most Active Administrators last edited by

                                      @Matze1708:

                                      Nein…. sorry....

                                      ABER.... auch nach java adapter neustart, ändert sich nichts am LOG. `

                                      Hast ne PN von mir

                                      –-----------------------

                                      Send from mobile device

                                      1 Reply Last reply Reply Quote 0
                                      • Dutchman
                                        Dutchman Developer Most Active Administrators last edited by

                                        da war noch ein kleiner fehler im script, probier mal version 0.8

                                        `//******************************************
                                        //*****************Dutchman*****************
                                        //****revert values to use KNX with yahka***
                                        //*******************V 0.8****************** 
                                        //******************************************
                                        //******************************************
                                        
                                        // Read all enums related to enum.functions
                                        functions = getEnums('functions');
                                        
                                        // Loop on all values and store members of function "rolladen" to variable
                                        for (var i in functions){
                                            if (functions[i].name == 'rolladen'){
                                                var rolladen = functions[i].members;
                                        
                                            }
                                        
                                        }
                                        
                                        //Seperate values in variable "rolladen" to seperate devices
                                        //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
                                        str = rolladen + ' ';
                                        
                                        var str_array = str.split(',');
                                        for(i = 0; i < str_array.length; i++) {
                                            str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
                                        
                                        	try{
                                        
                                                //retrieve device name for all found devices, replace empty spaces in name by _
                                                var objnameT =  getObject(str_array[i]).common.name;
                                                var objname = objnameT.split(' ').join('_');
                                                var objvalue = 100 - getState(str_array[i]).val;
                                                var revName = objname + '_reversed';
                                        
                                                //Check if object already exist, otherwise create and sync current value
                                        		if (typeof(getIdByName(revName)) === 'undefined') {
                                        
                                                    createState("rolladen_reversed_values." + objname, objvalue, {
                                                        name: revName,
                                                        read: true,
                                                        write: true,
                                                        min: 0,
                                                        max: 100,
                                                        type: 'number',
                                                        role: 'level.hight',
                                                        unit: "%",
                                                        linkorigin: str_array[i]
                                        
                                                    });
                                        
                                                    log('New object  "' + revName + '"  created within "rolladen_reversed_values"');
                                        
                                        		}
                                        
                                        	}   catch(e){}   
                                        
                                        }
                                        
                                        // Trigger on value change in reverse values and syncronise to origin
                                        on({id: /^javascript.1.rolladen_reversed_values\./, change: "ne"}, function (obj) {
                                        
                                            //reverse value from Yahka to KNX logic
                                            var newvalue = 100 - obj.state.val;
                                        
                                            //verify is calculated value is different, if yes update Yahka value to reversed object otherwise do nothing
                                            if (newvalue !== getState(obj.common.linkorigin).val){
                                                setState (obj.common.linkorigin, newvalue);
                                                console.debug('value change based on Yahka trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                        
                                            }
                                        
                                        });
                                        
                                        // Trigger on value change in origin values and syncronise to reverse values
                                        on({enumName: 'rolladen', change: "ne"}, function (obj) {
                                        
                                            //reverse value from KNX to Yahka logic
                                            var newvalue = 100 - obj.state.val;
                                            var objnameT =  obj.common.name;
                                            var objname = objnameT.split(' ').join('_');
                                        
                                            //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                                            if (newvalue !== getState("rolladen_reversed_values." + objname).val){
                                                setState("rolladen_reversed_values." + obj.common.name, newvalue, true);
                                                console.debug('value change based on KNX trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                        
                                            }
                                        
                                        });` [/i][/i][/i][/i][/i][/i][/i]
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • Dutchman
                                          Dutchman Developer Most Active Administrators last edited by

                                          So dar waren noch ein par fehlelr drin, mit zusammenarbeit dan im 0.9 geloest.

                                          Wen jemand interessiert ist hier das fertige script, gehen bestimmt sachen besser (tips wilkommen) aber es laeuft soweit 🙂

                                          `//******************************************
                                          //*****************Dutchman*****************
                                          //****revert values to use KNX with yahka***
                                          //*******************V 0.9****************** 
                                          //******************************************
                                          //******************************************
                                          
                                          // Read all enums related to enum.functions
                                          functions = getEnums('functions');
                                          
                                          // Loop on all values and store members of function "rolladen" to variable
                                          for (var i in functions){
                                              if (functions[i].name == 'rolladen'){
                                                  var rolladen = functions[i].members;
                                          
                                              }
                                          
                                          }
                                          
                                          //Seperate values in variable "rolladen" to seperate devices
                                          //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
                                          str = rolladen + ' ';
                                          
                                          var str_array = str.split(',');
                                          for(i = 0; i < str_array.length; i++) {
                                              str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
                                          
                                             try{
                                          
                                                  //retrieve device name for all found devices, replace empty spaces in name by _
                                                  var objnameT =  getObject(str_array[i]).common.name;
                                                  var objname = objnameT.split(' ').join('_');
                                                  var objvalue = 100 - getState(str_array[i]).val;
                                                  var revName = objname + '_reversed';
                                          
                                                  //Check if object already exist, otherwise create and sync current value
                                                if (typeof(getIdByName(revName)) === 'undefined') {
                                          
                                                      createState("rolladen_reversed_values." + objname, objvalue, {
                                                          name: revName,
                                                          read: true,
                                                          write: true,
                                                          min: 0,
                                                          max: 100,
                                                          type: 'number',
                                                          role: 'level.hight',
                                                          unit: "%",
                                                          linkorigin: str_array[i]
                                          
                                                      });
                                          
                                                      log('New object  "' + revName + '"  created within "rolladen_reversed_values"');
                                          
                                                }
                                          
                                             }   catch(e){}   
                                          
                                          }
                                          
                                          // Trigger on value change in reverse values and syncronise to origin
                                          on({id: /^javascript.0.rolladen_reversed_values\./, change: "ne"}, function (obj) {
                                          
                                              //reverse value from Yahka to KNX logic
                                              var newvalue = 100 - obj.state.val;
                                          
                                              //verify is calculated value is different, if yes update Yahka value to reversed object otherwise do nothing
                                              if (newvalue !== getState(obj.common.linkorigin).val){
                                          
                                                  log("object trigger reverses nach IF");
                                                  setState (obj.common.linkorigin, newvalue);
                                                  console.debug('value change based on Yahka trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                          
                                              }
                                          
                                          });
                                          
                                          // Trigger on value change in origin values and syncronise to reverse values
                                          on({enumName: 'rolladen', change: "ne"}, function (obj) {
                                          
                                              //reverse value from KNX to Yahka logic
                                              var newvalue = 100 - obj.state.val;
                                              var objnameT =  obj.common.name;
                                              var objname = objnameT.split(' ').join('_');
                                          
                                              //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                                              if (newvalue !== getState("rolladen_reversed_values." + objname).val){
                                          
                                                  setState("rolladen_reversed_values." + objname, newvalue, true);
                                                  console.debug('value change based on KNX trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                          
                                              }
                                          
                                          });` [/i][/i][/i][/i][/i][/i][/i]
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • Dutchman
                                            Dutchman Developer Most Active Administrators last edited by

                                            Der Entwickler des Adapters hat soeben auf github die Nachricht erstellt das yahka dies zukünftig Standard Unterstützung.

                                            Wer möchte kann bereits die github Version benutzen um zu testen

                                            Danke an den Entwickler !

                                            https://github.com/jensweigele/ioBroker … -351852394

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            480
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            3
                                            55
                                            6522
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo