Formular mehrfach in Tabelle verwenden
![](http://www.drupalcenter.de/files/noavatar_mini.gif)
am 01.02.2011 - 13:43 Uhr in
Hallo zusammen,
ich lasse im Rahmen eines Datenbankaufrufes eine Tabelle erstellen. In jeder Zeile steht ein Eintrag. Nun soll am Ende der Zeile ein Formular-Button stehen, mit dem man mit dem jeweiligen Zeile etwas machen kann.
Mal grob zusammengefasst:
echo '<table>';
$dbabfrage=db_query("SELECT filename FROM test");
while ($row = db_fetch_object($dbabfrage)) {
echo '<tr><td>$row->filename</td><td>';
echo drupal_get_form('recall_form',$row->filename);
echo '</td></tr>';
}
echo '</table>';
function recall_form($form_state,$filenames) {
$form['submit'] = array('#type' => 'image_button', '#value' => t(' '), '#src' => 'sites/default/files/reload.png');
$form['filenames'] = array('#type' => 'value', '#value' => $filenames,);
return $form;
}
function recall_form_submit($form, &$form_state) {
$form_values=$form_state['values'];
$filename_recall= $form_values['filenames'];
//Tue irgendwas
}
Doch leider funktioniert es nicht so, wie ich es mir vorstelle. Egal auf welchen Submit-Button man in der Tabelle klickt, es wird immer nur der erste Datenbankaufruf als "filename" genommen.
Wäre toll, wenn Ihr mir sagen könntet, was ich falsch mache :-)
Vielen Dank schon mal.
Grüße
tick313
- Anmelden oder Registrieren um Kommentare zu schreiben
Tabelle
am 01.02.2011 - 14:10 Uhr
Hallo.
Ersteinmal: es gibt [api:theme_table:6] und diese Funktion sollte auch verwendet werden.
Welche Aktionen möchtest Du denn genau pro Zeile ausführen? Eventuell kannst Du das auch über [do:views_bulk_operations VBO] in Verbindung mit [do:rules Rules] machen.
Kurz zur Erklärung: Du erstellst Dir einen View, der die gewünschten Einträge (Dateinamen) ausgibt und stellst als Ausgabestil "Views Bulk Operation" ein. Dann lässt Du als Aktion eine Rule ausführen. Somit ersparst Du Dir den Weg über ein eigenes Modul.
Stefan
Hallo, vielen Dank für den
am 03.02.2011 - 23:36 Uhr
Hallo,
vielen Dank für den Tipp mit theme_table. Damit sieht der Code auch sauberer aus :-)
Ich habe eine Tabelle, in der bestimmte Dateien (kleine Textdateien) gespeichert sind. Diese Dateien Liste ich untereinander auf. Mit einem Button sollen die jeweiligen Dateien ins Filesystem geschrieben werden. Das funktioniert soweit ja auch. Allerdings nicht mehr der Formularbauweise, wie ich sie verwendet habe, da hier immer nur der erste DB Eintrag ins FS geschrieben wird.
Ich habe hier in den Kommentaren eine Anleitung gefunden, wie man wohl das umsetzen könnte, was ich suche.
Dabei habe ich versucht mich an die Angaben zu halten. Doch leider funktioniert es nicht :-(
//mehrfacher des Formulars mit eindeutigem Key:
echo drupal_get_form('recall_form_'.$row->ID);
function recall_forms($form_id,$args){
if (strpos($form_id, 'recall_form_') !== FALSE) {
$forms[$form_id] = array(
'callback' => 'recall_form',
);
return $forms;
}
}
function recall_form($form_state,$args){
//$form['submit'] = array('#type' => 'image_button', '#value' => t(' '), '#src' => 'sites/default/files/reload.png');
$form['#submit'][] = 'recall_form_submit';
return $form;
}
function recall_form_submit($form_state) {
global $user;
}
Als Fehlermeldung erhalte ich je get_form:
warning: call_user_func_array() expects parameter 1 to be a valid callback, function 'recall_form_480' not found or invalid function name in /var/www/includes/form.inc on line 378.
Was mache ich hierbei falsch? Wäre echt super, wenn mir jemand einen Tipp geben könnte. Vielen Dank!
Grüße
Holger