ALV-Report von Tabelle TNAPR

Aus SAP-Wiki
Zur Navigation springenZur Suche springen

Die Tabelle TNAPR beinhaltet Daten zur Outputsteuerung von Nachrichten und sie wird sehr häufig von Formularentwicklern genutzt, um z. B zu einer gegebenen Nachrichtenart das passende Druckprogramm und Formular anzuzeigen, was über die Nachrichtensteuerung im Customizing eingestellt wurde.

*&---------------------------------------------------------------------*
*& Report  ZREBTNAPR
*&
*&---------------------------------------------------------------------*
*& Autor: René Eberstein, Eberstein Consulting
*& Liest die Tabelle TNAPR und gibt sie in ALV-Liste aus
*&---------------------------------------------------------------------*

REPORT  ZREBTNAPR.
****************
* DATA & TYPES *
****************
Types: begin of ty_itab,
       kschl type tnapr-kschl,
       nacha type tnapr-nacha,
       kappl type tnapr-kappl,
       pgnam type tnapr-pgnam,
       ronam type tnapr-ronam,
       fonam type tnapr-fonam,
       sform type tnapr-sform,
       type  type tnapr-formtype,
       end of ty_itab.

Types: tty_itab type standard table of ty_itab.

Data: gt_itab type Standard table of ty_itab.

Constants: true  type xfeld value 'X',
           false type xfeld value space.

Tables: tnapr.
**************
* PARAMETERS *
**************
SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-001.
Select-Options: s_kschl for tnapr-kschl.
SELECTION-SCREEN END OF BLOCK b1.
***********************
* AT SELECTION-SCREEN *
***********************
at selection-screen.
**********************
* START-OF-SELECTION *
**********************
start-of-selection.

************
* GET_DATA *
************
  perform get_data
    changing gt_itab.

************************
* Aufruf der ALV-Liste *
************************
  perform alv_itab
      using gt_itab.
**&---------------------------------------------------------------------
**& Form alv_itab
*&---------------------------------------------------------------------
* ALV Function Mod. 'REUSE_ALV_GRID_DISPLAY_LVC'
*----------------------------------------------------------------------
FORM alv_itab
     using p_it_itab type tty_itab.

  type-pools: slis.

  data: l_repid    type sy-repid,
        lt_fcat    type LVC_T_FCAT,
        ls_layout  type LVC_S_LAYO,
*       ls_sort    type LVC_S_SORT,
*       lt_sort    type LVC_T_SORT,
        lt_events  type slis_t_event.

  l_repid = sy-repid.

***************
* Fill Layout *
***************

* ls_layout-zebra      = 'X'.        "Liste wird im Zebra-Look ausgegeben
* LS_LAYOUT-BOX_FNAME  = 'SELKZ'.    "Zeilen der Liste können markiert werden mit Spalte SELKZ
* ls_layout-no_toolbar = 'X'.        "Keine Toolbar
* ls_layout-EXCP_FNAME = 'AMPEL'.    "'1'=rot, '2'=gelb, '3'=grün
* ls_layout-TOTALS_BEF = 'X'.        "Summen vor Einzelsätzen
  LS_LAYOUT-CWIDTH_OPT = 'A'.        "Spaltenbreite wird optimiert

*************
* Fill Sort *
*************
*  CLEAR ls_sort.                    "Liste wird nach Feldern sortiert
*  ls_sort-fieldname = ' '.          "Identische Werte, die übereinander stehen, werden
*  ls_sort-spos      = '1'.          "verbunden und nur der oberste Wert wird angezeigt
*  ls_sort-up        = 'X'.
*  ls_sort-group     = 'UL'.
*  ls_sort-subtot    = 'X'.          "Zwischensummen
*  APPEND ls_sort TO lt_sort.

***************
* Fill Events *
***************
  perform alv_itab_events            "Definition Events und Form-Routinten für
    changing lt_events.              "User-Command, Top-Of-List und Status

*****************
* Fill Fieldcat *
*****************
  perform alv_itab_fcat              "Definition Felder, die ausgegeben werden sollen
    changing lt_fcat.

  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY_LVC'
    EXPORTING
      i_interface_check  = 'I'
      i_callback_program = l_repid
      is_layout_lvc      = ls_layout    "Layout ALV
      it_fieldcat_lvc    = lt_fcat      "Tabellen mit Feldern der Liste
            "it_sort_lvc                = lt_sort      "Sortierung
      i_default          = 'X'          "Default Variante kann abgespeichert werden
      i_save             = 'A'          "Benutzerabhängige Varianten können gespeichert werden
      IT_EVENTS          = lt_events    "Event-Tabelle
            "i_screen_start_column      = 10
            "i_screen_start_line        = 10
            "i_screen_end_column        = 50
            "i_screen_end_line          = 50
    TABLES
      t_outtab           = p_it_itab    "Daten Ausgabetabelle
    EXCEPTIONS
      program_error      = 1
      OTHERS             = 2.

  IF sy-subrc <> 0.
    message i531(0u) with 'Problem beim Fuba REUSE_ALV_GRID_DISPLAY_LVC'.
  ENDIF.

ENDFORM. " alv_itab
*&---------------------------------------------------------------------*
*&      Form  pf_status_set
*&---------------------------------------------------------------------*
*       Kopie des Standardstatus STANDARD aus der Funktionsgruppe SALV
*----------------------------------------------------------------------*
form alv_itab_pf_status_set
    using rt_extab type slis_t_extab.                       "#EC CALLED

  set pf-status 'STATUS_ITAB' excluding rt_extab.
  set TITLEBAR 'TITLE_ITAB'.

endform.                    "pf_status_set
*&---------------------------------------------------------------------*
*&      Form  alv_itab_events
*&---------------------------------------------------------------------*
*       ALV-Events
*----------------------------------------------------------------------*
form alv_itab_events
   changing p_ct_events type SLIS_T_EVENT.

  Data: ls_events   type slis_alv_event.

  ls_events-name = 'USER_COMMAND'.
  ls_events-form = 'ALV_ITAB_USER_COMMAND'.
  append ls_events to p_ct_events.

  ls_events-name = 'TOP_OF_PAGE'.
  ls_events-form = 'ALV_ITAB_TOP_OF_PAGE'.
  append ls_events to p_ct_events.

*ls_events-name = 'PF_STATUS_SET'.
*ls_events-form = 'ALV_ITAB_PF_STATUS_SET'.
*append ls_events to p_ct_events.

endform.                    " alv_itab_events
*&---------------------------------------------------------------------*
*&      Form  alv_itab_fcat
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
form alv_itab_fcat
  changing p_ct_fcat type LVC_T_FCAT.

  data: ls_fcat type LVC_S_FCAT.

* Field = Nachrichtenart
  ls_fcat-fieldname   = 'KSCHL'.
  ls_fcat-rollname    = 'NA_KSCHL'.
  ls_fcat-key         = true.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Applikation
  ls_fcat-fieldname   = 'KAPPL'.
  ls_fcat-rollname    = 'KAPPL'.
  ls_fcat-key         = true.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Sendemedium Nachricht
  ls_fcat-fieldname   = 'NACHA'.
  ls_fcat-rollname    = 'NA_NACHA'.
  ls_fcat-key         = true.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Druckprogramm
  ls_fcat-fieldname   = 'PGNAM'.
  ls_fcat-rollname    = 'NA_PGNAM'.
  ls_fcat-key         = false.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Form-Routine
  ls_fcat-fieldname   = 'RONAM'.
  ls_fcat-rollname    = 'NA_RONAM'.
  ls_fcat-key         = false.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = SAPScript
  ls_fcat-fieldname   = 'FONAM'.
  ls_fcat-rollname    = 'TDFORM'.
  ls_fcat-key         = false.
  ls_fcat-emphasize   = 'C300'.  "zrebconstants=>cv_color_fcat_gelb
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Smart Forms/Adobe Forms
  ls_fcat-fieldname   = 'SFORM'.
  ls_fcat-rollname    = 'NA_FNAME'.
  ls_fcat-key         = false.
  ls_fcat-emphasize   = 'C300'.  "zrebconstants=>cv_color_fcat_gelb
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

