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

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Wie aus einem HTML-Widget ein neues Widget machen?

    This topic has been deleted. Only users with topic management privileges can see it.
    • 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
                                          • Bluefox
                                            Bluefox last edited by

                                            @Communicate:

                                            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: `
                                            Schau bitte den Spoiler im meinem vorletztem Post. (Das hier ist letzte 🙂 )
                                            48_widget.gif

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            839
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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