This is a test message to test the length of the message box.
Login
|
ABAP RAP Popup
Erstellt von Software-Heroes

RAP - Popup

834

Wie bekommen wir ein Popup mit RAP um weitere Eingaben an das Framework zu senden? Das und mehr erfährst du in diesem Artikel.

Werbung


In diesem Artikel wollen wir dir zeigen, wie du ohne viel Aufwand ein Popup für eine Aktion implementierst, ohne dabei auf JavaScript zurückgreifen zu müssen. Dabei schauen wir uns die abstrakten Entitäten an und wie du die Parameter dann im Backend auswerten kannst.

 

Einleitung

Beim Auslösen einer Aktion, egal ob instanzbasiert oder statisch, möchte man in bestimmten Situationen Werte mitgeben, zum Beispiel wenn man beim Kopieren einen neuen Namen vergeben möchte. In der Fiori Entwicklung kann man dafür ein Fragment anlegen und so das Popup implementieren. Im Anschluss müsste man die Function am OData Service aufrufen, um die Daten zu übergeben. Hier bietet das RAP Framework eine Out-of-the-Box Lösung an, die uns das Leben als ABAP Entwickler um einiges erleichtert.

 

Abstrakte Entität

Im ersten Schritt solltest du verstehen, was eine abstrakte Entität ist, da wir diese für die Definition des Popups benötigen. Hierbei handelt es sich um einen Core Data Service ohne Datengrundlage (Tabelle oder anderen CDS View). Im Grunde können wir damit auf Ebene CDS eine Struktur definieren, die wir mit weiteren Annotationen anreichern können, um so spezifische Eigenschaften zu definieren. Definieren wir uns dazu einmal den Inhalt eines möglichen Popups:

@EndUserText.label: 'Entity for popup'
define abstract entity ZBS_I_PopupEntity
{
  SearchCountry : land1;
  NewDate       : abap.dats;
  MessageType   : abap.int4;
  FlagUpdate    : abap.char(1);
  FlagMessage   : abap_boolean;
}

 

Die Entität besitzt keine Datengrundlage und für jedes Feld musst du noch einen Datentyp angeben. Die Felder kannst du frei benennen, so wie du sie benötigst. Im Kopf sind keine weiteren Annotationen nötig, da reicht der Name des Objekts bereits aus. Als Datentyp kannst du die eingebauten Elemente oder Datenelemente verwenden.

 

Popup einbinden

Um im Anschluss ein Popup für eine Aktion zu implementieren, musst du die Entität als Parameter mitgeben. Definieren wir dazu in der Partner Verhaltensdefinition "ZBS_I_RAPPartner" eine neue statische Aktion mit Parameter:

static action withPopup parameter ZBS_I_PopupEntity;

 

Der Zusatz "parameter" sorgt dafür, dass ein Popup für die Entität dahinter erzeugt wird und die Felder vor Ausführung der Aktion abgefragt werden. Im Anschluss muss die Aktion in der Verhaltensimplementierung angelegt werden, dies kannst du ganz einfach in Eclipse mit STRG + 1 auf der Aktion machen. Um die Aktion dann im UI zur Verfügung zu stellen, muss sie in die Projektion der Verhaltensdefinition aufgenommen werden und im Anschluss die Metadata Extension erweitert werden.

Nun haben wir einen Button in der Fiori Elements Preview, der beim Klick ein Popup anzeigt:

 

Einige Felder wurden bereits formatiert und in bessere Eingabefelder umgewandelt. So erhält das Datum bereits einen DatePicker, um einfach ein Datum zu wählen und im passenden Format zur Verfügung zu stellen. Das Datenelement "abap_boolean" wurde auch in eine Checkbox umgewandelt, was für das CHAR1 Feld nicht zutrifft.

Hinweis: In einem aktuellen Release gibt es keine Checkbox mehr, hier wird eine Dropdown mit Ja/Nein als Antwort generiert. Grundsätzlich kann nun damit auch der Zustand "Initial" abgebildet werden

 

Annotationen

