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.
    • OliverIO
      OliverIO @sigi234 last edited by

      @sigi234 said in Test Adapter tvprogram:

      @oliverio sagte in Test Adapter tvprogram:

      Neue Version 0.0.28

      • Neues Widget um Programme nach (Teil)-titel, nach Kategorie (Spielfilm, Nachrichten) und in einem Zeitbereich zu suchen.

      Hallo, kann ich die Gelbe Schrift wo umstellen?

      Screenshot (3304)_LI.jpg

      Ich verwende den datetimepicker, der auf den datepicker von jquery aufsetzt.
      Aktuell wird noch das original Farbschema von jquery verwendet, wleches ja genau wie bei meinen anderen Dialogen etwas mehr manipulation an den Eigenschaften benötigt.
      Ich werde das bei Gelegenheit noch anpassen.

      Bei dir kommt allerdings noch dazu, das du auch hier irgendwo weitere CSS-Anweisungen hast, die das Negativ beeinflussen. neben der gelben Schrift, sehe ich auch noch im Kalender ein Problem mit der Farbe für nicht auswählbare Tage

      Das Original-Layout sieht so aus:
      be5ddccd-128d-484b-867c-aa80564073e3-image.png

      1 Reply Last reply Reply Quote 0
      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            504
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

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