Projekt

Allgemein

Profil

Fehler #1206 » logic.js

Avishan Sharafi, 24.05.2025 15:52

 
1
 /**
2
 * Prevent automatic scrolling of page to anchor by browser after loading of page.
3
 * Do not call this function in $(...) or $(window).on('load', ...),
4
 * it should be called earlier, as soon as possible.
5
 */
6
function preventAnchorScroll () {
7
    var scrollToTop = function () {
8
        $(window).scrollTop(0);
9
    };
10
    if (window.location.hash) {
11
        // handler is executed at most once
12
        $(window).one('scroll', scrollToTop);
13
    }
14

    
15
    // make sure to release scroll 1 second after document readiness
16
    // to avoid negative UX
17
    $(function () {
18
        setTimeout(
19
            function () {
20
                $(window).off('scroll', scrollToTop);
21
            },
22
            500
23
        );
24
    });
25
}
26
preventAnchorScroll();
27

    
28
// frühzeitiges Springen zum target (Scrollen) verhindern
29
	var scrolltarget = window.location.hash,
30
	scrolltarget = scrolltarget.replace('#', '');
31
	location.hash = ""; 
32
	history.pushState("", document.title, window.location.pathname + window.location.search);
33

    
34
 
35
 
36
$(document).ready(function() {
37
    var bereiche = $("div[id^='bereich']");
38
		
39
		
40
		//Cheat fuer PDF-Erzeugung
41
        $(document).on('click', "h2", function(e) { 
42
            if (window.location.href.indexOf("file://")==0) {
43
                $(".loesung_zeigen").each(function(){
44
                    $(this).next().fadeOut(2000);
45
                    $(this).fadeIn(2000);
46
                })
47
                
48
                $("body").css("margin", "10px");
49
                $("#mycontent").css("margin", "1em");
50
                
51
            }
52
        });
53
    
54
         if (window.location.href.indexOf("file://")==0) {
55
                $(".loesung_zeigen").each(function(){
56
                    $(this).next().fadeIn(0);
57
                    $(this).fadeOut(0);
58
                })
59
                
60
                $("body").css("margin", "10px");
61
                $("#mycontent").css("margin", "1em");
62
                
63
            }
64
        
65
        /*
66
         * 
67
         * TODO:
68
         * 
69
         * Nach oben Scrollen nach Seitenwechsel
70
         * überlegen, ob Seitenlänge nach unten hin begrenzt wird
71
         * 
72
         * - Seitenzahlen in einem Bereich anzeigen, um Orientierung zu erleichtern?
73
         * 
74
         * 
75
         * 
76
         * */
77
       xcontent_position = Array();
78
       // Prevent crash if bereiche is not defined elsewhere
79
       if (typeof bereiche === "undefined") {
80
         var bereiche = [];
81
     }
82
       
83
       for (var i = 0; i < bereiche.length; i++) {
84
           xcontent_position["xcontent" + parseInt(i)] = 0;
85
       }
86
       
87
       current_xcontent = $("div[xcontent='xcontent']").attr("class");
88
       
89
       /** Init-Funktion **/
90
       xcontent_position[current_xcontent] = 0;
91
       
92
       button_next_deaktiviert = false;
93
       button_prev_deaktiviert = false;
94
       fading = false;
95
       
96
       first = true;
97
       $("body").find("div[xcontent='xcontent']").each(function(index){
98
            if (!first) {
99
                $(this).hide();
100
            }
101
            first = false;
102
       });
103
       
104
        //Aktuelle Position im Inhalt holen
105
       moodle_course_id = getGETParameter("id")
106
       if (moodle_course_id!=-1) {
107
        xcontent_position[current_xcontent] = parseInt(retrieve(moodle_course_id + "_" + current_xcontent));
108
        //console.log("retrieve: " + xcontent_position[current_xcontent])
109
        if (isNaN(xcontent_position[current_xcontent])) {//Wenn keine valide Position gespeichert wurde
110
            xcontent_position[current_xcontent] = 0;
111
        }
112
        
113
        //zurück-Button aktivieren, wenn nicht im ersten Bereich
114
        if (xcontent_position[current_xcontent]>0) {
115
            $("#button_prev").removeClass("grey");//Aktivieren
116
        } 
117
        
118
        //Probleme beim Laden vermeiden
119
        if (xcontent_position[current_xcontent] > get_current_max_subposition()) {
120
            xcontent_position[current_xcontent] = get_current_max_subposition();
121
        } else if (xcontent_position[current_xcontent]<0) {
122
            xcontent_position[current_xcontent] = 0;
123
        }
124
       }
125
       
126
       //Geöffnete Abschnitte wieder laden
127
       var tmp_position = xcontent_position[current_xcontent];
128
       //console.log("tmp pos: " + tmp_position);
129
       for (var i=0; i < tmp_position; i++) {
130
           //console.log("iterate");
131
           append_next_to_content();
132
       }
133
       
134
       xcontent_position[current_xcontent] = tmp_position;
135
       //console.log("tmp pos: " + tmp_position);
136
       
137
       
138
       $("#step_current").html(xcontent_position[current_xcontent]+1);
139
       $("#steps_total").html(get_current_max_subposition()+1);
140
       
141
       if(get_current_max_subposition() == 0) {//Navigation verbergen, wenn es nichts zu navigieren gibt
142
           $("#buttons").hide();
143
           $("#seitenanzeige").hide();
144
       }
145
       
146
       /****/
147
       
148
       //console.log("step here");
149
       //control_next_prev_buttons();//Buttons richtig einstellen
150
       //console.log("step");
151
       //load_example_exercise();
152
//        activate_input_tooltips ();
153
        //console.log("step");
154
        control_next_prev_buttons();
155
        $(document).on('click', "#example_exercise", function(e) {
156
            load_example_exercise();
157
        });
158
        
159

    
160
        
161
        
162
        
163
        $(document).on('click', "#button_next", function(e) {
164
             if ($(this).hasClass("grey")) return;//Nichts tun, wenn deaktiviert
165
            //load_content(current_xcontent + "_" + (get_current_subposition()+1))
166
            if(button_next_deaktiviert) return;//Fehlfunktion bei "wildem" Klicken vermeiden
167
            button_next_deaktiviert = true;           
168
            //console.log("next deaktiviert");
169
            append_next_to_content();
170
            button_next_deaktiviert = false;
171
            //console.log("next aktiv");
172
        });
173
        
174
         $(document).on('click', "#button_prev", function(e) {
175
            if ($(this).hasClass("grey")) return;//Nichts tun, wenn deaktiviert
176
            //load_content(current_xcontent + "_" + parseInt((get_current_subposition()-1)));
177
            if(button_prev_deaktiviert) {
178
                //console.log("deny prev");
179
                return;//Fehlfunktion bei "wildem" Klicken vermeiden
180
            }
181
            button_prev_deaktiviert = true;           
182
            //console.log("pref deaktiviert");
183
            remove_last_from_content();
184
            button_prev_deaktiviert = false;
185
            //console.log("prev aktiv");
186
        });
187

    
188
       $(document).on('click', ".bottom_link_example_exercise", function(e) {
189
           if (inMoodleCourse()) {
190
               setGetParameter("section", 0)
191
           }
192
        });
193
         
194
        
195
        $(document).on('click', ".bottom_link_math_content1", function(e) {
196
            if (inMoodleCourse()) {
197
                setGetParameter("section", 1)
198
           }
199
        });
200
        
201
        $(document).on('click', ".bottom_link_math_content2", function(e) {
202
            if (inMoodleCourse()) {
203
                setGetParameter("section", 2)
204
           }
205
        });
206
        
207
        $(document).on('click', ".bottom_link_math_content3", function(e) {
208
            if (inMoodleCourse()) {
209
                setGetParameter("section", 3)
210
           }
211
        });
212

    
213
        
214
        $(document).on('click', ".loesung_zeigen",function (e) {
215
                e.preventDefault();//Verhindert Sprung nach oben
216
                /*e.preventDefault();//Verhindert Sprung nach oben
217
                var loesung_index=$(".loesung_zeigen").index(this) + 1;
218

    
219
                var xcontent_parent = $(this);
220
                var i = 0;
221
                while (!xcontent_parent.attr("xcontent") && i < 20) {
222
                    xcontent_parent = xcontent_parent.parent("div");
223
                    i++;
224
                }
225
                //Welche Lösung gezeigt werden soll. NICHT zwangsläufig der lo_status Element Index!
226
                //Auch abhängig vom beinhaltenden xcontent
227
                var loesung_index = xcontent_parent.find(".loesung_zeigen").index(this) + 1;
228
                var xcontent_index = xcontent_parent.parent().children("div").index(xcontent_parent);
229
                
230
                //console.log(current_xcontent + "_" + xcontent_index + "_" + loesung_index + ".xml");
231
                $("#loesung").load(current_xcontent + "_" + xcontent_index + "_" + loesung_index + ".xml", function(){
232
                    //Nach dem Laden der Lösung MathJax neu rendern
233
                    $("#overlay").show();
234
                    $("#loesung").show();
235
                    MathJax.Hub.Queue(["Typeset", MathJax.Hub]); //MathJax nochmal rendern lassen
236
                });
237
                //210*0,8/2 = 84, da die Lösung 80% breit ist und das Menü ~210px
238
                $("#loesung").css({top: $(window).scrollTop()+40, left:  $(window).scrollLeft()+84}) 
239
                
240
                */
241
                //return false;
242
                
243
                /*
244
                 * Neuer Funktionalität für nicht dynamisch geladene Lösungen
245
                 */
246
                
247
                $(this).next().fadeIn(2000);
248
                $(this).fadeOut(2000);
249
                
250
                          //GGB initialisieren
251
                loesung = $(this);
252
                setTimeout(function(){
253
                    loesung.find(".ggb").each(function() {
254
                        var target_container = $(this).attr("id")
255
                        var applet = new GGBApplet('5.0', parameters[target_container.substring(3) + "_container"], ggb_views);
256
                        applet.inject(target_container, 'html5');
257
                    });
258
                }, 1);
259
               
260
                /*
261
                $(this).next().animate({
262
                    //display: 'inline',
263
                    height: '100%',
264
                    
265
                    }, 30000, function() {
266
                    // Animation complete.
267
                });*/
268
                    
269
        });
270
        
271
        $(".loesung_verbergen").on("click", function (e) {
272
            e.preventDefault();//Verhindert Sprung nach oben
273
                $(this).parent().prev().fadeIn(2000);
274
                $(this).parent().fadeOut(2000);
275
                
276
                /*
277
                
278
                $("#overlay").hide();
279
                $("#loesung").hide();           
280
                return false;
281
                */
282
        });
283
        
284
        
285
        //console.log("step last");
286
         
287

    
288
// qr-codes 
289
	// URL-Parameter auslesen zum Anzeigen von eigentlich versteckten QR-Codes im Aktivsystem
290
	const queryString = window.location.search;
291
	const urlParams = new URLSearchParams(queryString);
292
	
293
	
294
	// Jede Aufgabe, jeder Satz, usw. bekommt zwei kleine Bildchen neben die Überschrift "Satz 1" mit QR-Code und Text-Link
295
	$(document).find(".qrcode").each(function() {
296
		if (window.location.href.indexOf("file://")==0 || urlParams.has('activateqr')) { //QR-Code wird nur generiert, wenn Datei lokal angeschaut wird oder online der Parameter "activateqr" manuell eingegeben wird
297
				var target = "#" + $(this).attr("id");//speichert den id-Selector
298
			//Grafischer QR-Code
299
				$(this).empty;//Objekt komplett leeren
300
				$(this).qrcode({width: 256, height: 256, text: window.location.href + target});
301
				$($(this).parent()[0]).attr("href", $(this).find("canvas")[0].toDataURL("image/png"));
302
			// QR-Code bekommt id (z.B. "qrcode_aufgabe_1")	
303
				var idqr = "qrcode_" + $(this).find("canvas").parent().attr('id');
304
				$(this).find("canvas").attr('id', idqr);
305
			
306
			//Text-Link zum Kopieren
307
				text_link = $(' <a class="qrcode_link" href="' + (window.location.href + target) + '"><img src="" width="15" style="margin-left: .2em"/></a>');
308
				$(this).append(text_link);
309
		}
310
	});
311
			
312
			
313
		// Hilfsfunktion zum Download des QR-Codes als Bild
314
		function downloadqr(canvas, filename) {
315
		  // create an "off-screen" anchor tag
316
			var lnk = document.createElement('a'), e;
317
		  // set the download attribute of the a tag
318
			lnk.download = filename;
319
		  // convert canvas content to data-uri for link. When download attribute is set the content pointed to by link will be pushed as "download" in HTML5 capable browsers
320
			lnk.href = canvas.toDataURL("image/png;base64");
321
		  // create a "fake" click-event to trigger the download
322
			  if (document.createEvent) {
323
				e = document.createEvent("MouseEvents");
324
				e.initMouseEvent("click", true, true, window,
325
								 0, 0, 0, 0, 0, false, false, false,
326
								 false, 0, null);
327

    
328
				lnk.dispatchEvent(e);
329
			  } else if (lnk.fireEvent) {
330
				lnk.fireEvent("onclick");
331
			  }
332
		}
333
	
334
	// Bei Klick auf QR-Code wird dieser als Bild heruntergeladen (Name des Bilds ist z.B. "qrcode_aufgabe_1")
335
	$(document).on('click', ".qrcode canvas", function(e) {
336
		var idqr = $(this).attr('id');
337
		var kurzname = document.getElementsByClassName("kapitelnameqr").item(0).innerHTML;
338
		var	bildname = kurzname + $(this).attr('id') + ".png";
339
		var mycanvas = document.getElementById(idqr);
340
		downloadqr(mycanvas, bildname);
341
        });
342
		
343
	// Bei Klick auf den Textlink öffnet sich ein Fenster, das den Textlink samt Anker enthält
344
	$(document).on('click', ".qrcode_link", function(e) {
345
        e.preventDefault();//Normales Verhalten unterdrücken
346
        alert("Dieses Element ist unter dem folgenden Link zu erreichen:\n" + $(this).attr("href"));//Link wird im Dialogfenster gezeigt
347
    });
348

    
349
    $(document).on('click', ".ggb_starter", function(e) {
350
        jQuery(this).hide();
351
        eval(jQuery(this).next().find(".ggb_script").text());
352
        jQuery(this).next().show();
353
        
354
    });
355
       
356

    
357
// scrollen
358
	// animiertes Scrollen zum mitgegebenen Ziel-Element (id) mit vorgegebener Geschwindigkeit (geschw)
359
	function scrollto (id,geschw) {
360
		var hash = "#"+id;
361
		
362
		// weg bis id:
363
		var weg = $(hash).offset().top;
364
		
365
		//offset (Kopfzeilen...)
366
		var offset = 8;
367
		if ($("#page").length != 0) {
368
			offset += $("#page").offset().top;
369
		}
370
		else {
371
			offset += $("#mycontent").offset().top;
372
		}
373
		weg = weg - offset;
374
		
375
		// Scrollvorgang dauert max. 5 Sekunden
376
		var zeit=5000;
377
		if (weg*geschw <= 5000) {
378
			var zeit = weg*geschw
379
		}
380
		
381
		// Ausführen des Scrollens
382
		$('html, body').animate({scrollTop: weg}, zeit);
383
	};
384

    
385
    try {
386
        // Aufruf der scroll-Funktion
387
        MathJax.Hub.Queue(function () {
388
            // var scrolltarget schon vorher außerhalb der Funktion definiert
389
            var scrollgeschw = 0.4;
390
            
391
            if (scrolltarget !== "" && $("#"+scrolltarget).length != 0) {
392
                var idhidden = $("#"+scrolltarget).is(":hidden");
393
                var zaehler=0;
394
                // so lange weiter aufklappen, bis xcontent zur id sichtbar ist
395
                while (idhidden == true && zaehler <= 20){
396
                    append_next_to_content();									// Aufklappen des nächsten Abschnitts
397
                    window.scrollTo(0, 0);
398
                    
399
                    idhidden = $("#"+scrolltarget).is(":hidden")					// Sichtbarkeit mit neuem Bereich aktualisieren
400
                    
401
                    zaehler++;
402
                }
403
                
404
                setTimeout(
405
                    function () {
406
                        scrollto(scrolltarget,scrollgeschw); // runterscrollen
407
                    },
408
                    500
409
                );
410
            }
411
        });
412
    } catch (e) {
413
        //Es ist okay, wenn der MathJax Aufruf hier fehlschlägt, das passiert gerne beim Seitenaufruf. 
414
    }
415
	
416

    
417

    
418

    
419

    
420
// ggb download: Möglichkeiten zum sichtbar machen:
421
	$(document).find(".ggb_download").each(function() {
422
		if (window.location.href.indexOf("file://")==0 || urlParams.has('activateqr')) {
423
			$(this).parent().attr("style", "display:inline");
424
		}
425
	})
426

    
427

    
428

    
429

    
430

    
431
});
432

    
433

    
434
function remove_last_from_content() {
435
    if (fading) {
436
        //console.log("fade skip");
437
        return;
438
    }
439
    //xcontent_position[current_xcontent] = get_current_subposition()-1;
440
    xcontent_position[bereiche[get_current_position()][1]]--;
441
    $("#content_container").children(":first").children().each(function() {
442
        if ($(this).next().length == 0 || $(this).next().css("display") == "none") {
443
            fading = true;
444
            $(this).fadeOut(800, function() {
445
                fading = false;
446
                windows.scrollBy(0,-500);
447
            });
448
            return false;
449
        }
450
    });
451

    
452
    control_next_prev_buttons();
453
}
454

    
455
function append_next_to_content () {
456
    append_next_to_content(1);
457
}
458

    
459
function append_next_to_content (append_number) {
460
    if (append_number<=0) return;
461
    
462
    
463
    if (!inMoodleCourse()) {
464
        filename = current_xcontent + "_" + parseInt(get_current_subposition()+1);
465
//       console.log(filename);
466
        ////console.log("append: " + filename + ".xml")
467
        $("#content_loader").load("./" + filename + ".xml", function(a,b,c) {
468
            
469
            ////console.log(filename);
470
            if (b == "error") {
471
                //console.log("Fehler beim Nachladen des Inhalts");
472
                //Hinweistext, wie das Nachladen von Dateien aktiviert werden kannn, wenn das laden fehlschlägt
473
                //$("#content").html("Der Inhalt konnte nicht geladen werden. Ist JavaScript bei Ihnen deaktiviert?");
474
            }
475
            $("#content").append($("#content_loader").children(":first").clone());
476
            
477
//             $("div[xcontent='xcontent']").each(function(){
478
//             if ($(this).css("display")=="none") {
479
//                 $(this).show( 0, function() {
480
//                     //Manuelle Geogebra laden lassen
481
//                     $(this).find(".ggb").each(function() {
482
//                         var target_container = $(this).attr("id")
483
//                         var applet = new GGBApplet('4.4', parameters, ggb_views);
484
//                         applet.setHTML5CodebaseVersion('4.4');
485
//                         applet.setHTML5Codebase(geogebra_web, 'true');
486
//     
487
//                         applet.inject(target_container, 'html5');
488
//                     });
489
//                 });
490
            
491
            ////console.log("tt activated");
492
            activate_input_tooltips ();
493
            ////console.log("here");
494
            ////console.log(xcontent_position[current_xcontent]);
495
            xcontent_position[current_xcontent] = parseInt(filename.substr(filename.indexOf("_")+1, filename.length));
496
            ////console.log(xcontent_position[current_xcontent])
497
            ////console.log(current_xcontent + "\n " + filename +"\n" + xcontent_position[current_xcontent]);
498

    
499
            
500
            
501
            try {
502
                MathJax.Hub.Queue(["Typeset", MathJax.Hub]); //MathJax nochmal rendern lassen
503
            } catch (e) {
504
                console.log(e);
505
            }
506
            var xcontent_child = $("#content").children(":last");
507
//            $("#content").scrollTop($("#content").scrollTop() + 100);
508
            
509
            //setTimeout(function(){
510
	    /*try {
511
                $('#page').stop().animate({
512
                    scrollTop: (xcontent_child.offset().top + $("#content_container").scrollTop()-100)},//Position
513
                1500);//Zeit für Scrollanimation
514
            //},2000);
515
		
516
	    } catch (e) {
517
	      //Nichts tun
518
	    }*/
519
            
520
                
521
            $("iframe").each(function(){
522
                    try {
523
                        $(this).iFrameResize({});
524
                    } catch(e) {
525
                        //nix tun
526
                        //console.log("iframe resize failed");
527
                    }
528
            });
529
            
530
            xcontent_child.find(".ggb").each(function() {
531
                setTimeout(function() {
532
                        var target_container = $(this).attr("id")
533
                        var applet = new GGBApplet('5.0', parameters[target_container.substring(3) + "_container"], ggb_views);
534
                        applet.inject(target_container, 'html5');
535
                }, 200);
536
            });
537
            
538
            if (append_number>1) {
539
                append_next_to_content(append_number-1);
540
            } else {
541
                try {
542
                    MathJax.Hub.Queue(["Typeset", MathJax.Hub]); //MathJax nochmal rendern lassen
543
                } catch (e) {
544
                    console.log(e);
545
                }
546
            }
547
            
548
                //Navigationsanzeige anpassen
549
                control_next_prev_buttons();
550
                
551
                return false;//nur einen bereich auf einmal laden
552
            //}
553
                
554
            });
555
        //});
556
    } else {
557
         //In Moodle zeigen wir das nächste Element
558
        $("div[xcontent='xcontent']").each(function(){
559
            if ($(this).css("display")=="none") {
560
                $(this).fadeIn(700, function() {
561
                    //Manuelle Geogebra laden lassen
562
                    $(this).find(".ggb").each(function() {
563
                        var target_container = $(this).attr("id")
564
                        var applet = new GGBApplet('5.0', parameters[target_container.substring(3) + "_container"], ggb_views);
565
                        applet.inject(target_container, 'html5');
566
                    });
567
                });
568
                xcontent_position[current_xcontent]++;
569
                
570
                $('#content_container').stop().animate({
571
                    scrollTop: ($(this).offset().top + $("#content_container").scrollTop()-100)},//Position
572
                1500);
573
                
574
                if (append_number>1) {
575
                    append_next_to_content(append_number-1);
576
                } else {
577
                    try {
578
                        MathJax.Hub.Queue(["Typeset", MathJax.Hub]); //MathJax nochmal rendern lassen
579
                    } catch (e) {
580
                        console.log(e);
581
                    }
582
                }
583
                
584
                /*
585
                if ($(this).next("div[xcontent='xcontent']").length == 0) {
586
                    
587
                }*/
588
                
589
                //Navigationsanzeige anpassen
590
                control_next_prev_buttons();
591
                $(window).trigger('resize');//Interaktionen (GGB) werden ohne dieses künstlihce Event evlt. falsch dargestellt.
592
                return false;
593
            }
594
        });
595
        
596
    }
597
}   
598

    
599
function load_content (filename) {
600
    //console.log("rrrrr")
601
    ////console.log("Anfang: " + xcontent_position[current_xcontent])
602
    /*
603
    position = 1;
604
    if (last_position(filename)) {
605
        position = 1
606
    }*/
607

    
608
    if (filename.split("_").length < 2) {
609
        current_xcontent = filename;
610
        filename = filename + "_" + parseInt(get_current_subposition());
611
    } else {
612
        current_xcontent = filename.substr(0,filename.indexOf("_"));
613
    }
614
    
615
    
616
    $("#content").hide();
617
    $("#content").empty();
618
    //console.log(current_xcontent + "_0.xml");
619
        $("#content").load("./" + current_xcontent + "_0.xml", function(a,b,c) {
620
            
621
            ////console.log(filename);
622
            if (b == "error") {
623
                //console.log("Fehler beim Nachladen des Inhalts");
624
                //Hinweistext, wie das Nachladen von Dateien aktiviert werden kannn, wenn das laden fehlschlägt
625
                $("#content").html("Der Inhalt konnte nicht geladen werden. Ist JavaScript bei Ihnen deaktiviert?");
626
            }
627
            xcontent_position[current_xcontent] = parseInt(filename.substr(filename.indexOf("_")+1, filename.length));
628
            ////console.log(xcontent_position[current_xcontent])
629
            ////console.log(current_xcontent + "\n " + filename +"\n" + xcontent_position[current_xcontent]);
630
            control_next_prev_buttons();
631
            activate_input_tooltips();
632

    
633
            
634
            var end = get_current_subposition();
635
            xcontent_position[current_xcontent] = 0;
636
            //console.log("end: " + end);
637
            if (end>=1) {
638
                append_next_to_content(end);
639
            } else {
640
                try {
641
                    MathJax.Hub.Queue(["Typeset", MathJax.Hub]); //MathJax nochmal rendern lassen
642
                } catch (e) {
643
                    console.log(e);
644
                }
645
            }
646
            
647
            $("#content").show();
648
            
649
            $('.formula_helper').tooltipster({
650
                //content: input.next().next().children("div"),
651
                content: "In diesem Formeleingabefeld k&ouml;nnen Sie mathematische Formeln eingeben. Dazu stehen Ihnen unter Anderem die folgenden Eingabezeichen zur Verf&uuml;gung:<br/><br/>&nbsp; + Addition<br/>&nbsp; - Subtraktion<br/>&nbsp; * Multiplikation <br/>&nbsp; / Division (bzw. Bruchdarstellung)<br/>&nbsp; ^ f&uuml;r Potenzen<br/>&nbsp; sqrt() zur Eingabe von Wurzeln <br/>&nbsp; ( bzw. ) zur Klammerung von Ausdr&uuml;cken<br/>&nbsp; . bzw. , als Dezimaltrennzeichen<br/><br/>Probieren Sie es ruhig einmal aus! Die Interpretation Ihrer Eingabe als Formel wird Ihnen beim Tippen &uuml;ber dem Eingabefeld eingeblendet.",
652
                maxWidth: 350,
653
                contentAsHTML: true,
654
            });
655
        });
656

    
657
    
658
    
659
}
660

    
661
//Button-Steuerung für Vor-Zurück-Navigation in den Unterbereichen
662
function control_next_prev_buttons () {
663
    //Aktuelle Positionen ermitteln
664
    var current_position = get_current_position();
665
    var current_subposition = get_current_subposition();
666
    var current_max_subposition = get_current_max_subposition();
667
    
668
    //Prev-Button
669
    if (current_subposition == 0) {//Wenn ganz am Anfang
670
        $("#button_prev").addClass("grey");//Deaktivieren
671
    } else {
672
        $("#button_prev").removeClass("grey");//Aktivieren
673
    }
674
    
675
    //Next-Button
676
    if (current_subposition < current_max_subposition) {
677
        $("#button_next").removeClass("grey");//Deaktivieren
678
    } else {
679
        $("#button_next").addClass("grey");//Aktivieren
680
    }
681
    
682
    store(moodle_course_id + "_" + current_xcontent, "" + (xcontent_position[current_xcontent]));
683
    //console.log("store: " + xcontent_position[current_xcontent]);
684
    
685
    $("#step_current").html(xcontent_position[current_xcontent]+1);
686
}
687

    
688
//Welcher Index ist gerade im Bereiche-Array relevant?
689
function get_current_position () {
690
    for (var i = 0; i < bereiche.length; i++){
691
        if (bereiche[i][1] == current_xcontent) {
692
            return i;
693
        }
694
    }
695
    return 0;
696
}
697

    
698
function get_current_subposition () {
699
    return xcontent_position[bereiche[get_current_position()][1]]
700
}
701

    
702
function get_current_max_subposition () {
703
    return bereiche[get_current_position()][2].length-1;
704
}
705

    
706

    
707
/*
708
*       Adds or changes a GET parameter
709
*       See http://stackoverflow.com/a/13064060/703581
710
*       Adapted to handle '#' in the URL 
711
*/
712
function setGetParameter(paramName, paramValue)
713
{
714
        var url = window.location.href;
715
        var splitAtAnchor = url.split('#');
716
        url = splitAtAnchor[0];
717
        var anchor = typeof splitAtAnchor[1] === 'undefined' ? '' : '#' + splitAtAnchor[1];
718
    if (url.indexOf(paramName + "=") >= 0)
719
    {
720
        var prefix = url.substring(0, url.indexOf(paramName));
721
        var suffix = url.substring(url.indexOf(paramName));
722
        suffix = suffix.substring(suffix.indexOf("=") + 1);
723
        suffix = (suffix.indexOf("&") >= 0) ? suffix.substring(suffix.indexOf("&")) : "";
724
        url = prefix + paramName + "=" + paramValue + suffix;
725
    }
726
    else
727
    {
728
    if (url.indexOf("?") < 0)
729
        url += "?" + paramName + "=" + paramValue;
730
    else
731
        url += "&" + paramName + "=" + paramValue;
732
    }
733
    window.location.href = url + anchor;
734
}
735

    
736
function getGETParameter(val) {
737
    var result = -1,
738
        tmp = [];
739
    var items = location.search.substr(1).split("&");
740
    for (var index = 0; index < items.length; index++) {
741
        tmp = items[index].split("=");
742
        if (tmp[0] === val) result = decodeURIComponent(tmp[1]);
743
    }
744
    return result;
745
}
746

    
747
function inMoodleCourse() {
748
    //return true; //für Testzwecke
749
    // if (window.location.href.indexOf("modstart.html") > -1) return false;//In der Modstart-Datei 
750
    // wollen wir das Offline-Verhalten
751
    // Allow it to proceed, even in modstart.html
752
// (or handle differently only in offline testing)
753
     if (false) return false;
754

    
755
    return window.location.href.indexOf("course/view.php") > -1;
756
}
(1-1/4)