* Field = Typ (1 = Smart Forms, 2 = Adobe Forms)
  ls_fcat-fieldname   = 'TYPE'.
  ls_fcat-rollname    = 'NA_FORMTYPE'.
  ls_fcat-key         = false.
  append ls_fcat to p_ct_fcat.
  clear ls_fcat.

** Field = Original Language
*ls_fcat-fieldname    = ' '.
*ls_fcat-rollname     = ' '.
*ls_fcat-reptext      = ' '.
*ls_fcat-seltext      = ' '.
*ls_fcat-outputlen    = 10.
*ls_fcat-emphasize    = 'C300'.  "zrebconstants=>cv_color_fcat_gelb
*ls_fcat-edit         = 'X'.
*ls_fcat-do_sum       = 'X'.
*APPEND ls_fcat TO lt_fcat.
*CLEAR ls_fcat.

endform.                    " alv_KNA1_fcat
*&---------------------------------------------------------------------
*& Form USER_COMMAND
*&---------------------------------------------------------------------
*  User Command
*----------------------------------------------------------------------
form alv_itab_user_command                                  "#EC CALLED
  using r_ucomm     type sy-ucomm
        rs_selfield type slis_selfield.

  Data: ls_itab type ty_itab.

  DATA: l_ref_alv TYPE REF TO cl_gui_alv_grid,
        l_valid   TYPE c.                                   "#EC NEEDED

* geänderte Daten holen
* Referenz auf ALV holen
  CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'
    IMPORTING
      e_grid = l_ref_alv.

* Gibt die geänderte ITAB zurück
  CALL METHOD l_ref_alv->check_changed_data
    IMPORTING
      e_valid = l_valid.

* Prüfe ob ein Doppelklick auf eine Zeile erfolgte
  case r_ucomm.

    WHEN 'NEWLINE'.
      CALL METHOD l_ref_alv->APPEND_ROWS
        EXPORTING
          I_ROW_COUNT = 1.

    when '&IC1'.

*     Read line of clicked item
      read table gt_itab index rs_selfield-tabindex
      into ls_itab.

      DATA: ls_bdcdata  TYPE bdcdata,
            lt_bdcdata  TYPE TABLE OF bdcdata,
            lt_itab_msg TYPE TABLE OF bdcmsgcoll.           "#EC NEEDED

      case ls_itab-type.

*       Smart Forms/SAPscript
        when '1'
          or space.

          if ls_itab-fonam is initial and
             ls_itab-sform is initial.
             message i531(0u) with 'Kein Formular in Nachrichtenart vorhanden'(002).
             return.
          endif.

*         Smart Forms
          if ls_itab-sform is not initial.
*         Einstiegsbildschirm aufrufen
          ls_bdcdata-program = 'SAPMSSFO'.
          ls_bdcdata-dynpro = '0100'.
          ls_bdcdata-dynbegin = 'X'.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          "Bildschirm füllen
          ls_bdcdata-fnam = 'RB_SF'.
          ls_bdcdata-fval = 'X'.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          ls_bdcdata-fnam = 'SSFSCREEN-FNAME'.
          ls_bdcdata-fval = ls_itab-sform.
          APPEND ls_bdcdata TO lt_bdcdata.


*         OK-Code übergeben
          CLEAR ls_bdcdata.
          ls_bdcdata-fnam = 'BDC_OKCODE'.
          ls_bdcdata-fval = '=DISPLAY'.
          APPEND ls_bdcdata TO lt_bdcdata.

*         Transaktion ausführen
          CALL TRANSACTION 'SMARTFORMS'
            USING lt_bdcdata
             MODE 'E'                    "E = Stoppen nur bei Error, A = Anzeige (für Test)
             MESSAGES INTO lt_itab_msg.  "Fehlertabelle
          endif.

          if ls_itab-fonam is not initial.
