Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Wie aus einem HTML-Widget ein neues Widget machen?

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Wie aus einem HTML-Widget ein neues Widget machen?

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

      Hallo Bluefox, habe mir das eben mal auf die schnelle angesehen (muss natürlich noch ausführlicher schauen). In template.html definiere ich welche css Anweisungen und welche .js Anweisungen mein widget haben soll. Ferner definiere ich welche Eigenschaften das widget im Widget Editor haben soll. Was mir jetzt noch fehlt sind zwei Dinge: 1. Wo packe ich meinen html Inhalt (vgl. In Meinen ersten Post den html teil) und wie stelle ich eine Verbindung zwischen html, css und den definierten Widget - Attributen her? Oder anders fornuliert : wie kann ich z.B. dafür sorgen, mein Widget tatsächlich den in den Widget Eigenschaften ausgewählten wert für den background bekommt?

      von unterwegs gesendet

      1 Reply Last reply Reply Quote 0
      • Bluefox
        Bluefox last edited by

        Bevor man folgende Schritte macht, braucht man js-controller version mindestens 0.7.15.

        Es gibt momentan die nicht, deswegen direkt aus github installieren:

        cd /opt/iobroker
        sudo iobroker stop
        sudo npm install https://github.com/ioBroker/ioBroker.js-controller/tarball/master
        sudo iobroker start
        
        

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

        Schritt 1. - Template runterladen

        Runterladen https://github.com/ioBroker/ioBroker.vi … master.zip.

        Schritt 2 - Template auspacken

        Auspacken in /opt/iobroker/node_modules

        Schritt 3 - Template Verzeichnis umbenennen

        Umbenennen "/opt/iobroker/node_modules/ioBroker.vis-template-master" ins "/opt/iobroker/node_modules/iobroker.vis-communicate"

        Schritt 4 - npm Pakete laden

          cd /opt/iobroker/node_modules/iobroker.vis-communicate
          npm install
        

        Schritt 5 - Template selbst umbenennen

        grunt rename –name=communicate --author=Communicate --email=dominic@bialas24.de

        Schritt 6 - style.css befühlen

        Die Datei /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate/css/style.css

        mit

        ! @font-face { font-family: 'CF'; src: url('Cicle Fina.ttf'); } ! .communicate-ul { margin:0px; padding:0px; list-style-type:none; -webkit-backface-visibility: hidden; backface-visibility: hidden; } ! .communicate-var_nav { position:relative; background:#e2e1f4; width:361px; height:70px; margin-bottom:50px; } ! .communicate-link_bg { width:70px; height:70px; position:absolute; ! background:#7A56A0; color:white; ! z-index:2; } ! .communicate-link_bg-i { position:relative; } ! .communicate-link_title { position:absolute; width:100%; z-index:3; color:#7A56A0; } .communicate-link_title:hover .icon { -webkit-transform:rotate(360deg); -moz-transform:rotate(360deg); -o-transform:rotate(360deg); -ms-transform:rotate(360deg); transform:rotate(360deg); } ! .communicate-var_nav:hover .link_bg { width:100%; background:#E01B6A; -webkit-transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out; -o-transition: all 0.3s ease-in-out; -ms-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out; } ! .communicate-var_nav:hover { font-weight:bold; -webkit-transition:all .5s ease-in-out; -moz-transition:all .5s ease-in-out; -o-transition:all .5s ease-in-out; -ms-transition:all .5s ease-in-out; transition:all .5s ease-in-out; } ! .communicate-icon { position:relative; width:70px; height:70px; text-align:center; color:white; -webkit-transition:all .5s ease-in-out; -moz-transition:all .5s ease-in-out; -o-transition:all .5s ease-in-out; -ms-transition:all .5s ease-in-out; float:left; transition:all .5s ease-in-out; float:left; } ! .communicate-left { text-align:left; } .communicate-right { text-align: right; } .communicate-center { text-align: center; } .communicate-justify { text-align: justify; } .communicate-start { text-align: start; } .communicate-img { margin-top: 0.7em; } .communicate-p { margin-top: 0.7em; padding-left: 80px; } !
        Befüllen.

        Schritt 6 - communicate.html befühlen

        Die Datei /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate.html

        mit

        Befüllen.

        Schritt 7 - communicate.js löschen

        Die Datei /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate/js/communicate.js

        und Verzeichnis /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate/js/

        löschen, weil nicht benutzt wird.

        Schritt 8 - Image einfügen

        Alles was in /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate/img liegt

        löschen und die Datei sani_heating_temp.svg dorthin kopieren.

        Schritt 9 - Font einfügen

        Die Datei Cicle Fina.ttf ins /opt/iobroker/node_modules/ioBroker.vis-communicate/widgets/communicate/css kopieren.

        Schritt 10 - Debug einschalten und Kode uploaden

        cd /opt/iobroker
        iobroker visdebug communicate
        
        

        Hier sind Windows-Ausgaben:

        ! ````
        C:\pWork>iobroker visdebug communicate
        ! C:\pWork>node node_modules/iobroker.js-controller/iobroker.js visdebug communicate
        Upload "C:\pWork\node_modules\iobroker.js-controller\node_modules\iobroker.vis\www\index.html.original"
        Upload "C:\pWork\node_modules\iobroker.js-controller\node_modules\iobroker.vis\www\edit.html.original"
        Modify "C:\pWork\node_modules\iobroker.js-controller\node_modules\iobroker.vis\www\cache.manifest"
        Modify config.js
        Upload C:/pWork/node_modules/iobroker.vis-communicate/widgets
        Upload "C:/pWork/node_modules/iobroker.vis-communicate/widgets/communicate/css/style.css"
        Upload "C:/pWork/node_modules/iobroker.vis-communicate/widgets/communicate/img/sani_heating_temp.svg"
        Upload "C:/pWork/node_modules/iobroker.vis-communicate/widgets/communicate/js/communicate.js"
        Upload "C:/pWork/node_modules/iobroker.vis-communicate/widgets/communicate.html"

        
        Das muss man machen bei jeder Änderung in irgendeine Datei in ****C:/pWork/node_modules/iobroker.vis-communicate/widgets**** damit man die Änderungen in vis sieht.
        
        ****Schritt 11**** - Preview Erzeugen
        
        Widget auf dem View platzieren und alles einstellen, wie es sein sollte. F2 drucken so dass "Dev" Lasche sichtbar wird
         ![48_img_008.png](/assets/uploads/files/48_img_008.png) 
        
        Knopf "Show widget HTML" drucken, alles kopieren und in communicate.html die Zeile mit "data-vis-prev=" komplett ersetzen:
        
        >! ````
        data-vis-prev='  
        >! *   _ ![](widgets/communicate/img/sani_heating_temp.svg) _  Heating 0°C  
        >!   '
        

        "iobroker visdebug communicate" nicht vergessen.

        Schritt 12 - ID, Name und Typ anpassen

        id="tplCommunicateHeating"
        data-vis-type="val,heating"
        data-vis-name="Heating"
        

        Man kann die Development Variable bei der Entwicklung benutzen:
        48_img_011.png

        Schritt 13 - Screenshot machen für README.md Seite und Readme.md anpassen.
        48_img_013.png

        Schritt 14 - Version ändern

        Die Datei package.json editieren und Version einstellen. Danach "grunt p" schreiben und diese Versionnummer wird in alle Dateien rein geschrieben.

        Schritt 15 - Share

        Packe es alles zusammen und poste hier oder besser lade hoch auf github und teile hier einen Link.

        Vor dem packen "node_modules" löschen.

        48_iobroker.vis-communicate.zip.txt

        1 Reply Last reply Reply Quote 0
        • C
          Communicate last edited by

          Wow- das nenne ich mal Schritt für Schritt erklärt. Werde das morgen mal ausprobieren und ggf. Gleich noch ein paar weitere Widgets erstellen.

          Ich werde berichten ob's geklappt hat oder ob ich nochmal Hilfe brauche

          EDIT:

          Folgender Text ist leider verlorengegangen, daher hier nochmal:

          ` > Bluefox Re: Wie aus einem HTML-Widget ein neues Widget mac…

          'Habe jetzt Fehler mit "not found" gefunden.

          Entwider das ausführen

          CODE: ALLES AUSWÄHLEN

          cd /opt/iobroker

          sudo iobroker stop

          sudo npm install https://github.com/ioBroker/ioBroker.js ... all/master

          sudo iobroker start

          oder einfach die Datei /opt/iobroekr/node_modules/iobroker.js-controller/lib/setup/setupVisDebug.js

          mit https://github.com/ioBroker/ioBroker.js ... isDebug.js

          austauschen. Man braucht kein Neustart.

          Error: listen EADDRINUSE

          In der neuen Version gibt es Einstellung in /opt/iobroker/iobroker-data/iobroker.json connectTimeout

          CODE: ALLES AUSWÄHLEN

          "objects" : {

          "type" : "file",

          "typeComment": "Possible values: ''file'' - [port 9001], redis - [port 6379], couch - [port 5984].",

          "host" : "127.0.0.1",

          "port" : 9001,

          "user" : "",

          "pass" : "",

          "noFileCache": false,

          "connectTimeout": 2000

          },

          Man kann das auf 5000 ändern. `
          4447_iobroker.2018-07-22.log

          1 Reply Last reply Reply Quote 0
          • C
            Communicate last edited by

            Hallo Bluefox,

            ich hab jetzt ein neues Widget "buttons" erstellt.

            Bis Punkt 10 klappt auch alles super, aber dann, wenn ich versuche in VIS alles einzustellen, sehe ich nur ein transparentes Widget:

            515_bildschirmfoto_2015-10-17_um_21.07.45.png

            Kann ich irgendwie überprüfen, was da schief gegangen ist?

            Dann habe ich mal deinen ANhang probiert und nach /opt/iobroker/node_modules entpackt:

            root@raspberrypi:/opt/iobroker/node_modules# unzip ioBroker.vis-communicate.zip 
            Archive:  ioBroker.vis-communicate.zip
             extracting: ioBroker.vis-communicate/.gitignore  
             extracting: ioBroker.vis-communicate/.npmignore  
               creating: ioBroker.vis-communicate/admin/
              inflating: ioBroker.vis-communicate/admin/communicate.png  
              inflating: ioBroker.vis-communicate/admin/index.html  
              inflating: ioBroker.vis-communicate/Gruntfile.js  
               creating: ioBroker.vis-communicate/img/
              inflating: ioBroker.vis-communicate/img/widgets.png  
              inflating: ioBroker.vis-communicate/io-package.json  
              inflating: ioBroker.vis-communicate/LICENSE  
              inflating: ioBroker.vis-communicate/package.json  
              inflating: ioBroker.vis-communicate/README.md  
               creating: ioBroker.vis-communicate/tasks/
              inflating: ioBroker.vis-communicate/tasks/jscs.js  
              inflating: ioBroker.vis-communicate/tasks/jscsRules.js  
              inflating: ioBroker.vis-communicate/tasks/jshint.js  
               creating: ioBroker.vis-communicate/widgets/
              inflating: ioBroker.vis-communicate/widgets/communicate.html  
               creating: ioBroker.vis-communicate/widgets/communicate/
               creating: ioBroker.vis-communicate/widgets/communicate/css/
              inflating: ioBroker.vis-communicate/widgets/communicate/css/Cicle Fina.ttf  
              inflating: ioBroker.vis-communicate/widgets/communicate/css/style.css  
               creating: ioBroker.vis-communicate/widgets/communicate/img/
              inflating: ioBroker.vis-communicate/widgets/communicate/img/sani_heating_temp.svg  
            

            Bei Versuch von iobroker visdebug communicate

            kommt folgendes raus:

            root@raspberrypi:/opt/iobroker# iobroker visdebug communicate
            Upload "/opt/iobroker/node_modules/iobroker.vis/www/index.html.original"
            Upload "/opt/iobroker/node_modules/iobroker.vis/www/edit.html.original"
            Modify "/opt/iobroker/node_modules/iobroker.vis/www/cache.manifest"
            Modify config.js
            
            fs.js:427
              return binding.open(pathModule._makeLong(path), stringToFlags(flags), mode);
                             ^
            Error: ENOENT, no such file or directory '/opt/iobroker/node_modules/iobroker.js-controller/adapter/vis-communicate/io-package.json'
                at Object.fs.openSync (fs.js:427:18)
                at Object.fs.readFileSync (fs.js:284:15)
                at Socket. <anonymous>(/opt/iobroker/node_modules/iobroker.js-controller/lib/setup/setupVisDebug.js:103:46)
                at Socket.onack (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:295:6)
                at Socket.onpacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:220:12)
                at Manager. <anonymous>(/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-bind/index.js:21:15)
                at Manager.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-emitter/index.js:134:20)
                at Manager.ondecoded (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:301:8)
                at Decoder. <anonymous>(/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-bind/index.js:21:15)
                at Decoder.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-emitter/index.js:134:20)
            root@raspberrypi:/opt/iobroker# cd node_modules/iobroker.js-controller/adapter
            root@raspberrypi:/opt/iobroker/node_modules/iobroker.js-controller/adapter# ls
            example</anonymous></anonymous></anonymous> 
            
            1 Reply Last reply Reply Quote 0
            • Bluefox
              Bluefox last edited by

              Was siehst du in

              /opt/iobroker/node_modules/ioBroker.vis-communicate

              1 Reply Last reply Reply Quote 0
              • C
                Communicate last edited by

                pi@raspberrypi ~ $ cd /opt/iobroker/node_modules/ioBroker.vis-communicate

                pi@raspberrypi /opt/iobroker/node_modules/ioBroker.vis-communicate $ ls

                admin         img              LICENSE       README.md  widgets

                Gruntfile.js  io-package.json  package.json  tasks

                pi@raspberrypi /opt/iobroker/node_modules/ioBroker.vis-communicate $

                Aber unter cd node_modules/iobroker.js-controller/adapter

                gibts nur

                root@raspberrypi:/opt/iobroker# cd node_modules/iobroker.js-controller/adapter
                root@raspberrypi:/opt/iobroker/node_modules/iobroker.js-controller/adapter# ls
                example
                
                

                Ist das richtig?

                1 Reply Last reply Reply Quote 0
                • Bluefox
                  Bluefox last edited by

                  Und wenn du /opt/iobroker/node_modules/ioBroker.vis-communicate

                  ins

                  /opt/iobroker/node_modules/iobroker.vis-communicate

                  Umbenennst?

                  1 Reply Last reply Reply Quote 0
                  • C
                    Communicate last edited by

                    dann läuft der visdebug jetzt durch. Sehr gut.

                    Jetzt kämpfe ich nur damit, dass ich vorhin vis geupdatet habe und ich vis jetzt gar nicht mehr aufrufen kann.

                    das schau ich mir aber morgen erst an.

                    Danke für heute schonmal 🙂

                    1 Reply Last reply Reply Quote 0
                    • C
                      Communicate last edited by

                      So, das funktioniert prima.

                      Für den Moment hab ich dann nur noch eine Frage die das neue widget betrifft.

                      Wie kann ich denn jetzt die ganzen Einstellungen vornehmen? Konkret: wie kann Ich z.B. die beiden unterschiedlichen Farben der Rechtecke in den Einstellungen ändern ? Wenn ich background ändere wird das ganze widget eingefärbt. …

                      Und dann noch die Farbe bei hover-effekt wie komme ich da ran?

                      Gruß

                      Dominic

                      1 Reply Last reply Reply Quote 0
                      • C
                        Communicate last edited by

                        Guten Morgen,

                        es hat mir ja keine ruhe gelassen 🙂

                        Also das System läuft wieder einwandfrei - das ist gut 🙂

                        Ich kann die Farbe des kleinen vierecks über die Eigenschaft bcolor ändern - das ist auch gut 🙂

                        Was ich noch nicht herausgefunden habe ist, wie ich die andern Eigenschaften (also z.B. den Farbverlauf beim Hovereffekt),

                        die Hintergrundfarbe für das große Viereck etc. ändern kann, bzw. eine Verbindung (nennt man das dann binding? ) zwischen

                        der Eigenschaft und dem Widgeteditor herstellen kann?

                        Oder anders ausgedrückt - wie ist denn die Eigenschaft "bcolor" mit dem kleinen viereck verknüpft worden?

                        1 Reply Last reply Reply Quote 0
                        • C
                          Communicate last edited by

                          so, einen kleinen Schritt weiter bin ich schonmal.

                          grep -r -i 'color' ./ hat mir verraten, wo überall die Eigenschaft bcolor vorkommt.

                          Ich glaube, für mich relevant ist in diesem fall die Datei /opt/iobroker/iobroker-data/files/vis/widgets/communicate.html.

                          Diese habe ich auch editiert und zwar so:

                          ! ioBroker.vis communicate Widget-Set
                          ! version: "0.0.1"
                          ! Copyright 10.2015-2016 Communicatedominic@bialas24.de
                          ! -->
                          Soweit so gut - sobald ich aber dann ein iobroker visdebug communicate mache, wird der inhalt von communicate.html mit den ursprungswerten wieder überschrieben und meine Änderungen sind weg.

                          Daher zwei Fragen:

                          1. Kann mein Code überhaupt grundsätzlich funktionieren

                          2. Was mache ich falsch, dass die Änderungen immer wieder überschrieben werden?

                          1 Reply Last reply Reply Quote 0
                          • Bluefox
                            Bluefox last edited by

                            Wenn du die Datei in iobroker-data änderst, dann muss man visdebug nicht aufrufen(es reicht ein mal nach vis start). Man darf nicht vergessen, dass die Änderungen nach vis Restart überschrieben werden und man muss zurück zu node_modules /iobroker.vis-communicate mergen.

                            Deine Änderungen sehen gut aus und müssen gehen.

                            1 Reply Last reply Reply Quote 0
                            • C
                              Communicate last edited by

                              Danke! Das war mein Gedankenfehler.

                              Wenn ich unter /opt/iobroker/node_modules/iobroker.vis-communicate/widgets/communicate.html ändere, müsste ich mit visdebug wieder erfolg haben, oder?

                              Für mich als Anfänger ist das irgendwie einfach zu begreifen, wenn ich Änderungen vornehme und dann zum Schluss immer visdebug aufrufe.

                              1 Reply Last reply Reply Quote 0
                              • Bluefox
                                Bluefox last edited by

                                @Communicate:

                                Danke! Das war mein Gedankenfehler.

                                Wenn ich unter /opt/iobroker/node_modules/iobroker.vis-communicate/widgets/communicate.html ändere, müsste ich mit visdebug wieder erfolg haben, oder? `
                                Ja. Genau.

                                > Für mich als Anfänger ist das irgendwie einfach zu begreifen, wenn ich Änderungen vornehme und dann zum Schluss immer visdebug aufrufe.
                                Dann mach einfach so.
                                6558_unbenannt.png

                                1 Reply Last reply Reply Quote 0
                                • C
                                  Communicate last edited by

                                  so, ein letztes noch, dann hab ich hoffentlich alles was ich zunächst für meine Widget-Entwicklung benötige:

                                  Wie kann ich denn die Atrribute für breite und höhe (alos genau diese Werte:

                                  .var_nav
                                  {
                                  position:relative;
                                  background:#e2e1f4; 
                                  width:361px;
                                  height:70px;
                                  margin-bottom:50px;
                                  
                                  }
                                  

                                  einstellbar machen?

                                  Wenn ich höhe und Breite mit den normalen Widget-Einstellungen verändere, dann ändert sich nicht das WIdget selbst, sondenr ich ziehe quasi einen Hintergrund auf (hier braun dargestellt):
                                  515_bildschirmfoto_2015-10-18_um_12.55.30.png

                                  1 Reply Last reply Reply Quote 0
                                  • C
                                    Communicate last edited by

                                    ich kriegs einfach nicht hin 😞

                                    so sieht meine communicate.html jetzt aus - und ich verstehe nicht, warum ich die linke breite jetzt nicht steuern kann (über die widget eigenschaften) 😞

                                    ! ioBroker.vis communicate Widget-Set
                                    ! version: "0.0.1"
                                    ! Copyright 10.2015-2016 Communicatedominic@bialas24.de
                                    ! -->

                                    1 Reply Last reply Reply Quote 0
                                    • Bluefox
                                      Bluefox last edited by

                                      width:<%== this.data.attr('breite_links') %>px

                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        Communicate last edited by

                                        das wars leider nicht. Es passiert einfach gar nichts.

                                        Kannst Du Dir meine communicate.html mal anschauen / testen bei Dir?

                                        515_communicate.html.zip

                                        1 Reply Last reply Reply Quote 0
                                        • Bluefox
                                          Bluefox last edited by

                                          Du hast ";" in Still vergessen:

                                          style="background: <%== this.data.attr('bcolor') %>****;****width:<%== this.data.attr('breite_links') %>px"

                                          Schaue mal mein Widget, ich habe da ein paar Änderungen gemacht.

                                          1 Reply Last reply Reply Quote 0
                                          • C
                                            Communicate last edited by

                                            Danke, das ";" wars 🙂

                                            Was genau hast Du denn verändert? Ich habe die Datei jetzt nochmal gedownloaded (du hast es doch in deinem Post vom Anfang geändert, oder?)

                                            und eingespielt - kann aber keine Veränderung erkennen :roll:

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            507
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            79
                                            15549
                                            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