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 @MCU last edited by

      @mcu said in Test Adapter tvprogram:

      @oliverio Nachrichten nachmittags, abends, Er scheint nur eine Stunde zu berücksichtigen.

      und wie ist die Einstellung zu maxresults?

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

        @oliverio Lag bei 10. Funktioniert. Danke.

        1 Reply Last reply Reply Quote 0
        • sigi234
          sigi234 Forum Testing Most Active @OliverIO last edited by

          @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

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            475
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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