ALV-Report von Tabelle NAST
Aus SAP-Wiki
Zur Navigation springenZur Suche springen
*&---------------------------------------------------------------------* *& Report ZREBNAST *& Autor: René Eberstein, Eberstein Consulting *&---------------------------------------------------------------------* *& Selektion Tabelle NAST *& *&---------------------------------------------------------------------* REPORT ZREBNAST.
**************** * DATA & TYPES * **************** Types: begin of ty_itab, kappl type nast-KAPPL, "Applikation objky type nast-OBJKY, "Objektschlüssel kschl type nast-KSCHL, "Nachrichtenart spras type nast-SPRAS, "Sprache parnr type nast-PARNR, "Partnernummer parvw type nast-PARVW, "Partnerrolle erdat type nast-ERDAT, "Erstellungsdatum nacha type nast-nacha, "Medium DATVR type nast-DATVR, "Datum Verarbeitung usnam type nast-usnam, "Benutzer vstat type nast-vstat, "Versandstatus LDEST type nast-LDEST, "Ausgabegerät 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: nast, sscrfields.
************** * PARAMETERS * ************** selection-screen pushbutton /02(17) text user-command yz. selection-screen skip. SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-001. Select-Options: s_kappl for nast-kappl, "Applikation s_objky for nast-objky, "Objektschlüssel s_kschl for nast-kschl, "Nachrichtenart s_spras for nast-spras, "Sprache s_parnr for nast-parnr, "Partnernummer s_parvw for nast-parvw, "Partnerrolle s_erdat for nast-erdat, "Erstellungsdatum s_nacha for nast-nacha, "Medium s_datvr for nast-datvr, "Datum Verarbeitung s_usnam for nast-usnam, "Benutzer s_vstat for nast-vstat, "Versandstatus s_ldest for nast-ldest. "Ausgabegerät SELECTION-SCREEN END OF BLOCK b1.
****************** * INITIALIZATION * ****************** INITIALIZATION. text = 'TNAPR'.
*********************** * AT SELECTION-SCREEN * *********************** at selection-screen. * Programm ZREB_YZ aufrufen bei Push "Auswertung" if sscrfields-ucomm = 'YZ'. clear sscrfields-ucomm. call transaction 'ZREBTNAPR'. endif.
********************** * START-OF-SELECTION * ********************** start-of-selection. *********************** * Lese Daten von NAST * *********************** 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 = Applikation ls_fcat-fieldname = 'KAPPL'. ls_fcat-rollname = 'SNA_KAPPL'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'OBJKY'. ls_fcat-rollname = 'NA_OBJKEY'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'KSCHL'. ls_fcat-rollname = 'SNA_KSCHL'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'SPRAS'. ls_fcat-rollname = 'NA_SPRAS'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'PARNR'. ls_fcat-rollname = 'NA_PARNR'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'PARVW'. ls_fcat-rollname = 'SNA_PARVW'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'ERDAT'. ls_fcat-rollname = 'NA_ERDAT'. ls_fcat-key = true. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'NACHA'. ls_fcat-rollname = 'NA_NACHA'. ls_fcat-key = false. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'DATVR'. ls_fcat-rollname = 'NA_DATVR'. ls_fcat-key = false. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'USNAM'. ls_fcat-rollname = 'USNAM'. ls_fcat-key = false. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'VSTAT'. ls_fcat-rollname = 'NA_VSTAT'. ls_fcat-key = false. append ls_fcat to p_ct_fcat. clear ls_fcat. * Field = ls_fcat-fieldname = 'LDEST'. ls_fcat-rollname = 'RSPOPNAME'. 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. * case rs_selfield-fieldname. * * when ' '. * 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 *&---------------------------------------------------------------------* * Lese Daten von der Tabelle NAST *----------------------------------------------------------------------* FORM GET_DATA CHANGING PCT_ITAB type tty_itab. Select * into CORRESPONDING FIELDS OF TABLE pct_itab from nast where kappl in s_kappl and "Applikation objky in s_objky and "Objektschlüssel kschl in s_kschl and "Nachrichtenart spras in s_spras and "Sprache parnr in s_parnr and "Partnernummer parvw in s_parvw and "Partnerrolle erdat in s_erdat and "Erstellungsdatum nacha in s_nacha and "Medium datvr in s_datvr and "Verarbeitungsdatum usnam in s_usnam and "Benutzer vstat in s_vstat and "Versandstatus ldest in s_ldest. "Ausgabegerät ENDFORM. " GET_DATA