Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. neue Visualisierung "webui" (alternative zu vis & vis-2)

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    212

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    7.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

neue Visualisierung "webui" (alternative zu vis & vis-2)

neue Visualisierung "webui" (alternative zu vis & vis-2)

Scheduled Pinned Locked Moved Visualisierung
1.1k Posts 21 Posters 347.7k Views 18 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • jogibear9988J jogibear9988

    @kamikaze

    dann versuch mal ein full reload vom browser.
    ich hab das ja erst in 1.25 gefixt

    K Offline
    K Offline
    Kamikaze
    wrote on last edited by Kamikaze
    #985

    @jogibear9988 Leider muss ich einmal nachfragen. Was meinst du mit full reload vom browser?
    Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
    Außerdem habe ich vom GitHub den Adapter noch einmal installieren lassen.
    Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
    Habe auch iobroker-Server neu gestartet, erhalte immer noch Designer-Version 1.24.1.

    Nachdem ich meine Zahlen (Testzahl und Testzahl2) regelmäßig aktualisieren lasse, läuft es, da die change-events ausgelöst werden.
    Also hat das nur etwas mit dem Timing oder den initialen Werten zu tun.
    Ich warte jetzt erst einmal auf deinen Input. Testen kann ich heute noch einiges.

    Smilie108S jogibear9988J 2 Replies Last reply
    0
    • K Kamikaze

      @jogibear9988 Leider muss ich einmal nachfragen. Was meinst du mit full reload vom browser?
      Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
      Außerdem habe ich vom GitHub den Adapter noch einmal installieren lassen.
      Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
      Habe auch iobroker-Server neu gestartet, erhalte immer noch Designer-Version 1.24.1.

      Nachdem ich meine Zahlen (Testzahl und Testzahl2) regelmäßig aktualisieren lasse, läuft es, da die change-events ausgelöst werden.
      Also hat das nur etwas mit dem Timing oder den initialen Werten zu tun.
      Ich warte jetzt erst einmal auf deinen Input. Testen kann ich heute noch einiges.

      Smilie108S Offline
      Smilie108S Offline
      Smilie108
      wrote on last edited by
      #986

      @kamikaze normalerweise nur mit f5 aktualisieren dann sollte es gehend das auf der neune version bist ansonsten strg+f5

      K 1 Reply Last reply
      0
      • Smilie108S Smilie108

        @kamikaze normalerweise nur mit f5 aktualisieren dann sollte es gehend das auf der neune version bist ansonsten strg+f5

        K Offline
        K Offline
        Kamikaze
        wrote on last edited by
        #987

        @smilie108 Na ja, das ist mit meiner Aktivität ja nun mehrfach erledigt.
        Danke für die Erläuterung.

        1 Reply Last reply
        0
        • Smilie108S Offline
          Smilie108S Offline
          Smilie108
          wrote on last edited by
          #988

          @jogibear9988 Hi so schön langsam wieder ein bischen zeit 😉
          kannst du dir mal /smilie108/grafana auf dem testserver anschauen ob ich da am richtigen weg bin ?
          Steig da noch nicht ganuz durch mit dem ganzen. Kann ich das so verwenden im javascriptteil ioder anders ?

          Danke für alles was du so machst das sys ist echt schon voll supi 😉

          Gruß Tom

          jogibear9988J 2 Replies Last reply
          0
          • K Kamikaze

            @jogibear9988 Leider muss ich einmal nachfragen. Was meinst du mit full reload vom browser?
            Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
            Außerdem habe ich vom GitHub den Adapter noch einmal installieren lassen.
            Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
            Habe auch iobroker-Server neu gestartet, erhalte immer noch Designer-Version 1.24.1.

            Nachdem ich meine Zahlen (Testzahl und Testzahl2) regelmäßig aktualisieren lasse, läuft es, da die change-events ausgelöst werden.
            Also hat das nur etwas mit dem Timing oder den initialen Werten zu tun.
            Ich warte jetzt erst einmal auf deinen Input. Testen kann ich heute noch einiges.

            jogibear9988J Offline
            jogibear9988J Offline
            jogibear9988
            wrote on last edited by
            #989

            @kamikaze said in neue Visualisierung "webui" (alternative zu vis & vis-2):

            @jogibear9988 Leider muss ich einmal nachfragen. Was meinst du mit full reload vom browser?
            Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
            Außerdem habe ich vom GitHub den Adapter noch einmal installieren lassen.
            Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
            Habe auch iobroker-Server neu gestartet, erhalte immer noch Designer-Version 1.24.1.

            Nachdem ich meine Zahlen (Testzahl und Testzahl2) regelmäßig aktualisieren lasse, läuft es, da die change-events ausgelöst werden.
            Also hat das nur etwas mit dem Timing oder den initialen Werten zu tun.
            Ich warte jetzt erst einmal auf deinen Input. Testen kann ich heute noch einiges.

            ja es hat mit dem initialen laden zu tun, und das ist in 1.25.0 gefixt

            Check my ioBroker webui - a vis alternative
            see: https://github.com/iobroker-community-adapters/ioBroker.webui

            K 1 Reply Last reply
            0
            • Smilie108S Smilie108

              @jogibear9988 Hi so schön langsam wieder ein bischen zeit 😉
              kannst du dir mal /smilie108/grafana auf dem testserver anschauen ob ich da am richtigen weg bin ?
              Steig da noch nicht ganuz durch mit dem ganzen. Kann ich das so verwenden im javascriptteil ioder anders ?

              Danke für alles was du so machst das sys ist echt schon voll supi 😉

              Gruß Tom

              jogibear9988J Offline
              jogibear9988J Offline
              jogibear9988
              wrote on last edited by
              #990

              @smilie108

              grafana auf dem testserver ist leer

              Check my ioBroker webui - a vis alternative
              see: https://github.com/iobroker-community-adapters/ioBroker.webui

              Smilie108S 1 Reply Last reply
              0
              • jogibear9988J jogibear9988

                @smilie108

                grafana auf dem testserver ist leer

                Smilie108S Offline
                Smilie108S Offline
                Smilie108
                wrote on last edited by
                #991

                @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                export bei mir import bei dir

                <?xml version="1.0" encoding="UTF-8"?>
                <screen>
                    <html><![CDATA[
                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                    <option value="0">Keine</option>
                    <option value="10">10 sec</option>
                    <option value="30">30 sec</option>
                    <option value="60">60 sec</option>
                    <option value="120">120 sec</option>
                    <option value="240">240 sec</option>
                    <option value="300">300 sec</option>
                </select>
                <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                    <option value="1">Kurve 1</option>
                    <option value="2">Kurve 2</option>
                    <option value="3">Kurve 3</option>
                    <option value="4">Kurve 4</option>
                    <option value="5">Kurve 5</option>
                </select>
                <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                
                ]]></html>
                    <style><![CDATA[
                :host {
                }
                
                * {
                    box-sizing: border-box;
                }
                ]]></style>
                    <script><![CDATA[
                // 
                var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                /* Ab hier keine änderungen machen
                http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                */
                var ptag = selector_zeit;/*Selector Zeit*/
                var prange = selector_range;/*Selector Range*/
                var prefresh1 = selector_refresh;
                /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                var idselector = selector_id;/*Selector Graph ID*/
                /* Variabel wohin dei fertige Url geschrieben wird */
                var urlfertig = urliframe;/*Fertige Url*/
                var timezone = 2;
                var zeitverschiebung = timezone * 3600000;
                // Aufplitten zum später zusammensetzen
                var urlteil1 = url1;
                var urlteil2 = '&to=';
                var urlteil21 = '&refresh=';
                var urlteil3 = 's&panelId=';
                var urlteil4 = 'width="450" height="200" frameborder="0"';
                // Auf Änderungen reagieren
                var changesArray3 = [ptag, prange, idselector, prefresh1];
                on({ id: changesArray3, change: "any" }, function (obj) {
                    /* Ausführung der anpassung der Url für aufruf*/
                    /* Startzeit für Grafana in Timestamp*/
                    var startzeit = getState(ptag).val;
                    var endzeit = getState(prange).val;
                    var idselector1 = getState(idselector).val;
                    var refrescht = getState(prefresh1).val;
                    if (endzeit == "jetzt" && startzeit != "0") {
                        var helper23 = "0";
                        setState(ptag, helper23);
                    }
                
                    if (endzeit != "jetzt") {
                        var helper25 = "0";
                        refrescht = helper25;
                    }
                
                
                    if (endzeit != "jetzt" && startzeit == "0") {
                        const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                        const timestamp1 = currentDate.getTime();
                        var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                        setState(ptag, helper24)
                    }
                    /* von utc auf timezone +2h 
                    var startzeit1 = (startzeit + 3600000);*/
                    if (endzeit == "jetzt") {
                        startzeit1 = "0";
                    }
                    else { var startzeit1 = startzeit }
                
                
                    if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                        if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                        else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                        else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                        else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                        else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                        else { var startzeit2 = (Date.now() - 86400000) }
                    }
                
                
                    else { startzeit2 = startzeit1 }
                    /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                    var startzeitfertig = startzeit2 / 1;
                    if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                
                    /* Anzeigeende festlegen*/
                    var endezeitad = zeitverschiebung + 3600000;
                
                
                    if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                    else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                    else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                    else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                    else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                    else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                
                
                    // Fertige Url generieren
                    var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                    /* fertige url in Objekt schreiben*/
                    setState(urlfertig, urlberechnet);
                
                });
                
                
                ]]></script>
                    <properties>
                        <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                        <property name="selector_zeit" type="string" internal="true" />
                        <property name="selector_range" type="string" default="day" internal="true" />
                        <property name="selector_refresh" type="string" default="30s" internal="true" />
                        <property name="selector_id" type="string" default="1" internal="true" />
                    </properties>
                    <settings>
                    </settings>
                </screen>
                
                

                das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                komisch
                habs 3x probiert

                jogibear9988J 3 Replies Last reply
                0
                • jogibear9988J jogibear9988

                  @kamikaze said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                  @jogibear9988 Leider muss ich einmal nachfragen. Was meinst du mit full reload vom browser?
                  Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
                  Außerdem habe ich vom GitHub den Adapter noch einmal installieren lassen.
                  Ich habe den Cache geleert und einen anderen Browser genommen, erhalte immer noch Designer-Version 1.24.1.
                  Habe auch iobroker-Server neu gestartet, erhalte immer noch Designer-Version 1.24.1.

                  Nachdem ich meine Zahlen (Testzahl und Testzahl2) regelmäßig aktualisieren lasse, läuft es, da die change-events ausgelöst werden.
                  Also hat das nur etwas mit dem Timing oder den initialen Werten zu tun.
                  Ich warte jetzt erst einmal auf deinen Input. Testen kann ich heute noch einiges.

                  ja es hat mit dem initialen laden zu tun, und das ist in 1.25.0 gefixt

                  K Offline
                  K Offline
                  Kamikaze
                  wrote on last edited by Kamikaze
                  #992

                  @jogibear9988 Was kann ich noch tun, um die 1.25.0 zu bekommen.
                  Nach dem Neustart vom iobroker meldet er auch 1.25.0

                  info: host.iobroker instance system.adapter.webui.0 in version "1.25.0" (non-npm: iobroker-community-adapters/ioBroker.webui) started with pid 1184
                  

                  Nur im Designer steht 1.24.1

                  Jetzt habe ich den Adapter noch einmal installiert über den GitHub Link .

                  Auch hier im iobroker 1.25.0 und im designer 1.24.1

                  1 Reply Last reply
                  0
                  • Smilie108S Smilie108

                    @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                    export bei mir import bei dir

                    <?xml version="1.0" encoding="UTF-8"?>
                    <screen>
                        <html><![CDATA[
                    <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                    <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                    <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                    <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                    <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                    <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                    <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                        <option value="0">Keine</option>
                        <option value="10">10 sec</option>
                        <option value="30">30 sec</option>
                        <option value="60">60 sec</option>
                        <option value="120">120 sec</option>
                        <option value="240">240 sec</option>
                        <option value="300">300 sec</option>
                    </select>
                    <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                        <option value="1">Kurve 1</option>
                        <option value="2">Kurve 2</option>
                        <option value="3">Kurve 3</option>
                        <option value="4">Kurve 4</option>
                        <option value="5">Kurve 5</option>
                    </select>
                    <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                    <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                    <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                    
                    ]]></html>
                        <style><![CDATA[
                    :host {
                    }
                    
                    * {
                        box-sizing: border-box;
                    }
                    ]]></style>
                        <script><![CDATA[
                    // 
                    var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                    /* Ab hier keine änderungen machen
                    http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                    */
                    var ptag = selector_zeit;/*Selector Zeit*/
                    var prange = selector_range;/*Selector Range*/
                    var prefresh1 = selector_refresh;
                    /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                    /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                    var idselector = selector_id;/*Selector Graph ID*/
                    /* Variabel wohin dei fertige Url geschrieben wird */
                    var urlfertig = urliframe;/*Fertige Url*/
                    var timezone = 2;
                    var zeitverschiebung = timezone * 3600000;
                    // Aufplitten zum später zusammensetzen
                    var urlteil1 = url1;
                    var urlteil2 = '&to=';
                    var urlteil21 = '&refresh=';
                    var urlteil3 = 's&panelId=';
                    var urlteil4 = 'width="450" height="200" frameborder="0"';
                    // Auf Änderungen reagieren
                    var changesArray3 = [ptag, prange, idselector, prefresh1];
                    on({ id: changesArray3, change: "any" }, function (obj) {
                        /* Ausführung der anpassung der Url für aufruf*/
                        /* Startzeit für Grafana in Timestamp*/
                        var startzeit = getState(ptag).val;
                        var endzeit = getState(prange).val;
                        var idselector1 = getState(idselector).val;
                        var refrescht = getState(prefresh1).val;
                        if (endzeit == "jetzt" && startzeit != "0") {
                            var helper23 = "0";
                            setState(ptag, helper23);
                        }
                    
                        if (endzeit != "jetzt") {
                            var helper25 = "0";
                            refrescht = helper25;
                        }
                    
                    
                        if (endzeit != "jetzt" && startzeit == "0") {
                            const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                            const timestamp1 = currentDate.getTime();
                            var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                            setState(ptag, helper24)
                        }
                        /* von utc auf timezone +2h 
                        var startzeit1 = (startzeit + 3600000);*/
                        if (endzeit == "jetzt") {
                            startzeit1 = "0";
                        }
                        else { var startzeit1 = startzeit }
                    
                    
                        if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                            if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                            else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                            else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                            else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                            else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                            else { var startzeit2 = (Date.now() - 86400000) }
                        }
                    
                    
                        else { startzeit2 = startzeit1 }
                        /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                        var startzeitfertig = startzeit2 / 1;
                        if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                    
                        /* Anzeigeende festlegen*/
                        var endezeitad = zeitverschiebung + 3600000;
                    
                    
                        if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                        else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                        else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                        else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                        else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                        else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                    
                    
                        // Fertige Url generieren
                        var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                        /* fertige url in Objekt schreiben*/
                        setState(urlfertig, urlberechnet);
                    
                    });
                    
                    
                    ]]></script>
                        <properties>
                            <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                            <property name="selector_zeit" type="string" internal="true" />
                            <property name="selector_range" type="string" default="day" internal="true" />
                            <property name="selector_refresh" type="string" default="30s" internal="true" />
                            <property name="selector_id" type="string" default="1" internal="true" />
                        </properties>
                        <settings>
                        </settings>
                    </screen>
                    
                    

                    das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                    komisch
                    habs 3x probiert

                    jogibear9988J Offline
                    jogibear9988J Offline
                    jogibear9988
                    wrote on last edited by
                    #993

                    @smilie108 said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                    eight="200" frameborder="0">" internal="true"

                    da ist wohl ein fehler im export, ein " zuviel

                    Check my ioBroker webui - a vis alternative
                    see: https://github.com/iobroker-community-adapters/ioBroker.webui

                    K 1 Reply Last reply
                    0
                    • Smilie108S Smilie108

                      @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                      export bei mir import bei dir

                      <?xml version="1.0" encoding="UTF-8"?>
                      <screen>
                          <html><![CDATA[
                      <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                      <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                      <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                      <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                      <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                      <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                      <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                          <option value="0">Keine</option>
                          <option value="10">10 sec</option>
                          <option value="30">30 sec</option>
                          <option value="60">60 sec</option>
                          <option value="120">120 sec</option>
                          <option value="240">240 sec</option>
                          <option value="300">300 sec</option>
                      </select>
                      <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                          <option value="1">Kurve 1</option>
                          <option value="2">Kurve 2</option>
                          <option value="3">Kurve 3</option>
                          <option value="4">Kurve 4</option>
                          <option value="5">Kurve 5</option>
                      </select>
                      <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                      <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                      <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                      
                      ]]></html>
                          <style><![CDATA[
                      :host {
                      }
                      
                      * {
                          box-sizing: border-box;
                      }
                      ]]></style>
                          <script><![CDATA[
                      // 
                      var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                      /* Ab hier keine änderungen machen
                      http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                      */
                      var ptag = selector_zeit;/*Selector Zeit*/
                      var prange = selector_range;/*Selector Range*/
                      var prefresh1 = selector_refresh;
                      /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                      /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                      var idselector = selector_id;/*Selector Graph ID*/
                      /* Variabel wohin dei fertige Url geschrieben wird */
                      var urlfertig = urliframe;/*Fertige Url*/
                      var timezone = 2;
                      var zeitverschiebung = timezone * 3600000;
                      // Aufplitten zum später zusammensetzen
                      var urlteil1 = url1;
                      var urlteil2 = '&to=';
                      var urlteil21 = '&refresh=';
                      var urlteil3 = 's&panelId=';
                      var urlteil4 = 'width="450" height="200" frameborder="0"';
                      // Auf Änderungen reagieren
                      var changesArray3 = [ptag, prange, idselector, prefresh1];
                      on({ id: changesArray3, change: "any" }, function (obj) {
                          /* Ausführung der anpassung der Url für aufruf*/
                          /* Startzeit für Grafana in Timestamp*/
                          var startzeit = getState(ptag).val;
                          var endzeit = getState(prange).val;
                          var idselector1 = getState(idselector).val;
                          var refrescht = getState(prefresh1).val;
                          if (endzeit == "jetzt" && startzeit != "0") {
                              var helper23 = "0";
                              setState(ptag, helper23);
                          }
                      
                          if (endzeit != "jetzt") {
                              var helper25 = "0";
                              refrescht = helper25;
                          }
                      
                      
                          if (endzeit != "jetzt" && startzeit == "0") {
                              const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                              const timestamp1 = currentDate.getTime();
                              var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                              setState(ptag, helper24)
                          }
                          /* von utc auf timezone +2h 
                          var startzeit1 = (startzeit + 3600000);*/
                          if (endzeit == "jetzt") {
                              startzeit1 = "0";
                          }
                          else { var startzeit1 = startzeit }
                      
                      
                          if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                              if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                              else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                              else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                              else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                              else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                              else { var startzeit2 = (Date.now() - 86400000) }
                          }
                      
                      
                          else { startzeit2 = startzeit1 }
                          /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                          var startzeitfertig = startzeit2 / 1;
                          if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                      
                          /* Anzeigeende festlegen*/
                          var endezeitad = zeitverschiebung + 3600000;
                      
                      
                          if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                          else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                          else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                          else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                          else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                          else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                      
                      
                          // Fertige Url generieren
                          var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                          /* fertige url in Objekt schreiben*/
                          setState(urlfertig, urlberechnet);
                      
                      });
                      
                      
                      ]]></script>
                          <properties>
                              <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                              <property name="selector_zeit" type="string" internal="true" />
                              <property name="selector_range" type="string" default="day" internal="true" />
                              <property name="selector_refresh" type="string" default="30s" internal="true" />
                              <property name="selector_id" type="string" default="1" internal="true" />
                          </properties>
                          <settings>
                          </settings>
                      </screen>
                      
                      

                      das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                      komisch
                      habs 3x probiert

                      jogibear9988J Offline
                      jogibear9988J Offline
                      jogibear9988
                      wrote on last edited by
                      #994

                      @smilie108

                      ich schaus mir an, aber nicht heute... bin krank

                      Check my ioBroker webui - a vis alternative
                      see: https://github.com/iobroker-community-adapters/ioBroker.webui

                      1 Reply Last reply
                      0
                      • B Offline
                        B Offline
                        Blockmove
                        wrote on last edited by
                        #995

                        @jogibear9988 said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                        @smilie108

                        ich schaus mir an, aber nicht heute... bin krank

                        Gute Besserung!

                        The difference beetween Man and Boys:
                        The price of their toys 😀

                        1 Reply Last reply
                        0
                        • jogibear9988J jogibear9988

                          @smilie108 said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                          eight="200" frameborder="0">" internal="true"

                          da ist wohl ein fehler im export, ein " zuviel

                          K Offline
                          K Offline
                          Kamikaze
                          wrote on last edited by
                          #996

                          @jogibear9988 Hallo jogibear,
                          nachdem ich von dir nichts mehr gehört habe, habe ich erneut den Adapter installiert, dieses Mal über npm.
                          Und was soll ich sagen, jetzt ist auch die Runtime auf Version 1.25.0 und alles funktiniert wie gewünscht.

                          VIELEN DANK für deine tatkräftige Unterstützung.

                          jogibear9988J 1 Reply Last reply
                          0
                          • K Kamikaze

                            @jogibear9988 Hallo jogibear,
                            nachdem ich von dir nichts mehr gehört habe, habe ich erneut den Adapter installiert, dieses Mal über npm.
                            Und was soll ich sagen, jetzt ist auch die Runtime auf Version 1.25.0 und alles funktiniert wie gewünscht.

                            VIELEN DANK für deine tatkräftige Unterstützung.

                            jogibear9988J Offline
                            jogibear9988J Offline
                            jogibear9988
                            wrote on last edited by
                            #997

                            @kamikaze said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                            @jogibear9988 Hallo jogibear,
                            nachdem ich von dir nichts mehr gehört habe, habe ich erneut den Adapter installiert, dieses Mal über npm.
                            Und was soll ich sagen, jetzt ist auch die Runtime auf Version 1.25.0 und alles funktiniert wie gewünscht.

                            VIELEN DANK für deine tatkräftige Unterstützung.

                            sorry... bin krank seit gestern, daher keine antwort

                            Check my ioBroker webui - a vis alternative
                            see: https://github.com/iobroker-community-adapters/ioBroker.webui

                            K 1 Reply Last reply
                            0
                            • Smilie108S Smilie108

                              @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                              export bei mir import bei dir

                              <?xml version="1.0" encoding="UTF-8"?>
                              <screen>
                                  <html><![CDATA[
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                              <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                              <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                                  <option value="0">Keine</option>
                                  <option value="10">10 sec</option>
                                  <option value="30">30 sec</option>
                                  <option value="60">60 sec</option>
                                  <option value="120">120 sec</option>
                                  <option value="240">240 sec</option>
                                  <option value="300">300 sec</option>
                              </select>
                              <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                                  <option value="1">Kurve 1</option>
                                  <option value="2">Kurve 2</option>
                                  <option value="3">Kurve 3</option>
                                  <option value="4">Kurve 4</option>
                                  <option value="5">Kurve 5</option>
                              </select>
                              <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                              <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                              <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                              
                              ]]></html>
                                  <style><![CDATA[
                              :host {
                              }
                              
                              * {
                                  box-sizing: border-box;
                              }
                              ]]></style>
                                  <script><![CDATA[
                              // 
                              var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                              /* Ab hier keine änderungen machen
                              http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                              */
                              var ptag = selector_zeit;/*Selector Zeit*/
                              var prange = selector_range;/*Selector Range*/
                              var prefresh1 = selector_refresh;
                              /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                              /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                              var idselector = selector_id;/*Selector Graph ID*/
                              /* Variabel wohin dei fertige Url geschrieben wird */
                              var urlfertig = urliframe;/*Fertige Url*/
                              var timezone = 2;
                              var zeitverschiebung = timezone * 3600000;
                              // Aufplitten zum später zusammensetzen
                              var urlteil1 = url1;
                              var urlteil2 = '&to=';
                              var urlteil21 = '&refresh=';
                              var urlteil3 = 's&panelId=';
                              var urlteil4 = 'width="450" height="200" frameborder="0"';
                              // Auf Änderungen reagieren
                              var changesArray3 = [ptag, prange, idselector, prefresh1];
                              on({ id: changesArray3, change: "any" }, function (obj) {
                                  /* Ausführung der anpassung der Url für aufruf*/
                                  /* Startzeit für Grafana in Timestamp*/
                                  var startzeit = getState(ptag).val;
                                  var endzeit = getState(prange).val;
                                  var idselector1 = getState(idselector).val;
                                  var refrescht = getState(prefresh1).val;
                                  if (endzeit == "jetzt" && startzeit != "0") {
                                      var helper23 = "0";
                                      setState(ptag, helper23);
                                  }
                              
                                  if (endzeit != "jetzt") {
                                      var helper25 = "0";
                                      refrescht = helper25;
                                  }
                              
                              
                                  if (endzeit != "jetzt" && startzeit == "0") {
                                      const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                                      const timestamp1 = currentDate.getTime();
                                      var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                                      setState(ptag, helper24)
                                  }
                                  /* von utc auf timezone +2h 
                                  var startzeit1 = (startzeit + 3600000);*/
                                  if (endzeit == "jetzt") {
                                      startzeit1 = "0";
                                  }
                                  else { var startzeit1 = startzeit }
                              
                              
                                  if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                                      if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                                      else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                                      else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                                      else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                                      else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                                      else { var startzeit2 = (Date.now() - 86400000) }
                                  }
                              
                              
                                  else { startzeit2 = startzeit1 }
                                  /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                                  var startzeitfertig = startzeit2 / 1;
                                  if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                              
                                  /* Anzeigeende festlegen*/
                                  var endezeitad = zeitverschiebung + 3600000;
                              
                              
                                  if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                  else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                                  else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                                  else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                                  else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                                  else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                              
                              
                                  // Fertige Url generieren
                                  var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                                  /* fertige url in Objekt schreiben*/
                                  setState(urlfertig, urlberechnet);
                              
                              });
                              
                              
                              ]]></script>
                                  <properties>
                                      <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                                      <property name="selector_zeit" type="string" internal="true" />
                                      <property name="selector_range" type="string" default="day" internal="true" />
                                      <property name="selector_refresh" type="string" default="30s" internal="true" />
                                      <property name="selector_id" type="string" default="1" internal="true" />
                                  </properties>
                                  <settings>
                                  </settings>
                              </screen>
                              
                              

                              das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                              komisch
                              habs 3x probiert

                              jogibear9988J Offline
                              jogibear9988J Offline
                              jogibear9988
                              wrote on last edited by jogibear9988
                              #998

                              @smilie108 said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                              @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                              export bei mir import bei dir

                              <?xml version="1.0" encoding="UTF-8"?>
                              <screen>
                                  <html><![CDATA[
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                              <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                              <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                              <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                                  <option value="0">Keine</option>
                                  <option value="10">10 sec</option>
                                  <option value="30">30 sec</option>
                                  <option value="60">60 sec</option>
                                  <option value="120">120 sec</option>
                                  <option value="240">240 sec</option>
                                  <option value="300">300 sec</option>
                              </select>
                              <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                                  <option value="1">Kurve 1</option>
                                  <option value="2">Kurve 2</option>
                                  <option value="3">Kurve 3</option>
                                  <option value="4">Kurve 4</option>
                                  <option value="5">Kurve 5</option>
                              </select>
                              <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                              <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                              <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                              
                              ]]></html>
                                  <style><![CDATA[
                              :host {
                              }
                              
                              * {
                                  box-sizing: border-box;
                              }
                              ]]></style>
                                  <script><![CDATA[
                              // 
                              var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                              /* Ab hier keine änderungen machen
                              http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                              */
                              var ptag = selector_zeit;/*Selector Zeit*/
                              var prange = selector_range;/*Selector Range*/
                              var prefresh1 = selector_refresh;
                              /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                              /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                              var idselector = selector_id;/*Selector Graph ID*/
                              /* Variabel wohin dei fertige Url geschrieben wird */
                              var urlfertig = urliframe;/*Fertige Url*/
                              var timezone = 2;
                              var zeitverschiebung = timezone * 3600000;
                              // Aufplitten zum später zusammensetzen
                              var urlteil1 = url1;
                              var urlteil2 = '&to=';
                              var urlteil21 = '&refresh=';
                              var urlteil3 = 's&panelId=';
                              var urlteil4 = 'width="450" height="200" frameborder="0"';
                              // Auf Änderungen reagieren
                              var changesArray3 = [ptag, prange, idselector, prefresh1];
                              on({ id: changesArray3, change: "any" }, function (obj) {
                                  /* Ausführung der anpassung der Url für aufruf*/
                                  /* Startzeit für Grafana in Timestamp*/
                                  var startzeit = getState(ptag).val;
                                  var endzeit = getState(prange).val;
                                  var idselector1 = getState(idselector).val;
                                  var refrescht = getState(prefresh1).val;
                                  if (endzeit == "jetzt" && startzeit != "0") {
                                      var helper23 = "0";
                                      setState(ptag, helper23);
                                  }
                              
                                  if (endzeit != "jetzt") {
                                      var helper25 = "0";
                                      refrescht = helper25;
                                  }
                              
                              
                                  if (endzeit != "jetzt" && startzeit == "0") {
                                      const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                                      const timestamp1 = currentDate.getTime();
                                      var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                                      setState(ptag, helper24)
                                  }
                                  /* von utc auf timezone +2h 
                                  var startzeit1 = (startzeit + 3600000);*/
                                  if (endzeit == "jetzt") {
                                      startzeit1 = "0";
                                  }
                                  else { var startzeit1 = startzeit }
                              
                              
                                  if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                                      if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                                      else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                                      else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                                      else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                                      else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                                      else { var startzeit2 = (Date.now() - 86400000) }
                                  }
                              
                              
                                  else { startzeit2 = startzeit1 }
                                  /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                                  var startzeitfertig = startzeit2 / 1;
                                  if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                              
                                  /* Anzeigeende festlegen*/
                                  var endezeitad = zeitverschiebung + 3600000;
                              
                              
                                  if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                  else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                                  else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                                  else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                                  else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                                  else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                              
                              
                                  // Fertige Url generieren
                                  var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                                  /* fertige url in Objekt schreiben*/
                                  setState(urlfertig, urlberechnet);
                              
                              });
                              
                              
                              ]]></script>
                                  <properties>
                                      <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                                      <property name="selector_zeit" type="string" internal="true" />
                                      <property name="selector_range" type="string" default="day" internal="true" />
                                      <property name="selector_refresh" type="string" default="30s" internal="true" />
                                      <property name="selector_id" type="string" default="1" internal="true" />
                                  </properties>
                                  <settings>
                                  </settings>
                              </screen>
                              
                              

                              das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                              komisch
                              habs 3x probiert

                              kannst du bitte den js code, den css code und das html von hand einfügen? damit ich schauen kann was am export kaputt ist?
                              und die properties anlegen

                              Check my ioBroker webui - a vis alternative
                              see: https://github.com/iobroker-community-adapters/ioBroker.webui

                              Smilie108S 1 Reply Last reply
                              0
                              • jogibear9988J jogibear9988

                                @smilie108 said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                                @jogibear9988 mhm bei mir ae1bae27-604f-4acc-b70f-7c5928ae981a-grafik.png

                                export bei mir import bei dir

                                <?xml version="1.0" encoding="UTF-8"?>
                                <screen>
                                    <html><![CDATA[
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                                <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                                <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                                    <option value="0">Keine</option>
                                    <option value="10">10 sec</option>
                                    <option value="30">30 sec</option>
                                    <option value="60">60 sec</option>
                                    <option value="120">120 sec</option>
                                    <option value="240">240 sec</option>
                                    <option value="300">300 sec</option>
                                </select>
                                <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                                    <option value="1">Kurve 1</option>
                                    <option value="2">Kurve 2</option>
                                    <option value="3">Kurve 3</option>
                                    <option value="4">Kurve 4</option>
                                    <option value="5">Kurve 5</option>
                                </select>
                                <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                                <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                                <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                                
                                ]]></html>
                                    <style><![CDATA[
                                :host {
                                }
                                
                                * {
                                    box-sizing: border-box;
                                }
                                ]]></style>
                                    <script><![CDATA[
                                // 
                                var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                                /* Ab hier keine änderungen machen
                                http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                                */
                                var ptag = selector_zeit;/*Selector Zeit*/
                                var prange = selector_range;/*Selector Range*/
                                var prefresh1 = selector_refresh;
                                /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                                /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                                var idselector = selector_id;/*Selector Graph ID*/
                                /* Variabel wohin dei fertige Url geschrieben wird */
                                var urlfertig = urliframe;/*Fertige Url*/
                                var timezone = 2;
                                var zeitverschiebung = timezone * 3600000;
                                // Aufplitten zum später zusammensetzen
                                var urlteil1 = url1;
                                var urlteil2 = '&to=';
                                var urlteil21 = '&refresh=';
                                var urlteil3 = 's&panelId=';
                                var urlteil4 = 'width="450" height="200" frameborder="0"';
                                // Auf Änderungen reagieren
                                var changesArray3 = [ptag, prange, idselector, prefresh1];
                                on({ id: changesArray3, change: "any" }, function (obj) {
                                    /* Ausführung der anpassung der Url für aufruf*/
                                    /* Startzeit für Grafana in Timestamp*/
                                    var startzeit = getState(ptag).val;
                                    var endzeit = getState(prange).val;
                                    var idselector1 = getState(idselector).val;
                                    var refrescht = getState(prefresh1).val;
                                    if (endzeit == "jetzt" && startzeit != "0") {
                                        var helper23 = "0";
                                        setState(ptag, helper23);
                                    }
                                
                                    if (endzeit != "jetzt") {
                                        var helper25 = "0";
                                        refrescht = helper25;
                                    }
                                
                                
                                    if (endzeit != "jetzt" && startzeit == "0") {
                                        const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                                        const timestamp1 = currentDate.getTime();
                                        var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                                        setState(ptag, helper24)
                                    }
                                    /* von utc auf timezone +2h 
                                    var startzeit1 = (startzeit + 3600000);*/
                                    if (endzeit == "jetzt") {
                                        startzeit1 = "0";
                                    }
                                    else { var startzeit1 = startzeit }
                                
                                
                                    if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                                        if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                                        else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                                        else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                                        else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                                        else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                                        else { var startzeit2 = (Date.now() - 86400000) }
                                    }
                                
                                
                                    else { startzeit2 = startzeit1 }
                                    /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                                    var startzeitfertig = startzeit2 / 1;
                                    if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                                
                                    /* Anzeigeende festlegen*/
                                    var endezeitad = zeitverschiebung + 3600000;
                                
                                
                                    if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                    else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                                    else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                                    else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                                    else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                                    else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                
                                
                                    // Fertige Url generieren
                                    var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                                    /* fertige url in Objekt schreiben*/
                                    setState(urlfertig, urlberechnet);
                                
                                });
                                
                                
                                ]]></script>
                                    <properties>
                                        <property name="urliframe" type="string" default="http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">" internal="true" />
                                        <property name="selector_zeit" type="string" internal="true" />
                                        <property name="selector_range" type="string" default="day" internal="true" />
                                        <property name="selector_refresh" type="string" default="30s" internal="true" />
                                        <property name="selector_id" type="string" default="1" internal="true" />
                                    </properties>
                                    <settings>
                                    </settings>
                                </screen>
                                
                                

                                das ist in der export datei die ich bei dir via import reinhole und bei dir ist sie dann leer ?
                                komisch
                                habs 3x probiert

                                kannst du bitte den js code, den css code und das html von hand einfügen? damit ich schauen kann was am export kaputt ist?
                                und die properties anlegen

                                Smilie108S Offline
                                Smilie108S Offline
                                Smilie108
                                wrote on last edited by Smilie108
                                #999

                                @jogibear9988
                                Style

                                :host {
                                }
                                
                                * {
                                   box-sizing: border-box;
                                }
                                

                                JS Code

                                // 
                                var url1 = 'http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=';
                                /* Ab hier keine änderungen machen
                                http://192.168.2.30:3000/d-solo/ddkp5npbeom4gb/wasserstand-inn?orgId=1&from=1737548332076&to=1737580732076&timezone=browser&panelId=1&__feature.dashboardSceneSolo" width="450" height="200" frameborder="0">
                                */
                                var ptag = selector_zeit;/*Selector Zeit*/
                                var prange = selector_range;/*Selector Range*/
                                var prefresh1 = selector_refresh;
                                /* Id selector selektiert in graphana die id in einem chart dadurch kann man mehrere Vorlagen erstellen wegen mobilen Auswahlforamt*/
                                /* Wichtig die id muss natürlich auch in grafana vorhanden sein*/
                                var idselector = selector_id;/*Selector Graph ID*/
                                /* Variabel wohin dei fertige Url geschrieben wird */
                                var urlfertig = urliframe;/*Fertige Url*/
                                var timezone = 2;
                                var zeitverschiebung = timezone * 3600000;
                                // Aufplitten zum später zusammensetzen
                                var urlteil1 = url1;
                                var urlteil2 = '&to=';
                                var urlteil21 = '&refresh=';
                                var urlteil3 = 's&panelId=';
                                var urlteil4 = 'width="450" height="200" frameborder="0"';
                                // Auf Änderungen reagieren
                                var changesArray3 = [ptag, prange, idselector, prefresh1];
                                on({ id: changesArray3, change: "any" }, function (obj) {
                                    /* Ausführung der anpassung der Url für aufruf*/
                                    /* Startzeit für Grafana in Timestamp*/
                                    var startzeit = getState(ptag).val;
                                    var endzeit = getState(prange).val;
                                    var idselector1 = getState(idselector).val;
                                    var refrescht = getState(prefresh1).val;
                                    if (endzeit == "jetzt" && startzeit != "0") {
                                        var helper23 = "0";
                                        setState(ptag, helper23);
                                    }
                                
                                    if (endzeit != "jetzt") {
                                        var helper25 = "0";
                                        refrescht = helper25;
                                    }
                                
                                
                                    if (endzeit != "jetzt" && startzeit == "0") {
                                        const currentDate = new Date(new Date().setHours(0, 0, 0, 0));
                                        const timestamp1 = currentDate.getTime();
                                        var helper24 = (timestamp1 + 3600000);// (Date.now() - 21600000);
                                        setState(ptag, helper24)
                                    }
                                    /* von utc auf timezone +2h 
                                    var startzeit1 = (startzeit + 3600000);*/
                                    if (endzeit == "jetzt") {
                                        startzeit1 = "0";
                                    }
                                    else { var startzeit1 = startzeit }
                                
                                
                                    if (startzeit1 == "0" || startzeit1 == "null" || startzeit1 < "1000") {
                                        if (endzeit == "day") { var startzeit2 = (Date.now() - 86400000) }
                                        else if (endzeit == "jetzt") { var startzeitfertig1 = 'now-4h' }    /* 4h*/
                                        else if (endzeit == "week") { var startzeit2 = (Date.now() - 604800000) }
                                        else if (endzeit == "month") { var startzeit2 = (Date.now() - 2629743000) }
                                        else if (endzeit == "year") { var startzeit2 = (Date.now() - 31556926000) }
                                        else { var startzeit2 = (Date.now() - 86400000) }
                                    }
                                
                                
                                    else { startzeit2 = startzeit1 }
                                    /* da je nach system die Timestamps anders ausschauen kann man sie hier manipulieren */
                                    var startzeitfertig = startzeit2 / 1;
                                    if (endzeit == "jetzt") { startzeitfertig = 'now-8h' };
                                
                                    /* Anzeigeende festlegen*/
                                    var endezeitad = zeitverschiebung + 3600000;
                                
                                
                                    if (endzeit == "day") { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                    else if (endzeit == "jetzt") { var endzeitfertig = 'now%2B2h' }
                                    else if (endzeit == "week") { var endzeitfertig = startzeitfertig + 604800000 + endezeitad }
                                    else if (endzeit == "month") { var endzeitfertig = startzeitfertig + 2629743000 + endezeitad }
                                    else if (endzeit == "year") { var endzeitfertig = startzeitfertig + 31556926000 + endezeitad }
                                    else { var endzeitfertig = startzeitfertig + 86400000 + endezeitad }
                                
                                
                                    // Fertige Url generieren
                                    var urlberechnet = urlteil1 + startzeitfertig + urlteil2 + endzeitfertig + urlteil21 + refrescht + urlteil3 + idselector1 + urlteil4;
                                    /* fertige url in Objekt schreiben*/
                                    setState(urlfertig, urlberechnet);
                                
                                });
                                
                                
                                

                                HTML Fenster

                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"day"}]}' style="width:80px;height:30px;position:absolute;left:3px;top:31px;">Tag</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"week"}]}' style="width:80px;height:30px;position:absolute;left:83px;top:31px;">Woche</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"month"}]}' style="width:80px;height:30px;position:absolute;left:163px;top:31px;">Monat</button>
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_range","source":"property"},"value":"year"}]}' style="width:80px;height:30px;position:absolute;left:243px;top:31px;">Jahr</button>
                                <input type="date" id="theDate" bind-prop:value-as-number="=??selector_zeit" autofocus style="position:absolute;left:46.66669845581055px;top:4.5px;transform-origin:108.16669999999999px 8.5px;">
                                <button @click='{"commands":[{"type":"SetSignalValue","signal":{"name":"selector_zeit","source":"property"},"value":"jetzt"}]}' style="width:80px;height:30px;position:absolute;left:196px;top:0px;">Jetzt</button>
                                <select id="refresh" bind-prop:value="=??selector_refresh" style="position:absolute;left:323px;top:30px;width:113px;height:30px;">
                                    <option value="0">Keine</option>
                                    <option value="10">10 sec</option>
                                    <option value="30">30 sec</option>
                                    <option value="60">60 sec</option>
                                    <option value="120">120 sec</option>
                                    <option value="240">240 sec</option>
                                    <option value="300">300 sec</option>
                                </select>
                                <select id="refresh" bind-prop:value="=??selector_id" style="position:absolute;left:436px;top:30px;width:109px;height:30px;">
                                    <option value="1">Kurve 1</option>
                                    <option value="2">Kurve 2</option>
                                    <option value="3">Kurve 3</option>
                                    <option value="4">Kurve 4</option>
                                    <option value="5">Kurve 5</option>
                                </select>
                                <span style="position:absolute;left:436px;top:7px;">Kurvenauswahl</span>
                                <span style="position:absolute;left:326.5999984741211px;top:7px;">Aktualisierung</span>
                                <iframe bind-prop:src="??urliframe" style="position:absolute;left:63px;top:156px;width:1083px;height:614px;"></iframe>
                                
                                

                                wenn ich dir sonst helfen kann gib bescheid

                                prop
                                8a74af61-a54e-4123-9eaf-b33a709e7c20-grafik.png

                                Mfg Tom

                                1 Reply Last reply
                                0
                                • jogibear9988J Offline
                                  jogibear9988J Offline
                                  jogibear9988
                                  wrote on last edited by
                                  #1000

                                  @smilie108

                                  ich mein auf dem testserver 😉

                                  Check my ioBroker webui - a vis alternative
                                  see: https://github.com/iobroker-community-adapters/ioBroker.webui

                                  Smilie108S 1 Reply Last reply
                                  0
                                  • jogibear9988J jogibear9988

                                    @smilie108

                                    ich mein auf dem testserver 😉

                                    Smilie108S Offline
                                    Smilie108S Offline
                                    Smilie108
                                    wrote on last edited by
                                    #1001

                                    @jogibear9988 ok mach ich gleich

                                    Smilie108S 1 Reply Last reply
                                    0
                                    • Smilie108S Smilie108

                                      @jogibear9988 ok mach ich gleich

                                      Smilie108S Offline
                                      Smilie108S Offline
                                      Smilie108
                                      wrote on last edited by
                                      #1002

                                      @smilie108 alles in grafana1 reinkopiert
                                      😉

                                      1 Reply Last reply
                                      0
                                      • jogibear9988J jogibear9988

                                        @kamikaze said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                                        @jogibear9988 Hallo jogibear,
                                        nachdem ich von dir nichts mehr gehört habe, habe ich erneut den Adapter installiert, dieses Mal über npm.
                                        Und was soll ich sagen, jetzt ist auch die Runtime auf Version 1.25.0 und alles funktiniert wie gewünscht.

                                        VIELEN DANK für deine tatkräftige Unterstützung.

                                        sorry... bin krank seit gestern, daher keine antwort

                                        K Offline
                                        K Offline
                                        Kamikaze
                                        wrote on last edited by
                                        #1003

                                        @jogibear9988 Ich bin kurzzeitig auch wieder zurück.
                                        Es stellt sich für mich derzeit nur eine Verständnisfrage:
                                        Insgesamt erschließt sich für mich noch nicht der Unterschied zwischen signal, in den custom properties, und den andere Werten, da ich ja bei allen bindings verwenden kann.
                                        Also kurz gesagt: Kann du mir eine Definition für signal geben?
                                        Danke.

                                        jogibear9988J 1 Reply Last reply
                                        0
                                        • K Kamikaze

                                          @jogibear9988 Ich bin kurzzeitig auch wieder zurück.
                                          Es stellt sich für mich derzeit nur eine Verständnisfrage:
                                          Insgesamt erschließt sich für mich noch nicht der Unterschied zwischen signal, in den custom properties, und den andere Werten, da ich ja bei allen bindings verwenden kann.
                                          Also kurz gesagt: Kann du mir eine Definition für signal geben?
                                          Danke.

                                          jogibear9988J Offline
                                          jogibear9988J Offline
                                          jogibear9988
                                          wrote on last edited by
                                          #1004

                                          @kamikaze said in neue Visualisierung "webui" (alternative zu vis & vis-2):

                                          @jogibear9988 Ich bin kurzzeitig auch wieder zurück.
                                          Es stellt sich für mich derzeit nur eine Verständnisfrage:
                                          Insgesamt erschließt sich für mich noch nicht der Unterschied zwischen signal, in den custom properties, und den andere Werten, da ich ja bei allen bindings verwenden kann.
                                          Also kurz gesagt: Kann du mir eine Definition für signal geben?
                                          Danke.

                                          Signal als property, erwartet einen iobroker objekt "namen", nicht den wert eines iobroker objektes. Wenn du ein object mit einem Binding auf eine Property verbindest, dann übergibst du den wert des objektes.
                                          Bei deinem Control macht es z.b. mehr sinn "number" zu verwenden, statt signal. Weil man kann das control ja auch ohne ein Signal verwenden, um z.b. einen festen wert anzuzeigen, oder man könnte per script einen wert setzen.

                                          Bsp. bei meinem "chart-button" (im view WebuiControls), dort ist die property vom type signal. warum? weil der chart button, sich direkt an die history signale des signals bindet und diese vom backend lädt. Daher wird der objekt name aber auch nicht per binding zugewiesen. Wenn ich da an ein objekt binden würde, müsste dieses objekt wiederum den namen eines anderen objektes enthalten...

                                          Check my ioBroker webui - a vis alternative
                                          see: https://github.com/iobroker-community-adapters/ioBroker.webui

                                          K 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          71

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe