Tipps & Tricks und weitere Beiträge:
© M.K. Hitzigrath
Alle Rechte vorbehalten.
(Wenn nicht anders angegeben.)
Tipps & Tricks und weitere Beiträge:
© M.K. Hitzigrath
Alle Rechte vorbehalten.
(Wenn nicht anders angegeben.)
In/seit „Weatherwax“ gibt es eine Classe um Formulare zu erstellen. Diese ist deswegen sehr nützlich, da hier in den Formularen bereits das „sectok“ mit gesetzt wird um eine gewisse Sicherheit zu erhalten.
Des Weiteren kann auch bei der Abarbeitung der Eingaben mit dem globalen Objekt $INPUT
anstatt der üblichen globalen Variablen ($_GET
, $_POST
und $_REQUEST
) eine Datenprüfung zur Sicherheit mit verwendet werden.
Leider hab ich bisher keine wirkliche Dokumentation darüber gefunden, weswegen ich hier für mich selbst versuche zumindest einen gewissen Grundstock zu dokumentieren.
Um an die Sprach-Variablen zu gelangen sollte $this->setupLocale();
zumindest in der entsprechenden Funktion ausgeführt sein. Alternativ kann auch mit global $lang;
gearbeitet werden, wodurch ein Array mit den lokalisierten Daten zur Verfügung steht.
Des weiteren gibt es ein paar Grund-Elemente, die in einem Formular (zumindest versteckt) eingebunden seien sollten. Diese sind:
Element | Wert | Bemerkung |
---|---|---|
id | <name current wikipage> | |
do | admin | bei einem Admin Plugin und dessen Admin-Page |
show | bei einem Formular, dass in einer Wiki-Seite zur Anwendung kommt | |
page | <plugin name> | wird nur in Admin-Pages benötigt |
Um ein Formular zu erstellen ist eigentlich nicht viel nötig.
Der grundlegende Ablauf besteht aus folgenden Schritten:
$obj = new Doku_Form()
id
, do
, gegebenenfalls page
bei Admin-Pages)$obj->addElement(form_makeButton('submit','','Button-Beschriftung'))
Es empfiehlt sich ein verstecktes Element für die Kennzeichnung der eigentlichen Aktion mit zu integrieren.
Ein einfaches Beispiel ist in Beispiel 1 zu sehen.
Hier nun ein paar Beispiele für ein Formular in einem Admin-Plugin.
Hier wird mit der Classe zur Lokalisierung gearbeitet:
function html() { global $lang; // wird benötigt, wenn globale Sprach-Inhalte benötigt werden. $this->setupLocale(); ptln('<div id="'.$this->getPluginName().'_manager" class="formular">'); $form = new Doku_Form('formID',wl($ID)); $form->addHidden('id',$ID); $form->addHidden('do','admin'); $form->addHidden('page',$this->getPluginName()); $form->addHidden('act','save'); // Die von der Funktion "handle()" abzuarbeitende Aktion. // $form->addElement(form_makeButton('submit','',$this->getLang('own_btn_submit'))); $form->addElement(form_makeButton('submit','',$lang['btn_save'])); $form->printForm(); // html_form('formsave', $form); // Formular-Ausgabe mit Trigger auf HTML_{$name}FORM_OUTPUT ptln('</div>'); }
Eine Übersicht der globalen Sprach-Inhalte kann (z.B. für deutsch) hier eingesehen werden.
Die Abarbeitung der Aktionen/Eingaben des Formulars geschieht in der Funktion handle()
:
function handle() { global $INPUT; if ($INPUT->str('act') && checkSecurityToken()) { // Prüfen des Sicherheits-Tokens (sectoc) if ($INPUT->str('act') == "save") { // Die erste Aktion aus dem ersten Beispiel // ... tue was auch immer bei dieser Aktion ... } } }
Beispiele für die Verwendung des $INPUT-Objekts können hier eingesehen werden.