Webform: nur vom User geänderte Werte mailen
am 24.07.2018 - 13:42 Uhr in
User sollen Vorschläge zu Änderungen an den Werten eines Inhaltstyps machen dürfen. Ausgewählt und eingetragen werden diese vom Admin. Den Overhead von Revisions oder Workbench Moderation möchte ich für diese Anwendung gerne umgehen. Deshalb habe ich ein Formular gebaut, auf das mit einem Link "Änderungen vorschlagen" von der Ansicht der jeweiligen Node verlinkt wird.
Der Link wird mittels des Tokens [node:nid] z.B. zu node/305?nid="2".
Die Werte des Formulars werden aus der verlinkten Node dynamisch vorbelegt. Da es in der Node wiederum einige entity references gibt, geschieht das mit Hilfe des entity_metadata_wrappers, um auch an Felder der referenzeirten Nodes zu kommen.
Der Admin soll in der Webform-Mail sofort sehen, um welche Änderungen es geht. Daher möchte ich nur diejenigen Werte in ein Array schreiben, bei denen sich vorbelegt und eingegeben unterscheiden und die zudem überhaupt User Input haben. Dieses Array möchte ich einem vorbereiteten, verborgenen Feld übergeben, sodass es automatisch in die Mail übernommen wird.
Innerhalb von HOOK_form_webform_client_form_NID_alter(&$form, &$form_state, $form_id)
habe ich mit kpr($form)
folgende Möglichkeiten gefunden, die sich für den Vergleich anbieten:
$form['submitted']['mein_feld']['#default_value']
--- akzeptiert die Vorbelegung,$form['submitted']['mein_feld']['#webform_component']['value']
--- nimmt den User Input auf,$form['submitted']['mein_feld']['#webform_component']['extra']['placeholder']
--- lässt sich trotz der Bezeichnung nicht vorbelegen. Wozu ist er vorgesehen?
Für die Übergabe an das verborgene Feld finden sich im Netz verschiedene Vorschläge:
- einen eigenen submit_handler,
- einen eigenen validate_handler oder
HOOK_webform_submission_presave($node, &$submission)
.
submit_handler und validate_handler haben den Vorteil, dass sie eigentlich auf $form und damit auf
$form['submitted']['mein_feld']['#default_value']
und
$form['submitted']['mein_feld']['#webform_component']['value']
zugreifen können.
Dennoch ließ sich durch keine der folgenden Varianten ein Wert übergeben:
$form['submitted']['geaenderte_felder']['#webform_component']['value'] = 'geändert';
$form_state['webform']['component_tree']['children'][DELTA]['value'] = 'geändert';
$form_state['values']['geaenderte_felder'][und][0]['value'] = 'geändert';
(diese Struktur findet sich auch indpm($form_state)
nicht wieder)form_set_value($form['submitted']['geaenderte_felder'], array('und' => array(0 => array('value' => 'geändert'))), $form_state);
Mit HOOK_webform_submission_presave($node, &$submission)
lässt sich via
$submission->data[DELTA][0] = 'geändert';
zwar ein Wert übertragen, aber ich finde keine "Brücke", um das Ergebnis des Feldervergleichs in diesen Hook zu übertragen. $node enthält zwar webform, aber nicht den default_value. $submission enthält pro Feld ohnehin nur den endgültigen Wert.
Hat jemand eine Idee, wie sich eine Brücke zwischen HOOK_form_webform_client_form_NID_alter
und HOOK_webform_submission_presave
bewerkstelligen ließe?
Natürlich kann man Inputs auch mit JS auslesen, aber es hätte ein paar Vorteile, wenn es innerhalb Webform zu lösen wäre. Zumal mir nicht einleuchten will, dass es nicht funktionieren soll, obwohl doch eigentlich die Voraussetzungen in der Struktur vorhanden sind.
Vielen Dank im voraus für Eure Ideen!
Gruß
kissmedve
- Anmelden oder Registrieren um Kommentare zu schreiben
Workaround
am 24.07.2018 - 20:40 Uhr
Nach weiterem Herumforschen kam ich auf die Idee, nicht default_value und input zu vergleichen, sondern den default_value (= die Vorbelegung) einfach wieder zu löschen, sodass in der Submission nur noch User-Input-Werte übrig bleiben. Das hat aber weder via validate_handler noch über submit_handler funktioniert.
Das nächste hat dann funktioniert:
$form['submitted']['mein_feld']['#markup']
.In der Submission erscheinen nur noch die ausgefüllten Felder und die Benachrichtigungsmail ist knapp und informativ.
Bingo! Ein bisschen hacky, aber wenn's zum Ziel führt ;-) ...