Wir haben am Anfang eine abstrakte Entität erstellt, da wir hier noch mehr mit der Formatierung tun können. Dazu binden wir zum Beispiel unsere Suchhilfe vom letzten Artikel ein und geben den Elementen noch passende Beschriftungen.

@EndUserText.label: 'Entity for popup'
define abstract entity ZBS_I_PopupEntity
{
  @Consumption.valueHelpDefinition: [{ entity: { name: 'ZBS_C_CountryVH', element: 'Country' } }]
  @EndUserText.label: 'Search Country'
  SearchCountry : land1;
  @EndUserText.label: 'New date'
  NewDate       : abap.dats;
  @EndUserText.label: 'Message type'
  MessageType   : abap.int4;
  @EndUserText.label: 'Update data'
  FlagUpdate    : abap.char(1);
  @EndUserText.label: 'Show Messages'
  FlagMessage   : abap_boolean;
}

 

Dafür erhalten wir nun ein objektiv besseres Popup für den Anwender mit aktuellen Labels und einer weiteren Suchhilfe für das Land:

 

Verarbeitung

Wie sieht es nun mit der Verarbeitung der Daten aus? Wie kommen wir wieder an die Eingabewerte heran? Dazu befüllen wir das Popup einmal mit den folgenden Werten:

 

In der Methode der Implementierung setzen wir nun einen Breakpoint, dazu haben wir ein Dummy Statement implementiert, auf das wir den Breakpoint in Eclipse setzen können:

METHOD withPopup.
  IF 0 = 0.
  ENDIF.
ENDMETHOD.

 

Über die "Locals" unter den Variablen können wir nun prüfen, wie die Parameter in die Methode gegeben werden. Wie du siehst befinden sich diese in den Keys, erreichbar unter "%param". Die Datentypen haben bereits die korrekten internen Formatierungen und können damit direkt für die Weiterverarbeitung verwendet werden.

 

Fazit

In diesem Aritkel hast du erfahren, wie du einfach für eine Aktion ein Popup definieren kannst, die Werte ins Backend bekommst und auch noch die Eingaben entsprechend gestalten kannst, ohne eine Zeile JavaScript.


Enthaltene Themen:
RAPBTPPopupREX1
Kommentare (0)



Und weiter ...

Bist du zufrieden mit dem Inhalt des Artikels? Wir posten jeden Dienstag und Freitag neuen Content im Bereich ABAP und unregelmäßig in allen anderen Bereichen. Schaue bei unseren Tools und Apps vorbei, diese stellen wir kostenlos zur Verfügung.


RAP - Icons

Kategorie - ABAP

Wie findest du eigentliche Icons im UI5 Umfeld und wie kannst du diese mit ABAP Mitteln in deine Fiori Elements Anwendung einbauen? Lass uns diese Frage im Artikel beantworten.

13.03.2026

RAP - Gruppierung von Aktionen

Kategorie - ABAP

Wie kannst du eigentlich deine verschiedenen Aktion in RAP unter einem Button gruppieren, vor allem wenn die Aktionen relativ ähnlich sind. In diesem Artikel schauen wir uns die Details zur Umsetzung mit ABAP an.

10.03.2026

ADT - RAP Extension Assistent [MIA]

Kategorie - ABAP

Du möchtest ein RAP Objekt erweitern und weißt nicht genau wo du starten sollst? Vielleicht hilft dir die Idee des Extension Assistant weiter und leitet dich Schritt für Schritt durch den Prozess.

06.03.2026

ADT - RAP Analyzer [MIA]

Kategorie - ABAP

Die Einarbeitung und Übersicht in bestehende RAP Objekte kann nicht immer einfach sein, vor allem wenn es sich um komplexe Objekte handelt. Fragen wie das verwendete Pattern und wichtige Objekte müssen sich meist erarbeitet werden.

24.02.2026

RAP - Position der Buttons

Kategorie - ABAP

In diesem Artikel schauen wir uns die verschiedenen Positionen der Buttons an. Wo können wir in RAP die verschiedenen Actions platzieren und wie nutzen wir diese.

17.02.2026