Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Test Adapter tvprogram

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Test Adapter tvprogram

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      Ash2k @MCU last edited by Ash2k

      @mcu said in Test Adapter tvprogram:

      @ash2k

      // Datenpunkt html
      createState('0_userdata.0.tvprogram.Html','',false, {read: true, write: true, name: "HTML Datenpunktbeispiel", type: "string", role: "text", def: "" });
      // Schriftgröße 
      createState('0_userdata.0.tvprogram.Zeichengroesse','12',false, {read: true, write: true, name: "Zeichen Größe", type: "number", role: "state", def: "10" });
      // Hintergrund-Farbe von der Überschrift
      createState('0_userdata.0.tvprogram.Farbe_Ueberschrift','blue',false, {read: true, write: true, name: "Hintergrund-Farbe Überschrift #000000 oder grey", type: "string", role: "text", def: "" });
      //Hintergrund-Farbe von der Zeile alternierend
      createState('0_userdata.0.tvprogram.Farbe_Zeile','grey',false, {read: true, write: true, name: "Hintergrund-Farbe Zeile #000000 oder grey", type: "string", role: "text", def: "" });
      //Schriftfarbe von der Schrift
      createState('0_userdata.0.tvprogram.Farbe_Schrift','white',false, {read: true, write: true, name: "Schrift-Farbe #000000 oder grey", type: "string", role: "text", def: "" });
      // Zeitpunkt für die Startzeit 
      createState('0_userdata.0.tvprogram.Zeit','15:00',false, {read: true, write: true, name: "Zeit im Format HH:MM", type: "string", role: "text", def: "" });
      // Datenpunkt in den die html-Seite geschrieben werden soll
      createState('0_userdata.0.tvprogram.Datenpunkt','0_userdata.0.tvprogram.Html',false, {read: true, write: true, name: "Datenpunkt in den die HTML geschrieben wird", type: "string", role: "text", def: "" });
      // tvchannels
      createState('0_userdata.0.tvprogram.tvchannels','',false, {read: true, write: true, name: "TV Sender JSON", type: "string", role: "text", def: "" });
      // tvcategories
      createState('0_userdata.0.tvprogram.tvcategories','',false, {read: true, write: true, name: "TV Kategorien JSON", type: "string", role: "text", def: "" });
      // Boolean html erzeugen
      createState('0_userdata.0.tvprogram.HtmlSet','false',false, { read: true, write: true, name: "HTML erzeugen", type: "boolean", role: "button", def: "false" });
      // Sender-Logos anzeigen
      createState('0_userdata.0.tvprogram.show_logos','true',false, { read: true, write: true, name: "Logos anzeigen / false-> Text", type: "boolean", role: "state", def: "false" });
      // channelfilter datapoint of your tv
      var channelfilterDP = "tvprogram.0.tv1.channelfilter";
      var channelfilter = JSON.parse(getState(channelfilterDP).val);
      
      
      
      var dateheute = new Date();
      // Einlesen der Channels falls nicht vorhanden
      if ((getState("0_userdata.0.tvprogram.tvchannels").val) ==""){
         console.log("Channel-DP wird geschrieben");
         sendTo("tvprogram.0","getServerData","channels",(data)=>{
             setState("0_userdata.0.tvprogram.tvchannels",JSON.stringify(data));    
         });
      }
      // Einlesen der Categories falls nicht vorhanden
      if ((getState("0_userdata.0.tvprogram.tvcategories").val) ==""){
         console.log("Categories-DP wird geschrieben");
         sendTo("tvprogram.0","getServerData","categories",(data)=>{
             setState("0_userdata.0.tvprogram.tvcategories",JSON.stringify(data));    
         });
      }
      
      
      
      
      function findElement(arr, propName, propValue) {
       for (var i=0; i < arr.length; i++) {
         if (arr[i][propName] == propValue)
           return arr[i];
         }
       // will return undefined if not found; you could return a default instead
      } 
      
      function html_erzeugen() { 
         //var date = new Date("2/9/2021 20:15:00");
         var Farbe_Ueberschrift = getState("0_userdata.0.tvprogram.Farbe_Ueberschrift").val;
         var Farbe_Zeile = getState("0_userdata.0.tvprogram.Farbe_Zeile").val;
         var Bool_Farbe = false;
         var ZG = getState("0_userdata.0.tvprogram.Zeichengroesse").val;
         var SchriftFarbe = getState("0_userdata.0.tvprogram.Farbe_Schrift").val;
         var zeichengroesse = '<span style="font-size:'+ ZG +'px">';
         var Abfragezeit =  getState("0_userdata.0.tvprogram.Zeit").val;
         var date = formatDate(dateheute, 'MM/DD/YYYY ' + Abfragezeit + ':00');
         var categories = JSON.parse(getState("0_userdata.0.tvprogram.tvcategories").val);
         var channels = JSON.parse(getState("0_userdata.0.tvprogram.tvchannels").val);
         var show_logos = getState("0_userdata.0.tvprogram.show_logos").val;
         var Log_Html = ['<!DOCTYPE HTML>','<html><head><title>','LOG TABELLE</title><style>table {width: 100%; color:'+ SchriftFarbe + '}</style></head> ','<body style = "text-align:center;" id = "body">','<table align = "center" id="table" border="1">'].join('');
         Log_Html= Log_Html + ['<tr bgcolor=',Farbe_Ueberschrift,'><th>Sender</th><th>Sendung</th><th>Beginn</th><th>Ende</th><th>Typ</th></tr>'].join(''); //,'<tr><th>-</th><th>-</th><th>-</th><th>-</th></tr>'
             
         sendTo("tvprogram.0","getServerBroadcastDate",{channelfilter:channelfilter,date:date},(data)=>{
             //console.log(data);
             var daten = data; //im JSON.parse Format object
             var i,j,z;
      
         
             for (j = 0; j< daten.length ; j++) {
                 
                 if (daten[j] != null){
                     var sendungstr = "";
                     if (Bool_Farbe) {
                         Log_Html = Log_Html + '<tr bgcolor=' + Farbe_Zeile +'>';   
                     }else
                     {
                         Log_Html = Log_Html + '<tr>';
                     }
                 
                     i=0;
                 
                     var x = findElement(channels,"id",daten[j].events[i].channel);
                     if (x!= undefined){
                         sendungstr = x["name"];
                         if (show_logos == true){
                             var foto = 'https://tvfueralle.de/channel-logos/' + x["channelId"] +'.png';
                             Log_Html = Log_Html + '<td width="10%" align="center" bgcolor=white>'+ '<img src="' + foto + '" width="30" height="30">' +'</td>';
                         } else {
                             Log_Html = Log_Html +'<td width="10%">'+ zeichengroesse +  x["name"] +'</span></td>';
                         }
                     }
                     if (daten[j].events[i].title != undefined) {
                         //console.log(daten[j].events[i]);
                         sendungstr = sendungstr + " " + daten[j].events[i].title;
                         Log_Html = Log_Html +'<td width="40%">'+ zeichengroesse + daten[j].events[i].title +'</span></td>';
                     }
                     sendungstr = sendungstr + " " + formatDate(daten[j].events[i].startTime,'hh:mm ') + " Uhr";
                     Log_Html = Log_Html +'<td width="15%">'+ zeichengroesse + formatDate(daten[j].events[i].startTime,'hh:mm ') +'</span></td>';
                     sendungstr = sendungstr + " " + formatDate(daten[j].events[i].endTime,'hh:mm ') + " Uhr";
                     Log_Html = Log_Html +'<td width="15%">'+ zeichengroesse + formatDate(daten[j].events[i].endTime,'hh:mm ') +'</span></td>';
                     
                     x = findElement(categories,"id",daten[j].events[i].content.category);
                     //console.log(x);
                     if (x !=undefined){
                         if (x["title"]!= undefined) {
                             sendungstr = sendungstr + " - " + daten[j].events[i].content.category + " " + x["title"];
                             Log_Html = Log_Html +'</td><td width="20%">'+ zeichengroesse + x["title"] + '</span></td>';
                         }        
                     }
                     Log_Html = Log_Html + '</tr>';
                     //if (daten[j].events[i].content.texts.VeryShort.value != null){
                         //console.log(daten[j].events[i].content.texts.VeryShort.value);
                         //sendungstr = sendungstr + " " + daten[j].events[i].content.texts.VeryShort.value;
                     //}
                 
                 }
                 //Ende einer Zeile
                 Bool_Farbe = !Bool_Farbe;
             }
             //Ende von HTML
             Log_Html = Log_Html + '</table></body></html>';
             setState(getState('0_userdata.0.tvprogram.Datenpunkt').val,Log_Html);
         });
      };
      
      // Html-erzeugen Boolean ausführen
      on({id: '0_userdata.0.tvprogram.HtmlSet', change: "ne"}, function (obj) {
         if (getState('0_userdata.0.tvprogram.HtmlSet').val == true){
             html_erzeugen();
         }
         setState('0_userdata.0.tvprogram.HtmlSet',false);
      });
      

      Jarvis-Implementierung

      824eb889-61ec-4cfc-823f-82036ec3e077-image.png

      Möchte man alle 10 Minuten die Zeit automatisch gesetzt bekommen, muß man den folgenden Code anhängen:

      var schedule1;
      (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
      
      schedule1 = schedule('*/10 * * * *', async function () {
        //ZEIT_1 = formatDate(new Date(), "hh:mm");
        setState('0_userdata.0.tvprogram.Zeit',formatDate(new Date(), "hh:mm"));
      });
      
      

      Kann es sein das man noch irgendwie einstellen muss das es den neuen Tag nimmt? Habe es gestern erstellt, heute werden mir aber nur die Daten von gestern angezeigt:

      TVProgramm.PNG

      Edit: Hab mir jetzt erstmal damit geholfen mir per Blockly ein Zeitplan zu erstellen der beide Scripts (eins für Wunschzeit, eins für fest 20:15) morgens um 06:00 neu startet.

      Gleichzeitig wird für das 20:15 die HTML-Seite aktualisiert.

      Dann habe ich noch im Blockly ein Trigger auf die Zeit des Wunschzeit-Scripts gesetzt, der bei Aktualisierung der Zeit die HTML-Seite gleich aktualisiert.

      Vielleicht interessant für jemanden, daher anbei das Blockly-Script:

      <xml xmlns="https://developers.google.com/blockly/xml">
       <block type="schedule" id="T^QdUF#`kr8$!7*ecxE*" x="63" y="63">
         <field name="SCHEDULE">{"time":{"exactTime":true,"start":"06:00"},"period":{"days":1}}</field>
         <statement name="STATEMENT">
           <block type="control" id="WH4}z^SlS-9uPyibt/}/">
             <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
             <field name="OID">javascript.0.scriptEnabled.TV_Programm_20:15</field>
             <field name="WITH_DELAY">FALSE</field>
             <value name="VALUE">
               <block type="logic_boolean" id="NHJ:aB]Nq]yv;rQw|XeU">
                 <field name="BOOL">FALSE</field>
               </block>
             </value>
             <next>
               <block type="control" id="j~qmKuoL]eL#tiF~Kdrz">
                 <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="true"></mutation>
                 <field name="OID">javascript.0.scriptEnabled.TV_Programm_20:15</field>
                 <field name="WITH_DELAY">TRUE</field>
                 <field name="DELAY_MS">1</field>
                 <field name="UNIT">sec</field>
                 <field name="CLEAR_RUNNING">FALSE</field>
                 <value name="VALUE">
                   <block type="logic_boolean" id="H*~{xxttk54Tphw?g1{}">
                     <field name="BOOL">TRUE</field>
                   </block>
                 </value>
                 <next>
                   <block type="control" id="Y]KE,PM~%xD~SEWS8}eA">
                     <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                     <field name="OID">javascript.0.scriptEnabled.TV_Programm_Jetzt</field>
                     <field name="WITH_DELAY">FALSE</field>
                     <value name="VALUE">
                       <block type="logic_boolean" id="+]6=prcd4F4Q||7{gM`f">
                         <field name="BOOL">FALSE</field>
                       </block>
                     </value>
                     <next>
                       <block type="control" id="{6ql,I}5(Ieh0ibe8ai*">
                         <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="true"></mutation>
                         <field name="OID">javascript.0.scriptEnabled.TV_Programm_Jetzt</field>
                         <field name="WITH_DELAY">TRUE</field>
                         <field name="DELAY_MS">1</field>
                         <field name="UNIT">sec</field>
                         <field name="CLEAR_RUNNING">FALSE</field>
                         <value name="VALUE">
                           <block type="logic_boolean" id="*q@PlQDmy}EbETMvdeEP">
                             <field name="BOOL">TRUE</field>
                           </block>
                         </value>
                         <next>
                           <block type="control" id="gtLJ.,o=!1D+tzvM;YlW">
                             <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="true"></mutation>
                             <field name="OID">0_userdata.0.tvprogram.2015.HtmlSet</field>
                             <field name="WITH_DELAY">TRUE</field>
                             <field name="DELAY_MS">5</field>
                             <field name="UNIT">sec</field>
                             <field name="CLEAR_RUNNING">FALSE</field>
                             <value name="VALUE">
                               <block type="logic_boolean" id="]Cpq3*mOc4DBmsxHp8G)">
                                 <field name="BOOL">TRUE</field>
                               </block>
                             </value>
                           </block>
                         </next>
                       </block>
                     </next>
                   </block>
                 </next>
               </block>
             </next>
           </block>
         </statement>
         <next>
           <block type="on" id="#4]RTZku|=RIS$qe49P[">
             <field name="OID">0_userdata.0.tvprogram.Zeit</field>
             <field name="CONDITION">any</field>
             <field name="ACK_CONDITION"></field>
             <statement name="STATEMENT">
               <block type="control" id="}[d{Pf2NHVwX8o$GoB8J">
                 <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="true"></mutation>
                 <field name="OID">0_userdata.0.tvprogram.HtmlSet</field>
                 <field name="WITH_DELAY">TRUE</field>
                 <field name="DELAY_MS">1</field>
                 <field name="UNIT">sec</field>
                 <field name="CLEAR_RUNNING">FALSE</field>
                 <value name="VALUE">
                   <block type="logic_boolean" id="fLP0^QQx)G|QDC?l9:@/">
                     <field name="BOOL">TRUE</field>
                   </block>
                 </value>
               </block>
             </statement>
           </block>
         </next>
       </block>
      </xml>
      

      OliverIO M 2 Replies Last reply Reply Quote 0
      • OliverIO
        OliverIO @Ash2k last edited by

        @ash2k said in Test Adapter tvprogram:

        @mcu said in Test Adapter tvprogram:

        @ash2k

        // Datenpunkt html
        createState('0_userdata.0.tvprogram.Html','',false, {read: true, write: true, name: "HTML Datenpunktbeispiel", type: "string", role: "text", def: "" });
        // Schriftgröße 
        createState('0_userdata.0.tvprogram.Zeichengroesse','12',false, {read: true, write: true, name: "Zeichen Größe", type: "number", role: "state", def: "10" });
        // Hintergrund-Farbe von der Überschrift
        createState('0_userdata.0.tvprogram.Farbe_Ueberschrift','blue',false, {read: true, write: true, name: "Hintergrund-Farbe Überschrift #000000 oder grey", type: "string", role: "text", def: "" });
        //Hintergrund-Farbe von der Zeile alternierend
        createState('0_userdata.0.tvprogram.Farbe_Zeile','grey',false, {read: true, write: true, name: "Hintergrund-Farbe Zeile #000000 oder grey", type: "string", role: "text", def: "" });
        //Schriftfarbe von der Schrift
        createState('0_userdata.0.tvprogram.Farbe_Schrift','white',false, {read: true, write: true, name: "Schrift-Farbe #000000 oder grey", type: "string", role: "text", def: "" });
        // Zeitpunkt für die Startzeit 
        createState('0_userdata.0.tvprogram.Zeit','15:00',false, {read: true, write: true, name: "Zeit im Format HH:MM", type: "string", role: "text", def: "" });
        // Datenpunkt in den die html-Seite geschrieben werden soll
        createState('0_userdata.0.tvprogram.Datenpunkt','0_userdata.0.tvprogram.Html',false, {read: true, write: true, name: "Datenpunkt in den die HTML geschrieben wird", type: "string", role: "text", def: "" });
        // tvchannels
        createState('0_userdata.0.tvprogram.tvchannels','',false, {read: true, write: true, name: "TV Sender JSON", type: "string", role: "text", def: "" });
        // tvcategories
        createState('0_userdata.0.tvprogram.tvcategories','',false, {read: true, write: true, name: "TV Kategorien JSON", type: "string", role: "text", def: "" });
        // Boolean html erzeugen
        createState('0_userdata.0.tvprogram.HtmlSet','false',false, { read: true, write: true, name: "HTML erzeugen", type: "boolean", role: "button", def: "false" });
        // Sender-Logos anzeigen
        createState('0_userdata.0.tvprogram.show_logos','true',false, { read: true, write: true, name: "Logos anzeigen / false-> Text", type: "boolean", role: "state", def: "false" });
        // channelfilter datapoint of your tv
        var channelfilterDP = "tvprogram.0.tv1.channelfilter";
        var channelfilter = JSON.parse(getState(channelfilterDP).val);
        
        
        
        var dateheute = new Date();
        // Einlesen der Channels falls nicht vorhanden
        if ((getState("0_userdata.0.tvprogram.tvchannels").val) ==""){
           console.log("Channel-DP wird geschrieben");
           sendTo("tvprogram.0","getServerData","channels",(data)=>{
               setState("0_userdata.0.tvprogram.tvchannels",JSON.stringify(data));    
           });
        }
        // Einlesen der Categories falls nicht vorhanden
        if ((getState("0_userdata.0.tvprogram.tvcategories").val) ==""){
           console.log("Categories-DP wird geschrieben");
           sendTo("tvprogram.0","getServerData","categories",(data)=>{
               setState("0_userdata.0.tvprogram.tvcategories",JSON.stringify(data));    
           });
        }
        
        
        
        
        function findElement(arr, propName, propValue) {
         for (var i=0; i < arr.length; i++) {
           if (arr[i][propName] == propValue)
             return arr[i];
           }
         // will return undefined if not found; you could return a default instead
        } 
        
        function html_erzeugen() { 
           //var date = new Date("2/9/2021 20:15:00");
           var Farbe_Ueberschrift = getState("0_userdata.0.tvprogram.Farbe_Ueberschrift").val;
           var Farbe_Zeile = getState("0_userdata.0.tvprogram.Farbe_Zeile").val;
           var Bool_Farbe = false;
           var ZG = getState("0_userdata.0.tvprogram.Zeichengroesse").val;
           var SchriftFarbe = getState("0_userdata.0.tvprogram.Farbe_Schrift").val;
           var zeichengroesse = '<span style="font-size:'+ ZG +'px">';
           var Abfragezeit =  getState("0_userdata.0.tvprogram.Zeit").val;
           var date = formatDate(dateheute, 'MM/DD/YYYY ' + Abfragezeit + ':00');
           var categories = JSON.parse(getState("0_userdata.0.tvprogram.tvcategories").val);
           var channels = JSON.parse(getState("0_userdata.0.tvprogram.tvchannels").val);
           var show_logos = getState("0_userdata.0.tvprogram.show_logos").val;
           var Log_Html = ['<!DOCTYPE HTML>','<html><head><title>','LOG TABELLE</title><style>table {width: 100%; color:'+ SchriftFarbe + '}</style></head> ','<body style = "text-align:center;" id = "body">','<table align = "center" id="table" border="1">'].join('');
           Log_Html= Log_Html + ['<tr bgcolor=',Farbe_Ueberschrift,'><th>Sender</th><th>Sendung</th><th>Beginn</th><th>Ende</th><th>Typ</th></tr>'].join(''); //,'<tr><th>-</th><th>-</th><th>-</th><th>-</th></tr>'
               
           sendTo("tvprogram.0","getServerBroadcastDate",{channelfilter:channelfilter,date:date},(data)=>{
               //console.log(data);
               var daten = data; //im JSON.parse Format object
               var i,j,z;
        
           
               for (j = 0; j< daten.length ; j++) {
                   
                   if (daten[j] != null){
                       var sendungstr = "";
                       if (Bool_Farbe) {
                           Log_Html = Log_Html + '<tr bgcolor=' + Farbe_Zeile +'>';   
                       }else
                       {
                           Log_Html = Log_Html + '<tr>';
                       }
                   
                       i=0;
                   
                       var x = findElement(channels,"id",daten[j].events[i].channel);
                       if (x!= undefined){
                           sendungstr = x["name"];
                           if (show_logos == true){
                               var foto = 'https://tvfueralle.de/channel-logos/' + x["channelId"] +'.png';
                               Log_Html = Log_Html + '<td width="10%" align="center" bgcolor=white>'+ '<img src="' + foto + '" width="30" height="30">' +'</td>';
                           } else {
                               Log_Html = Log_Html +'<td width="10%">'+ zeichengroesse +  x["name"] +'</span></td>';
                           }
                       }
                       if (daten[j].events[i].title != undefined) {
                           //console.log(daten[j].events[i]);
                           sendungstr = sendungstr + " " + daten[j].events[i].title;
                           Log_Html = Log_Html +'<td width="40%">'+ zeichengroesse + daten[j].events[i].title +'</span></td>';
                       }
                       sendungstr = sendungstr + " " + formatDate(daten[j].events[i].startTime,'hh:mm ') + " Uhr";
                       Log_Html = Log_Html +'<td width="15%">'+ zeichengroesse + formatDate(daten[j].events[i].startTime,'hh:mm ') +'</span></td>';
                       sendungstr = sendungstr + " " + formatDate(daten[j].events[i].endTime,'hh:mm ') + " Uhr";
                       Log_Html = Log_Html +'<td width="15%">'+ zeichengroesse + formatDate(daten[j].events[i].endTime,'hh:mm ') +'</span></td>';
                       
                       x = findElement(categories,"id",daten[j].events[i].content.category);
                       //console.log(x);
                       if (x !=undefined){
                           if (x["title"]!= undefined) {
                               sendungstr = sendungstr + " - " + daten[j].events[i].content.category + " " + x["title"];
                               Log_Html = Log_Html +'</td><td width="20%">'+ zeichengroesse + x["title"] + '</span></td>';
                           }        
                       }
                       Log_Html = Log_Html + '</tr>';
                       //if (daten[j].events[i].content.texts.VeryShort.value != null){
                           //console.log(daten[j].events[i].content.texts.VeryShort.value);
                           //sendungstr = sendungstr + " " + daten[j].events[i].content.texts.VeryShort.value;
                       //}
                   
                   }
                   //Ende einer Zeile
                   Bool_Farbe = !Bool_Farbe;
               }
               //Ende von HTML
               Log_Html = Log_Html + '</table></body></html>';
               setState(getState('0_userdata.0.tvprogram.Datenpunkt').val,Log_Html);
           });
        };
        
        // Html-erzeugen Boolean ausführen
        on({id: '0_userdata.0.tvprogram.HtmlSet', change: "ne"}, function (obj) {
           if (getState('0_userdata.0.tvprogram.HtmlSet').val == true){
               html_erzeugen();
           }
           setState('0_userdata.0.tvprogram.HtmlSet',false);
        });
        

        Jarvis-Implementierung

        824eb889-61ec-4cfc-823f-82036ec3e077-image.png

        Möchte man alle 10 Minuten die Zeit automatisch gesetzt bekommen, muß man den folgenden Code anhängen:

        var schedule1;
        (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
        
        schedule1 = schedule('*/10 * * * *', async function () {
          //ZEIT_1 = formatDate(new Date(), "hh:mm");
          setState('0_userdata.0.tvprogram.Zeit',formatDate(new Date(), "hh:mm"));
        });
        
        

        Kann es sein das man noch irgendwie einstellen muss das es den neuen Tag nimmt? Habe es gestern erstellt, heute werden mir aber nur die Daten von gestern angezeigt:

        TVProgramm.PNG

        Edit: Hab mir jetzt erstmal damit geholfen mir per Blockly ein Zeitplan zu erstellen der beide Scripts (eins für Wunschzeit, eins für fest 20:15) morgens um 06:00 neu startet.

        Gleichzeitig wird für das 20:15 die HTML-Seite aktualisiert.

        Dann habe ich noch im Blockly ein Trigger auf die Zeit des Wunschzeit-Scripts gesetzt, der bei Aktualisierung der Zeit die HTML-Seite gleich aktualisiert.

        Um das Program jetzt anzuzeigen ist ja eigentlich das widget "control" da.
        Ich dachte du wolltest da eine fest eingestellte Uhrzeit (2015) dir immer anzeigen lassen?

        A 1 Reply Last reply Reply Quote 0
        • A
          Ash2k @OliverIO last edited by

          @oliverio

          Das 20:15 habe ich auch, war jetzt nur nicht auf dem Screenshot zu sehen. Bei dem "Jetzt" kann ich halt auch jede andere Uhrzeit anzeigen lassen, nach dem Motto: Zeig mir alles was um 23:00 anfängt.

          Das mit control hatte ich ehrlich gesagt noch gar nich so beachtet, schau ich mir aber auf jeden Fall mal an, danke für den Hinweis!

          OliverIO 1 Reply Last reply Reply Quote 0
          • OliverIO
            OliverIO @Ash2k last edited by OliverIO

            Neue Version 0.0.280.0.29:

            • Die formatierung des Datum-dialog wurde etwas verbessert.

            @sigi234 Die gelbe Schrift und die Darsellung der inaktiven Tage wird es wahrscheinlich nicht verbessern.
            Da wird man sich wieder auf die Suche machen müssen, welche css-Anweisung, dies verursacht

            Chaot Knallochse 2 Replies Last reply Reply Quote 0
            • Chaot
              Chaot @OliverIO last edited by

              @oliverio ???
              Ich habe gerade eine 0.0.29 gezogen?

              OliverIO 1 Reply Last reply Reply Quote 0
              • Knallochse
                Knallochse @OliverIO last edited by

                @oliverio ich habe leider Probleme mit dem neuen Suche Widget.
                Unter Windows funktioniert das wunderbar. Der Kalender zum auswählen wird angezeigt. Unter Android (FullyBrowser) als auch IOS (Safari) habe ich das Problem, dass beim klicken in die Felder „From“ & „Till“ die Tastatur eingeblendet wird aber das Kalender-Popup nicht erscheint.
                Würde es nicht reichen, wenn man hier feste Werte annimmt? (From=heute & Till=heute+XTage)

                OliverIO 2 Replies Last reply Reply Quote 0
                • OliverIO
                  OliverIO @Chaot last edited by

                  @chaot said in Test Adapter tvprogram:

                  @oliverio ???
                  Ich habe gerade eine 0.0.29 gezogen?

                  ja 0.0.29

                  1 Reply Last reply Reply Quote 0
                  • OliverIO
                    OliverIO @Knallochse last edited by

                    @knallochse said in Test Adapter tvprogram:

                    @oliverio ich habe leider Probleme mit dem neuen Suche Widget.
                    Unter Windows funktioniert das wunderbar. Der Kalender zum auswählen wird angezeigt. Unter Android (FullyBrowser) als auch IOS (Safari) habe ich das Problem, dass beim klicken in die Felder „From“ & „Till“ die Tastatur eingeblendet wird aber das Kalender-Popup nicht erscheint.
                    Würde es nicht reichen, wenn man hier feste Werte annimmt? (From=heute & Till=heute+XTage)

                    deswegen testen wir ja.
                    ich schau ob man das für android verbessert werden kann

                    1 Reply Last reply Reply Quote 0
                    • OliverIO
                      OliverIO @Knallochse last edited by

                      @knallochse said in Test Adapter tvprogram:

                      @oliverio ich habe leider Probleme mit dem neuen Suche Widget.
                      Unter Windows funktioniert das wunderbar. Der Kalender zum auswählen wird angezeigt. Unter Android (FullyBrowser) als auch IOS (Safari) habe ich das Problem, dass beim klicken in die Felder „From“ & „Till“ die Tastatur eingeblendet wird aber das Kalender-Popup nicht erscheint.
                      Würde es nicht reichen, wenn man hier feste Werte annimmt? (From=heute & Till=heute+XTage)

                      ja das mit datum und uhrzeit ist über die verschiedenen browser und mobil kein einfaches thema, da es sehr unterschiedlich bis gar nicht einheitlich unterstützt wird.

                      auf alle würde ich nicht verzichten wollen, wenn dann würde ich das startdatum drin behalten und das mit dem aktuellen datum vorbelegen. Für das Datum würde ich den input typ date nehmen. ob der überall unterstützt wird schauen wir, ansonsten muss man per hand eingeben.
                      als Uhrzeit würde es am gleichen tag erst ab der aktuellen Uhrzeit suchen, bei allen anderen daten, ab 00:00 Uhr. Eine Validierung ob ein Datum möglich ist, gibt es nicht, es kommt halt dann kein Ergebnis zurück.
                      Bin mal gespannt, welche Herausforderungen die jeweilige Lokalisierung bei der Erkennung des Datums bevorstehen

                      Knallochse 1 Reply Last reply Reply Quote 1
                      • M
                        MCU @Ash2k last edited by MCU

                        @ash2k Ja, musst die Funktion einmal anpassen:

                        function html_erzeugen() { 
                            var dateheute = new Date(); // Diese Zeile ergänzen
                        

                        Wurde im Original angepasst:
                        https://forum.iobroker.net/topic/40168/test-adapter-tvprogram/593

                        O 1 Reply Last reply Reply Quote 0
                        • Knallochse
                          Knallochse @OliverIO last edited by

                          @oliverio als Idee für die Datumsangabe im Such-Widget:
                          From=jetzt (find ich gut)
                          Till: vielleicht einfach wie im Programm-Widget mit Pfeil (links/rechts) für nächster Tag. Oder einfach mit „+“ & „-“ für Anzahl der Tage in Voraus

                          Wie auch immer du dich entscheidest, eine Vorgabe (mit oder ohne Änderungsmöglichkeit) fände ich toll, damit man schnell was suchen kann, ohne erst ein Datum eingeben zu müssen.

                          Auch hier wieder: bitte als Vorschlag zur Diskussion und nicht als Umsetzungsbitte verstehen

                          1 Reply Last reply Reply Quote 0
                          • C
                            claus1993 last edited by

                            @OliverIO

                            Habe bei mir folgende Fehler, vielleicht weißt du mit Rat zu helfen.

                            Wenn ich die VIS im View anscheue bekomme ich im Widget "TV Program Timetable1" nur die Anzeige "Datapoints loading...".

                            Des weiteren habe ich ein Thema mit der Ansicht der einzelnen Popups im oben genanten Widgets. Diese werden nicht über dem TV Programm Timetable1 angezeigt sondern liegen darunter. Habe hier bereits mit dem z-index versucht das anzupassen. Finde aber bei mir immer nur die Anpassung für das Timetable1 Widget. Eine Einstellung für die Popup kann ich nicht finden.

                            Ich nutze bei mir den Google Chrome Version 88.0.4324.150 auf einem Windows Rechner.

                            Dane und Grüße,
                            Claus

                            OliverIO 1 Reply Last reply Reply Quote 0
                            • S
                              spaceduck last edited by spaceduck

                              Wollte einfach mal Danke sagen für diesen genialen Adapter!!!

                              1 Reply Last reply Reply Quote 5
                              • Knallochse
                                Knallochse last edited by

                                Das ist natürlich angebracht. Auch von mir ein dickes DANKESCHÖN 👍
                                Echt geiler Adapter, mit mehr Funktionen als ich mir zu Beginn erhofft hatte.

                                1 Reply Last reply Reply Quote 2
                                • OliverIO
                                  OliverIO @claus1993 last edited by

                                  @claus1993 sagte in Test Adapter tvprogram:

                                  @OliverIO

                                  Habe bei mir folgende Fehler, vielleicht weißt du mit Rat zu helfen.

                                  Wenn ich die VIS im View anscheue bekomme ich im Widget "TV Program Timetable1" nur die Anzeige "Datapoints loading...".

                                  Des weiteren habe ich ein Thema mit der Ansicht der einzelnen Popups im oben genanten Widgets. Diese werden nicht über dem TV Programm Timetable1 angezeigt sondern liegen darunter. Habe hier bereits mit dem z-index versucht das anzupassen. Finde aber bei mir immer nur die Anpassung für das Timetable1 Widget. Eine Einstellung für die Popup kann ich nicht finden.

                                  Ich nutze bei mir den Google Chrome Version 88.0.4324.150 auf einem Windows Rechner.

                                  Dane und Grüße,
                                  Claus

                                  Am besten den Adapter komplett deinstallieren und dann neu installieren
                                  .dann die Widgets neu hinzufügen. Als datenpunkt immer den cmd datenpunkt auswählen.
                                  Falls es dann noch Probleme gibt, dann auf der console
                                  Iobroker upload all
                                  Eingeben.
                                  Falls es dann immer noch Probleme gibt bitte in der developer console vom Browser mal nach Fehlern suchen wo tvprogram dabei steht

                                  C 1 Reply Last reply Reply Quote 0
                                  • C
                                    claus1993 @OliverIO last edited by

                                    @oliverio

                                    Habe alles durchlaufen leide ohne Erfolg. Auf der Console auch keinen Fehler gefunden was den TV Adapter betrifft.

                                    Anbei mal die Meldungen aus der Console, vielleicht siehst du etwas das verkehrt ist.

                                    Version vis-map: 1.0.3
                                    index.html:12624 Uncaught TypeError: vis.addFont is not a function
                                        at index.html:12624
                                    (anonymous) @ index.html:12624
                                    material.js:29 Version material: 0.1.3
                                    DevTools failed to load SourceMap: Could not load content for http://192.168.178.11:8082/lib/js/socket.io.js.map: HTTP error: status code 404, net::ERR_HTTP_RESPONSE_CODE_FAILURE
                                    index.html:14575 Metro version: "1.1.2"
                                    lib.min.js:22 Download the Vue Devtools extension for a better development experience:
                                    https://github.com/vuejs/vue-devtools
                                    lib.min.js:22 You are running Vue in development mode.
                                    Make sure to turn on production mode when deploying for production.
                                    See more tips at https://vuejs.org/guide/deployment.html
                                    mytime.js:22 Version mytime: 0.0.1
                                    openligadb.js:27 Version openligadb: 0.5.0
                                    players.js:55 Version players: 0.1.0
                                    index.html:16347 Version vis-plumb: 1.0.0
                                    DevTools failed to load SourceMap: Could not load content for http://192.168.178.11:8082/vis/widgets/material-webfont/css/materialdesignicons.css.map: HTTP error: status code 404, net::ERR_HTTP_RESPONSE_CODE_FAILURE
                                    trashschedule.js:47 Version trashschedule: 0.0.10
                                    tvprogram.js:36 Version tvprogram: 0.0.1
                                    vis-material-advanced.js:174 Version vis-material-advanced: 0.6.5
                                    index.html:24700 Version vis-weather: 2.4.1
                                    jquery-1.11.2.min.js:4 GET http://192.168.178.11:8082/vis/adapter/mytime/words.js 404 (Not Found)
                                    send @ jquery-1.11.2.min.js:4
                                    ajax @ jquery-1.11.2.min.js:4
                                    m.<computed> @ jquery-1.11.2.min.js:4
                                    (anonymous) @ mytime.js:11
                                    conn.js:273 2021-02-13T15:00:33.908Z Connected => authenticate
                                    conn.js:293 2021-02-13T15:00:34.047Z Authenticated: true
                                    materialdesign.js:33 Version vis-materialdesign: 0.3.19
                                    VM346:1 Uncaught SyntaxError: Unexpected end of input
                                        at Object.<anonymous> (vis.js:3420)
                                        at vis.js:1960
                                        at conn.js:530
                                    (anonymous) @ vis.js:3420
                                    (anonymous) @ vis.js:1960
                                    (anonymous) @ conn.js:530
                                    setTimeout (async)
                                    (anonymous) @ conn.js:529
                                    r.onack @ index.js:83
                                    r.onpacket @ index.js:83
                                    (anonymous) @ index.js:83
                                    r.emit @ index.js:83
                                    r.ondecoded @ index.js:83
                                    (anonymous) @ index.js:83
                                    r.emit @ index.js:83
                                    a.add @ index.js:83
                                    r.ondata @ index.js:83
                                    (anonymous) @ index.js:83
                                    r.emit @ index.js:83
                                    r.onPacket @ index.js:83
                                    (anonymous) @ index.js:83
                                    r.emit @ index.js:83
                                    r.onPacket @ index.js:83
                                    r.onData @ index.js:83
                                    ws.onmessage @ index.js:83
                                    instrument.ts:129 sentry initialized for vis-materialdesign
                                    instrument.ts:129 
                                    
                                    OliverIO 1 Reply Last reply Reply Quote 0
                                    • OliverIO
                                      OliverIO @claus1993 last edited by OliverIO

                                      @claus1993 sagte in Test Adapter tvprogram:

                                      @oliverio

                                      Habe alles durchlaufen leide ohne Erfolg. Auf der Console auch keinen Fehler gefunden was den TV Adapter betrifft.

                                      Anbei mal die Meldungen aus der Console, vielleicht siehst du etwas das verkehrt ist.

                                      Version vis-map: 1.0.3
                                      index.html:12624 Uncaught TypeError: vis.addFont is not a function
                                          at index.html:12624
                                      (anonymous) @ index.html:12624
                                      material.js:29 Version material: 0.1.3
                                      DevTools failed to load SourceMap: Could not load content for http://192.168.178.11:8082/lib/js/socket.io.js.map: HTTP error: status code 404, net::ERR_HTTP_RESPONSE_CODE_FAILURE
                                      index.html:14575 Metro version: "1.1.2"
                                      lib.min.js:22 Download the Vue Devtools extension for a better development experience:
                                      https://github.com/vuejs/vue-devtools
                                      lib.min.js:22 You are running Vue in development mode.
                                      Make sure to turn on production mode when deploying for production.
                                      See more tips at https://vuejs.org/guide/deployment.html
                                      mytime.js:22 Version mytime: 0.0.1
                                      openligadb.js:27 Version openligadb: 0.5.0
                                      players.js:55 Version players: 0.1.0
                                      index.html:16347 Version vis-plumb: 1.0.0
                                      DevTools failed to load SourceMap: Could not load content for http://192.168.178.11:8082/vis/widgets/material-webfont/css/materialdesignicons.css.map: HTTP error: status code 404, net::ERR_HTTP_RESPONSE_CODE_FAILURE
                                      trashschedule.js:47 Version trashschedule: 0.0.10
                                      tvprogram.js:36 Version tvprogram: 0.0.1
                                      vis-material-advanced.js:174 Version vis-material-advanced: 0.6.5
                                      index.html:24700 Version vis-weather: 2.4.1
                                      jquery-1.11.2.min.js:4 GET http://192.168.178.11:8082/vis/adapter/mytime/words.js 404 (Not Found)
                                      send @ jquery-1.11.2.min.js:4
                                      ajax @ jquery-1.11.2.min.js:4
                                      m.<computed> @ jquery-1.11.2.min.js:4
                                      (anonymous) @ mytime.js:11
                                      conn.js:273 2021-02-13T15:00:33.908Z Connected => authenticate
                                      conn.js:293 2021-02-13T15:00:34.047Z Authenticated: true
                                      materialdesign.js:33 Version vis-materialdesign: 0.3.19
                                      VM346:1 Uncaught SyntaxError: Unexpected end of input
                                          at Object.<anonymous> (vis.js:3420)
                                          at vis.js:1960
                                          at conn.js:530
                                      (anonymous) @ vis.js:3420
                                      (anonymous) @ vis.js:1960
                                      (anonymous) @ conn.js:530
                                      setTimeout (async)
                                      (anonymous) @ conn.js:529
                                      r.onack @ index.js:83
                                      r.onpacket @ index.js:83
                                      (anonymous) @ index.js:83
                                      r.emit @ index.js:83
                                      r.ondecoded @ index.js:83
                                      (anonymous) @ index.js:83
                                      r.emit @ index.js:83
                                      a.add @ index.js:83
                                      r.ondata @ index.js:83
                                      (anonymous) @ index.js:83
                                      r.emit @ index.js:83
                                      r.onPacket @ index.js:83
                                      (anonymous) @ index.js:83
                                      r.emit @ index.js:83
                                      r.onPacket @ index.js:83
                                      r.onData @ index.js:83
                                      ws.onmessage @ index.js:83
                                      instrument.ts:129 sentry initialized for vis-materialdesign
                                      instrument.ts:129 
                                      

                                      hm, da sehe ich keine Fehler, die von tvprorgam verursacht werden.
                                      Was definitiv zum Abbruch führt ist dieser hier:

                                      VM346:1 Uncaught SyntaxError: Unexpected end of input
                                          at Object.<anonymous> (vis.js:3420)
                                          at vis.js:1960
                                          at conn.js:530
                                      

                                      Ich weiß jetzt nicht welche vis-version du hast. Bei mir wird an dieser Zeile ein script, welches geladen wird in das HTML hinzugefügt.
                                      tvprogram ist es nicht, das wurde bereits in zeile 19 deines Protokolls erfolgreich geladen

                                      theoretisch müsste der gleiche Fehler auch drin stehen, wenn du alle tvprogram widgets entfernst.
                                      Kannst du mal den script-Reiter von vis kontrollieren oder mal leeren.
                                      Eine Vermutung ist, das da fehlerhaftes javascript enthalten ist.

                                      Ein weiterer seltsamer Fehler ist auch

                                      index.html:12624 Uncaught TypeError: vis.addFont is not a function
                                          at index.html:12624
                                      

                                      Der ist aber unkritisch, da er nicht zum kompletten Abbruch führt. Sollte aber auch nicht sein.

                                      C OliverIO 2 Replies Last reply Reply Quote 0
                                      • C
                                        claus1993 @OliverIO last edited by

                                        @oliverio

                                        Habe den Eintrag im Vis-Script entfernt und zumindest eine Meldung weniger. Dennoch werden immer noch keine Daten für das TV Widget geladen. Das TV Widget ist aber nicht die Quelle des Übels, nach dem löschen waren die Meldungen, wie du bereits geschrieben hast, immer noch da. Jetzt heißt es auf die Fehlersuche gehen.
                                        Solltest du noch einen Tipp haben ist dieser gerne gesehen 🙂

                                        Danke dir!

                                        1 Reply Last reply Reply Quote 0
                                        • OliverIO
                                          OliverIO @OliverIO last edited by

                                          Ein weiterer seltsamer Fehler ist auch

                                          index.html:12624 Uncaught TypeError: vis.addFont is not a function
                                              at index.html:12624
                                          

                                          Der ist aber unkritisch, da er nicht zum kompletten Abbruch führt. Sollte aber auch nicht sein.

                                          Such mal nochmal nach diesem Fehler in der console und schau mal was in dieser Zeilennummern in der Index.html steht. Evtl kann sich mittlerweile die zeilennummer geändert haben.
                                          Wenn du da ein paar Zeilen davor oder danach schaust könntest du sehen was das genau betrifft. Ich vermute es ist ein Adapter, dessen Skripte an dieser Stelle eingefügt werden die fehlerhaft sind

                                          OliverIO 1 Reply Last reply Reply Quote 0
                                          • OliverIO
                                            OliverIO @OliverIO last edited by OliverIO

                                            Neue Version 0.0.30

                                            • Das search widget wurde angepasst.
                                              Es enthält nur noch ein reines Datumsfeld, welches durch die meisten Browser auch als solches erkannt wird.
                                              Dieses ist mit dem aktuellen Datum vorbelegt.
                                              Suche startet, wenn es der gleiche Tag ist um die aktuelle Zeit.
                                              Wenn es ein anderer Tag ist, um 00:00 Uhr.
                                              Das Search widget hat nun ein Attribut maxresults erhalten, um die Menge der Daten, die zu übertragen sind zu begrenzen.
                                              Es erfolgt keine Suche, wenn das Textfeld UND die Kategorienauswahl leer ist.

                                            • Im control-widget wurde ein weiteres Attribut time eingeführt um das widget etwas flexibler einsetzen zu können. Es gibt nun 3 Möglichkeiten:

                                              1. time bleibt leer
                                                Sendungen zur aktuellen Uhrzeit wird angezeigt und auch immer aktualisiert.
                                              1. time wird mit Uhrzeit im 24h-Format belegt, bspw 20:15:
                                                Es werden die Sendungen die zu dieser Uhrzeit laufen angezeigt.
                                                Ist die aktuelle Uhrzeit nach dieser Zeit, werden die Sendungen des nächsten Tages zu dieser Uhrzeit angezeigt. auch hier erfolgt automatisch die Aktualisierung.
                                              2. time wird mit einem validen Datumsausdruck belegt
                                                bspw. 2021-02-15T19:15:00.000Z (Achtung Zeitzonen beachten)
                                                valide bedeutet, wenn der folgende javascript-Ausdruck ein gültiges Datumsobjekt zurückgibt:
                                                new Date("2021-02-15T19:15:00.000Z")
                                                siehe auch https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/Date
                                                Es werden die Sendungen genau zu diesem Zeitpunkt laufen angezeigt. So können wechselnde Zeiten, die in einen Datenpunkt geschrieben und über Bindung in diesem Feld gesetzt werden, realisiert werden. Ich warne allerdings davor, dieses Feld sekündlich zu ändern, das dürfte den Netzwerkverkehr, vis und iobroker über Gebühr belasten. Minütlich müsste reichen, wenn nicht gar erst auf Knopfdruck oder in größere Zeitabstände.
                                                .
                                            A 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            964
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            adapter tvprogram vis widget
                                            51
                                            911
                                            188946
                                            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