Application mit thickbox als Popup öffnen und Daten zurück geben

Öffnen einer anderen Application zur Dateneingabe mit Rückgabe des Ergebnisses

Scriptcase bringt standardmäßig thickbox als externe Bibliothek mit, die ohne getrennte Installation gestartet werden kann.

Die jquery-Bibliothek thickbox ist in der Lage praktisch alle fremden Website, aber auch PDF und sogar Videos anzuzeigen.

In diesem Beitrag zeige ich, wie aus einer Form heraus eine control-Application geöffnet wird (als modales Popup) in der dann Daten ausgewählt und das Ergebnis direkt in eine Text-Box der ursprünglichen Form zurückgeschrieben werden.

Die eigentliche Form

Das kann eine beliebige Form sein, die ganz normal an eine Tabelle gebunden ist.

Wir brauchen eine Textbox (multible line Text) die den Namen  to  hat.
Außerdem ein Label-Feld mit dem Namen  edit_to .

Im onLoad-Ereignis der Form fügen wir ein:

Mit sc_include_lib wird Scriptcase mitgeteilt, dass die zusätzliche Bibliothek thickbox zu laden ist.

Hinweis:  Da die Bibliothek von Scriptcase verwaltet wird, braucht man sich auch beim Veröffentlichen der Projekts (deploy) auf einen anderen Server nicht darum zu kümmern, die Dateien für thickbox zu kopieren und auf dem Server zu installieren.

Mit dem Scriptcase Macro sc_make_link  wird eine URL erzeugt mit der wir die control-Application  email_select öffnen und ggfls. Parameter mit übergeben.
In dem Beispiel sind das die Parameter work_on='to'  und selected_email_id  mit dem bisherigen Inhalt von to .

In der letzten Zeile wird dem Label-Feld edit_to ein normaler HTML-Link übergeben, der damit angezeigt (und vom Anwender geklickt) werden kann.
Dabei verwenden wir als Ziel die gerade erzeugte URL die wir durch die Parameter für die thickbox erweitern:  &TB_iframe=true&height=500&width=800&modal=true

Die Beschreibung von thickbox und den möglichen Parametern findet am unter: http://codylindley.com/thickbox/

Nicht vergessen auch die Class entsprechend zu setzen:  class="thickbox"

Die control-Applikation zur Dateneingabe

In unserem Fall ist das eine einfach control, in der via Double-Select die möglichen Email-Empfänger aus einer Tabelle ausgewählt werden können.

Das Double Select heißt email_receiptiants und wir weisen im in onLoad der Control den bisherigen Wert von [to] zu (Vorbelegung):

Die eigentliche Auswahl kann sehr viel komfortabler sein. In unserem Fall macht das alles bereits Scriptcase.

Sobald der Anwender den üblichen OK-Button drückt, wird das Ergebnis zurückgegeben – im OnValidateSuccess-Ereignis:

Dazu verwenden wir ein kleines jQuery-Script, das per ‚echo‘ ausgeführt wird.

1. Zuweisen des Ergebnisses (aus dem Double-Select) an das Feld to  in der ursprünglichen Form:

$('textarea#id_sc_field_to', window.parent.document).text('" . $t . "');

2. Sicherstellen, dass Scriptcase auch erkennt, dass sich der Feldinhalt geändert hat:

$('textarea#id_sc_field_to', window.parent.document).trigger('change');

3. Speichern des Inhalts der ursprünglichen Form:

self.parent.nm_atualiza ('alterar');

4. Neu Laden der ursprünglichen Form. Das müssen wir nur machen, wenn wir angängige Felder haben, die sich mit ändern sollen. In meiner Anwendung haben wir in Abhängigkeit des to Feldes noch eine Liste (Select) angezeigt, die sich entsprechend mit verändern muß. Ein normaler Ajax-Event würde nicht auslösen.

self.parent.location.reload();

5. Das Popup, also die Control-Application dann schließen:

self.parent.tb_remove();

 

Veröffentlicht in Scriptcase Sniplets Getagged mit: , , ,