*         Einstiegsbildschirm aufrufen
          ls_bdcdata-program = 'SAPMSSCF'.
          ls_bdcdata-dynpro = '1101'.
          ls_bdcdata-dynbegin = 'X'.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          "Bildschirm füllen
          ls_bdcdata-fnam = 'RSSCF-TDFORM'.
          ls_bdcdata-fval = ls_itab-fonam.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          ls_bdcdata-fnam = 'RSSCF-TDSPRAS'.
          ls_bdcdata-fval = sy-langu.
          APPEND ls_bdcdata TO lt_bdcdata.

*         OK-Code übergeben
          CLEAR ls_bdcdata.
          ls_bdcdata-fnam = 'BDC_OKCODE'.
          ls_bdcdata-fval = '=SHOW'.
          APPEND ls_bdcdata TO lt_bdcdata.

*         Transaktion ausführen
          CALL TRANSACTION 'SE71'
            USING lt_bdcdata
             MODE 'E'                    "E = Stoppen nur bei Error, A = Anzeige (für Test)
             MESSAGES INTO lt_itab_msg.  "Fehlertabelle
          endif.

*      Adobe Forms
       when '2'.
*         Einstiegsbildschirm aufrufen
          ls_bdcdata-program = 'SAPLFPUIFB'.
          ls_bdcdata-dynpro = '1000'.
          ls_bdcdata-dynbegin = 'X'.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          "Bildschirm füllen
          ls_bdcdata-fnam = 'D_FORM_RADIO'.
          ls_bdcdata-fval = 'X'.
          APPEND ls_bdcdata TO lt_bdcdata.
          CLEAR ls_bdcdata.

          ls_bdcdata-fnam = 'D_FORM_NAME'.
          ls_bdcdata-fval = ls_itab-sform.
          APPEND ls_bdcdata TO lt_bdcdata.


*         OK-Code übergeben
          CLEAR ls_bdcdata.
          ls_bdcdata-fnam = 'BDC_OKCODE'.
          ls_bdcdata-fval = '=WB_DISPLAY'.
          APPEND ls_bdcdata TO lt_bdcdata.

*         Transaktion ausführen
          CALL TRANSACTION 'SFP'
            USING lt_bdcdata
             MODE 'E'                    "E = Stoppen nur bei Error, A = Anzeige (für Test)
             MESSAGES INTO lt_itab_msg.  "Fehlertabelle

      endcase.
  endcase.

endform. " USER_COMMAND_ITAB
*---------------------------------------------------------------------
*      FORM top_of_page
*---------------------------------------------------------------------
*      Fülle Header für ALV-Listen
*----------------------------------------------------------------------
FORM alv_itab_top_of_page.                                  "#EC CALLED

  DATA: listheader TYPE slis_t_listheader,
        w_listheader TYPE slis_listheader,
        l_datum(10) TYPE c,
        l_lines TYPE i.

* Schreibe Anzahl Datensätze Reporte in Grid Titel
  DESCRIBE TABLE gt_itab LINES l_lines.

* Datum in Ausgabeform bringen
  WRITE sy-datum TO l_datum.

  w_listheader-typ = 'S'.
  w_listheader-key = 'Datum'.
  w_listheader-info = l_datum.
  APPEND w_listheader TO listheader.

  w_listheader-typ = 'S'.
  w_listheader-key = 'Anzahl Datensätze'.
  w_listheader-info = l_lines.
  APPEND w_listheader TO listheader.

  CALL FUNCTION 'REUSE_ALV_COMMENTARY_WRITE'
    EXPORTING
      it_list_commentary = listheader.
*          I_LOGO             =
*          I_END_OF_LIST_GRID =

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  GET_DATA
*&---------------------------------------------------------------------*
*       Lesen Daten aus Tabelle TNAPR
*----------------------------------------------------------------------*
FORM GET_DATA  CHANGING PCT_ITAB type tty_itab.

  Select
    kschl      "Nachrichtenart
    nacha      "Medium
    kappl      "Applikation
    pgnam      "Programmname
    ronam      "Form-Routine
    fonam      "SAPScript
    sform      "Smart Forms/Adobe Forms
    formtype   "Typ 1 (Smart Forms), 2 (Adobe Forms)
    into table pct_itab
    from tnapr
    where kschl in s_kschl.

ENDFORM.