Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. DSB - Abrage

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    DSB - Abrage

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

      @Brunoz

      erstelle jetzt ein neues Skript. Beide Skripte laufen parallel. Als klasse kannst du die Klasse deiner Kinder eingeben. Alle andere Einträge sollten ausgeblendet werden.

      var klasse = "8A";
      var myArrayA;
      var myArrayB;
      var mystra;
      var bid;
      
      const TT = $('state[state.id=javascript.0.VIS.DSBMmobile-tmp.Kind*.Timetable]').each(function(id) {
           on({id: id, change: "ne"}, function (obj) {
              myArrayA = [];
              myArrayB = [];
      
              mystra = getState(id).val;
              mystra = mystra.replace(/<table/gi, "\n<table");
              mystra = mystra.replace(/<tr/gi, "\n<tr");
              mystra = mystra.replace(/<\/body>/gi, "\n<\/body>");
              mystra = mystra.replace(/<\/table/gi, "\n<\/table");
              myArrayA = mystra.split("\n");
      
              myArrayA.forEach(function (element) {
                  if(element.startsWith("<table") || element.startsWith("<tr")) {
                      myArrayB.push(element);
                  }
              });
      
              myArrayA = [];
              scharf = true;
              myArrayB.forEach(function (element) {
                  if(element.startsWith("<tr class=\"head\">")) {
                      scharf = false;
                      myArrayA.push(element);
                  } else {
                      if(scharf || element.includes(klasse) || element.includes("<\/table") ) myArrayA.push(element);
                  }
              });
         
              mystra = "";
              myArrayA.forEach(function (element) {
                  mystra += element + "\n";
              });
      
              bid = id.replace(/\.Timetable/gi, "\.vis");
              setState(bid, mystra);
           });
      });
       
      

      Dieses Skript überwacht die Datenpunkte ".Timetable" und erstellt die neue Version in ".vis".
      Wenn du dann testen willst, dann lösche den Inhalt des ".Timetable" und führe Skript 1 aus. .Timetable sollte gefüllt werden und dann springt Skript 2 an.

      Wenn das funktioniert, (ich musste es blind programmieren) dann kümmern wir uns die regelmäßige Aufrufe.

      1 Reply Last reply Reply Quote 0
      • B
        Brunoz last edited by

        Die Übernahme in den Datenpunkt VIS hat funktioniert!

        Wie binde ich das in meine VIS ein?

        a200 2 Replies Last reply Reply Quote 0
        • a200
          a200 @Brunoz last edited by a200

          @Brunoz sagte in DSB - Abrage:

          Die Übernahme in den Datenpunkt VIS hat funktioniert!

          Wie binde ich das in meine VIS ein?

          Erstelle ein HTML-Objekt. Als Inhalt kannst du den Datenpunkt in {} setzen.

          also z.B.

          {javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}
          <table>
          <tr><td>Stand:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.Time}</td></tr> 
          <tr><td>Abruf:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis.ts;date(DD.MM.YYYY hh:mm)}</td></tr> 
          </table>
          
          {javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}
          <table>
          <tr><td>Stand:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.Time}</td></tr> 
          <tr><td>Abruf:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis.ts;date(DD.MM.YYYY hh:mm)}</td></tr> 
          </table>
          
          

          die Schriftart, -farbe, -größe kannst du im VIS konfigurieren.
          versuche das mal und wir schauen ob wir noch was optimieren können.

          Alternativ kann du dieses widget importieren und anpassen:

          [{"tpl":"tplHtml","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":true,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"30000","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html":"{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}<table><tr><td>Stand:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.Time}</td></tr><tr><td>Abruf:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis.ts;date(DD.MM.YYYY hh:mm)}</td></tr></table>{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}<table><tr><td>Stand:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.Time}</td></tr><tr><td>Abruf:</td><td>{javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis.ts;date(DD.MM.YYYY hh:mm)}</td></tr></table>","class":"vertretungsplan"},"style":{"left":"26px","top":"203px","background-color":"#222","border-radius":"15px","box-shadow":"10px 10px 12px -3px rgba(0,0,0,0.75)","width":"1010px","height":"789px","color":"#ffffff","font-family":"RobotoCondensed-Regular","font-size":"21px","padding-left":"","padding-right":"","line-height":"","padding":"15px","z-index":"1","overflow-y":"scroll","margin-left":"","overflow-x":"","border-width":"2px","border-style":"solid","border-color":"#777"},"widgetSet":"basic"}]
          

          1 Reply Last reply Reply Quote 0
          • a200
            a200 @Brunoz last edited by a200

            @Brunoz UPDATE

            script 1:

            var cron1 = "14,29,44,59 * * * *";  // Alle 15 Min
            var cron2 = "13,28,43,58 * * * *";  // Alle 15 Min
            var cron3 = "3,8,13,18,23,28,33,38,43,48,53,58 7 * * *"; 		// von 7:00 - 7:58 Alle 5 Min
            var cron4 = "4,9,14,19,24,29,34,39,44,49,54,59 6,7 * * *";		// von 6:00 - 7:59 Alle 5 Min
            
            var BaseUrl = "https://iphone.dsbcontrol.de/iPhoneService.svc/DSB";
            var UserName = ["XXX", "XXX"];
            var Passwort = ["YYY", "YYY"];
            var KindTT = ["javascript.0.VIS.DSBMmobile-tmp.Kind1", "javascript.0.VIS.DSBMmobile-tmp.Kind2"];
            var Tage = ["heute", "morgen"];
            var debug = true;
             
            var Loginreq;
            var MyToken;
            var ausgabe;
            var retArr = [];
            var tmpArr = [];
            var scharf;
            var inhalt;
            var anzahl;
            var TTreq;
             
            for( var i = 0; i<KindTT.length; i++) {
                Tage.forEach(function(element) {
                    if (!getObject(KindTT[i] + "." + element + ".Timetable")) {
                        createState(KindTT[i] + "." + element + ".Timetable", "", {
                            "desc": "TimeTable",
                            "name": "TimeTable fuer Kind " + i,
                            "type": "string",
                            "role": "html"
                        });
                    }
                    if (!getObject(KindTT[i] + "." + element + ".vis")) {
                        createState(KindTT[i] + "." + element + ".vis", "", {
                            "desc": "TimeTable",
                            "name": "TimeTable fuer Kind " + i,
                            "type": "string",
                            "role": "html"
                        });
                    }
                    if (!getObject(KindTT[i] + "." + element + ".Events")) {
                        createState(KindTT[i] + "." + element + ".Events", 0, {
                            "desc": "TimeTable",
                            "name": "TimeTable fuer Kind " + i,
                            "type": "number",
                        });
                    }
                    if (!getObject(KindTT[i] + "." + element + ".Time")) {
                        createState(KindTT[i] + "." + element + ".Time", "", {
                            "desc": "TimeTable",
                            "name": "TimeTable fuer Kind " + i,
                            "type": "string",
                            "role": "html"
                        });
                    }
                });
            }
             
            var request = require('request');
             
            var ttype = [];
            var url2 = [];
            var Tage2 = [];
            var k, eintraege;
             
            Tage2 = [].concat(Tage);
             
            function getData(Kind) {
                request(url2[k], function (error, response, body) {
                    if(debug) log("Error 3: " + error + "\nCode 3: " + response.statusCode);
                	if (!error && response.statusCode == 200) {
                	    if(debug) log("Schreibe nach: " + KindTT[Kind] + "." + Tage2[0] + ".Timetable");
                	    setState(KindTT[Kind] + "." + Tage2[0] + ".Timetable", body, true, function() {
                			//CreateVP(Kind);
                 		});    
                 	}
                 	Tage2.shift();
                     k++;
                     if(k < eintraege) getData(Kind);
                });
             }
              
             function GetTT(Kind) {
                 url2=[];
                 ttype=[];
             	Loginreq = BaseUrl + "/authid/" + UserName[Kind] + "/" + Passwort[Kind];
             	request(Loginreq, function (error, response, body) {
             		if(debug) log("Error 1: " + error + "\nCode 1: " + response.statusCode);
             		if (!error && response.statusCode == 200) {
             			TTreq = BaseUrl + "/timetables/" + body.replace(/\"/g, "");
             			request(TTreq, function (error, response, body) {
             				if(debug) log("Error 2: " + error + "\nCode 2: " + response.statusCode);
             				if (!error && response.statusCode == 200) {
             					body = JSON.parse(body);
             					eintraege = body.length;
             					for(var i=0; i<eintraege; i++) {
             					    ttype.push(body[i].ishtml);
             					    url2.push(body[i].timetableurl);
             					    setState(KindTT[Kind] + "." + Tage[i] + ".Time", body[0].timetabledate);
             					}
             					log(JSON.stringify(body, null, 4));
             					k = 0;
             					getData(Kind);
             				}
             			});
             		}
             	});
             }
              
            schedule(cron1, function () { 	// Kind 1 - Abruf alle 15Min
                GetTT(0);
            });
            schedule(cron3, function () { 	// Kind 1 - von 7:00 - 7:58 Alle 5 Min
                GetTT(0);
            });
            
            schedule(cron2, function () {	// Kind 2 - Abruf alle 15Min
                GetTT(1);
            });
            
            schedule(cron4, function () {	// Kind 2 - von 6:00 - 7:59 Alle 5 Min
                GetTT(1);
            });
            

            script 2:

            var klasse = "8A";   // Gesuchte Klasse anpassen!
            var myArrayA;
            var myArrayB;
            var mystra;
            var bid;
            
            const TT = $('state[state.id=javascript.0.VIS.DSBMmobile-tmp.Kind*.Timetable]').each(function(id) {
                 on({id: id, change: "ne"}, function (obj) {
                    myArrayA = [];
                    myArrayB = [];
            
                    mystra = getState(id).val;
                    mystra = mystra.replace(/<table/gi, "\n<table");
                    mystra = mystra.replace(/<tr/gi, "\n<tr");
                    mystra = mystra.replace(/<\/body>/gi, "\n<\/body>");
                    mystra = mystra.replace(/<\/table/gi, "\n<\/table");
                    myArrayA = mystra.split("\n");
            
                    myArrayA.forEach(function (element) {
                        if(element.startsWith("<table") || element.startsWith("<tr") || element.startsWith("<\/table")) {
                            myArrayB.push(element);
                        }
                    });
            
                    myArrayA = [];
                    scharf = true;
                    myArrayB.forEach(function (element) {
                        if(element.startsWith("<tr class=\"head\">")) {
                            scharf = false;
                            myArrayA.push(element);
                        } else {
                            if(scharf || element.includes(klasse) || element.includes("<\/table") ) myArrayA.push(element);
                        }
                    });
               
                    mystra = "";
                    myArrayA.forEach(function (element) {
                        mystra += element + "\n";
                    });
            
                    bid = id.replace(/\.Timetable/gi, "\.vis");
                    setState(bid, mystra);
                 });
            });
            

            widget:

            [{"tpl":"tplHtml","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":true,"g_css_border":true,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"30000","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html":"{javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}\n<br>\n{javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis}\n","class":"vertretungsplan"},"style":{"left":"20px","top":"20px","background-color":"#222","border-radius":"15px","box-shadow":"10px 10px 12px -3px rgba(0,0,0,0.75)","width":"1000px","height":"800px","color":"#ffffff","font-family":"RobotoCondensed-Regular","font-size":"21px","padding-left":"","padding-right":"","line-height":"","padding":"15px","z-index":"1","overflow-y":"scroll","margin-left":"","overflow-x":"","border-width":"2px","border-style":"solid","border-color":"#777"},"widgetSet":"basic"}]
            

            CSS:

            .vertretungsplan table {
                width: 100%;
            }
            
            .vertretungsplan td {
                border: solid 1px white;
            }
            

            Melde dich ob das funktioniert!

            1 Reply Last reply Reply Quote 0
            • B
              Brunoz last edited by

              Hallo a200,

              also es klappt schon ganz gut. Habe den HTML-Code nur leicht geändert, weil ich sonst den Überblick verloren hätte.

              <p>HEUTE</p>
              {javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis}
              <br>
              <p>MORGEN<P>
              {javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis}
              
              

              Die Tabelle von "heute" wird bei "morgen" angezeigt, wenn ich das richtig sehe.

              {63AD84BB-A18A-42C0-BB57-4CEC36973E93}.png.jpg

              Und, kann ich auch zwei Klassen angeben? Meine zwei Jungs, gehen in unterschiedliche Klasse. Muss ich den obigen Script einfach zweimal mit unterschiedlichen Klassen laufen lassen?

              Gruß
              Claudio

              a200 1 Reply Last reply Reply Quote 0
              • a200
                a200 @Brunoz last edited by a200

                @Brunoz

                1. nimm die aktuelle Version. Dort sind Korrekturen und automatische Abfrage eingebaut worden
                2. Wenn die Jungs in die gleiche Schule gehen, dann trage einfach die Logindaten doppelt ein.
                3. Skript 2 bitte anpassen:
                var klasse = ["8A","5C"];
                var myArrayA;
                var myArrayB;
                var mystra;
                var bid;
                var kid
                
                const TT = $('state[state.id=javascript.0.VIS.DSBMmobile-tmp.Kind*.Timetable]').each(function(id) {
                     on({id: id, change: "ne"}, function (obj) {
                         
                        kid = id.replace("javascript.0.VIS.DSBMmobile-tmp.Kind", "").charAt(0);
                
                        myArrayA = [];
                        myArrayB = [];
                
                        mystra = getState(id).val;
                        mystra = mystra.replace(/<table/gi, "\n<table");
                        mystra = mystra.replace(/<tr/gi, "\n<tr");
                        mystra = mystra.replace(/<\/body>/gi, "\n<\/body>");
                        mystra = mystra.replace(/<\/table/gi, "\n<\/table");
                        myArrayA = mystra.split("\n");
                
                        myArrayA.forEach(function (element) {
                            if(element.startsWith("<table") || element.startsWith("<tr") || element.startsWith("<\/table")) {
                                myArrayB.push(element);
                            }
                        });
                
                        myArrayA = [];
                        scharf = true;
                        myArrayB.forEach(function (element) {
                            if(element.startsWith("<tr class=\"head\">")) {
                                scharf = false;
                                myArrayA.push(element);
                            } else {
                                if(scharf || element.includes(klasse[kid-1]) || element.includes("<\/table") ) myArrayA.push(element);
                            }
                        });
                   
                        mystra = "";
                        myArrayA.forEach(function (element) {
                            mystra += element + "\n";
                        });
                
                        bid = id.replace(/\.Timetable/gi, "\.vis");
                        setState(bid, mystra);
                     });
                });
                 
                

                Das sollte die entsprechende Datenpunkte füllen. Oben im Skript die Klassen anpassen nicht vergessen.

                Es gibt noch eine Möglichkeit, dass es nur zwei Tabellen (heute, morgen) angelegt werden und in den Tabellen beide Klassen für beide Jungs angezeigt werden. Falls du das haben willst, dann sag mir Bescheid.

                1 Reply Last reply Reply Quote 0
                • B
                  Brunoz last edited by

                  Hallo a200,

                  sorry, das ich mich erst heute melde.

                  Bild3.jpg

                  Bild2.jpg

                  Bild1.jpg

                  Wie Sie sehen können, werden die Daten nicht korrekt angezeigt. (1. Bild)

                  Im meinem Falle reicht mir die Darstellung aber wie auf dem 3. Bild.
                  Das ist schon so wie ich es mir erhofft hatte.

                  Vielen Dank für die Arbeit.

                  Gruß
                  Claudio

                  a200 1 Reply Last reply Reply Quote 0
                  • a200
                    a200 @Brunoz last edited by

                    @Brunoz

                    hi,
                    kannst du mir bitte die die HTML-Datei aus dem *.Timetable Datenpunkt der Klasse, die nihct richtig angezeigt wird. Ich muss den Code analysieren.

                    1 Reply Last reply Reply Quote 0
                    • B
                      Brunoz last edited by Brunoz

                      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>  <head>    <title>HeinekingMedia Vertretungsplan - Classic</title>    <style type="text/css">      html, body { font-family:  Arial; }      .head { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .TeacherHead { background-color: #FFFFFF; color: #000000; font-weight: normal; }      .TeacherHead td { border-top: 2px solid #000000; border-bottom: 1px solid #000000; }      .SubTypeHead { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .def { background-color: #dedede; color: #000000; }      .alt { background-color: #b1f073; color: #000000; }      .new.def { background-color: #FFE97F; color: #000000; }      .new.alt { background-color: #FF75EC; color: #000000; }      table { width: 100%; margin-top: 5px; background-color: black; }      td { padding-left: 4px; padding-right: 4px; }      .additionInfoTable { width: 100%; border: 1px solid black; padding: 0; margin: 0; }      .additionInfoTable th { background: #000000; color: #FFFFFF; font-weight: bold; }      .additionInfoTable td { background: white; color: black; border-bottom: 0px solid black; font-weight: normal; }      .headTable { background: white; width: 100%; border: 0px; padding: 0; margin: 0; }      .headTable td { background: white; color: black; font-weight: bold; text-align: right; border: 0;}      h2 { font-size: 0.8em; margin:0; text-align: right; }      h1 { font-size: 2em;margin-bottom:5px; }      td.teacherNew { font-weight: bold; }      td.teacherOld { opacity: .40; filter: alpha(opacity = 40); -ms-filter: "alpha(opacity = 40)" }      span.hilite { font-weight: bold; text-decoration:underline; }      .NoSubstitutes { text-align: center; border: 0; }    </style>    <link rel="stylesheet" type="text/css" href="a6b426b1-76c0-4330-b4e1-ce564b4c8e44.css">    <script language="javascript">    </script>  </head>  <body>    <table class="headTable">    <tr><td>Letzte Änderung: 08.03.2019 01:05</td></tr>    </table><center><h1>11.03.2019, Montag</h1></center><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>7A, 7C, 7M+, 8B, 9B, 9C</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr><tr class="def"><td>7A, 7C</td><td>4</td><td></td><td>KREL</td><td>009</td><td>Vertretung</td></tr><tr class="alt"><td>7C</td><td>1</td><td></td><td>CH</td><td></td><td>Ausfall</td></tr><tr class="def"><td>7M+</td><td>5</td><td></td><td>D</td><td>010</td><td>Vertretung</td></tr><tr class="alt"><td>7M+</td><td>6</td><td></td><td>D</td><td></td><td>Ausfall</td></tr><tr class="def"><td>8B</td><td>3</td><td>Geo</td><td>CH</td><td>010</td><td>Vertretung</td></tr><tr class="alt"><td>9B</td><td>2</td><td>EWG</td><td>M</td><td>206</td><td>Vertretung</td></tr><tr class="def"><td>9B</td><td>3</td><td>G</td><td>M</td><td>206</td><td>Vertretung</td></tr><tr class="alt"><td>9B, 9C</td><td>8-9</td><td></td><td>TE</td><td></td><td>Ausfall</td></tr><tr class="def"><td>9B, 9C</td><td>10</td><td></td><td>TE</td><td></td><td>Ausfall</td></tr></table></body></html>
                      
                      a200 1 Reply Last reply Reply Quote 0
                      • a200
                        a200 @Brunoz last edited by

                        @Brunoz sagte in DSB - Abrage:

                        hier die neue Version von Skript 2. Bei einer Änderungen der Datenpunkte:

                        • javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.Timetable
                        • javascript.0.VIS.DSBMmobile-tmp.Kind2.heute.Timetable
                        • javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.Timetable
                        • javascript.0.VIS.DSBMmobile-tmp.Kind2.morgen.Timetable

                        werden beide Klassen gesucht und in den entsprechenden Datenpunkt .vis geschrieben. Da deine Kinder auf der gleichen Schule sind, kannst du das Kind2 ignorieren und nur die DP

                        • javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis
                        • javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis

                        ausgeben. Dort werden jeweils beide Klassen aufgeführt (falls vorganden!). Da die Skripte auf Änderungen in den Datenpunkten reagieren, kannst du zum Testen den Inhalte des Datenpunktes javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.Timetable löschen und Enter drücken. Nach der nächsten Abfrage wird der DP wieder gefüllt und der Filter (Skript 2) sollte die gesuchten Klassen ausgeben.

                        var klasse = ["7A","9C"];
                        var myArrayA;
                        var myArrayB;
                        var mystra;
                        var bid;
                        var kid
                        
                        const TT = $('state[state.id=javascript.0.VIS.DSBMmobile-tmp.Kind*.Timetable]').each(function(id) {
                             on({id: id, change: "ne"}, function (obj) {
                                 
                                kid = id.replace("javascript.0.VIS.DSBMmobile-tmp.Kind", "").charAt(0);
                        
                                myArrayA = [];
                                myArrayB = [];
                        
                                mystra = getState(id).val;
                                mystra = mystra.replace(/<table/gi, "\n<table");
                                mystra = mystra.replace(/<tr/gi, "\n<tr");
                                mystra = mystra.replace(/<\/body>/gi, "\n<\/body>");
                                mystra = mystra.replace(/<\/table/gi, "\n<\/table");
                                myArrayA = mystra.split("\n");
                        
                                myArrayA.forEach(function (element) {
                                    if(element.startsWith("<table") || element.startsWith("<tr") || element.startsWith("<\/table")) {
                                        myArrayB.push(element);
                                    }
                                });
                        
                                myArrayA = [];
                                scharf = true;
                                myArrayB.forEach(function (element) {
                                    if(element.startsWith("<tr class=\"head\">")) {
                                        scharf = false;
                                        myArrayA.push(element);
                                    } else {
                                        if(scharf || element.includes(klasse[0]) || element.includes(klasse[1]) || element.includes("<\/table") ) myArrayA.push(element);
                                    }
                                });
                           
                                mystra = "";
                                myArrayA.forEach(function (element) {
                                    mystra += element + "\n";
                                });
                        
                                bid = id.replace(/\.Timetable/gi, "\.vis");
                                setState(bid, mystra);
                             });
                        });
                         
                        

                        1 Reply Last reply Reply Quote 0
                        • B
                          Brunoz last edited by

                          Hallo a200,

                          funktioniert bisher super! Nur ist mir eines noch im nachhinein aufgefallen.

                          Am zweiten Tag - fehlt das Datum!

                          1. Tag
                            Anmerkung 2019-03-14 110226.jpg

                          2. Tag
                            Anmerkung 2019-03-14 110248.jpg

                          a200 2 Replies Last reply Reply Quote 0
                          • a200
                            a200 @Brunoz last edited by a200

                            @Brunoz Ich werde es am Abend prüfen.

                            1 Reply Last reply Reply Quote 0
                            • a200
                              a200 @Brunoz last edited by

                              @Brunoz

                              ich kann das Problem nicht nachstellen. Beide Stundenpläne werden von dem gleichen Skript bearbeitet und sollten gleiche Ergebnisse liefern.

                              1. Bitte prüfe ob das Problem immer noch besteht.
                              2. Prüfe ob du im VIS die richtigen Datenpunkte ausgibst.
                              3. Prüfe ob alte Skripte nicht aktiv sind.
                              4. Sollte das alles der Fall sein, dann stelle mir beide Stundenpläne (heute + morgen) zur Verfügung. Ich habe deinen Stundenplan in beide Datenpunkte kopiert und bekam in ...heute.vis und ...morgen.vis identische Ausgabe.
                              1 Reply Last reply Reply Quote 0
                              • B
                                Brunoz last edited by

                                Hallo a200,

                                zu 1. - ja, leider immer noch. Jetzt fehlt die Tagesanzeige an beiden Tagen.

                                zu 2. - siehe Foto

                                zu2.jpg

                                zu 3. - folge Scripte laufen:

                                 var klasse = ["7A","5C"];
                                
                                var myArrayA;
                                
                                var myArrayB;
                                
                                var mystra;
                                
                                var bid;
                                
                                var kid
                                
                                 
                                
                                const TT = $('state[state.id=javascript.0.VIS.DSBMmobile-tmp.Kind*.Timetable]').each(function(id) {
                                
                                     on({id: id, change: "ne"}, function (obj) {
                                
                                         
                                
                                        kid = id.replace("javascript.0.VIS.DSBMmobile-tmp.Kind", "").charAt(0);
                                
                                 
                                
                                        myArrayA = [];
                                
                                        myArrayB = [];
                                
                                 
                                
                                        mystra = getState(id).val;
                                
                                        mystra = mystra.replace(/<table/gi, "\n<table");
                                
                                        mystra = mystra.replace(/<tr/gi, "\n<tr");
                                
                                        mystra = mystra.replace(/<\/body>/gi, "\n<\/body>");
                                
                                        mystra = mystra.replace(/<\/table/gi, "\n<\/table");
                                
                                        myArrayA = mystra.split("\n");
                                
                                 
                                
                                        myArrayA.forEach(function (element) {
                                
                                            if(element.startsWith("<table") || element.startsWith("<tr") || element.startsWith("<\/table")) {
                                
                                                myArrayB.push(element);
                                
                                            }
                                
                                        });
                                
                                 
                                
                                        myArrayA = [];
                                
                                        scharf = true;
                                
                                        myArrayB.forEach(function (element) {
                                
                                            if(element.startsWith("<tr class=\"head\">")) {
                                
                                                scharf = false;
                                
                                                myArrayA.push(element);
                                
                                            } else {
                                
                                                if(scharf || element.includes(klasse[0]) || element.includes(klasse[1]) || element.includes("<\/table") ) myArrayA.push(element);
                                
                                            }
                                
                                        });
                                
                                   
                                
                                        mystra = "";
                                
                                        myArrayA.forEach(function (element) {
                                
                                            mystra += element + "\n";
                                
                                        });
                                
                                 
                                
                                        bid = id.replace(/\.Timetable/gi, "\.vis");
                                
                                        setState(bid, mystra);
                                
                                     });
                                
                                });
                                
                                 
                                
                                var cron1 = "14,29,44,59 * * * *";  // Alle 15 Min
                                
                                var cron2 = "13,28,43,58 * * * *";  // Alle 15 Min
                                
                                var cron3 = "3,8,13,18,23,28,33,38,43,48,53,58 7 * * *"; 		// von 7:00 - 7:58 Alle 5 Min
                                
                                var cron4 = "4,9,14,19,24,29,34,39,44,49,54,59 6,7 * * *";		// von 6:00 - 7:59 Alle 5 Min
                                
                                 
                                
                                var BaseUrl = "https://iphone.dsbcontrol.de/iPhoneService.svc/DSB";
                                
                                var UserName = ["xxxxxx", "xxxxxx];
                                
                                var Passwort = ["abc", "abc"];
                                
                                var KindTT = ["javascript.0.VIS.DSBMmobile-tmp.Kind1", "javascript.0.VIS.DSBMmobile-tmp.Kind2"];
                                
                                var Tage = ["heute", "morgen"];
                                
                                var debug = true;
                                
                                 
                                
                                var Loginreq;
                                
                                var MyToken;
                                
                                var ausgabe;
                                
                                var retArr = [];
                                
                                var tmpArr = [];
                                
                                var scharf;
                                
                                var inhalt;
                                
                                var anzahl;
                                
                                var TTreq;
                                
                                 
                                
                                for( var i = 0; i<KindTT.length; i++) {
                                
                                    Tage.forEach(function(element) {
                                
                                        if (!getObject(KindTT[i] + "." + element + ".Timetable")) {
                                
                                            createState(KindTT[i] + "." + element + ".Timetable", "", {
                                
                                                "desc": "TimeTable",
                                
                                                "name": "TimeTable fuer Kind " + i,
                                
                                                "type": "string",
                                
                                                "role": "html"
                                
                                            });
                                
                                        }
                                
                                        if (!getObject(KindTT[i] + "." + element + ".vis")) {
                                
                                            createState(KindTT[i] + "." + element + ".vis", "", {
                                
                                                "desc": "TimeTable",
                                
                                                "name": "TimeTable fuer Kind " + i,
                                
                                                "type": "string",
                                
                                                "role": "html"
                                
                                            });
                                
                                        }
                                
                                        if (!getObject(KindTT[i] + "." + element + ".Events")) {
                                
                                            createState(KindTT[i] + "." + element + ".Events", 0, {
                                
                                                "desc": "TimeTable",
                                
                                                "name": "TimeTable fuer Kind " + i,
                                
                                                "type": "number",
                                
                                            });
                                
                                        }
                                
                                        if (!getObject(KindTT[i] + "." + element + ".Time")) {
                                
                                            createState(KindTT[i] + "." + element + ".Time", "", {
                                
                                                "desc": "TimeTable",
                                
                                                "name": "TimeTable fuer Kind " + i,
                                
                                                "type": "string",
                                
                                                "role": "html"
                                
                                            });
                                
                                        }
                                
                                    });
                                
                                }
                                
                                 
                                
                                var request = require('request');
                                
                                 
                                
                                var ttype = [];
                                
                                var url2 = [];
                                
                                var Tage2 = [];
                                
                                var k, eintraege;
                                
                                 
                                
                                Tage2 = [].concat(Tage);
                                
                                 
                                
                                function getData(Kind) {
                                
                                    request(url2[k], function (error, response, body) {
                                
                                        if(debug) log("Error 3: " + error + "\nCode 3: " + response.statusCode);
                                
                                    	if (!error && response.statusCode == 200) {
                                
                                    	    if(debug) log("Schreibe nach: " + KindTT[Kind] + "." + Tage2[0] + ".Timetable");
                                
                                    	    setState(KindTT[Kind] + "." + Tage2[0] + ".Timetable", body, true, function() {
                                
                                    			//CreateVP(Kind);
                                
                                     		});    
                                
                                     	}
                                
                                     	Tage2.shift();
                                
                                         k++;
                                
                                         if(k < eintraege) getData(Kind);
                                
                                    });
                                
                                 }
                                
                                  
                                
                                 function GetTT(Kind) {
                                
                                     url2=[];
                                
                                     ttype=[];
                                
                                 	Loginreq = BaseUrl + "/authid/" + UserName[Kind] + "/" + Passwort[Kind];
                                
                                 	request(Loginreq, function (error, response, body) {
                                
                                 		if(debug) log("Error 1: " + error + "\nCode 1: " + response.statusCode);
                                
                                 		if (!error && response.statusCode == 200) {
                                
                                 			TTreq = BaseUrl + "/timetables/" + body.replace(/\"/g, "");
                                
                                 			request(TTreq, function (error, response, body) {
                                
                                 				if(debug) log("Error 2: " + error + "\nCode 2: " + response.statusCode);
                                
                                 				if (!error && response.statusCode == 200) {
                                
                                 					body = JSON.parse(body);
                                
                                 					eintraege = body.length;
                                
                                 					for(var i=0; i<eintraege; i++) {
                                
                                 					    ttype.push(body[i].ishtml);
                                
                                 					    url2.push(body[i].timetableurl);
                                
                                 					    setState(KindTT[Kind] + "." + Tage[i] + ".Time", body[0].timetabledate);
                                
                                 					}
                                
                                 					log(JSON.stringify(body, null, 4));
                                
                                 					k = 0;
                                
                                 					getData(Kind);
                                
                                 				}
                                
                                 			});
                                
                                 		}
                                
                                 	});
                                
                                 }
                                
                                  
                                
                                schedule(cron1, function () { 	// Kind 1 - Abruf alle 15Min
                                
                                    GetTT(0);
                                
                                });
                                
                                schedule(cron3, function () { 	// Kind 1 - von 7:00 - 7:58 Alle 5 Min
                                
                                    GetTT(0);
                                
                                });
                                
                                 
                                
                                schedule(cron2, function () {	// Kind 2 - Abruf alle 15Min
                                
                                    GetTT(1);
                                
                                });
                                
                                 
                                
                                schedule(cron4, function () {	// Kind 2 - von 6:00 - 7:59 Alle 5 Min
                                
                                    GetTT(1);
                                
                                });
                                
                                
                                 
                                

                                zu 4.

                                Heute (timetable)

                                <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>  <head>    <title>HeinekingMedia Vertretungsplan - Classic</title>    <style type="text/css">      html, body { font-family:  Arial; }      .head { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .TeacherHead { background-color: #FFFFFF; color: #000000; font-weight: normal; }      .TeacherHead td { border-top: 2px solid #000000; border-bottom: 1px solid #000000; }      .SubTypeHead { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .def { background-color: #dedede; color: #000000; }      .alt { background-color: #b1f073; color: #000000; }      .new.def { background-color: #FFE97F; color: #000000; }      .new.alt { background-color: #FF75EC; color: #000000; }      table { width: 100%; margin-top: 5px; background-color: black; }      td { padding-left: 4px; padding-right: 4px; }      .additionInfoTable { width: 100%; border: 1px solid black; padding: 0; margin: 0; }      .additionInfoTable th { background: #000000; color: #FFFFFF; font-weight: bold; }      .additionInfoTable td { background: white; color: black; border-bottom: 0px solid black; font-weight: normal; }      .headTable { background: white; width: 100%; border: 0px; padding: 0; margin: 0; }      .headTable td { background: white; color: black; font-weight: bold; text-align: right; border: 0;}      h2 { font-size: 0.8em; margin:0; text-align: right; }      h1 { font-size: 2em;margin-bottom:5px; }      td.teacherNew { font-weight: bold; }      td.teacherOld { opacity: .40; filter: alpha(opacity = 40); -ms-filter: "alpha(opacity = 40)" }      span.hilite { font-weight: bold; text-decoration:underline; }      .NoSubstitutes { text-align: center; border: 0; }    </style>    <link rel="stylesheet" type="text/css" href="a6b426b1-76c0-4330-b4e1-ce564b4c8e44.css">    <script language="javascript">    </script>  </head>  <body>    <table class="headTable">    <tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr>    </table><center><h1>18.03.2019, Montag</h1></center><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5A, 5B, 5C, 5D, 6B, 8D, 9A, 10A, 10C</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr><tr class="def"><td>5A, 5B, 5C, 5D</td><td>1-2</td><td></td><td>NSW</td><td>TH2</td><td>Vertretung</td></tr><tr class="alt"><td>6B</td><td>4</td><td>M</td><td>M</td><td>127</td><td>Vertretung</td></tr><tr class="def"><td>8D</td><td>4-5</td><td></td><td>AES</td><td></td><td>Ausfall</td></tr><tr class="alt"><td>8D</td><td>6</td><td></td><td>AES</td><td></td><td>Ausfall</td></tr><tr class="def"><td>9A</td><td>3</td><td>M</td><td>M</td><td>203</td><td>Vertretung</td></tr><tr class="alt"><td>9A</td><td>5</td><td></td><td>G</td><td>203</td><td>Vertretung</td></tr><tr class="def"><td>9A</td><td>6</td><td></td><td>BIO</td><td></td><td>Ausfall</td></tr><tr class="alt"><td>10A</td><td>2</td><td>BIO</td><td>BIO</td><td>220</td><td>Vertretung</td></tr><tr class="def"><td>10C</td><td>1</td><td>BIO</td><td>BIO</td><td>220</td><td>Vertretung</td></tr></table></body></html>
                                
                                

                                VIS

                                <table class="headTable"><tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr></table><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5A, 5B, 5C, 5D, 6B, 8D, 9A, 10A, 10C</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr><tr class="def"><td>5A, 5B, 5C, 5D</td><td>1-2</td><td></td><td>NSW</td><td>TH2</td><td>Vertretung</td></tr></table>
                                

                                Morgen (timetable)

                                <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>  <head>    <title>HeinekingMedia Vertretungsplan - Classic</title>    <style type="text/css">      html, body { font-family:  Arial; }      .head { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .TeacherHead { background-color: #FFFFFF; color: #000000; font-weight: normal; }      .TeacherHead td { border-top: 2px solid #000000; border-bottom: 1px solid #000000; }      .SubTypeHead { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .def { background-color: #dedede; color: #000000; }      .alt { background-color: #b1f073; color: #000000; }      .new.def { background-color: #FFE97F; color: #000000; }      .new.alt { background-color: #FF75EC; color: #000000; }      table { width: 100%; margin-top: 5px; background-color: black; }      td { padding-left: 4px; padding-right: 4px; }      .additionInfoTable { width: 100%; border: 1px solid black; padding: 0; margin: 0; }      .additionInfoTable th { background: #000000; color: #FFFFFF; font-weight: bold; }      .additionInfoTable td { background: white; color: black; border-bottom: 0px solid black; font-weight: normal; }      .headTable { background: white; width: 100%; border: 0px; padding: 0; margin: 0; }      .headTable td { background: white; color: black; font-weight: bold; text-align: right; border: 0;}      h2 { font-size: 0.8em; margin:0; text-align: right; }      h1 { font-size: 2em;margin-bottom:5px; }      td.teacherNew { font-weight: bold; }      td.teacherOld { opacity: .40; filter: alpha(opacity = 40); -ms-filter: "alpha(opacity = 40)" }      span.hilite { font-weight: bold; text-decoration:underline; }      .NoSubstitutes { text-align: center; border: 0; }    </style>    <link rel="stylesheet" type="text/css" href="8f1de2b3-789f-487d-bf0d-8af71b991eda.css">    <script language="javascript">    </script>  </head>  <body>    <table class="headTable">    <tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr>    </table><center><h1>19.03.2019, Dienstag</h1></center><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5D, 10A, 10B, 10C, 10D</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr><tr class="def"><td>5D</td><td>8-9</td><td></td><td>BNT</td><td>220</td><td>Vertretung</td></tr><tr class="alt"><td>5D</td><td>10</td><td></td><td>LQ</td><td></td><td>Ausfall</td></tr><tr class="def"><td>10A, 10B, 10C, 10D</td><td>7</td><td></td><td>M-Plus</td><td>107</td><td>Vertretung</td></tr></table></body></html>
                                

                                VIS

                                <table class="headTable"><tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr></table><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5D, 10A, 10B, 10C, 10D</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr></table>
                                
                                a200 1 Reply Last reply Reply Quote 0
                                • a200
                                  a200 @Brunoz last edited by

                                  @Brunoz

                                  zu 2. Hier sieht man nur den Aufruf von heute (Schultag). Hast du in der "Morgen" Ansicht (Folgender Schultag) den Aufruf von morgen? Also
                                  {javascript.0.VIS.DSBMmobile-tmp.Kind1.heute.vis} und
                                  {javascript.0.VIS.DSBMmobile-tmp.Kind1.morgen.vis}
                                  ?

                                  1 Reply Last reply Reply Quote 0
                                  • B
                                    Brunoz last edited by

                                    Hallo a200,

                                    der zweite Tag ist auf einer anderen View.

                                    zu2.jpg

                                    a200 1 Reply Last reply Reply Quote 0
                                    • a200
                                      a200 @Brunoz last edited by

                                      @Brunoz komisch! Wenn ich deinen html-Code (Heute timetable) bei mir in TimeTable kopiere:

                                      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>  <head>    <title>HeinekingMedia Vertretungsplan - Classic</title>    <style type="text/css">      html, body { font-family:  Arial; }      .head { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .TeacherHead { background-color: #FFFFFF; color: #000000; font-weight: normal; }      .TeacherHead td { border-top: 2px solid #000000; border-bottom: 1px solid #000000; }      .SubTypeHead { background-color: #000000; color: #FFFFFF; font-weight: bold; }      .def { background-color: #dedede; color: #000000; }      .alt { background-color: #b1f073; color: #000000; }      .new.def { background-color: #FFE97F; color: #000000; }      .new.alt { background-color: #FF75EC; color: #000000; }      table { width: 100%; margin-top: 5px; background-color: black; }      td { padding-left: 4px; padding-right: 4px; }      .additionInfoTable { width: 100%; border: 1px solid black; padding: 0; margin: 0; }      .additionInfoTable th { background: #000000; color: #FFFFFF; font-weight: bold; }      .additionInfoTable td { background: white; color: black; border-bottom: 0px solid black; font-weight: normal; }      .headTable { background: white; width: 100%; border: 0px; padding: 0; margin: 0; }      .headTable td { background: white; color: black; font-weight: bold; text-align: right; border: 0;}      h2 { font-size: 0.8em; margin:0; text-align: right; }      h1 { font-size: 2em;margin-bottom:5px; }      td.teacherNew { font-weight: bold; }      td.teacherOld { opacity: .40; filter: alpha(opacity = 40); -ms-filter: "alpha(opacity = 40)" }      span.hilite { font-weight: bold; text-decoration:underline; }      .NoSubstitutes { text-align: center; border: 0; }    </style>    <link rel="stylesheet" type="text/css" href="a6b426b1-76c0-4330-b4e1-ce564b4c8e44.css">    <script language="javascript">    </script>  </head>  <body>    <table class="headTable">    <tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr>    </table><center><h1>18.03.2019, Montag</h1></center><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5A, 5B, 5C, 5D, 6B, 8D, 9A, 10A, 10C</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr><tr class="def"><td>5A, 5B, 5C, 5D</td><td>1-2</td><td></td><td>NSW</td><td>TH2</td><td>Vertretung</td></tr><tr class="alt"><td>6B</td><td>4</td><td>M</td><td>M</td><td>127</td><td>Vertretung</td></tr><tr class="def"><td>8D</td><td>4-5</td><td></td><td>AES</td><td></td><td>Ausfall</td></tr><tr class="alt"><td>8D</td><td>6</td><td></td><td>AES</td><td></td><td>Ausfall</td></tr><tr class="def"><td>9A</td><td>3</td><td>M</td><td>M</td><td>203</td><td>Vertretung</td></tr><tr class="alt"><td>9A</td><td>5</td><td></td><td>G</td><td>203</td><td>Vertretung</td></tr><tr class="def"><td>9A</td><td>6</td><td></td><td>BIO</td><td></td><td>Ausfall</td></tr><tr class="alt"><td>10A</td><td>2</td><td>BIO</td><td>BIO</td><td>220</td><td>Vertretung</td></tr><tr class="def"><td>10C</td><td>1</td><td>BIO</td><td>BIO</td><td>220</td><td>Vertretung</td></tr></table></body></html>
                                      

                                      dann kommt in heute vis Folgendes raus:

                                      <table class="headTable">    <tr><td>Letzte Änderung: 17.03.2019 01:05</td></tr>    </table><center><h1>18.03.2019, Montag</h1></center><table class="additionInfoTable"><tr><th colspan="2">Nachrichten zum Tag</th></tr><tr><td>Betroffene Klassen</td><td>5A, 5B, 5C, 5D, 6B, 8D, 9A, 10A, 10C</td></tr></table><table cellspacing="1"><tr class="head"><td>Klasse</td><td>Stunde</td><td>Fach</td><td>Fach alt</td><td>Raum</td><td>Art</td></tr></table>
                                      

                                      und wie man sieht steht dort: 18.03.2019, Montag

                                      und so sieht es bei mir aus:
                                      0001.PNG

                                      Deshalb wundere ich mich, wieso der Filter bei dir was anderes ausgibt, als bei mir!

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

                                        @a200 Welche JavaScript Version benutzt du und welches Betriebssystem nutzt du für IoBroker?

                                        1 Reply Last reply Reply Quote 0
                                        • B
                                          Brunoz last edited by Brunoz

                                          Info.jpg

                                          In der Zwischenzeit habe ich aber den Iobroker geupdatet.

                                          Hier noch ein Log vom Script:

                                          18.3.2019, 08:42:38.435 [info ]: javascript.0 Stop script script.js.common.Schule.Vertretungsplan
                                          18.3.2019, 08:42:38.554 [info ]: javascript.0 Start javascript script.js.common.Schule.Vertretungsplan
                                          18.3.2019, 08:42:38.556 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: registered 0 subscriptions and 4 schedules
                                          18.3.2019, 08:43:00.423 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 1: null
                                          Code 1: 200
                                          18.3.2019, 08:43:00.697 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 2: null
                                          Code 2: 200
                                          18.3.2019, 08:43:00.698 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: [
                                          {
                                          "ishtml": true,
                                          "timetabledate": "18.03.2019 08:30",
                                          "timetablegroupname": "Pläne",
                                          "timetabletitle": "Schüler Mobile heute",
                                          "timetableurl": "https://light.dsbcontrol.de/DSBlightWebsite/Data/09a0d92a-cff0-44f4-81de-fc84623d6395/a6b426b1-76c0-4330-b4e1-ce564b4c8e44/a6b426b1-76c0-4330-b4e1-ce564b4c8e44.html"
                                          },
                                          {
                                          "ishtml": true,
                                          "timetabledate": "18.03.2019 08:30",
                                          "timetablegroupname": "Pläne",
                                          "timetabletitle": "Schüler Mobile morgen",
                                          "timetableurl": "https://light.dsbcontrol.de/DSBlightWebsite/Data/09a0d92a-cff0-44f4-81de-fc84623d6395/8f1de2b3-789f-487d-bf0d-8af71b991eda/8f1de2b3-789f-487d-bf0d-8af71b991eda.html"
                                          }
                                          ]
                                          18.3.2019, 08:43:00.921 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 3: null
                                          Code 3: 200
                                          18.3.2019, 08:43:00.923 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Schreibe nach: javascript.0.VIS.DSBMmobile-tmp.Kind2.heute.Timetable
                                          18.3.2019, 08:43:01.044 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 3: null
                                          Code 3: 200
                                          18.3.2019, 08:43:01.045 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Schreibe nach: javascript.0.VIS.DSBMmobile-tmp.Kind2.morgen.Timetable
                                          18.3.2019, 08:44:00.355 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 1: null
                                          Code 1: 200
                                          18.3.2019, 08:44:00.592 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 2: null
                                          Code 2: 200
                                          18.3.2019, 08:44:00.594 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: [
                                          {
                                          "ishtml": true,
                                          "timetabledate": "18.03.2019 08:30",
                                          "timetablegroupname": "Pläne",
                                          "timetabletitle": "Schüler Mobile heute",
                                          "timetableurl": "https://light.dsbcontrol.de/DSBlightWebsite/Data/09a0d92a-cff0-44f4-81de-fc84623d6395/a6b426b1-76c0-4330-b4e1-ce564b4c8e44/a6b426b1-76c0-4330-b4e1-ce564b4c8e44.html"
                                          },
                                          {
                                          "ishtml": true,
                                          "timetabledate": "18.03.2019 08:30",
                                          "timetablegroupname": "Pläne",
                                          "timetabletitle": "Schüler Mobile morgen",
                                          "timetableurl": "https://light.dsbcontrol.de/DSBlightWebsite/Data/09a0d92a-cff0-44f4-81de-fc84623d6395/8f1de2b3-789f-487d-bf0d-8af71b991eda/8f1de2b3-789f-487d-bf0d-8af71b991eda.html"
                                          }
                                          ]
                                          18.3.2019, 08:44:00.802 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 3: null
                                          Code 3: 200
                                          18.3.2019, 08:44:00.807 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Schreibe nach: javascript.0.VIS.DSBMmobile-tmp.Kind1.undefined.Timetable
                                          18.3.2019, 08:44:00.808 [warn ]: javascript.0 at Request._callback (script.js.common.Schule.Vertretungsplan:145:10)
                                          18.3.2019, 08:44:00.929 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Error 3: null
                                          Code 3: 200
                                          18.3.2019, 08:44:00.931 [info ]: javascript.0 script.js.common.Schule.Vertretungsplan: Schreibe nach: javascript.0.VIS.DSBMmobile-tmp.Kind1.undefined.Timetable
                                          18.3.2019, 08:44:00.932 [warn ]: javascript.0 at Request._callback (script.js.common.Schule.Vertretungsplan:145:10)

                                          1 Reply Last reply Reply Quote 0
                                          • D
                                            dtp last edited by dtp

                                            Hi,

                                            hab mal versucht, die beiden Skripte zum Laufen zu bringen. Kann es sein, dass der Link "https://iphone.dsbcontrol.de/iPhoneService.svc/DSB/authid/<username>/<password>" nicht mehr funktioniert?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript
                                            7
                                            36
                                            2612
                                            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