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.
    • 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

                          609
                          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