Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Frage] View über Skript aufrufen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Frage] View über Skript aufrufen

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

      Hallo,

      ich kann mir zwar nicht vorstellen wie es gehen soll, aber ich versuch mein Glück mal.

      Mein Views sind sowohl in Englischer Sprache als auch in Deutscher Sprache und meine Gäste (ich verwende es in einer Ferienwohnung) können zwischen den Sprachen hin und her wechseln. Da ich die Information welche Sprache der Gast spricht in einem Objekt habe würde ich nun gerne je nach Sprache den View in Englischer Sprache anzeigen bzw. wenn der Gast aus dem deutschsprachigen Raum kommt den View in Deutsche Sprache anzeigen.

      Zur Frage: Ist es möglich aus dem System heraus einen bestimmten View der auf einem Android Tablet angezeigt werden soll, z.B. per Skript einzustellen ?

      Andreas

      1 Reply Last reply Reply Quote 0
      • R
        RappiRN Most Active last edited by

        Ja das geht. In den Objekten ist unter vis der Punkt Control:

        2216_vis-control.jpg

        Darüber kann man bestimmte Views aufrufen, das geht für bestimmte Instanzen oder auch für alle. Wie genau hab ich schon mal im Forum gelesen, musst du mal nach Viewwechsel javascript suchen.

        Aber warum machst du nicht im Startview einen Sprachauswahlbutton mit dem du eine Variable änderst. Darüber kannst du dann mit der bedingten Anzeige entweder die deutschen oder eben die englischen Sprachen anzeigen. Damit würdest du die Anzahl der Views geringer halten.

        Enrico

        1 Reply Last reply Reply Quote 0
        • R
          RandyAndy last edited by

          Hallo,

          im Prinzip habe ich schon eine Art Sprachauswahl-Button (in meinem Fall die Flagge).

          Sobald die Flagge gedrückt wird, wird entweder die dt-Version aufgerufen oder eben der englische View.

          Am liebsten wäre es mir natürlich wenn ich in einer Art Tabelle mit Variablen definieren kann die je nach Sprachauswahl mit den dt. Informationen gefüllt werden z.B. Fenster oder eben mit dem englischen Ausdruck. Das würde die Views um die Hälfte reduzieren. Derzeit muss ich immer beide Sprachen mit der entsprechenden Anzahl von Views vorhalten. Dann müsste ich aber die Widget-Informationen irgendwie beim Aufruf des Views befüllen z.B. den Tab-Titel des Tab-Widgets (roter Kreis).

          Andreas
          2213_2017-05-30_23_54_05-edit_vis.png
          2213_2017-05-30_23_53_32-einstellungen.png

          1 Reply Last reply Reply Quote 0
          • P
            pix last edited by

            Hallo,

            es gibt in VIS die Funktion "Filter" bzw. die Einstellung Filterwort.

            Du legst jedes Widget, das mehrsprachig erscheint doppelt an. Der z-index spielt keine Rolle. Die Widgets in deutscher Sprache markierts du mit dem Filter Wort "deutsch", die in Englischer Sprache mit dem Filterwort "englisch". Mit einem der beiden Filter-Widgets (entweder Filter-Bar oder Filter- dropdown) kannsr du dann die richtige Sprache anzeigen und die andere ausblenden. 261_bildschirmfoto_2017-05-31_um_00.31.12.jpg

            Hier eine paar Beispiel-Widgets````
            [{"tpl":"tplHtml","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"html":"Wohnzimmer | Musik","name":"Überschrift","filterkey":"deutsch"},"style":{"left":"498px","top":"33px","z-index":"25","width":"auto","height":"auto","font-size":"25px"},"widgetSet":"basic"},{"tpl":"tplHtml","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"html":"Living room | Music","name":"Überschrift","filterkey":"englisch"},"style":{"left":"498px","top":"33px","z-index":"25","width":"240px","height":"29px","font-size":"25px"},"widgetSet":"basic"},{"tpl":"tplBarFilter","data":{"buttonsImage1":"","buttonsText1":"english","buttonsOption1":"englisch","bCount":"2","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","bTheme":"","bPosition":"floatHorizontal","bSpace":"30","bRadius":"5","bOffset":"96","bTextAlign":"left","bImageAlign":"left","bLayout":"fixed","imagePaddingLeft":"0","imagePaddingTop":"3","bShowEffect":"show","bShowEffectMs":"50","bHideEffect":"show","bHideEffectMs":"50","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"bOnlyOneSelected":true,"alwaysOpened":false,"buttonsImage2":"https://www.eb-zuerich.ch/site/filemanager/files/images/flags/de.svg","buttonsText2":"deutsch","buttonsOption2":"deutsch","bValue":"englisch"},"style":{"left":"499px","top":"70px","z-index":"20","width":"200px","height":"34px"},"widgetSet":"bars"}]

            
            Versuche es mal!
            
            Gruß
            
            Pix
            1 Reply Last reply Reply Quote 0
            • R
              RandyAndy last edited by

              Werde ich heute Abend mal testen.

              Interessanter Ansatz

              Andreas

              1 Reply Last reply Reply Quote 0
              • Jey Cee
                Jey Cee Developer last edited by

                Ich hab eine Lösung für dich bei der du nicht mehrere Widgets oder Views bauen musst.

                Vis bietet die Möglichkeit Skripte zu hinterlegen, das findet man im Editor rechts bei Eigenschaften.

                Mit JavaScript kann man HTML Objekte verändern in dem man sie mit Hilfe ihrer ID oder ClassName anspricht.

                Für ein Widget mit Hilfe von ClassName

                document.getElementsByClassName("label fg-white")[0].innerHTML = 'Test';
                

                Für mehrere Wisdgets mit Hilfe von ClassName

                `var x = document.getElementsByClassName("label fg-white").length; for(i = 0; i`
                
                Mit der ID spricht man immer nur genau ein Element an. Das wird aber in 99% der Fälle in Vis nicht Funktionieren, da die Widgets wie Container zu betrachten sind. Die ID bezieht sich auf den Container, aber das zu ändernde Element ist im Container mit anderen Elementen.
                `~~[code]~~document.getElementByID("w00049").innerHTML = 'Test'[/code]`
                
                Dafür gibt es aber eine Lösung, man sucht sich den Container anhand der ID und sucht nur im Container nach der ClassName.
                `~~[code]~~var y = document.getElementById("w00063"); 
                y.getElementsByClassName("vis-widget-body")[0].innerHTML = 'Doof';[/code]`
                
                Wenn du die ID oder den ClassName nicht kennst, kannst du dein View im Chrome Browser (geht vermutlich genau so mit FireFox) und einen rechts Klick auf das Widget machen das du haben willst und Untersuchen Klicken. Jetzt siehst du den Quellcode zum Entsprechenden Widget.
                
                Zur einfacheren Verwaltung würde ich dir Empfehlen ein Dictionary an zu legen und eine Funktion die diese Abarbeitet.[/i]
                
                1 Reply Last reply Reply Quote 0
                • R
                  RandyAndy last edited by

                  Hallo Jey Cee,

                  die Lösung wäre in der Summe recht flexxibel und kommt der Lösung einfach die "Beschreibung zu ändern" sehr nah. Kann man vermutlich auch per Blockly lösen.

                  aber ganz kann icb deinem Ansazu nicht folgen.

                  Nehmen wir z.b. das HQWidget - Inner temperature.

                  In diesem Fall möchte ich die Bezeichnung links (in meinem Fall "Bathroom") in "Bad" ändern.

                  Die ID kann ich noch leicht finden, aber dann wird es schon recht schwierig, wie spreche ich das Element "Bathroom" an.

                  Screenshot des Inspectors von Firefox anbei.

                  Wie würde in dem Fall der JS-Code aussehen ?

                  Wäre dies "document.getElementsByClassName("vis-widget vis-hq-button-base")[0].vis-hq-left-info-text = 'Bad' ?

                  Andreas
                  2213_2017-05-31_23_53_50-vis.png

                  1 Reply Last reply Reply Quote 0
                  • Jey Cee
                    Jey Cee Developer last edited by

                    @RandyAndy:

                    Kann man vermutlich auch per Blockly lösen. `
                    Wohl eher nicht. Den das/die Skripte in vis haben nichts mit dem JavaScript Adapter oder Blockly zu tun.
                    282_unbenannt.png
                    Vielleicht lässt sich eine Logik mit Blockly bauen die man dann mit minimalen Anpassungen in vis verwenden kann. Das musst du Testen, ich nutze Blockly gar nicht.

                    @RandyAndy:

                    Die ID kann ich noch leicht finden `
                    Die ID ist aber nicht der Class Name und das ist was dein Screenshot zeigt und was du in dem Fetzen code verwendest.
                    282_unbenannt2.png

                    So ist es richtig:

                    var y = document.getElementById("w00049"); 
                    y.getElementsByClassName("vis-hq-leftinfo-text")[0].innerHTML = 'Bad';
                    

                    "var y" speichert das Element mit der ID W00049. In Zeile 2 wird dann die Variable "y" einem Element mit dem Namen "vis-hq-leftinfo-text" durchsucht. "[0]" ist das erste der gefundenen Elemente die zu dieser Class gehören. "innerHTML" ist dann der Text der Angezeigt wird.

                    Nicht vergessen du musst die ID (hier die "w00049") noch durch die deines Widgets ersetzen.

                    1 Reply Last reply Reply Quote 0
                    • R
                      RandyAndy last edited by

                      Hi,

                      ok versuche ich dann mal.

                      Habe ja nun ein paar Tage frei :lol:

                      Andreas

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

                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      808
                      Online

                      31.7k
                      Users

                      79.8k
                      Topics

                      1.3m
                      Posts

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