====== Timer: Weiter-Knopf nach bestimmter Zeit einblenden ====== Dieses Kapitel beschreibt, wie man den Weiter- und Zurück-Knopf auf einer Fragebogen-Seite so manipuliert, dass sie erst nach einer vorgegebene Zeit erscheinen. Prinzipiell kann man mit der vorgestellten Lösung auch beliebige andere Inhalte erst nach einer vorgegeben Zeit präsentieren. Diese Lösung basiert (wie die meisten dynamischen Inhalte) auf [[:de:create:javascript|JavaScript]] und hat folgende Einschränkungen: * Wenn ein Teilnehmer JavaScript gezielt deaktiviert, funktioniert die Automatik nicht. Damit der Teilnehmer dennoch teilnehmen kann, ist das Script so ausgelegt, dass der Weiter-Knopf ganz normal erscheint. * Wenn der Teilnehmer die Seite erneut lädt (Taste F5, //Aktualisieren// oder //Neu Laden//) oder durch den Zurück-Knopf auf die Seite zurückkehrt, beginnt der Timer von vorne zu laufen. Den Zurück-Knopf auf der aktuellen und/oder folgenden Seite kann man mit der PHP-Funktion ''[[:de:create:functions:option|option()]]'' deaktivieren. ===== Funktion ===== - Wenn die Seite geladen wurde, wird der //Weiter//-Knopf mittels JavaScript ausgeblendet. - Anschließend wird ein Timer gestartet, der den Knopf nach einer vorgegeben Zeit wieder einblendet. ===== Umsetzung ===== Man benötigt lediglich einen Textbaustein mit nachfolgendem Inhalt (anzulegen unter **Textbausteine u. Beschriftung**, //Darstellung// "HTML_Code"). Diesen Textbaustein zieht man dann beim Zusammenstellen des Fragebogens in die entsprechende Fragebogen-Seite. **Hinweis:** Dieser JavaScript-Code verwendet die SoSci Survey spezifische Funktion ''SoSciTools.submitButtonsHide()'', um alle Knöpfe auszublenden. Ebenso können Sie über ''%%document.getElementById("submit0")%%'' spezifisch den Weiter-Knopf identifizieren und dessen Eigenschaft ''.style.display'' auf den Wert ''%%"none"%%'' setzen. Für das wieder-Anzeigen des Knopfes müssen Sie dann ggf. eine eigene Funktion als Pendant ergänzen. ===== Andere Inhalte einblenden ===== In dem JavaScript-Code sehen Sie die Kennung (HTML-ID) ''buttonsAuto''. Diese Kennung wird automatisch für die Knöpfe vergeben, die unten auf der Fragebogen-Seite erscheinen -- egal ob dort nur ein Weiter- oder auch ein Zurück-Knopf steht. Wenn Sie eine andere HTML-ID angeben, werden andere Objekte auf der Seite ein- und ausgeblendet. Wenn Ihre Inhalte noch keine HTML-ID haben, dann können Sie einfach ein ''
''-Tag außenherum setzen:

Überschrift

Hier lesen Sie nun den geheimen Text.

Anstatt des Textes können Sie auch einen Textbaustein, eine Frage oder andere Inhalte im ''
''-Tag platzieren. Dafür müssen Sie lediglich zwei HTML-Bausteine verwenden, die Sie vor und nach dem entsprechenden Inhalt im Fragebogen:
**Tipp:** Für Fragen ist das nicht notwendig, weil diese bereits eine HTML-ID tragen ([[:de:create:dynamic|Fragen bei Auswahl einer bestimmten Option sofort einblenden]]). Der entsprechende HTML-/JavaScript-Code würde dann wie folgt aussehen: ===== Platzhalter für den Knopf ===== Bei der vorgestellten Lösung wird das Layout beim Erscheinen des Knopfes leicht verändert -- die Seite wird größer. Wenn Sie das nicht möchten, können Sie den Inhalt statt mit ''display'' auch mit dem CSS-Attribut ''visibility'' ausblenden: ===== Countdown zeigen ===== Es ist für die Teilnehmer u.U. irritierend, wenn auf einer Seite plötzlich der Weiter-Knopf fehlt. Daher kann es sinnvoll sein, anstatt des Knopfes einen Countdown anzuzeigen. Dies erreichen Sie mit folgendem HTML-/JavaScript-Code: