Druckansicht in SAP aus einem externen OMS erzeugen
Bei manchen SAP Anwendern werden SAP Formulare nicht mit den SAP-internen Formularwerkzeugen (SAP Script, Smart Forms, Adobe Forms) erzeugt, sondern die Formulargenerierung geschieht über ein externes Outputmanagement-System (OMS). Bei dem externen OMS kann es sich z.B. um die Produkte Jetforms, Formscape, Streamserve oder den TDS (Tentacle Document Server) handeln.
Werden SAP Formulare mit einem externen OMS erzeugt, so ist häufig die Druckbildansicht direkt in SAP nicht möglich. Man müsste in das externe OMS verzweigen, um die Druckbildansicht zu sehen. Ein typischer SAP Anwender hat jedoch keinen Zugang zum externen OMS und wünscht in vielen Fällen eine Druckbildansicht direkt in SAP, bevor das Formular gedruckt oder per Mail verschickt wird.
Szenario
Der SAP Anwender erzeugt die Formulare mit einem externen OMS, im expliziten Beispiel wurde ein TDS (Tentacle Document Server) über eine SAP PI an das SAP ERP angebunden. Die Rohdaten hierzu werden in einem SAP Script-Druckprogramm erzeugt. Das SAP Script-Formular ist so eingestellt, dass kein Formulardruck erfolgt, sondern die Rohdaten des Formulars als Idoc über die SAP PI an das externe OMS geschickt werden. Alternativ könnte auch ein RDI-Datenstrom im SAP Spool erzeugt werden, den sich dann das externe OMS abgreift.
Wünscht der SAP Anwender eine Druckbildansicht, so wird im Idoc ein Kennzeichen an das externe OMS mitgegeben, damit es eine PDF-Datei erstellt und als binäres Objekt in der SAP Datenbank ablegt. Die SAP-Anwendung wartet dabei so lange, bis die PDF-Datei gelesen werden und in einem HTML-Control im Sapgui angezeigt werden kann.
Umsetzen der Anforderung
Realisierung im Druckprogramm
Vor dem Aufruf des Funktionsbausteins OPEN_FORM wird im Falle einer Druckbildansicht eine eindeutige GUID erzeugt.
* GUID bei Druckbildansicht erzeugen
if us_screen = abap_true.
* CALL METHOD cl_guid_services=>create
* IMPORTING
* ev_guid_16 = yvbdka-guid.
call function 'GUID_CREATE'
importing
ev_guid_16 = yvbdka-guid.
endif.
Direkt vor OPEN_FORM wird die GUID in das Feld ITCPO-TDCOVTITLE geschrieben.
* Spoolparameter setzen
if not yvbdka-guid is initial.
lvs_itcpo-tdcovtitle = 'GUID:'.
lvs_itcpo-tdcovtitle+5 = yvbdka-guid.
endif.
* OPEN_FORM
call function 'OPEN_FORM'
exporting
archive_index = toa_dara
archive_params = arc_params
device = lvf_device
dialog = ' '
form = tnapr-fonam
language = nast-spras
options = lvs_itcpo
mail_sender = lvs_sender
mail_recipient = lvs_recipient
exceptions
canceled = 1
device = 2
form = 3
options = 4
unclosed = 5
mail_options = 6
archive_error = 7
others = 8.
Das Formular wird nun erzeugt, CLOSE_FORM wird prozessiert und das SAP Script-Formular geht als Idoc an das externe OMS.
Wenn die GUID gefüllt ist, dann druckt das externe OMS nicht das Formular, sondern reicht das PDF im Format BASE64 an die SAP PI weiter.
Die SAP PI ruft nun einen Proxy im ERP auf und übergibt die PDF-Datei in folgender Struktur.
Im Feld Content vom Typ RAWSTRING befindet sich die PDF-Datei.
In einem eigens entwickelten Funktionsbaustein Z_PI_SAVE_PDF_FROM_TDS erfolgt die Speicherung der PDF-Datei zur GUID in Tabelle ZTDS_PREVIEW. Der Funktionsbaustein Z_PI_SAVE_PDF_FROM_TDS wird in die Methode des Proxy im SAP ERP eingebunden.
So sieht die PDF-Datei im Format BASE64 in der Datenbank aus (Transaktion SE16).
Coding im Funktionsbaustein Z_PI_SAVE_PDF_FROM_TDS:
FUNCTION z_pi_save_pdf_from_tds.
*"----------------------------------------------------------------------
*"*"Lokale Schnittstelle:
*" IMPORTING
*" VALUE(IT_CONTENT) TYPE ZPI_CONTENT_T OPTIONAL
*"----------------------------------------------------------------------
* Deklarationen ------------------------------------------------------ *
DATA: ls_content TYPE zpi_content_s,
ls_preview type ztds_preview.
* Uhrzeit holen ------------------------------------------------------ *
GET TIME.
* PDF aus TDS sichern ------------------------------------------------ *
LOOP AT it_content INTO ls_content.
MOVE-CORRESPONDING ls_content TO ls_preview.
ls_preview-ernam = sy-uname.
ls_preview-erdat = sy-datum.
ls_preview-eruhr = sy-uzeit.
MODIFY ztds_preview from ls_preview.
ENDLOOP.
* ... und sofort verbuchen ------------------------------------------- *
COMMIT WORK.
ENDFUNCTION.
Das PDF liegt nun in der Tabelle und kann jetzt auf dem Bildschirm angezeigt werden.
Im FuBa CLOSE_FORM wurde direkt an das Ende ein Enhancement implementiert, wo dann das PDF in einem HTML-Control am Bildschirm angezeigt wird.
Coding im Enhancement am Ende des Funktionsbausteins CLOSE_FORM:
ENHANCEMENT 1 ZZ_TDS_PREVIEW. "active version
* Im folgenden wird bei einer Druckbildansicht aus dem TDS ein Dynpro * mit einem HTML-Control angezeigt, der das Formular als PDF zeigt.
data: lv_guid type guid_16.
if result-tdcovtitle+0(5) = 'GUID:'.
lv_guid = result-tdcovtitle+5.
CALL FUNCTION 'Z_FRM_PRINT_PREVIEW_FROM_TDS'
EXPORTING
iv_guid = lv_guid.
endif.
ENDENHANCEMENT.
Der FuBa Z_FRM_PRINT_PREVIEW_FROM_TDS pollt jetzt insgesamt 10 x mit einer Verzögerung von 1 sec zur GUID auf die Tabelle ZTDS_PREVIEW und zeigt im Erfolgsfall das PDF in einem HTML-Control an. Wird nichts gefunden, wird nach 10 sec abgebrochen.
Coding im Funktionsbaustein Z_FRM_PRINT_PREVIEW_FROM_TDS:
FUNCTION-POOL zfrm_preview_01 MESSAGE-ID zfrm.
* TYPES -------------------------------------------------------------- *
TYPES: tt_pdf TYPE TABLE OF sdokcntbin.
* OBJEKTREFERENZEN --------------------------------------------------- *
DATA: go_viewer TYPE REF TO i_oi_document_viewer,
go_container TYPE REF TO cl_gui_custom_container.
* INTERNE TABELLEN --------------------------------------------------- *
DATA: gt_pdf TYPE tt_pdf.
* HILFSFELDER -------------------------------------------------------- *
DATA: subrc TYPE sysubrc,
gv_file_size TYPE i,
gv_guid TYPE guid_16,
gv_counter TYPE i.
DATA: go_timer TYPE REF TO cl_gui_timer.
*----------------------------------------------------------------------*
* CLASS lcl_receiver DEFINITION
*----------------------------------------------------------------------*
CLASS lcl_receiver DEFINITION.
PUBLIC SECTION.
METHODS:
handle_finished FOR EVENT finished OF cl_gui_timer.
ENDCLASS. "lcl_receiver DEFINITION
*----------------------------------------------------------------------*
* CLASS lcl_receiver IMPLEMENTATION
*----------------------------------------------------------------------*
CLASS lcl_receiver IMPLEMENTATION.
METHOD handle_finished.
DATA: lv_count_c(5) TYPE c.
ADD 1 TO gv_counter.
WRITE gv_counter TO lv_count_c LEFT-JUSTIFIED.
CALL METHOD go_timer->run.
PERFORM read_pdf USING gv_guid
CHANGING subrc
gt_pdf
gv_file_size.
IF subrc = 0.
go_timer->cancel( ).
CALL SCREEN 2000.
CALL METHOD go_viewer->destroy_viewer.
CALL METHOD go_container->free.
FREE: go_viewer,
go_container.
ELSE.
MESSAGE s001.
ENDIF.
IF gv_counter = 10.
MESSAGE s002.
LEAVE TO SCREEN 0.
ENDIF.
ENDMETHOD. "handle_finished
ENDCLASS. "lcl_receiver IMPLEMENTATION
*----------------------------------------------------------------------*
***INCLUDE LZFRM_PREVIEW_01F01 .
*----------------------------------------------------------------------*
*&---------------------------------------------------------------------*
*& Form READ_PDF
*&---------------------------------------------------------------------*
FORM read_pdf USING pv_guid TYPE guid_16
CHANGING subrc TYPE sysubrc
gt_pdf TYPE tt_pdf
gv_file_size TYPE i.
* Deklarationen ------------------------------------------------------ *
DATA: ls_preview TYPE ztds_preview.
* Initialisieren ----------------------------------------------------- *
CLEAR: subrc,
gv_file_size,
gt_pdf,
ls_preview.
REFRESH: gt_pdf.
* PDF in Tabelle lesen ----------------------------------------------- *
SELECT single * INTO ls_preview
FROM ztds_preview
WHERE guid = pv_guid.
IF sy-subrc NE 0.
subrc = 8.
EXIT.
ENDIF.
CALL FUNCTION 'SCMS_XSTRING_TO_BINARY'
EXPORTING
buffer = ls_preview-content
append_to_table = 'X'
IMPORTING
output_length = gv_file_size
TABLES
binary_tab = gt_pdf.
ENDFORM. " READ_PDF
*&---------------------------------------------------------------------*
*& Form SHOW_PDF_INPLACE
*&---------------------------------------------------------------------*
FORM show_pdf_inplace .
* Deklarationen ------------------------------------------------------ *
IF go_viewer IS INITIAL.
CALL METHOD c_oi_container_control_creator=>get_document_viewer
IMPORTING
viewer = go_viewer.
CREATE OBJECT go_container
EXPORTING
container_name = 'CONTAINER'.
CALL METHOD go_viewer->init_viewer
EXPORTING
parent = go_container.
CALL METHOD go_viewer->view_document_from_table
EXPORTING
show_inplace = 'X' "Mit ' ' funktioniert es einwandfrei...
type = 'application'
subtype = 'pdf'
size = gv_file_size
CHANGING
document_table = gt_pdf.
ENDIF.
ENDFORM. " SHOW_PDF_INPLACE
*&---------------------------------------------------------------------*
*& Form SHOW_PDF_INPLACE
*&---------------------------------------------------------------------*
FORM print_preview.
PERFORM read_pdf USING gv_guid
CHANGING subrc
gt_pdf
gv_file_size.
CHECK subrc = 0.
* Dynpro aufrufen ---------------------------------------------------- *
CALL SCREEN 2000.
ENDFORM. " PRINT_PREVIEW
Dynpro 2000
PROCESS BEFORE OUTPUT.
MODULE status_2000.
*
PROCESS AFTER INPUT.
MODULE exit_2000 AT EXIT-COMMAND.
MODULE user_command_2000.
Weitere Informationen











