Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [geloest] Javascript aus basicHTML starten

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    [geloest] Javascript aus basicHTML starten

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

      Hallo Jey Cee, danke für die Antwort …

      Das mit Objekt das weiss ich, was mir unklar ist wie der HTML Code dafür aussieht.

      Hab folgendes schon probiert ..

      ... funzt aber nicht ...

      Ich lese per Script TV Programme in VIS ein und erzeuge damit einen MINI-EPG.

      Mit CSS formatiere ich das ganze. Sieht dann so aus.

      926_vis_epg.png

      Nun möchte ich mit dem Button zu dem Sender am Fernseher umschalten.

      Dazu brauch den Button auf der rechten Seite.

      Das Script liegt im Adapter ….

      Danke

      Sly

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

        @Sly:

        Hallo Jey Cee, danke für die Antwort …

        Das mit Objekt das weiss ich, was mir unklar ist wie der HTML Code dafür aussieht.

        Hab folgendes schon probiert ..

        ... funzt aber nicht ...

        Ich lese per Script TV Programme in VIS ein und erzeuge damit einen MINI-EPG.

        Mit CSS formatiere ich das ganze. Sieht dann so aus.

        filename="VIS_EPG.png" index="0">~~

        Nun möchte ich mit dem Button zu dem Sender am Fernseher umschalten.

        Dazu brauch den Button auf der rechten Seite.

        Das Script liegt im Adapter ….

        Danke

        Sly `
        Du kannst nicht die Funktionen aus Vis in JS-Adapter aufrufen. Da liegst du komplett falsch…

        Du kannst eine Variable in JS-Adapter erzeigen (z.B. javascript.0.Ansehen) und dann im JS-Adapter auf die Änderungen reagieren:

        on('Ansehen', function (obj) {
        	log(obj.state.val);
        });
        
        

        HTML sieht dafür so aus:

        1 Reply Last reply Reply Quote 1
        • S
          Sly last edited by

          Danke Jey Cee & Bluefox für die Hilfe …

          sieht jetzt so aus ... funzt ....
          926_vis_epg.png

          Ich weiß zwar nicht wie man einen Beitrag als "GELÖST" markiert, aber für mich ich das Thema gelöst ….

          Sly

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

            Bitte super das es geht.

            Gelöst: Einfach den betreff im ersten Beitrag um [gelöst] erweitern.

            Gesendet von meinem Tab2A7-10F mit Tapatalk

            1 Reply Last reply Reply Quote 0
            • S
              Sly last edited by

              Danke für die INFO …

              Sly

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

                Gefällt mir, dein EPG. Vielleicht möchtest du ja das Script hier zur Verfügung stellen?

                Gesendet von meinem SM-T700 mit Tapatalk

                1 Reply Last reply Reply Quote 0
                • S
                  Sly last edited by

                  Danke Coyote,

                  werd ich noch machen … aber muss das Skript noch auskommentieren.

                  Sobald ich das hab stell ich es ein.

                  Sly

                  1 Reply Last reply Reply Quote 0
                  • S
                    Sly last edited by

                    Wie gewünscht das Script.

                    Gewisse Abschnitte lassen sich wahrscheinlich einfacher schreiben, aber das ist eins meiner ersten Scripte.

                    Super wäre Feedback zu erhalten wie man gewisse Passagen kürzer schreiben könnte.

                    Im oberen Bereich ist das SCRIPT, im unteren Bereiche sind die Einträge für CSS & Widget.

                    ! ````
                    // MINI-EPG
                    // EINLESEN VON TELE.AT
                    "use strict";
                    createState('MM.TVPrg.IsRunning', "", {name: 'Abfrage ob Aktualisierung läuft'});
                    createState('MM.TVPrg.CMD', "false", {name: 'Startbefehl für Aktualisierung'});
                    createState('MM.TVPrg.Switch', "0", {name: 'Umschalten TV Programm Liste-Sender'});
                    var request = require('request');
                    var bodyText;
                    var abschnittText;
                    var UmrechnenWert;
                    var counter = 0;
                    var counterStep = 30;
                    var counterStart = 0;
                    var counterEnde = 120; // max. 120 ANZAHL DER PROGAMME BEI TELE 4
                    ! // DATEN BEI TELE.AT ANFORDERN
                    function WEBRequest(counter) {
                    console.log("Anfrage bei TELE.AT");

                    // WEBSEITEN EINLESEN
                    //var Datum = formatDate(new Date(), "YYYY-MM-DD");
                    if (counter < 30) //ANZAHL DER TV-SENDUNGEN/HTNL-SEITE
                        {
                        TVURL = 'http://www.tele.at/tv-programm/jetzt-im-tv.html?limit=30&stationType=-1&timeGroup=1&'; //ERSTE HTML-SEITE
                        console.log('Daten werden eingelesen ... ');
                        }
                    else
                        {
                        TVURL = 'http://www.tele.at/tv-programm/jetzt-im-tv.html?limit=30&stationType=-1&timeGroup=1&start=' + counterStart; //ALLE WEITEREN HTML-SEITEN
                        console.log('Daten werden eingelesen ... ');
                        }
                    request(TVURL, function (error, response, body) {
                        body = body.replace(//g, ')');
                        // SUCHTEXT FÜR ABSCHNITT MIT DATEN 
                        var bodyAnfang = '(body)';
                        var bodyEnde   = '(/body)';
                        // POSITIONEN IN DATENBLOCK SUCHEN    
                        var bodyZeichenAnfang = body.indexOf(bodyAnfang, 1);
                        var bodyZeichenEnde   = body.indexOf(bodyEnde, bodyZeichenAnfang + bodyAnfang.length + 1);
                        bodyText              = body.slice(bodyZeichenAnfang, bodyZeichenEnde +1); //NUR DATEN AUSSCHNEIDEN -> REST WEGSCHMEISSEN
                    
                        body = null;
                        bodyZeichenAnfang = 1;
                    
                        abschnitt(bodyZeichenAnfang);
                        // TV SENDER MIT INFOS EXTRAHIEREN    
                        function abschnitt(startAnfang) {
                            setTimeout(function() {
                                counter++;
                                var asTitel = 'hasNext'; // BEGINN TV-SENDER DATENSATZ
                    
                                var asZeichenAnfang = bodyText.indexOf(asTitel, startAnfang + 1);
                                var asZeichenEnde   = bodyText.indexOf(asTitel, asZeichenAnfang + asTitel.length + 1);
                                var asText          = bodyText.slice(asZeichenAnfang, asZeichenEnde);
                                    asText          = asText.trim();
                    
                                var SenderAnfang    = asText.indexOf('alt="', 1);
                                var SenderEnde      = asText.indexOf('"', SenderAnfang + 'alt="'.length + 1);
                                var Sender          = asText.slice(SenderAnfang + 'alt="'.length, SenderEnde);
                                    Sender          = Sender.trim();
                    
                                var BeginnAnfang    = asText.indexOf('(br/)', SenderEnde + '"'.length + 1);
                                var BeginnEnde      = asText.indexOf('(br/)', BeginnAnfang + '(br/)'.length + 1);
                                var BeginnZeit      = asText.slice(BeginnAnfang + '(br/)'.length, BeginnEnde);
                                    BeginnZeit      = BeginnZeit.trim();
                    
                                var EndeAnfang    = asText.indexOf('(br/)', BeginnEnde + '(br/)'.length + 1);
                                var EndeEnde      = asText.indexOf('(/div)', EndeAnfang + '(br/)'.length + 1);
                                var EndeZeit      = asText.slice(EndeAnfang + '(br/)'.length, EndeEnde);
                                    EndeZeit      = EndeZeit.trim();
                    
                                var TitelAnfang     = asText.indexOf('title="', EndeEnde + '(/div)'.length + 1);
                                var TitelEnde       = asText.indexOf('"', TitelAnfang + 'title="'.length + 1);
                                var Titel           = asText.slice(TitelAnfang + 'title="'.length, TitelEnde);
                                    Titel           = Titel.trim();
                                    //if (Titel.length > 60) {Titel = Titel.slice(0,70) + '...'}
                    
                                //var DauerAnfang     = asText.indexOf('(div class="progress")', TitelEnde + '"'.length + 1);
                                //var DauerEnde       = asText.indexOf('(/div)', DauerAnfang + '(div class="progress")'.length + 1);
                                //var Dauer           = asText.slice(DauerAnfang + '(div class="progress")'.length, DauerEnde);
                                //if (DauerAnfang == -1) {Dauer = "keine Laufzeit"}
                                //    Dauer           = Dauer.trim();
                    

                    ! var LabelAnfang = asText.indexOf('class="info")', TitelEnde + '"'.length + 1);
                    //var LabelAnfang = asText.indexOf('class="info")', DauerEnde + '(/div)'.length + 1);
                    var LabelEnde = asText.indexOf('(/div)', LabelAnfang + 'class="info")'.length + 1);
                    var Label = asText.slice(LabelAnfang + 'class="info")'.length, LabelEnde);
                    if (LabelAnfang == -1) {Label = "keine Information"}
                    Label = Label.trim();

                                var DanachAnfang    = asText.indexOf('Anschließend', LabelEnde + '"'.length + 1);
                                var DanachEnde      = asText.indexOf('(/a)', DanachAnfang + 'Anschließend'.length + 1);
                                var Danach          = asText.slice(DanachAnfang + 'Anschließend '.length + 1 , DanachEnde);
                                    Danach          = Danach.replace(/[0-9]\w:[0-9]\w Uhr/g, '');
                                    Danach          = Danach.trim();
                                console.log('Sender: ' + Sender + ' eingelesen ...');
                    

                    ! // AUSGABE AN VIS - VARIABELN DEFINIEREN
                    //DATENSATZDEFINITION: = ['POSITION IN VIS'], ['BILDDATEI'], ['PROGRAMMNUMMER TV-GERÄT']
                    var SenderData = [];
                    SenderData['ORF eins'] = ['0', 'ORF_1.png' ,'p149' ];
                    SenderData['ORF 2'] = ['1', 'ORF_2.png' ,'p150' ];
                    SenderData['3sat'] = ['2', '3SAT.png' ,'p74' ];
                    SenderData['ORF 3'] = ['3', 'ORF_III.png' ,'p212' ];
                    SenderData['ORF Sport +'] = ['4', 'ORF_Sport+.png' ,'p213' ];
                    SenderData['ATV'] = ['5', 'ATV.png' ,'p165' ];
                    SenderData['Servus TV'] = ['6', 'ServusTV.png' ,'p151' ];
                    SenderData['Sat.1'] = ['7', 'SAT1Austria.png' ,'p113' ];
                    SenderData['SAT.1 Gold'] = ['8', 'SAT1Gold.png' ,'p108' ];
                    SenderData['RTL'] = ['9', 'RTL.png' ,'p133' ];
                    SenderData['ProSieben'] = ['10', 'Pro7.png' ,'p110' ];
                    SenderData['Pro7 MAXX'] = ['11', 'Pro7_MAXX.png' ,'p101' ];
                    SenderData['kabel eins'] = ['12', 'Kabel1Austria.png' ,'p112' ];
                    SenderData['Puls 4'] = ['13', 'Puls4.png' ,'p115' ];
                    SenderData['SIXX Austria'] = ['14', 'Sixx.png' ,'p68' ];
                    SenderData['Super RTL'] = ['15', 'SuperRTL.png' ,'p136' ];
                    SenderData['RTL II'] = ['16', 'RTL_II.png' ,'p135' ];
                    SenderData['RTL NITRO'] = ['17', 'RTL_Nitro.png' ,'p102' ];
                    SenderData['Tele 5'] = ['18', 'Tele_5.png' ,'p131' ];
                    SenderData['VOX'] = ['19', 'VOX.png' ,'p134' ];
                    SenderData['ARTE'] = ['20', 'Arte.png' ,'p2' ];
                    SenderData['Das Erste'] = ['21', 'Das_Erste.png' ,'p1' ];
                    SenderData['ZDF'] = ['22', 'ZDF.png' ,'p161' ];
                    SenderData['Eins plus'] = ['23', 'EinsPlus.png' ,'p41' ];
                    SenderData['Eins festival'] = ['24', 'EinsFestival.png' ,'p40' ];
                    SenderData['ZDFkultur'] = ['25', 'ZDFKultur.png' ,'p163' ];
                    SenderData['ZDF neo'] = ['26', 'ZDFNEO.png' ,'p162' ];
                    SenderData['ZDF infokanal'] = ['27', 'ZDFInfo.png' ,'p78' ];
                    SenderData['SF1'] = ['28', 'SRF_1.png' ,'p154' ];
                    SenderData['SF2'] = ['29', 'SRF_2.png' ,'p155' ];
                    SenderData['TLC'] = ['30', 'TLC.png' ,'p100' ];
                    SenderData['DMAX'] = ['31', 'DMAX.png' ,'p24' ];
                    // PRÜFEN OB EINGELESENER SENDER IN DATEN-ARRAY
                    var AnzeigeZeit;
                    var elem;
                    for (elem in SenderData)
                    {
                    if (elem == Sender) // WENN VORHANDEN -> ZEIT BERECHNEN & AUSGABE IN VARIABLE
                    {
                    log('Sender: ' + Sender + ' aktualisiert ...', 'warn');

                                            createState('MM.TVPrg.Sender.' + SenderData[Sender][0], "", {name: Sender});
                                            createState('MM.TVPrg.Sender.' + SenderData[Sender][0] + '.html', "", {name: "SenderHTML"});
                    
                                            var AktuellZeit = formatDate(new Date(), "hh:mm");
                                            var BeginnStd = parseInt(BeginnZeit.slice(0, BeginnZeit.indexOf(':')));
                                            var BeginnMin = parseInt(BeginnZeit.slice(BeginnZeit.indexOf(':') + 1 , BeginnZeit.indexOf(':') + 3));
                    

                    ! var AktuellStd = parseInt(AktuellZeit.slice(0, AktuellZeit.indexOf(':')));
                    var AktuellMin = parseInt(AktuellZeit.slice(AktuellZeit.indexOf(':') + 1 , AktuellZeit.indexOf(':') + 3));
                    ! var EndeStd = parseInt(EndeZeit.slice(0, EndeZeit.indexOf(':')));
                    var EndeMin = parseInt(EndeZeit.slice(EndeZeit.indexOf(':') + 1 , EndeZeit.indexOf(':') + 3));
                    // WENN ENDZEIT/AKTUELLE ZEIT ÜBER 24:00 LIEGT
                    if (EndeStd < BeginnStd) {EndeStd = EndeStd + 24}
                    if (AktuellStd < BeginnStd) {AktuellStd = AktuellStd + 24}
                    ! var tmpBeginnZeit = ((BeginnStd * 60) + BeginnMin);
                    var tmpAktuellZeit = ((AktuellStd * 60) + AktuellMin);
                    var tmpEndeZeit = ((EndeStd) * 60 + EndeMin);
                    ! var LaufZeit = (tmpAktuellZeit - tmpBeginnZeit);
                    if (LaufZeit >= 0)
                    {
                    AnzeigeZeit = "Seit " + LaufZeit + " Minute(n)";
                    }
                    else
                    {
                    AnzeigeZeit = "Beginnt in " + -LaufZeit + " Minute(n)";
                    LaufZeit = 0;
                    }
                    var LaufZeitProzent = ((tmpAktuellZeit - tmpBeginnZeit) / (tmpEndeZeit - tmpBeginnZeit)) * 100;
                    // DATENSATZ FÜR SENDER ERSTELLEN
                    var VisHTML = "" + BeginnZeit + ": " + Titel + "
                    " + Label + "";
                    VisHTML = VisHTML + "" + EndeZeit + ": " + Danach + "";
                    VisHTML = VisHTML + " " + AnzeigeZeit + "";

                    ! setState('javascript.0.MM.TVPrg.Sender.' + SenderData[Sender][0] + '.html', VisHTML);
                    }
                    }
                    // LETZTEN DATENSATZ ERREICHT
                    var startAnfangNeu = asZeichenAnfang + DanachEnde + 1;
                    // PROGRAMMENDE / NÄCHSTER DATENSATZ
                    if (counter == counterEnde)
                    {
                    console.log('Einlesen ENDE');
                    setState('MM.TVPrg.IsRunning', false);
                    return;
                    }
                    else
                    {
                    if (counter == counterStart + counterStep)
                    {
                    startAnfangNeu = 1;
                    asZeichenAnfang = 1;
                    counterStart = counterStart + counterStep;
                    console.log('WEBREQUEST');
                    WEBRequest(counter);
                    }
                    else
                    {
                    if (counter == 1) {counterStart = 0} // FALSCHEN COUNTER-WERT BEI PROGRAMMSTART RÜCKSETZEN
                    abschnitt(startAnfangNeu);
                    }
                    }
                    },750);
                    }
                    });
                    }
                    ! // STARTAURUF DURCH VISU
                    on ('javascript.0.MM.TVPrg.CMD', function(obj) {
                    console.log("TV Programm einlesen START");
                    setState('MM.TVPrg.IsRunning', true); // OPTISCHE ANZEIGE FÜR PROGRAMMSTART EIN
                    var counter = 0;
                    WEBRequest (counter);
                    });
                    ! /*
                    DARSTELLUNG IN WIDGET "BASIC - HTML"
                    ! {javascript.0.MM.TVPrg.Sender.0.html}
                    {javascript.0.MM.TVPrg.Sender.1.html}
                    {javascript.0.MM.TVPrg.Sender.2.html}
                    {javascript.0.MM.TVPrg.Sender.3.html}
                    {javascript.0.MM.TVPrg.Sender.4.html}
                    {javascript.0.MM.TVPrg.Sender.5.html}
                    {javascript.0.MM.TVPrg.Sender.6.html}
                    {javascript.0.MM.TVPrg.Sender.7.html}
                    {javascript.0.MM.TVPrg.Sender.8.html}
                    {javascript.0.MM.TVPrg.Sender.9.html}
                    {javascript.0.MM.TVPrg.Sender.10.html}
                    {javascript.0.MM.TVPrg.Sender.11.html}
                    {javascript.0.MM.TVPrg.Sender.12.html}
                    {javascript.0.MM.TVPrg.Sender.13.html}
                    {javascript.0.MM.TVPrg.Sender.14.html}
                    {javascript.0.MM.TVPrg.Sender.15.html}
                    {javascript.0.MM.TVPrg.Sender.16.html}
                    {javascript.0.MM.TVPrg.Sender.17.html}
                    {javascript.0.MM.TVPrg.Sender.18.html}
                    {javascript.0.MM.TVPrg.Sender.19.html}
                    {javascript.0.MM.TVPrg.Sender.20.html}
                    {javascript.0.MM.TVPrg.Sender.21.html}
                    {javascript.0.MM.TVPrg.Sender.22.html}
                    {javascript.0.MM.TVPrg.Sender.23.html}
                    {javascript.0.MM.TVPrg.Sender.24.html}
                    {javascript.0.MM.TVPrg.Sender.25.html}
                    {javascript.0.MM.TVPrg.Sender.26.html}
                    {javascript.0.MM.TVPrg.Sender.27.html}
                    {javascript.0.MM.TVPrg.Sender.28.html}
                    {javascript.0.MM.TVPrg.Sender.29.html}
                    {javascript.0.MM.TVPrg.Sender.30.html}
                    {javascript.0.MM.TVPrg.Sender.31.html}
                    ! CSS - FORMATIERUNG FÜR DARSTELLUNG IN WIDGET "BASIC - HTML"
                    .TVPrgAktuell {
                    width:280px;
                    height:50px;
                    border-width:0;
                    background-color:#CCFFCC;
                    font-family:sans-serif;
                    font-size:small;
                    text-align:left;
                    vertical-align:top;
                    color:black;
                    }
                    .TVPrgDauer {
                    height:15px;
                    border-width:0;
                    background-color:white;
                    font-family:sans-serif;
                    font-size:small;
                    text-align:left;
                    color:black;
                    }
                    .TVPrgDanach {
                    width:150px;
                    border-width:0;
                    background-color:#eeeeee;
                    font-family:sans-serif;
                    font-size:small;
                    text-align:left;
                    vertical-align:top;
                    color:black;
                    }
                    .TVPrgButton {
                    width:60px;
                    height:60px;
                    background: none center no-repeat transparent;
                    background-size: 60px 60px;
                    }
                    */

                    Bei mir funzt's …
                    
                    Sly
                    1 Reply Last reply Reply Quote 0
                    • P
                      pix last edited by

                      Hallo Sly,

                      sehr schöne Umsetzung. Mir gefällt die Idee, mit einem Knopfdruck, gleich den entsprechenden Sender zu schalten.

                      Ich würde die Funktion abschnitt() aus der Funktion WEBrequest auslagern (keine Funktion in einer Funktion).

                      "console.log" kannst du durch "log" ersetzen. Wird die Variable TVURL irgendwo angelegt?

                      bzw. gleich so

                      // DATEN BEI TELE.AT ANFORDERN
                      function WEBRequest(counter) {
                          log("Anfrage bei TELE.AT");
                      
                          // WEBSEITEN EINLESEN
                          //var Datum = formatDate(new Date(), "YYYY-MM-DD");
                          var TVURL = 'http://www.tele.at/tv-programm/jetzt-im-tv.html?limit=30&stationType=-1&timeGroup=1&'; //ERSTE HTML-SEITE
                          if (counter >= 30) TVURL = TVURL + 'start=' + counterStart
                          log('Daten werden eingelesen ... ');
                      
                          request...
                      
                      

                      Und warum änderst beim Parsen du den html-Tag in (body) ? Funktioniert indexOf('', 1) nicht?

                      Gruß,

                      Pix

                      1 Reply Last reply Reply Quote 0
                      • S
                        Sly last edited by

                        Hallo pix,

                        danke für die Infos.

                        Anscheinend habe ich vergessen die URL Variable zu definieren.

                        Die Umwandlung im body hab ich eigentlich nur zum Testen verwendet,

                        damit ich im LOG keine HTML Darstellung angezeigt bekomme.

                        Könnte man theoretisch herausnehmen.

                        Danke für Infos

                        Sly

                        1 Reply Last reply Reply Quote 0
                        • S
                          Sly last edited by

                          <u>Warum die Antwort doppelt angezeigt wird weiß ich nicht, wie kann ich den wieder löschen?</u>

                          Hallo pix,

                          danke für die Infos.

                          Anscheinend habe ich vergessen die URL Variable zu definieren.

                          Die Umwandlung im body hab ich eigentlich nur zum Testen verwendet,

                          damit ich im LOG keine HTML Darstellung angezeigt bekomme.

                          Könnte man theoretisch herausnehmen.

                          Danke für Infos

                          Sly

                          1 Reply Last reply Reply Quote 0
                          • F
                            File last edited by

                            Hallo Sly,

                            bin nicht so fit in Javascript. Funktioniert dein Script 2019 auch noch so wie du es hier oben gepostest hast? Bekomme Fehler wenn ich es in IO-broker einbinden will.
                            Kannst du eventuell nur das spript mal als Datei anhängen?

                            LG
                            Philipp

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

                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            601
                            Online

                            31.8k
                            Users

                            80.0k
                            Topics

                            1.3m
                            Posts

                            6
                            14
                            2621
                            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