ajax_examples
am 04.10.2010 - 19:22 Uhr in
In Drupal 7 hat sich geändert, dass man Feldern in Formularen eine Ajax-Funtionalität hinzufügen kann.
Im examples_module für D7 gibt es auch ajax_examples.
Ich wollte das nun mal für abhängige Listenfelder versuchen.
Allerdings ist das Beispiel des Moduls insofern untauglich, als die Listeninhalte im Modul selbst erzeugt/codiert sind.
Der Anwendungsfall ist aber, dass die Listeninhalte aus Feldern, die mit der Datenbank verbunden sind, stammen, macht ja sonst keinen Sinn.
Ich habe mir vorgestellt, die Listenfelder ganz normal über das Eingabeformular zu befüllen und die Ajax-Funktionalität für die Listenfelder dann über hook_form_alter hinzuzufügen.
Die Listeneinträge des 1. Listenfeldes sind also bereits vorhanden.
Die Listeneinträge des 2. Listenfeldes sind auch vorhanden, müssen aber per Datenbankabfrage nach einer Bedingung gefiltert und zurückgegeben werden.
Hat schon jemand ein Beispiel dafür ?
Oder einen Link ?
- Anmelden oder Registrieren um Kommentare zu schreiben
Hat das noch keiner versucht
am 26.12.2010 - 11:43 Uhr
Hat das noch keiner versucht ?
Ich habe folgendes versucht:
frische D7RC3-Installation, dazu das Modul References (Nachfolger von Nodereference des CCK für D6)
Inhaltstyp Verein erstellt und zwei Vereine eingegeben
Inhaltstyp Spieler erstellt mit einem Referencefeld spieler_team und mehrere Spieler eingegeben
Nun habe ich versucht, das ajax_example "simplest" nachzubauen, d.h. wenn ein Verein aus dem Listenfeld "spieler_team" ausgewählt wird, wird die Beschreibung eines neuen (hier unsinnigen) Formularfeldes "Meldung" geändert.
Mein Modulcode:
<?php
function verein_form_alter(&$form, &$form_state, $form_id) {
switch ($form_id) {
case 'spieler_node_form':
$form['spieler_team']['#ajax']['callback'] = 'verein_simplest_callback';
$form['spieler_team']['#ajax']['wrapper'] = 'replace_meldung_div';
$form['meldung'] = array(
'#type' => 'textfield',
'#title' => t('Meldung'),
'#prefix' => '<div id="replace_meldung_div">',
'#suffix' => '</div>',
);
if (!empty($form_state['values']['spieler_team'])) {
$form['meldung']['#description'] = t('spielt in Mannschaft'). " '{$form_state['values']['spieler_team']}'";
}
break;
}
}
function verein_simplest_callback($form, $form_state) {
return $form['meldung'];
}
Hinsichtlich der Ajax-Funtionalität passiert aber nichts.
Der Unterschied zum ajax_example besteht darin, dass das Listenformularfeld nicht völlig neu aufgebaut wird, sondern nur mittels hook_form_alter um den 'ajax'-Teil ergänzt werden soll.
Was ist an meinem Code falsch ?
Mit ist nur aufgefallen, dass in docs auf drupal.org immer in folgender Schreibweise dargestellt wird: #ajax['wrapper']. Das haut dann aber mit array-Klammern überhaupt nicht hin.
Wenn ich das Listenfeld selbst aufbaue (per Hand als Textarray) klappt auch der Ajax-Teil. Dann habe ich aber das Problem, dass ich unnötiger Weise den Listeninhalt erst im Modul dynamisch mühsam über eine Select-Abfrage aufbauen müsste, obwohl das Feld den Inhalt eigentlich ja schon hat.
Ich hoffe jemand weiss Rat oder kann einen Link zu einem Beispiel mit hook_form_alter in Verbindung mit ajax nennen.