abhängige Listenfelder mit AJAX
am 06.05.2011 - 10:56 Uhr in
Es gibt zwei über die Benutzerobfläche erstellte Inhaltstypen, nämlich
Vereine (es gibt dann auch 4 eingegebene Mannschaften)
und
Spieler (es gibt dann auch zu jeder Mannschaft 4 Spieler, also insgesamt 16 Spieler)
Im Inhaltstyp Spieler gibt es ein per Modul "References" ermöglichtes Nodereferencefeld spieler_team, in dem die nid des betreffenden Vereins gespeichert ist.
Nun habe ich einen dritten Inhaltstypen Brettpaarung erstellt, in dem es zwei Nodereferencefelder gibt, nämlich
brettpaarung_brettheimteam
und
brettpaarung_brettheimspieler
gibt.
Nachdem ein brettheimteam ausgewählt wurde, sollen im Feld brettheimspieler nur noch die zur Mannschaft gehörenden Spieler angezeigt werden.
Mit dem folgenden Code funktioniert das auch für neue (also node/add) Datensätze vom Typ brettpaarung:
<?php
function brettpaarung_form_alter(&$form, &$form_state, $form_id) {
//drupal_set_message("Form ID is : " . $form_id);
//drupal_set_message('<pre>'. print_r($form, 1) .'</pre>');
switch ($form_id) {
case 'brettpaarung_node_form':
$form['brettpaarung_brettheimteam'][LANGUAGE_NONE] += array(
'#ajax' => array(
'callback' => 'brettpaarung_callback',
'wrapper' => 'dropdown-second-replace',
),
);
$ausgabetext = '';
if (!empty($form_state['values']['brettpaarung_brettheimteam'])) {
$ausgabetext = $form_state['values']['brettpaarung_brettheimteam'][LANGUAGE_NONE][0]['nid'];
}
drupal_set_message('<pre>'. $ausgabetext .'</pre>');
$form['brettpaarung_brettheimspieler'][LANGUAGE_NONE]['#description'] = 'Die möglichen Spieler der Heimmannschaft.';
$form['brettpaarung_brettheimspieler'][LANGUAGE_NONE]['#options'] = _ajax_example_get_second_dropdown_options($ausgabetext);
$form['brettpaarung_brettheimspieler'][LANGUAGE_NONE]['#default_value'] = ''; //???
$form['brettpaarung_brettheimspieler'][LANGUAGE_NONE] += array(
'#prefix' => '<div id="dropdown-second-replace">',
'#suffix' => '</div>',
);
break;
default:
break;
}
}
function brettpaarung_callback($form, $form_state) {
return $form['brettpaarung_brettheimspieler'];
}
function _ajax_example_get_second_dropdown_options($arg) {
$query = db_select('node', 'n');
$query->condition('n.type', 'spieler', '=')
->fields('n', array('nid', 'title'));
$query->join('field_data_spieler_team', 's', 'n.nid = s.entity_id');
$query->condition('s.spieler_team_nid', $arg, '=');
$result = $query->execute();
$options = array();
$options['_none'] = '- Keine -';
foreach ($result->fetchAll() as $node) {
$options[$node->nid] = $node->title;
}
return $options;
}
Wählt man eine Mannschaft aus, wird der AJAX-callback ausgelöst und anschließend sind die Spieler dieser Mannschaft auswählbar, soweit wunderbar.
Nun zum Problem:
Wenn ich eine bereits gespeicherte Paarung erneut aufrufe (in der bereits eine Mannschaft und auch ein Spieler ausgewählt wurde, also node/edit), zeigt das Listenfeld für den brettspieler immer nur - keine - an.
Soweit ich das bisher feststellen kann, liegt es daran, dass form_state['values']['brettheimteam'] nach dem Öffnen des Formulars immer leer ist, statt den schon vorhandenen Wert (die nid des Vereins) auszulesen. Das passiert erst wenn ich erneut einen anderen Verein auswähle.
konkrete Frage:
Wie bringe ich Drupal dazu, schon beim öffnen des Edit-Formulars
1. den Wert des Feldes brettheimteam auszulesen
2. die ajax_callback-Funktion auszuführen und damit die richtige Spielerliste anzuzeigen
und
3. den richtigen Spieler in den #default_value des Feldes brettheimspieler zu schreiben ?
- Anmelden oder Registrieren um Kommentare zu schreiben
Neue Kommentare
vor 4 Stunden 14 Minuten
vor 22 Stunden 2 Minuten
vor 1 Tag 38 Minuten
vor 1 Tag 1 Stunde
vor 1 Tag 4 Stunden
vor 1 Tag 5 Stunden
vor 1 Tag 13 Stunden
vor 1 Tag 21 Stunden
vor 1 Tag 21 Stunden
vor 1 Tag 21 Stunden