====== Texteingabe ======
Die Texteingabe-Fragen unterstützen unterschiedliche Anwendungsfälle:
=== Offene Texteingabe ===
Die "Offene Texteingabe" zeigt ein oder mehrere Eingabefelder für Text.
* Jedes Textfeld kann eine Beschriftung (davor und dahinter) haben.
* Die Textfelder können ein- oder mehrzeilig ausgelegt werden -- es sind also auch große Eingabefelder für längere Texte möglich, spezifizieren Sie dafür eine Höhe für das Eingabefeld.
* Das Format kann für jedes Eingabefeld festgelegt werden, wenn Sie es links im **Fragenkatalog** zum Bearbeiten auswählen. So akzeptieren Eingabefelder z.B. nur noch Zahlen.
* In der Frage oder für einzelne Eingabefelder können Ausweichoptionen ("keine Antwort") aktiviert werden, die mit einem Kästchen zum ankreuzen rechts des Eingabefelds angezeigt werden.
* Sie können festlegen, dass -- wenn Sie in den Eingabefeldern Zahlenwerte erwarten (z.B. Punkte) -- die Summe aller Eingabefelder einen konstanten Wert ergeben muss, bevor der Teilnehmer fortfahren kann. So können Sie den Teilnehmer z.B. 100% auf 5 Kategorien verteilen lassen.
=== Offene Nennungen ===
"Offene Nennungen" sind optimal geeignet, um Ideen oder Argumente zu sammeln -- also mehrere gleichartige Eingaben.
* Gegenüber einem mehrzeiligen Eingabefeld haben sie den Vorteil, dass jede Zeile in eine eigene Variable gespeichert wird -- außerdem wird die Anzahl der Angaben in einer gesonderten Variable ausgewiesen.
* Standardmäßig zeigen die offenen Nennungen zunächst nur 2 Zeilen zur Texteingabe. Trägt der Teilnehmer in eine der Zeilen etwas ein, erscheinen sukzessive weitere Zeilen.
=== Lückentext ===
Der "Lückentext" zeigt Texteingabefelder direkt in einem Fließtext an. Die einzelnen Eingabefelder können wie bei der "offenen Texteingabe" detailliert formatiert werden.
=== Texteingabe mit Auswahlempfehlung ===
Die [[::de:create:questions:suggest]] zeigt ein Textfeld (bzw. mehrere Kopien davon), für welches eine Reihe von möglichen Antworten hinterlegt sind. Sobald der Teilnehmer einige Buchstaben in das Eingabefeld eingibt, erscheinen passende Antwortoptionen zur Auswahl. Wird eine der vorgegeben Optionen ausgewählt, so wird die Antwort gleich kodiert -- optional kann man dem Teilnehmer gestatten, auch andere Texte einzugeben, die dann als Text im Datensatz abgelegt werden.
=== Ballontest ===
Beim "Ballontest" wird unter **Bilder und Mediendateien** zunächst ein Bild ins Projektverzeichnis hochgeladen. Die Frage zeigt dann ein ausgewähltes Bild, in welchem Sie ein oder mehrere Texteingabefelder platzieren können.
===== Breite und Höhen von Texteingabefeldern =====
Sie können für die //Breite// von Texteingabefeldern wie folgt festlegen:
* Keine Angabe bedeutet ...
* ... beim Lückentext, dass kein Eingabefeld angezeigt wird.
* ... beim der offenen Texteingabe, dass die gesamte Breite für das Eingabefeld genutzt werden soll.
* Eine Angabe von 1 bis 15 definiert die Anzahl an Zeichen, die im Eingabefeld Platz finden sollen. Diese Breite variiert mit der Größe der verwendeten Schriftart.
* Eine Angabe von 16 oder mehr (Standard: 200) definiert die Breite in Pixeln, welche für das Eingabefeld verwendet werden soll. Diese Breite ist unabhängig von Schriftgröße und Layout.
Bei der offenen Texteingabe und bei [[:de:create:selection-textinput|Eingabefeldern in Auswahlfragen]] können Sie auch eine //Höhe// für die Eingabefelder festlegen.
* Wenn Sie keine Höhe eintragen, wird ein einzeiliges Eingabefeld erzeugt. Wenn der Text größer als das Eingabefeld ist, bewegt sich der Text nach links.
* Wenn Sie eine Höhe eintragen, dann wird __immer__ ein mehrzeiliges Eingabefeld erzeugt. Wenn mehr Text eingetragen wird als das Eingabefeld breit ist, dann bricht der Text in die nächste Zeile um.
* Wenn Sie zusätzlich die Option //Höhe automatisch anpassen// aktivieren, dann wird das Eingabefeld größer, wenn die Höhe für den Text nicht ausreicht.
**Wichtig:** Tragen Sie __keine__ Höhe ein, wenn Sie keine mehrzeilige Eingabe erwarten. Falls Sie die Höhe von einzeiligen Eingabefeldern anpassen möchten, nehmen Sie eine entsprechende Änderung im [[:de:create:layout|Fragebogen-Layout]] vor.
===== Einschränkungen für den eingegeben Text =====
Die offene Texteingabe (wie übrigens auch offene Eingabefelder in anderen Fragetypen) erlaubt eine automatische Überprüfung des Eingabeformats. Dies ist insbesondere dann empfehlenswert, wenn die Befragten Zahlen (z.B. Alter) oder ein Datum eingeben sollen. Aber es sind auch weitere Anwendungen möglich, wenn die Befragten z.B. einen Geldbetrag mit Nachkommastellen oder genau 2 Buchstaben eintragen sollen.
Wählen Sie links im **Fragenkatalog** zunächst die Frage und anschließend das Eingabefeld innerhalb der Frage aus. Bei Auswahlfragen wählen Sie die [[:de:create:selection-textinput|Auswahloption mit dem offenen Eingabefeld]].
{{:de:create:questions:scr.text.charset1.png?nolink|Auswahl des Eingabefelds in der Navigation}}
Alternativ können Sie in der Item-Eingabe innerhalb der Frage auf den Knopf zum Bearbeiten ({{::button.edit3.png?nolink|Knopf: Bearbeiten}}) der Item- bzw. Eingabefeld-Einstellungen klicken.
{{:de:create:questions:scr.text.charset3.png?nolink|Detaileinstellungen für ein Eingabefeld aufrufen}}
In den Detaileinstellungen für das Eingabefeld finden Sie die //Einschränkungen für die Texteingabe//. Wählen Sie hier bei //Definierte Zeichen// aus, welches Eingabeformat für das Auswahlfeld gelten soll.
**Hinweis:** Wenn Sie als //definierte Zeichen// eine "Zahl" oder "Dezimalzahl" festlegen, wird die Eingabe im Eingabefeld standardmäßig rechtsbündig ausgerichtet und die Angabe wird beim Download der Daten als Zahl behandelt. Die "Ziffern" hingegen werden als Text bestehend aus Ziffern behandelt.
{{:de:create:questions:scr.text.charset2.png?nolink|Einstellungen für das Format einer offenen Texteingabe}}
Je nach gewähltem Format können weitere Einschränkungen festgelegt werden. Bei Zahlen etwas ein Wertebereich oder bei Buchstaben die Anzahl der Zeichen.
Für komplexere Formate steht die Einstellung //Regulärer Ausdruck// zur Verfügung. Falls hier etwas eingetragen wird, deaktiviert dies ein eventuell bei //Definierte Zeichen// festgelegtes Format. Ein regulärer Ausdruck, der z.B. zwei Großbuchstaben (ohne Umlaute) und zwei Ziffern erfordert, würde wie folgt aussehen:
/[A-Z]{2}[0-9]{2}/
Für eine ausführliche Dokumentation regulärer Ausdrücke sei auf [[https://www.regular-expressions.info/|regular-expressions.info]] verwiesen.
===== JavaScript für Texteingabefelder =====
Unter anderem verwendet SoSci Survey JavaScript, um etwa die erlaubten Zeichen (Ziffern, Buchstaben, etc.) zu begrenzten. Mittels [[:de:create:javascript|JavaScript]] kann das Verhalten einzelner Eingabelfelder weiter angepasst werden.
==== Formatierungen erlauben ====
Mithilfe der JavaScript-Bibliothek [[http://www.sceditor.com/|SCEditor]] (in SoSci Survey automatisch verfügbar) können Sie Textfelder so verändern, dass der Teilnehmer -- ähnlich wie in einer Textverarbeitung -- den Text formatieren kann. Etwa Wörter unterstreichen, Emoticons einfügen, etc.
Erstellen Sie zunächst eine Frage vom Typ "Offene Texteingabe" mit mehrzeiligem (!) Texteingabefeld. Um ein mehrzeiliges Eingabefeld zu erhalten, tragen Sie eine Höhe (z.B. 120 Pixel) für das Eingabefeld ein.
Fügen Sie diese Frage unter **Fragebogen zusammenstellen** auf der passenden Seite in den Fragebogen ein.
Platzieren Sie auf derselben Fragebogen-Seite folgenden PHP-Code, um den SCEditor zu laden:
library('SCEditor');
Legen Sie unter **Textbausteine und Beschriftungen** einen neuen Textbaustein (z.B. mit der Kennung "jsSCEditor" und Typ "HTML-Code") mit folgendem Inhalt an:
Diesen Textbaustein fügen Sie ebenfalls unter **Fragebogen zusammenstellen** auf der Fragebogen-Seite ein -- und zwar unterhalb der Textfrage. Der JavaScript-Code sorgt dafür, dass alle mehrzeiligen Texteingabefelder (''