Help required on ALV REPORT

Hi,
Please help with a solution:
my requirement is to add the following to an existing program.
i need to add 3 fields from a new table(a table which is not used in the program).
the fields are :
Vendor Part No. : Field ZWTYVND-Z_WTY_MAT_VPN
Mail To Vendor No.:  Field ZWTYVND-Z_WTY_LIFNR_MAIL
Mail To Vendor Name:  Field ZWTYVND-WTY_NAME1
here is the program code:
REPORT  zwtyrep008
        LINE-SIZE 500
        MESSAGE-ID zpp02.
*& Report  ZWTYREP008                                                  *
*$*$----------------------------------------------------------------$*$*
*$*$---T A B L E S--------------------------------------------------$*$*
*$*$----------------------------------------------------------------$*$*
TABLES: wty_pnwtyh_dia,    "
        wty_pnwtyv_dia,
        mara,
        usr21,
        pnwtyv,
        adrp,
        s084.
*$*$----------------------------------------------------------------$*$*
*$*$ CONSTANTS
*$*$----------------------------------------------------------------$*$*
CONSTANTS: true(1)                                VALUE 'X',
           false(1)                               VALUE ' '.
CONSTANTS: c_year_low(4)                          VALUE '1960',
           c_year_high(4)                         VALUE '9999',
           c_zero        LIKE wty_pvwty_dia-valiv VALUE '0.00',
           c_claim_to_process TYPE i              VALUE 3000.
CONSTANTS: c_save(1)               VALUE 'U'.
*$*$----------------------------------------------------------------$*$*
*$*$ TYPES
*$*$----------------------------------------------------------------$*$*
TYPE-POOLS: slis, pwty.
TYPES: BEGIN OF lt_period,
               year(4),
               poper(2),
               start     TYPE d,
               end       TYPE d,
      END   OF lt_period.
TYPES: BEGIN OF tp_charac_value,
             atwrt LIKE cawn-atwrt,
       END   OF tp_charac_value.
TYPES: BEGIN OF tp_submit_records,
             header_guid   LIKE wty_pnwtyv_dia-header_guid,
             versn         LIKE wty_pnwtyv_dia-versn,
             prev_version  LIKE wty_pnwtyv_dia-prev_version,
             kateg         LIKE wty_pnwtyv_dia-kateg,
             aktiv         LIKE wty_pnwtyv_dia-aktiv,
             pnguid        LIKE wty_pnwtyv_dia-pnguid,
             knumv         LIKE wty_pnwtyv_dia-knumv,
       END   OF tp_submit_records.
TYPES: BEGIN OF tp_cond_table,
             kschl  LIKE konv-kschl,
             zaehk  LIKE konv-zaehk,
             kinak  LIKE konv-kinak,
             kbetr  LIKE konv-kbetr,
       END   OF tp_cond_table.
*$*$----------------------------------------------------------------$*$*
*$*$---I N T E R N A L   T A B L E S--------------------------------$*$*
*$*$----------------------------------------------------------------$*$*
* Report table to display with ALV
DATA: t_detail_info TYPE STANDARD TABLE OF zwty_claim_avg_rep_det
                    WITH HEADER LINE
                    INITIAL SIZE 0.
FIELD-SYMBOLS:<fs_detail_info> LIKE LINE OF t_detail_info.
DATA: t_summary_alv TYPE STANDARD TABLE OF zwty_claim_avg_rep_sum
                    WITH HEADER LINE
                    INITIAL SIZE 0.
FIELD-SYMBOLS:<fs_summary_alv>  LIKE LINE OF t_summary_alv.
DATA: t_detail_alv  TYPE STANDARD TABLE OF zwty_claim_avg_rep_det
                    WITH HEADER LINE
                    INITIAL SIZE 0.
FIELD-SYMBOLS:<fs_detail_alv> LIKE LINE OF t_detail_alv.
DATA: it_submit_records TYPE HASHED TABLE OF tp_submit_records
                       WITH UNIQUE KEY header_guid versn
                       WITH HEADER LINE
                       INITIAL SIZE 0.
FIELD-SYMBOLS: <fs_submit_rec_vs2> TYPE tp_submit_records.
DATA: it_period TYPE HASHED TABLE OF lt_period
                WITH UNIQUE KEY year poper
                WITH HEADER LINE
                INITIAL SIZE 0.
FIELD-SYMBOLS: <fs_it_period>      LIKE LINE OF it_period.
DATA: it_pvwty_dia_all  TYPE wty_pvwty_dia_tab.
FIELD-SYMBOLS: <fs_pvwty_dia_es3> LIKE LINE OF it_pvwty_dia_all.
DATA: it_cond_table TYPE STANDARD TABLE OF tp_cond_table
                    WITH HEADER LINE
                    INITIAL SIZE 0.
FIELD-SYMBOLS: <fs_cond_table> TYPE tp_cond_table.
*$*$----------------------------------------------------------------$*$*
*$*$---G L O B A L  D A T A  ---------------------------------------$*$*
*$*$----------------------------------------------------------------$*$*
DATA: gt_fieldcat_sum   TYPE slis_t_fieldcat_alv,
      gt_fieldcat_det  TYPE slis_t_fieldcat_alv,
      gtw_fieldcat     LIKE LINE OF gt_fieldcat_sum,
      gt_top_of_page   TYPE slis_t_listheader,
      gtw_top_of_page  LIKE LINE OF gt_top_of_page,
      gt_end_of_page   TYPE slis_t_listheader,
      gtw_end_of_page  LIKE LINE OF gt_end_of_page,
      gs_layout        TYPE slis_layout_alv,
      gt_excluding     TYPE slis_t_extab,
      gtw_excluding    LIKE LINE OF gt_excluding,
      gs_variant1       TYPE disvariant,
      gs_variant2       TYPE disvariant,
      eventcat         TYPE slis_t_event,         "EVENEMENT
      eventcat_ln      LIKE LINE OF eventcat,     "LIGNE D'EVENEMENT
      gt_sort          TYPE slis_t_sortinfo_alv,
      gtw_sort         LIKE LINE OF gt_sort.
DATA: wa_lis_progname  LIKE sy-cprog,
      wa_low_date      TYPE d,
      wa_high_date     TYPE d,
      wa_index_mat     TYPE i,
      wa_index_link    TYPE i,
      wa_level_alv     TYPE i.
DATA: g_callback_pgm(40)          TYPE c,
      g_callback_user_command(30) TYPE c.
DATA: my_print TYPE  slis_print_alv.
FIELD-SYMBOLS: <fs_pvwty_dia> TYPE wty_pvwty_dia.
* SELECTION SCREEN                                          *
SELECTION-SCREEN SKIP 1.
SELECTION-SCREEN BEGIN OF BLOCK post WITH FRAME TITLE text-001.
SELECT-OPTIONS: s_cpudt FOR s084-spmon NO-EXTENSION,
                s_postdt FOR  wty_pnwtyv_dia-fkdat NO-EXTENSION.
SELECTION-SCREEN END   OF BLOCK post.
SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE text-002.
SELECT-OPTIONS: s_vend  FOR pnwtyv-v_parnr NO INTERVALS.
SELECT-OPTIONS: s_clgrp FOR wty_pnwtyh_dia-clmgrp.
SELECTION-SCREEN SKIP 1.
SELECT-OPTIONS: s_model  FOR  wty_pnwtyh_dia-z_wty_model.
SELECT-OPTIONS: s_matnr  FOR  mara-matnr.
SELECTION-SCREEN END   OF BLOCK b1.
SELECTION-SCREEN BEGIN OF BLOCK lay WITH FRAME TITLE text-004.
PARAMETERS: varn1  TYPE slis_vari MEMORY ID fit_alv_gl,  "Dis. variant
            varn2  TYPE slis_vari.
SELECTION-SCREEN END   OF BLOCK lay.
*$*$----------------------------------------------------------------$*$*
*$*$---A T  S E L E C T I O N - S C R E E N-------------------------$*$*
*$*$----------------------------------------------------------------$*$*
AT SELECTION-SCREEN ON VALUE-REQUEST FOR varn1.
  PERFORM alv_variant_f4 USING '0001' CHANGING varn1.
AT SELECTION-SCREEN ON VALUE-REQUEST FOR varn2.
  PERFORM alv_variant_f4 USING '0002' CHANGING varn2.
AT SELECTION-SCREEN ON BLOCK post.  "Validate posting parameters
  PERFORM validate_posting_parameter.
AT SELECTION-SCREEN ON s_model.     "Validate model
  PERFORM validate_model.
AT SELECTION-SCREEN ON s_vend.      "Validate vendor
  PERFORM validate_vendor.
AT SELECTION-SCREEN ON s_matnr.      "Validate material
  PERFORM validate_material.
AT SELECTION-SCREEN ON s_clgrp.     "Validate claim group
  PERFORM validate_claim_group.
AT SELECTION-SCREEN OUTPUT.
* Initialization.
INITIALIZATION.
* Initialize default display variant for ALV report
  CLEAR gs_variant1.
  MOVE sy-repid TO: gs_variant1-report,
                    gs_variant2-report.
  gs_variant1-handle = '0001'.
  gs_variant2-handle = '0002'.
  wa_lis_progname   = sy-repid.
  PERFORM set_default_variant CHANGING gs_variant1
                                       varn1.
  PERFORM set_default_variant CHANGING gs_variant2
                                       varn2.
  PERFORM get_fin_period USING c_year_low c_year_high.
  PERFORM set_period_to_analyse.
*$*$----------------------------------------------------------------$*$*
*$*$---S T A R T - O F - S E L E C T I O N--------------------------$*$*
*$*$----------------------------------------------------------------$*$*
START-OF-SELECTION.
  PERFORM select_claim_to_process.
*$*$----------------------------------------------------------------$*$*
*$*$---E N D - O F - S E L E C T I O N------------------------------$*$*
*$*$----------------------------------------------------------------$*$*
END-OF-SELECTION.
  CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
   EXPORTING
*        PERCENTAGE       = 0
     text             =  text-m02.
  IF sy-batch = 'X'.
    PERFORM set_print_alv_grid.
  ENDIF.
  PERFORM show_alv_grid.
*&      Form  PRINT_DETAIL_ALV
FORM show_alv_grid.
* Prepare ALV_GRID before display
* ===============================
  PERFORM init_field.
  PERFORM init_layout.
  PERFORM init_fieldcat.
  PERFORM init_excluding.
  PERFORM init_event.
*  SORT report_data BY bukrs werks.
  PERFORM call_alv_list_display_level_1.
ENDFORM.                    " PRINT_DETAIL
*&      Form  VARIANT_F4   copied from RPCWCCK3
*       Display a list of all available display variants for the ALV.
*      <--P_varn1  Return the selected variant and return
FORM variant_f4 CHANGING p_varn1 TYPE disvariant-variant.
  DATA: l_variant LIKE disvariant.
* Get the list of available variants for the report
  l_variant-report = sy-repid.
  CALL FUNCTION 'REUSE_ALV_VARIANT_F4'
    EXPORTING
      is_variant = l_variant
      i_save     = 'A'
    IMPORTING
      es_variant = l_variant.
  p_varn1 = l_variant-variant.
ENDFORM.                               " VARIANT_F4
*&      Form  INIT_FIELD
FORM init_field.
  MOVE sy-repid          TO g_callback_pgm.
  MOVE 'MY_USER_COMMAND' TO g_callback_user_command.
ENDFORM.                    " INIT_FIELD
*&      Form  INIT_LAYOUT
FORM init_layout.
  gs_layout-window_titlebar   = sy-title.
  gs_layout-colwidth_optimize = 'X'.
  gs_layout-expand_all        = 'X'.
  gs_layout-no_subtotals      = ''.
  gs_layout-key_hotspot       = 'X'.         " Afficher Hotspot
  gs_layout-zebra             = 'X'.
  gs_layout-group_change_edit = 'X'.
  gs_layout-f2code            = 'DISPLAY'.
* gs_layout-max_linesize      = 400.
* gs_layout-totals_only       = 'X'.
ENDFORM.                    " INIT_LAYOUT
*&      Form  INIT_FIELDCAT
FORM init_fieldcat.
  DATA: lt_fieldcatalog    TYPE lvc_t_fcat,
        ltw_fieldcatalog   TYPE lvc_s_fcat.
  REFRESH: lt_fieldcatalog,
           gt_fieldcat_sum,
           gt_fieldcat_det.
  CLEAR   gtw_sort.
  REFRESH gt_sort.
* ==============================================
* Set the label column for summary report leve 1
* ==============================================
  CALL FUNCTION 'LVC_FIELDCATALOG_MERGE'
    EXPORTING
      i_structure_name       = 'ZWTY_CLAIM_AVG_REP_SUM'
      i_client_never_display = 'X'
    CHANGING
      ct_fieldcat            = lt_fieldcatalog.
*                             FIELD     pos sub  up  down Group
  PERFORM create_sort USING: 'V_PARNR'   1  'X'  'X'  ' '   'X',
                             'NAME'      2  'X'  'X'  ' '   'X',
                             'MAKTX'     3  'X'  'X'  ' '   'X',
                             'MATNR'     4  'X'  'X'  ' '   'X'.
  LOOP AT lt_fieldcatalog INTO ltw_fieldcatalog.
    CLEAR: gtw_fieldcat.
    MOVE-CORRESPONDING ltw_fieldcatalog TO gtw_fieldcat.
    PERFORM set_alv_field_desc USING  ltw_fieldcatalog '1'.
    APPEND gtw_fieldcat TO gt_fieldcat_sum.
  ENDLOOP.
  PERFORM set_hot_spot TABLES gt_fieldcat_sum USING 'CLAIM_NB'.
* =========================================
* Field Catalog for Detail report (level 2)
* =========================================
  REFRESH: lt_fieldcatalog.
  CALL FUNCTION 'LVC_FIELDCATALOG_MERGE'
    EXPORTING
      i_structure_name       = 'ZWTY_CLAIM_AVG_REP_DET'
      i_client_never_display = 'X'
    CHANGING
      ct_fieldcat            = lt_fieldcatalog.
  LOOP AT lt_fieldcatalog INTO ltw_fieldcatalog.
    CLEAR: gtw_fieldcat.
    MOVE-CORRESPONDING ltw_fieldcatalog TO gtw_fieldcat.
    PERFORM set_alv_field_desc USING  ltw_fieldcatalog '2'.
    APPEND gtw_fieldcat TO gt_fieldcat_det.
  ENDLOOP.
  PERFORM set_hot_spot TABLES gt_fieldcat_det USING 'CLMNO'.
ENDFORM.                    " INIT_FIELDCAT
*&      Form  INIT_SORT
FORM create_sort USING  p_fieldname p_spos
                        p_subtot            TYPE char1
                        p_up                TYPE char1
                        p_down              TYPE char1
                        p_group             TYPE char1.
  CLEAR: gtw_sort.
  gtw_sort-fieldname = p_fieldname.
  gtw_sort-spos      = p_spos.
  gtw_sort-subtot    = p_subtot.
  gtw_sort-up        = p_up.
  gtw_sort-down      = p_down.
  gtw_sort-group     = p_group.
  APPEND gtw_sort TO gt_sort.
ENDFORM.                    "create_sort
*&      Form  INIT_EXCLUDING
*       Exclude des option de l'application tool bar
FORM init_excluding.
  CLEAR   gtw_excluding.
  REFRESH gt_excluding.
  gtw_excluding-fcode   = '&ABC'.
  APPEND gtw_excluding TO gt_excluding.
ENDFORM.                    " INIT_EXCLUDING
*&      Form  call_alv_list_display_level_1
FORM call_alv_list_display_level_1.
* DATA: l_i_save  VALUE 'U'.   "User-specific variants only
  DATA: l_i_save  VALUE 'A'.   "Any type of variants
  gs_variant1-report  = sy-repid.
  gs_variant1-variant = varn1.
  gs_layout-colwidth_optimize = true.
  wa_level_alv = 1.
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      i_callback_program      = g_callback_pgm
      i_callback_user_command = g_callback_user_command
      is_layout               = gs_layout
      it_fieldcat             = gt_fieldcat_sum
      it_excluding            = gt_excluding
      it_sort                 = gt_sort
      i_save                  = l_i_save
      is_variant              = gs_variant1
      it_events               = eventcat
      is_print                = my_print
    TABLES
      t_outtab                = t_summary_alv
    EXCEPTIONS
      program_error           = 1
      OTHERS                  = 2.
ENDFORM.                    " call_alv_list_display_level_1
*&      Form  INIT_EVENT
*       Determine quelle routine a executer selon l'event
FORM init_event.
  eventcat_ln-name = 'TOP_OF_PAGE'.
  eventcat_ln-form = 'ALV_PAGE_HEADER'.
  APPEND eventcat_ln TO eventcat.
  eventcat_ln-name = 'END_OF_PAGE'.
  eventcat_ln-form = 'FOOTER_PAGE'.
  APPEND eventcat_ln TO eventcat.
ENDFORM.                    " INIT_EVENT
*&      Form  ALV_PAGE_HEADER
FORM alv_page_header.
  DATA: l_date_time(22),
        l_char7(7),
        l_char10(10).
  DATA: p_date(10) TYPE c.
  DATA: p_time(8)  TYPE c.
  DATA: p_name(80) TYPE c.
* Format current date and time
  WRITE sy-datum TO p_date USING EDIT MASK '____/__/__'.
  WRITE sy-uzeit TO p_time USING EDIT MASK '__:__:__'.
  CONCATENATE p_date '-' p_time
              INTO l_date_time SEPARATED BY space.
* Set the user name
  SELECT SINGLE
         persnumber addrnumber INTO (usr21-persnumber, usr21-addrnumber)
             FROM  usr21
             WHERE bname = sy-uname.
  SELECT SINGLE name_first name_last
         INTO   (adrp-name_first, adrp-name_last )
         FROM   adrp
         WHERE  persnumber = usr21-persnumber.
  CONCATENATE adrp-name_first adrp-name_last INTO p_name
  SEPARATED BY space.
  REFRESH gt_top_of_page.
  CLEAR   gtw_top_of_page.
* Program title ------------------------------------------------
  CLEAR gtw_top_of_page.
  gtw_top_of_page-typ  = 'H'.
  gtw_top_of_page-info = sy-title.
  APPEND gtw_top_of_page TO gt_top_of_page.
  CLEAR gtw_top_of_page.
  gtw_top_of_page-typ     = 'S'.
  gtw_top_of_page-key  = 'Parameters :'.
* Period / Posting Date -----------------------------------------
  IF s_cpudt[] IS INITIAL.
    WRITE s_postdt-low TO l_char10.
    CONCATENATE gtw_top_of_page-info
                text-104
                l_char10
           INTO gtw_top_of_page-info SEPARATED BY space.
    IF NOT s_postdt-high IS INITIAL.
      WRITE s_postdt-high TO l_char10.
      CONCATENATE gtw_top_of_page-info
                  text-105
                  l_char10
                  INTO gtw_top_of_page-info SEPARATED BY space.
    ENDIF.
    APPEND gtw_top_of_page TO gt_top_of_page.
  ELSE.
    CONCATENATE s_cpudt-low(4) '/' s_cpudt-low+4(2)
                INTO l_char7 .
    CONCATENATE gtw_top_of_page-info
                text-103
                l_char7
                INTO gtw_top_of_page-info SEPARATED BY space.
    IF s_cpudt-high NE space.
      CONCATENATE s_cpudt-high(4) '/' s_cpudt-high+4(2)
                  INTO l_char7 .
      CONCATENATE gtw_top_of_page-info
                  text-105
                  l_char7
                  INTO gtw_top_of_page-info SEPARATED BY space.
    ENDIF.
    APPEND gtw_top_of_page TO gt_top_of_page.
  ENDIF.
* Display wich level we display -----------------------------
*  IF wa_level_alv > 1.
*    CLEAR gtw_top_of_page.
*    IF wa_level_alv = 2.
*      gtw_top_of_page-info = t_summary_alv-v_parnr.
*      SHIFT gtw_top_of_page-info LEFT DELETING LEADING '0'.
*    ENDIF.
*    gtw_top_of_page-typ     = 'S'.
*    gtw_top_of_page-key  = 'Partner:'.
*    APPEND gtw_top_of_page TO gt_top_of_page.
*  ENDIF.
* Executed by -----------------------------------------------
  CLEAR gtw_top_of_page.
  gtw_top_of_page-typ     = 'S'.
  gtw_top_of_page-key  = 'Report executed by :'.
  gtw_top_of_page-info =  p_name.
* * Date & time of execution --------------------------------
  APPEND gtw_top_of_page TO gt_top_of_page.
  gtw_top_of_page-key  = 'DATE :'.
  gtw_top_of_page-info = l_date_time.
  APPEND gtw_top_of_page TO gt_top_of_page.
* Name of the report ----------------------------------------
  CLEAR gtw_top_of_page.
  gtw_top_of_page-typ  = 'A'.
* LS_LINE-KEY:  not used for this type
  gtw_top_of_page-info = sy-repid.
  APPEND gtw_top_of_page TO gt_top_of_page.
  CALL FUNCTION 'REUSE_ALV_COMMENTARY_WRITE'
    EXPORTING
      it_list_commentary = gt_top_of_page.
*  IF sy-batch = 'X' AND sy-linsz > 255 AND l_ctr_newpage = 0.
*    NEW-PAGE PRINT ON LINE-SIZE 255.   "Pour wrapper !!!!!!
*  ENDIF.
ENDFORM.                    "ALV_PAGE_HEADER
*&      Form  footer_page
FORM footer_page.
  DATA: l_footer(300),
        l_page_no(5).
  l_page_no   = sy-pagno.
  CONCATENATE 'Page' l_page_no INTO l_footer SEPARATED BY space.
  SKIP 2.
  WRITE:/001 l_footer(sy-linsz) CENTERED.
ENDFORM.                    "footer_page
*&      Form  MY_USER_COMMAND
*       text
*      -->P_SY_UCOMM  text
*      -->P_GS_SELFIELD  text
FORM my_user_command USING    p_sy_ucomm
                              p_gs_selfield TYPE slis_selfield.
  DATA: l_claim_no         LIKE mcshier-hiername,
        lv_tcode_last(15).
* ======================================================
* Call TX WTY to display the claim. Only possible at the
* detail report(level 3)
* ======================================================
  CASE p_gs_selfield-fieldname.
    WHEN 'CLMNO'.
      READ TABLE t_detail_alv INDEX p_gs_selfield-tabindex.
      SHIFT t_detail_alv-clmno LEFT DELETING LEADING '0'.
      l_claim_no = t_detail_alv-clmno.
      CONCATENATE sy-tcode syst-modno
                  INTO lv_tcode_last.
      EXPORT wty_tcode_last_memoid FROM lv_tcode_last TO MEMORY
                                   ID    'WTY_TCODE_LAST_MEMOID'.
      SET PARAMETER ID 'CLMNO' FIELD l_claim_no.
      CALL TRANSACTION 'WTY' AND SKIP FIRST SCREEN.
    WHEN 'CLAIM_NB'.
*     =====================================
*     Display the next level of information
*     =====================================
      CASE  wa_level_alv.
        WHEN 1.
          REFRESH: t_detail_alv.
          wa_level_alv = 2.
          READ TABLE t_summary_alv INDEX p_gs_selfield-tabindex.
          LOOP AT t_detail_info
                  ASSIGNING <fs_detail_info>
                  WHERE v_parnr    EQ t_summary_alv-v_parnr
                    AND crncy      EQ t_summary_alv-crncy
                    AND item_type  EQ t_summary_alv-item_type
                    AND ov_meinh   EQ t_summary_alv-ov_meinh
                    AND iv_meinh   EQ t_summary_alv-iv_meinh
                    AND matnr      EQ t_summary_alv-matnr.
            MOVE-CORRESPONDING <fs_detail_info> TO t_detail_alv.
            APPEND t_detail_alv.
          ENDLOOP.
          CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
            EXPORTING
              i_callback_program      = g_callback_pgm
              i_callback_user_command = g_callback_user_command
              is_layout               = gs_layout
              it_fieldcat             = gt_fieldcat_det
              it_excluding            = gt_excluding
*              it_sort                 = gt_sort
              i_save                  = c_save
              is_variant              = gs_variant2
              it_events               = eventcat
              is_print                = my_print
            TABLES
              t_outtab                = t_detail_alv
            EXCEPTIONS
              program_error           = 1
              OTHERS                  = 2.
          wa_level_alv = 1.
      ENDCASE.
  ENDCASE.
ENDFORM.                    " MY_USER_COMMAND
*       FORM PRINT_ALV_GRID                                           *
*       Print the report not on screen for special batch processing.  *
*  -->  IT         Table to print  -   Z_HRF_BEN_CONF_FLEX
FORM set_print_alv_grid.
  my_print-print              = 'X'.  "Force printing
  my_print-no_print_selinfos  = 'X'.
  my_print-no_print_listinfos = 'X'.
  my_print-no_new_page        = ''.   "Separate spool files
  my_print-prnt_title         = 'X'.
  my_print-prnt_info          = 'X'.
  my_print-reserve_lines      = 3.
ENDFORM.                    "set_print_alv_grid
*&      Form  ALV_VARIANT_F4
FORM alv_variant_f4 USING    p_handle
                    CHANGING p_vari.
  DATA: rs_variant LIKE disvariant.
  DATA: nof4 TYPE c.
  CLEAR nof4.
  LOOP AT SCREEN.
    IF screen-name = p_vari.
      IF screen-input = 0.
        nof4 = 'X'.
      ENDIF.
    ENDIF.
  ENDLOOP.
  rs_variant-report   = sy-repid.
  rs_variant-username = sy-uname.
  rs_variant-handle   = p_handle.
  CALL FUNCTION 'REUSE_ALV_VARIANT_F4'
    EXPORTING
      is_variant = rs_variant
      i_save     = 'A'
    IMPORTING
      es_variant = rs_variant
    EXCEPTIONS
      OTHERS     = 1.
  IF sy-subrc = 0 AND nof4 EQ space.
    p_vari = rs_variant-variant.
  ENDIF.
ENDFORM.                               " ALV_VARIANT_F4
*&      Form  validate_model
*       text
*  -->  p1        text
*  <--  p2        text
FORM validate_model .
  DATA: l_matnr LIKE mara-matnr.
  SELECT SINGLE matnr
         INTO  l_matnr
         FROM  mara
         WHERE matnr IN s_model
           AND mtart EQ 'ZKMA'.
  IF sy-subrc NE 0.
    MESSAGE e000 WITH text-e07.
  ENDIF.
ENDFORM.                    " validate_model
*&      Form  select_claim_to_process
*       text
*  -->  p1        text
*  <--  p2        text
FORM select_claim_to_process .
  DATA: lt_pnwtyh_dia     TYPE wty_pnwtyh_dia_tab,
        lt_pnwtyv_dia     TYPE wty_pnwtyv_dia_tab,
        lt_pvwty_dia      TYPE wty_pvwty_dia_tab,
        lt_pnwtyh_dia_tmp TYPE wty_pnwtyh_dia_tab,
        lt_pnwtyv_dia_tmp TYPE wty_pnwtyv_dia_tab,
        lt_pvwty_dia_tmp  TYPE wty_pvwty_dia_tab,
        lt_pvwty_dia_mat  TYPE wty_pvwty_dia_tab,
        lt_sel_fkdat      TYPE pwty_sel_fkdat_pt,
        lt_sel_v_parnr    TYPE pwty_sel_v_parnr_pt,
        lt_sel_clmty      TYPE pwty_sel_clmty_pt,
        lt_sel_clmgrp     TYPE pwty_sel_clmgrp_pt.
  DATA: lst_sel_fkdat LIKE LINE OF lt_sel_fkdat,
        lst_sel_clmty LIKE LINE OF lt_sel_clmty.
  DATA: BEGIN OF lt_clmno OCCURS 0,
              clmno   LIKE pnwtyh-clmno,
        END   OF lt_clmno,
        lt_clmno_tmp   LIKE lt_clmno OCCURS 0,
        lt_claim    TYPE pwty_sel_clmno_pt,
        wa_clmno    LIKE LINE OF lt_claim.
  DATA: l_nb_claim         TYPE i.
  RANGES: lr_model FOR wty_pnwtyh_dia-z_wty_model.
  FIELD-SYMBOLS: <lfs_pnwtyh_dia>    LIKE LINE OF lt_pnwtyh_dia,
                 <lfs_pnwtyv_dia>    LIKE LINE OF lt_pnwtyv_dia,
                 <lfs_pvwty_dia_es2> LIKE LINE OF lt_pvwty_dia,
                 <lfs_pvwty_dia_mat> LIKE LINE OF lt_pvwty_dia_mat.
  REFRESH: lt_pnwtyh_dia, lt_pnwtyv_dia,lt_pvwty_dia, lt_sel_clmty,
           lr_model, t_detail_info, t_summary_alv, lt_pvwty_dia_mat.
  CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
   EXPORTING
*    PERCENTAGE       = 0
     text             =  text-m01. "Extracting claim
* ========================
* Get the Claim to process
* ========================
*  SELECT clmno
*         INTO  TABLE lt_clmno
*         FROM  pnwtyh
*         WHERE z_wty_convflg  EQ space
*           AND z_wty_error    EQ space
*  wa_clmno-sign   = 'I'.
*  wa_clmno-option = 'EQ'.
*  LOOP AT lt_clmno.
*    wa_clmno-low     = lt_clmno-clmno.
*    APPEND wa_clmno  TO lt_claim.
*  ENDLOOP.
  lst_sel_fkdat-sign   = 'I'.
  lst_sel_fkdat-option = 'BT'.
  lst_sel_fkdat-low    = wa_low_date.
  lst_sel_fkdat-high   = wa_high_date.
  APPEND lst_sel_fkdat TO lt_sel_fkdat.
  lst_sel_clmty-sign   = 'E'.
  lst_sel_clmty-option = 'EQ'.
  lst_sel_clmty-low    = 'ZSBC'.
  APPEND lst_sel_clmty TO lt_sel_clmty.
  lt_sel_v_parnr[] = s_vend[].
  lt_sel_clmgrp[]  = s_clgrp[].
  CALL FUNCTION 'PVSDBWTY_CLAIM_SELECT'
    EXPORTING
      it_sel_fkdat     = lt_sel_fkdat
      it_sel_clmgrp    = lt_sel_clmgrp
      it_sel_v_parnr   = lt_sel_v_parnr
      it_sel_clmty     = lt_sel_clmty
*      it_sel_clmno     = lt_claim
    IMPORTING
      et_pnwtyh_dia    = lt_pnwtyh_dia
      et_pnwtyv_dia    = lt_pnwtyv_dia
      et_pvwty_dia     = lt_pvwty_dia
    EXCEPTIONS
      no_entry_found   = 1
      authority_failed = 2
      OTHERS           = 3.
  IF sy-subrc = 3 .
    MESSAGE e309(wty) .
  ENDIF .
  CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
   EXPORTING
*    PERCENTAGE       = 0
     text             =  text-m03. "Extracting claim
  LOOP AT lt_pvwty_dia
       ASSIGNING <fs_pvwty_dia>
       WHERE poskt_cust = 'MAT'.
    INSERT <fs_pvwty_dia> INTO TABLE lt_pvwty_dia_mat.
  ENDLOOP.
  it_pvwty_dia_all[] = lt_pvwty_dia[].
  SORT lt_pnwtyh_dia     BY pnguid.
  SORT lt_pvwty_dia      BY version_guid z_wty_posnr_hier.
  SORT lt_pvwty_dia_mat  BY version_guid.
  SORT it_pvwty_dia_all  BY version_guid posnr.
* Keep Version record OC or IV in a separate table for later use
  LOOP AT lt_pnwtyv_dia
          ASSIGNING <lfs_pnwtyv_dia>.
    it_submit_records-header_guid  = <lfs_pnwtyv_dia>-header_guid.
    it_submit_records-versn        = <lfs_pnwtyv_dia>-versn.
    it_submit_records-prev_version = <lfs_pnwtyv_dia>-prev_version.
    it_submit_records-kateg        = <lfs_pnwtyv_dia>-kateg.
    it_submit_records-aktiv        = <lfs_pnwtyv_dia>-aktiv.
    it_submit_records-knumv        = <lfs_pnwtyv_dia>-knumv.
    it_submit_records-pnguid       = <lfs_pnwtyv_dia>-pnguid.
    INSERT TABLE it_submit_records.
  ENDLOOP.
* =============
* Process Claim
* =============
  LOOP AT lt_pnwtyv_dia
          ASSIGNING <lfs_pnwtyv_dia>
          WHERE aktiv        EQ true   "Active version only
            AND kateg        EQ 'IV'   "Category
            AND fi_doc_exist EQ 'X'.
    CLEAR: t_detail_info, t_summary_alv.
*   Read Header detail
    READ TABLE lt_pnwtyh_dia
         WITH KEY pnguid = <lfs_pnwtyv_dia>-header_guid
         ASSIGNING <lfs_pnwtyh_dia>
         BINARY SEARCH.
*   Claim must be without error -----------------------------
    IF sy-subrc                      NE 0      OR
       <lfs_pnwtyh_dia>-z_wty_error   = true   OR
       <lfs_pnwtyh_dia>-z_wty_convflg = true.
      CONTINUE. "Rejected this Claim
    ENDIF.
*   Check Model
    IF <lfs_pnwtyh_dia>-z_wty_model IN s_model.
    ELSE.
      CONTINUE. "Rejected this Claim
    ENDIF.
*   Read first "MAT" Item information ------------------
    READ TABLE lt_pvwty_dia_mat
         WITH KEY version_guid = <lfs_pnwtyv_dia>-pnguid
         ASSIGNING <lfs_pvwty_dia_mat>
         BINARY SEARCH.
    wa_index_mat = sy-tabix.
    IF sy-subrc NE 0.
      CONTINUE. "Rejected this Claim
    ENDIF.
*   ====================================================
*   Process all item "MAT" linked to the current version
*   ====================================================
    WHILE sy-subrc                     = 0
          AND
          <lfs_pvwty_dia_mat>-version_guid = <lfs_pnwtyv_dia>-pnguid.
      IF <lfs_pvwty_dia_mat>-matnr IN s_matnr.
*       ======================================
*       Process Items linked to the "MAT" Item
*       ======================================
        READ TABLE lt_pvwty_dia
             WITH KEY version_guid     = <lfs_pnwtyv_dia>-pnguid
                      z_wty_posnr_hier = <lfs_pvwty_dia_mat>-posnr
             ASSIGNING <lfs_pvwty_dia_es2>
             BINARY SEARCH.
        wa_index_link = sy-tabix.
        DO. "Execute only ONCE (to process all items linked to the)
          "MAT Item
          IF sy-subrc NE 0.
            EXIT.  "Exit the DO loop
          ENDIF.
          WHILE sy-subrc                     = 0
                AND
               <lfs_pvwty_dia_es2>-version_guid =
                       <lfs_pnwtyv_dia>-pnguid
                AND
               <lfs_pvwty_dia_es2>-z_wty_posnr_hier =
                       <lfs_pvwty_dia_mat>-posnr.
            IF <lfs_pvwty_dia_es2>-valiv EQ c_zero.
            ELSE.
*             Initialize the detail information to display ---------
              CLEAR: t_detail_info.
              t_detail_info-v_parnr    = <lfs_pnwtyv_dia>-v_parnr.
              t_detail_info-matnr      = <lfs_pvwty_dia_mat>-matnr.
              t_detail_info-item_type  = <lfs_pvwty_dia_es2>-poskt_cust.
              t_detail_info-iv_versn   = <lfs_pnwtyv_dia>-versn.
              t_detail_info-clmno      = <lfs_pnwtyh_dia>-clmno.
              t_detail_info-crncy      = <lfs_pnwtyv_dia>-v_crncy.
              t_detail_info-iv_meinh   = <lfs_pvwty_dia_es2>-meinh.
              t_detail_info-z_wty_model = <lfs_pnwtyh_dia>-z_wty_model.
              ADD  <lfs_pvwty_dia_es2>-quant TO
                                             t_detail_info-iv_appr_qty.
              SELECT SINGLE kbetr
                     INTO   t_detail_info-iv_appr_rate
                     FROM   konv
                     WHERE  knumv  = <lfs_pnwtyv_dia>-knumv
                       AND  kposn  = <lfs_pvwty_dia_es2>-posnr
                       AND  kschl  = 'ZVAP'
                       AND  kinak  = space.
*              t_detail_info-flat_indic   = <lfs_pnwtyh_dia>-z_wty_model
*             t_detail_info-pric_indic   = <lfs_pnwtyh_dia>-z_wty_serno
              PERFORM get_the_submit_record
                      USING <lfs_pnwtyv_dia>-header_guid
                            <lfs_pnwtyv_dia>-prev_version
                            <lfs_pnwtyh_dia>-clmno
                            <lfs_pvwty_dia_es2>-posnr.
            ENDIF.
*           =====================
*           Read next Linked item
*           =====================
            PERFORM read_next_item  TABLES   lt_pvwty_dia
                                    CHANGING wa_index_link.
            IF sy-subrc = 0.
              ASSIGN <fs_pvwty_dia> TO <lfs_pvwty_dia_es2>.
            ENDIF.
          ENDWHILE.
          EXIT.  "Exit the DO loop
        ENDDO.
      ENDIF.
*     ====================
*     Read next "MAT" item
*     ====================
      PERFORM read_next_item  TABLES   lt_pvwty_dia_mat
                              CHANGING wa_index_mat.
      IF sy-subrc = 0.
        ASSIGN <fs_pvwty_dia> TO <lfs_pvwty_dia_mat>.
      ENDIF.
    ENDWHILE.
  ENDLOOP.
* ========================
* Get the description text
* ========================
  LOOP AT t_detail_info
       ASSIGNING <fs_detail_info>.
*   Get the model text -------------------------------------
    SELECT SINGLE mfrpn
           INTO   <fs_detail_info>-z_wty_model
           FROM   mara
           WHERE  matnr = <fs_detail_info>-z_wty_model.
*   Set Node name to regroup later by group -----------------
    SELECT SINGLE name1
           INTO   <fs_detail_info>-name
           FROM   lfa1
           WHERE  lifnr = <fs_detail_info>-v_parnr.
*   Set Node name to regroup later by group -----------------
    SELECT SINGLE maktx
           INTO   <fs_detail_info>-maktx
           FROM   makt
           WHERE  matnr = <fs_detail_info>-matnr
             AND  spras = sy-langu.
    MOVE-CORRESPONDING <fs_detail_info> TO t_summary_alv.
    t_summary_alv-claim_nb = 1.
    COLLECT t_summary_alv.
  ENDLOOP.
* ===========================================
* Calculate the average of the summary report
* ===========================================
  LOOP AT t_summary_alv
       ASSIGNING <fs_summary_alv>.
    DIVIDE <fs_summary_alv>-ov_prop_qty   BY <fs_summary_alv>-claim_nb.
    DIVIDE <fs_summary_alv>-ov_prop_rate  BY <fs_summary_alv>-claim_nb.
    DIVIDE <fs_summary_alv>-ov_submit_qty  BY <fs_summary_alv>-claim_nb.
    DIVIDE <fs_summary_alv>-ov_submit_rate BY <fs_summary_alv>-claim_nb.
    DIVIDE <fs_summary_alv>-iv_appr_qty    BY <fs_summary_alv>-claim_nb.
    DIVIDE <fs_summary_alv>-iv_appr_rate   BY <fs_summary_alv>-claim_nb.
  ENDLOOP.
  DELETE t_summary_alv WHERE v_parnr NOT IN s_vend.
ENDFORM.                    " select_claim_to_process
*&      Form  SET_HOT_SPOT
*       text
*      -->P_0287   text
FORM set_hot_spot  TABLES   p_fieldcat     TYPE slis_t_fieldcat_alv
                   USING    value(p_field).
  FIELD-SYMBOLS: <lfs_field_cat> LIKE LINE OF gt_fieldcat_sum.
  READ TABLE p_fieldcat WITH KEY fieldname  = p_field
       ASSIGNING <lfs_field_cat>.
  IF sy-subrc = 0.
    <lfs_field_cat>-hotspot = 'X'.
    <lfs_field_cat>-key     = 'X'.
  ENDIF.
ENDFORM.                    " SET_HOT_SPOT
*&      Form  set_screen_text
*       text
*      -->P_0997   text
FORM set_screen_text  USING    p_label
                               p_text.
  MOVE p_label TO :gtw_fieldcat-seltext_l,
                   gtw_fieldcat-seltext_m,
                   gtw_fieldcat-seltext_s,
                   gtw_fieldcat-reptext_ddic.
  IF p_text NE space.
    gtw_fieldcat-ddictxt = p_text.
  ENDIF.
ENDFORM.                    " set_screen_text
*&      Form  set_default_variant
*       text
*      -->P_0822   text
*      <--P_GS_VARIANT1  text
FORM set_default_variant  CHANGING p_variant     TYPE disvariant
                                   p_disvar      TYPE slis_vari.
* Get default variant
  CALL FUNCTION 'REUSE_ALV_VARIANT_DEFAULT_GET'
    EXPORTING
      i_save     = c_save
    CHANGING
      cs_variant = p_variant
    EXCEPTIONS
      not_found  = 2.
  IF sy-subrc = 0.
    p_disvar =  p_variant-variant.
  ENDIF.
ENDFORM.                    " set_default_variant
*&      Form  validate_vendor
*       text
*  -->  p1        text
*  <--  p2        text
FORM validate_vendor.
  DATA: l_lifnr LIKE lfa1-lifnr.
  IF s_vend[] IS INITIAL.
  ELSE.
    SELECT SINGLE lifnr
           INTO   l_lifnr
           FROM   lfa1
           WHERE  lifnr IN s_vend.
    IF sy-subrc NE 0.
      MESSAGE e000 WITH text-e01.
    ENDIF.
  ENDIF.
ENDFORM.                    " validate_vendor
*&      Form  inform_claim_error
*       text
*  -->  p1        text
*  <--  p2        text
FORM inform_claim_error USING value(p_claim_no)
                              value(p_version).
  DATA: l_text1(50),
        l_text2(50).
  CONCATENATE text-301
              p_claim_no
              INTO l_text1 SEPARATED BY space.
  CONCATENATE text-302
              p_version
              text-303
              INTO l_text2 SEPARATED BY space.
  CALL FUNCTION 'POPUP_TO_INFORM'
    EXPORTING
      titel = text-200
      txt1  = l_text1
      txt2  = l_text2
      txt3  = ' '
      txt4  = text-304.
ENDFORM.                    " inform_claim_error
*&      Form  validate_posting_parameter
*       text
*  -->  p1        text
*  <--  p2        text
FORM validate_posting_parameter .
  DATA: l_low_date  TYPE d,
        l_high_date TYPE d.
  CLEAR: wa_low_date, wa_high_date.
* Posting parameters must be entered
  IF s_cpudt[] IS INITIAL AND s_postdt[] IS INITIAL.
    MESSAGE e000 WITH text-e04.
  ENDIF.
* Posting paramters can't be intered at the same time
  IF s_cpudt[] IS INITIAL OR s_postdt[] IS INITIAL.
  ELSE.
    MESSAGE e000 WITH text-e03.
  ENDIF.
* Validate posting period ---------------------------------------------
  IF s_postdt[] IS INITIAL.
    READ TABLE s_cpudt INDEX 1.
    IF s_cpudt-low IS INITIAL.
      MESSAGE e000 WITH text-e03.
    ENDIF.
    PERFORM validate_period USING    s_cpudt-low
                            CHANGING l_low_date
                                     l_high_date.
    wa_low_date  = l_low_date.
    wa_high_date = l_high_date.
    IF s_cpudt-high IS INITIAL.
    ELSE.
      PERFORM validate_period USING    s_cpudt-high
                              CHANGING l_low_date
                                       l_high_date.
      IF s_cpudt-high LT s_cpudt-low.
        MESSAGE ID 'DB' TYPE 'E' NUMBER '650' .
      ENDIF.
      wa_high_date = l_high_date.
    ENDIF.
  ELSE.
*   Validate posting date --------------------------------------------
    READ TABLE s_postdt INDEX 1.
    wa_low_date  = s_postdt-low.
    IF s_postdt-high IS INITIAL.
      wa_high_date = wa_low_date.
    ELSE.
      wa_high_date = s_postdt-high.
    ENDIF.
  ENDIF.
ENDFORM.                    " validate_posting_parameter
*&      Form  get_fin_period
*       Get the financial period from 1960 to 9999
*  -->  p1        text
*  <--  p2        text
FORM get_fin_period USING value(p_year_low)
                          value(p_year_high).
  DATA : BEGIN OF fp_table OCCURS 0,
               periv LIKE t009b-periv, "FINANCIAL YEAR VARIANT
               bdatj LIKE t009b-bdatj, "CALENDAR YEAR
               bumon LIKE t009b-bumon, "MONTH
               butag LIKE t009b-butag, "DAY OF MONTH
               poper LIKE t009b-poper, "COST PERIOD
               reljr LIKE t009b-reljr, "YEAR SHIFT
         END OF fp_table.
  DATA: l_fin_bdatj       LIKE t009b-bdatj,
        l_period_start    TYPE d,
        l_period_end      TYPE d,
        l_prev_period_end TYPE d,
        l_prev_fin_bdatj  LIKE t009b-bdatj,
        l_prev_poper      LIKE t009b-poper,
        l_count           TYPE n.
* Get the Fiscal year variant periods
  SELECT periv bdatj bumon butag poper reljr
         INTO  TABLE fp_table
         FROM  t009b
         WHERE periv = 'ZB'.
  LOOP AT fp_table.
    IF l_prev_period_end NE '00000000'.
      l_period_start = l_prev_period_end + 1.
    ENDIF.
    CONCATENATE fp_table-bdatj fp_table-bumon fp_table-butag
                INTO l_period_end.
    l_prev_period_end = l_period_end.
    l_fin_bdatj       = fp_table-bdatj + fp_table-reljr.
    IF c_year_low NE ''      AND l_fin_bdatj LT p_year_low.
      CONTINUE.
    ELSEIF p_year_high NE '' AND l_fin_bdatj GT p_year_high.
      CONTINUE.
    ELSEIF p_year_low NE '' AND p_year_high EQ '' AND
           l_fin_bdatj  GT c_year_low.
      CONTINUE.
    ENDIF.
    IF l_prev_fin_bdatj EQ l_fin_bdatj         AND
       l_prev_poper     EQ fp_table-poper.
      it_period-end    = l_period_end.
      MODIFY it_period TRANSPORTING  end
             WHERE year  = it_period-year
               AND poper = it_period-poper.
    ELSE.
      it_period-year   = l_fin_bdatj.
      it_period-poper  = fp_table-poper+1.
      it_period-start  = l_period_start.
      it_period-end    = l_period_end.
      INSERT TABLE it_period.
    ENDIF.
    l_prev_fin_bdatj = l_fin_bdatj.
    l_prev_poper     = fp_table-poper.
    IF l_count EQ 0.
      l_count = l_count + 1.
    ENDIF.
  ENDLOOP.
ENDFORM.                    " get_fin_period
*&      Form  set_period_to_analyse
*       Find the fiscal period for a specific date
*  -->  p1        text
*  <--  p2        text
FORM set_period_to_analyse.
  LOOP AT it_period
       ASSIGNING <fs_it_period>
       WHERE start LE sy-datum
         AND end   GE sy-datum.
    CONCATENATE <fs_it_period>-year
                <fs_it_period>-poper
                INTO s_cpudt-low.
    s_cpudt-sign   = 'I'.
    s_cpudt-option = 'EQ'.
    APPEND s_cpudt.
    EXIT.
  ENDLOOP.
ENDFORM.                    " set_period_to_analyse
*&      Form  validate_material
*       text
*  -->  p1        text
*  <--  p2        text
FORM validate_material .
  DATA: l_matnr LIKE mara-matnr.
  IF s_matnr[] IS INITIAL.
  ELSE.
    SELECT SINGLE matnr
           INTO   l_matnr
           FROM   mara
           WHERE  matnr IN s_matnr.
    IF sy-subrc NE 0.
      MESSAGE e000 WITH text-e02.
    ENDIF.
  ENDIF.
ENDFORM.                    " validate_material
*&      Form  validate_claim_group
*       text
*  -->  p1        text
*  <--  p2        text
FORM validate_claim_group .
  DATA: l_clmgrp LIKE cwty006-clmgrp.
  IF s_clgrp[] IS INITIAL.
  ELSE.
    SELECT SINGLE clmgrp
           INTO   l_clmgrp
           FROM   cwty006
           WHERE  clmgrp IN s_clgrp.
    IF sy-subrc NE 0.
      MESSAGE e000 WITH text-e06.
    ENDIF.
  ENDIF.
ENDFORM.                    " validate_claim_group
*&      Form  set_alv_field_desc
*       text
*      -->P_LTW_FIELDCATALOG  text
*      <--P_GTW_FIELDCAT  text
FORM set_alv_field_desc USING value(p_fieldcat) TYPE lvc_s_fcat
                              value(p_level).
  gtw_fieldcat-seltext_l    = p_fieldcat-scrtext_l.
  gtw_fieldcat-seltext_m    = p_fieldcat-scrtext_m.
  gtw_fieldcat-seltext_s    = p_fieldcat-scrtext_s.
  gtw_fieldcat-reptext_ddic = p_fieldcat-reptext.
  CASE p_fieldcat-fieldname.
    WHEN 'NAME'.
      PERFORM set_screen_text USING 'Vendor Name'           'L'.
    WHEN 'MAKTX'.
      PERFORM set_screen_text USING 'Material Description'  'L'.
    WHEN 'CLAIM_NB'.
      PERFORM set_screen_text USING '#Claims'               'L'.
    WHEN 'IV_MEINH'.
      PERFORM set_screen_text USING 'IV UoM'                'L'.
    WHEN 'OV_MEINH'.
      PERFORM set_screen_text USING 'OV UoM'                'L'.
    WHEN 'FLAT_INDIC'.
      PERFORM set_screen_text USING 'Flat Rate Ind.'        'L'.
    WHEN 'PRIC_INDIC'.
      PERFORM set_screen_text USING 'Price Ind.'            'L'.
    WHEN 'OV_PROP_QTY'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'OV avg. Prop. Qty'    'L'.
         PERFORM set_screen_text USING 'Avg Prop Qty Sub'    'L'.  "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'OV Prop. Qty'         'L'.
      ENDIF.
    WHEN 'OV_PROP_RATE'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'OV avg. Prop. Rate $'  'L'.
         PERFORM set_screen_text USING 'Avg Prop Rate Sub'  'L'.    "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'OV Prop. Rate $'       'L'.
      ENDIF.
    WHEN 'OV_SUBMIT_QTY'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'OV avg. Submit Qty'    'L'.
         PERFORM set_screen_text USING 'Avg Qty Sub'    'L'.          "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'OV Submit Qty'         'L'.
      ENDIF.
    WHEN 'OV_SUBMIT_RATE'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'OV avg. Submit Rate $' 'L'.
        PERFORM set_screen_text USING 'Avg Rate Sub' 'L'.        "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'OV Submit Rate $'      'L'.
      ENDIF.
    WHEN 'IV_APPR_QTY'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'IV Avg. Appr. Qty'     'L'.
        PERFORM set_screen_text USING 'Avg Qty Pd'     'L'.     "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'IV Appr. Qty'          'L'.
      ENDIF.
    WHEN 'IV_APPR_RATE'.
      IF p_level = 1. "Summary report
*BEGIN OF TR#D03K935718
*        PERFORM set_screen_text USING 'IV Avg. Appr. Rate $'  'L'.
        PERFORM set_screen_text USING 'Avg Rate Pd'  'L'.   "RFC2917
*END OF TR#D03K935718
      ELSE.
        PERFORM set_screen_text USING 'IV Appr. Rate $'       'L'.
      ENDIF.
    WHEN 'OV_VERSN'.
      PERFORM set_screen_text USING 'OV Versn.'               'L'.
    WHEN 'IV_VERSN'.
      PERFORM set_screen_text USING 'IV Versn.'               'L'.
    WHEN OTHERS.
      gtw_fieldcat-ddictxt      = p_fieldcat-selddictxt.
  ENDCASE.
*   Initialisation des Labels des entetes de colonne -------------------
  gtw_fieldcat-no_out       = p_fieldcat-no_out.
  gtw_fieldcat-emphasize    = p_fieldcat-emphasize.
  gtw_fieldcat-fix_column   = p_fieldcat-fix_column.
  gtw_fieldcat-icon         = p_fieldcat-icon.
  gtw_fieldcat-no_zero      = 'X'.
  gtw_fieldcat-do_sum       = p_fieldcat-do_sum.
ENDFORM.                    " set_alv_field_desc
*&      Form  validate_period
*       text
*      -->P_S_CPUDT_LOW  text
FORM validate_period  USING value(p_period)
                      CHANGING p_low_date    TYPE d
                               p_high_date   TYPE d.
  DATA: l_year(4),
        l_poper(2).
  l_year  = p_period(4).
  l_poper = p_period+4(2).
  READ TABLE it_period WITH KEY year  = l_year
                                poper = l_poper
             ASSIGNING <fs_it_period>.
  IF sy-subrc NE 0.
    MESSAGE e000 WITH text-e04.
  ENDIF.
  p_low_date  = <fs_it_period>-start.
  p_high_date = <fs_it_period>-end.
ENDFORM.                    " validate_period
*&      Form  read_next_item
*       text
*  -->  p1        text
*  <--  p2        text
FORM read_next_item  TABLES pt_pvwty_dia     STRUCTURE wty_pvwty_dia
                     CHANGING p_index TYPE i.
  p_index = p_index + 1.
*     Read next Item information ------------------------------
  READ TABLE pt_pvwty_dia INDEX p_index
       ASSIGNING <fs_pvwty_dia>.
ENDFORM.                    " read_next_item
*&      Form  get_the_submit_record
*       text
*      -->P_<LFS_PNWTYV_DIA>_HEADER_GUID  text
*      -->P_<LFS_PNWTYV_DIA>_PREV_VERSION  text
FORM get_the_submit_record  USING    p_header_guid
                                     p_prev_version
                                     p_claim_no
                                     p_posnr.
  DATA: l_nb_while       TYPE i,
        l_zaehk          LIKE konv-zaehk,
        l_submit_found(1).
* ... USD1092841 - Add Start
  FIELD-SYMBOLS: <fs_submit_rec_vs3> TYPE tp_submit_records.
* ... USD1092841 - Add End
  CLEAR: l_submit_found, l_nb_while.
  READ TABLE it_submit_records
       WITH KEY header_guid  = p_header_guid
                versn        = p_prev_version
       ASSIGNING <fs_submit_rec_vs2>.
  WHILE sy-subrc = 0 .
    ADD 1 TO l_nb_while.
*   if more than 30 loop(endless loop), it means som

Hi Siddarth
As per query, if you want to display sums automatically when you report is displayed for the first time, you'll have to modify your field catalog a bit.
To acheive this, you need to identify the field for which the totals are calculated ex- for every new material num, or for every new documnet number etc.
once you have this info, you identify the field that has to be totaled.
then while building your fieldcatalog, set this parameter :
l_wa_fieldcat-do_sum     =  'X' for the field that has to be totaled.
and when you build a sort table then set this parameter:
l_t_sort           TYPE slis_t_sortinfo_alv.
l_s_sort-subtot    = 'X'. for the field for which totals are calculated.
Hope this helps.
Cheers
Ravish
Reward if helpful

Similar Messages

  • F4 Help needed in ALV report

    Hi Gurus,
    I have create one report which should monitor the batch jobs.
    I some small requirements in that report. Can one can help in updating my code.
    Reuirements:
    Last run date and time should allow only one entry and these should be placed in one line as shown in the requirements.
    ·         F4 on Job status should show the description also.
    ·         F4 on user name should give user details. It should be similar to the f4 in transaction SU01D
    ·         Donu2019t show the entire log on the report. Show only 1 line per job with similar to what is shown in the SM37 report. Job Name, Start Date, Start Time, Job Created By, Sppol, Status, Duration. User can double click on it to see job log or spool list.
    below is the report. Please help me out
    REPORT ZJOB_MONITORING.
    T A B L E S
    TABLES: tbtco.
    T Y P E - S P O O L S
    TYPE-POOLS: slis.
    T Y P E  D E C L A R A T I O N S
    *TYPES: BEGIN OF type_tbtco,
           include TYPE tbtco,
          END OF type_tbtco.
    TYPES: BEGIN OF type_output,
           STRTTIME TYPE tbtco-STRTTIME,
           strtdate TYPE tbtco-strtdate,
           jobname  TYPE tbtco-jobname,
           line     TYPE string,
           END OF type_output.
    S T R U C T U R E S
    DATA: s_tbtco  TYPE tbtco,
          s_joblog TYPE zsbb_uc4_joblog,
          s_output TYPE type_output.
    I N T E R N A L  T A B L E S
    DATA: i_tbtco  TYPE STANDARD TABLE OF tbtco,
          i_joblog TYPE STANDARD TABLE OF zsbb_uc4_joblog,
          i_output TYPE STANDARD TABLE OF type_output.
    DATA: Begin of itab_jobname OCCURS 0,
          jobname type tbtco-jobname,
          end of itab_jobname.
    DATA: Begin of itab_user OCCURS 0,
          jobname type tbtco-sdluname,
          end of itab_user.
    DATA: Begin of itab_stat OCCURS 0,
          jobname type tbtco-status,
          end of itab_stat.
    DATA: Begin of itab_uzeit occurs 0,
          uzeit type sy-uzeit,
          end of itab_uzeit.
    Heading of the report.
    DATA: t_heading TYPE slis_t_listheader.
    DATA : t_fieldcat TYPE slis_t_fieldcat_alv.
    S E L E C T I O N  S C R E E N
    SELECTION-SCREEN BEGIN OF BLOCK bl1 WITH FRAME TITLE text-001.
    SELECT-OPTIONS: s_strtda FOR sy-datum,
                    s_lstrun FOR sy-uzeit OBLIGATORY,
                    s_jobnam FOR tbtco-jobname,
                    s_user   FOR tbtco-sdluname,
                    s_status FOR tbtco-status.
    PARAMETERS: p_email AS CHECKBOX.
    SELECTION-SCREEN END OF BLOCK bl1.
    "                         AT SELECTION-SCREEN
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_JOBNAM-LOW.
      PERFORM f4_JOBNAM-LOW.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_JOBNAM-HIGH.
      PERFORM f4_JOBNAM-HIGH.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_user-low.
      PERFORM f4_USER-LOW.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_user-high.
      PERFORM f4_USER-HIGH.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_status-low.
      PERFORM f4_STATUS-LOW.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_status-high.
      PERFORM f4_STATUS-HIGH.
    S T A R T  O F  S E L E C T I O N
    START-OF-SELECTION.
      PERFORM select_data.
    If email is checked.
    Send the output table as an email attachment to the distribution list.
    Get the email list from the config table. " ask from where to get it
      IF p_email = 'X'.
    Call FM 'SO_OBJECT_SEND'.
    Fill the fields which are not commented accordingly.
    CALL FUNCTION 'SO_OBJECT_SEND'
       EXPORTING
         OBJECT_HD_CHANGE = OBJECT_HD_CHANGE
         OBJECT_TYPE      = 'RAW'
         OWNER            = SY-UNAME
       TABLES
         OBJCONT          = TEXT
         OBJPARA          = OBJPARA
         RECEIVERS        = RECEIVERS
       EXCEPTIONS
         OTHERS           = 01.
    IF SY-SUBRC NE 0.
       RAISE ERROR.
    ENDIF.
    ENDIF.
    Prepare the ALV Report.
    PERFORM alv_grid_display.
    *&      Form  alv_grid_display
          text
    FORM alv_grid_display .
    alv required data objects.
      DATA: w_repid    TYPE syrepid,
            x_layout   TYPE slis_layout_alv,
            t_event    TYPE slis_t_event,
           t_fieldcat TYPE slis_t_fieldcat_alv,
            w_title    TYPE lvc_title,
            w_print    TYPE slis_print_alv,
            w_comm    TYPE slis_formname,
            flag       TYPE c VALUE 'N'.
      REFRESH t_fieldcat.
      REFRESH t_event.
      CLEAR   x_layout.
      CLEAR   w_title.
    Field Catalog
    PERFORM set_fieldcat2 USING:
       1 'strttime'   'BTCXTIME'   space           t_fieldcat ,
       2 'jobname'    'BTCJOB'     space           t_fieldcat ,
       3 'line'        space       'Job Log'       t_fieldcat .
    *PERFORM set_fieldcat2 USING:
       1 'strttime'   'BTCXTIME'   space     'I_OUTPUT'      t_fieldcat ,
       2 'jobname'    'BTCJOB'     space     'I_OUTPUT'      t_fieldcat ,
       3 'line'        space       'Job Log' 'I_OUTPUT'      t_fieldcat .
      PERFORM set_fieldcat.
    Layout
      x_layout-zebra = 'X'.
      x_layout-colwidth_optimize = 'X'.
    GUI Status
      w_repid = sy-repid .
    Top of page heading
    PERFORM set_top_page_heading USING t_heading t_event flag.
    call the FM 'REUSE_ALV_GRID_DISPLAY'
      CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
       EXPORTING
         i_callback_program                = w_repid
         is_layout                         = x_layout
         it_fieldcat                       = t_fieldcat
        IT_SORT                           =
         i_save                            = 'X'
         it_events                         = t_event
       TABLES
          t_outtab                         = i_output
       EXCEPTIONS
         program_error                     = 1
         OTHERS                            = 2.
      IF sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                    " alv_grid_display
    *&      Form  set_top_page_heading
          text
    FORM set_top_page_heading  USING
                               t_heading TYPE slis_t_listheader
                               t_events  TYPE slis_t_event
                               flag      TYPE c.
      DATA: x_heading TYPE slis_listheader,
            x_event   TYPE LINE OF slis_t_event.
    Report title
      CLEAR t_heading[].
      CLEAR x_heading.
      x_heading-typ = 'H'.
      x_heading-info = 'Job Details'(002).
      APPEND x_heading TO t_heading.
    Name of the report program
      CLEAR x_heading.
      x_heading-typ = 'S'.
      x_heading-key = 'Report ID:'.
      x_heading-info = sy-repid.
      APPEND x_heading TO t_heading.
    User who is running the report
      CLEAR x_heading.
      x_heading-typ = 'S'.
      x_heading-key = 'User: '.
      x_heading-info = sy-uname.
      APPEND x_heading TO t_heading.
    Date of execution
      CLEAR x_heading.
      x_heading-typ = 'S'.
      x_heading-key = 'Date: '.
      WRITE sy-datum TO x_heading-info.
      APPEND x_heading TO t_heading.
    Time of execution
      CLEAR x_heading.
      x_heading-typ = 'S'.
      x_heading-key = 'Time: '.
      WRITE sy-uzeit TO x_heading-info.
      APPEND x_heading TO t_heading.
    Top of page event
      x_event-name = slis_ev_top_of_page.
      x_event-form = 'TOP_OF_PAGE'.
      APPEND x_event TO t_events.
    ENDFORM.                    " set_top_page_heading
    *&      Form  set_fieldcat2
          text
    FORM set_fieldcat2  USING
                        p_colpos p_fieldname p_ref_fieldname
                        p_seltext_m
                        p_tabname
                        t_fieldcat TYPE slis_t_fieldcat_alv.
      DATA: wa_fieldcat TYPE slis_fieldcat_alv.
      CLEAR wa_fieldcat.
    General settings
      wa_fieldcat-fieldname = p_fieldname.
      wa_fieldcat-col_pos = p_colpos.
    the ref_fieldname given is a data element.
      IF NOT p_ref_fieldname IS INITIAL.
        wa_fieldcat-rollname =   p_ref_fieldname.
      ENDIF.
    Set text headers.
      IF NOT p_seltext_m IS INITIAL.
        wa_fieldcat-seltext_m = p_seltext_m.
      ENDIF.
      wa_fieldcat-tabname = 'I_OUTPUT'.
      APPEND wa_fieldcat TO t_fieldcat.
    ENDFORM.                    " set_fieldcat2
    *&      Form  F4_JOBNAM-LOW
          text
    -->  p1        text
    <--  p2        text
    FORM F4_JOBNAM-LOW .
      SELECT jobname FROM tbtco
                  INTO TABLE itab_jobname.
      DELETE ADJACENT DUPLICATES FROM itab_jobname.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield             = 'jobname'
      PVALKEY                = ' '
         DYNPPROG               = 'sy-repid'
         DYNPNR                 = '1000'
         DYNPROFIELD            = 's_jobnam-low'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
       VALUE_ORG               = 'S'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab            = itab_jobname
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_JOBNAM-LOW
    *&      Form  F4_JOBNAM-HIGH
          text
    -->  p1        text
    <--  p2        text
    FORM F4_JOBNAM-HIGH .
      SELECT jobname FROM tbtco
                    INTO TABLE itab_jobname.
      DELETE ADJACENT DUPLICATES FROM itab_jobname.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield             = 'jobname'
      PVALKEY                = ' '
         DYNPPROG              = 'sy-repid'
         DYNPNR                = '1000'
         DYNPROFIELD           = 's_jobnam-high'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
       VALUE_ORG               = 'S'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab            = itab_jobname
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_JOBNAM-HIGH
    *&      Form  F4_USER-LOW
          text
    -->  p1        text
    <--  p2        text
    FORM F4_USER-LOW .
      SELECT sdluname  FROM tbtco
                    INTO TABLE itab_user.
      DELETE ADJACENT DUPLICATES FROM itab_user.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield               = 'user'
      PVALKEY                = ' '
         DYNPPROG               = 'sy-repid'
         DYNPNR                 = '1000'
         DYNPROFIELD            = 's_user-low'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
       VALUE_ORG              = 'S'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab            = itab_user
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_USER-LOW
    *&      Form  F4_USER-HIGH
          text
    -->  p1        text
    <--  p2        text
    FORM F4_USER-HIGH .
      SELECT sdluname  FROM tbtco
                    INTO TABLE itab_user.
      DELETE ADJACENT DUPLICATES FROM itab_user.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield               = 'user'
      PVALKEY                = ' '
         DYNPPROG               = 'sy-repid'
         DYNPNR                 = '1000'
         DYNPROFIELD            = 's_user-high'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
       VALUE_ORG              = 'S'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab            = itab_user
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_USER-HIGH
    *&      Form  F4_STATUS-LOW
          text
    -->  p1        text
    <--  p2        text
    FORM F4_STATUS-LOW .
      SELECT status  FROM tbtco
                    INTO TABLE itab_stat.
      DELETE ADJACENT DUPLICATES FROM itab_stat.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield               = 'status'
      PVALKEY                = ' '
         DYNPPROG               = 'sy-repid'
         DYNPNR                 = '1000'
         DYNPROFIELD            = 's_status-low'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
       VALUE_ORG              = 'S'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab            = itab_stat
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_STATUS-LOW
    *&      Form  F4_STATUS-HIGH
          text
    -->  p1        text
    <--  p2        text
    FORM F4_STATUS-HIGH .
      SELECT status  FROM tbtco
                    INTO TABLE itab_stat.
      DELETE ADJACENT DUPLICATES FROM itab_stat.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        exporting
      DDIC_STRUCTURE         = ' '
          retfield               = 'status'
      PVALKEY                = ' '
         DYNPPROG               = 'sy-repid'
         DYNPNR                 = '1000'
         DYNPROFIELD            = 's_status-high'
      STEPL                  = 0
      WINDOW_TITLE           =
      VALUE                  = ' '
      VALUE_ORG              = 'C'
      MULTIPLE_CHOICE        = ' '
      DISPLAY                = ' '
      CALLBACK_PROGRAM       = ' '
      CALLBACK_FORM          = ' '
        tables
          value_tab              = itab_stat
      FIELD_TAB              =
      RETURN_TAB             =
      DYNPFLD_MAPPING        =
    EXCEPTIONS
      PARAMETER_ERROR        = 1
      NO_VALUES_FOUND        = 2
      OTHERS                 = 3
      if sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      endif.
    ENDFORM.                    " F4_STATUS-HIGH
    *&      Form  SELECT_DATA
          text
    -->  p1        text
    <--  p2        text
    FORM SELECT_DATA .
    select the entries from the table TBTCO
    as per the selection screen
      SELECT * FROM tbtco
               INTO TABLE i_tbtco
               WHERE STRTTIME IN s_lstrun AND
                     strtdate IN s_strtda AND
                     jobname  IN s_jobnam AND
                     sdluname IN s_user   AND
                     status   IN s_status.
    Get the job details for the above jobs.
      LOOP AT i_tbtco INTO s_tbtco.
        CALL FUNCTION 'ZSBB_UC4_JOB_READ_LOG'
          EXPORTING
            client                = sy-mandt
            jobcount              = s_tbtco-jobcount
            joblog                = s_tbtco-joblog
            jobname               = s_tbtco-jobname
          TABLES
            joblog_tab            = i_joblog
          EXCEPTIONS
            cant_read_joblog      = 1
            jobcount_missing      = 2
            joblog_does_not_exist = 3
            joblog_is_empty       = 4
            joblog_name_missing   = 5
            jobname_missing       = 6
            job_does_not_exist    = 7
            OTHERS                = 8.
    Write the Error handling as needed.
        IF sy-subrc <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
        ELSE.
    Append entries to main table.
          s_output-STRTTIME = s_tbtco-STRTTIME.
          s_output-jobname  = s_tbtco-jobname.
          LOOP AT  i_joblog INTO s_joblog.
            s_output-line = s_joblog-text.
            APPEND s_output TO i_output.
            CLEAR s_output.
          ENDLOOP.
        ENDIF.
      ENDLOOP.
    ENDFORM.                    " SELECT_DATA
    *&      Form  SET_FIELDCAT
          text
    -->  p1        text
    <--  p2        text
    form SET_FIELDCAT .
      DATA: wa_fieldcat TYPE slis_fieldcat_alv.
      wa_fieldcat-col_pos = 1.
      wa_fieldcat-fieldname = 'STRTTIME'.
      wa_fieldcat-seltext_m = 'Start Time'.
      wa_fieldcat-tabname = 'I_OUTPUT'.
    wa_fieldcat-reptext = p_reptext.
      APPEND wa_fieldcat to t_fieldcat.
      wa_fieldcat-col_pos = 2.
      wa_fieldcat-fieldname = 'JOBNAME'.
      wa_fieldcat-seltext_m = 'Job Name'.
      wa_fieldcat-tabname = 'I_OUTPUT'.
    wa_fieldcat-reptext = p_reptext.
      APPEND wa_fieldcat to t_fieldcat.
      wa_fieldcat-col_pos = 3.
      wa_fieldcat-fieldname = 'LINE'.
      wa_fieldcat-seltext_m = 'Job Log'.
      wa_fieldcat-tabname = 'I_OUTPUT'.
      APPEND wa_fieldcat to t_fieldcat.
    endform.                    " SET_FIELDCAT

    solved

  • Information required on ALV report

    Hello,
    I am working on ALV report my requirement is I have to display output in colors like first line is as in white color and second line is light blue....this is applicable for all records in ALV Grid output.
    Could you please help me how to get the alternate rows in color.
    Thank you in Advance.

    Hi Kishore ,
    See This links
    Row color in ALV grid
    selecting multiple rows in alv grid

  • Help needed regarding ALV report

    Hi,
    I have a query regarding ALV report.
    The requirement is as follows:-
    When the user executes the ALV report and if he sums one numeric field column values and filters out some of the field columns ( for example there r 5 columns in the report and the user has filtered out 2 of them and viewing only 3 columns)
    and now the requirements is that when the user runs the report later he should see the modified report ( i mean only 3 cloumns and the total value of the column which he has made) but not the original output which was there when the report was developed.
    First of all i wanna know is it possible to do r not. If yes then how
    Hope u have got what i want.
    eagerly waiting for ur reply.
    regards,
    maqsood

    Hi
    Yes you can! You have to manage the layout variant.
    So when you call your ALV you have to set the parameter I_SAVE = 'A'.
    In this way you'll allow the user to save the variants for layout.
    After you has to have a chance to choose the variant in selection-screen.
    See the demo program BCALV_GRID_11 to manage the variant in selection-screen.
    Max

  • Help needed..ALV report

    Hello,
    I have a new requirement in a report. There would be two radio buttons on the selection-screen. One for Search Material plant wise and other to search material details only.
    Depending on the choice of radio button different selection-screen blocks need to be called.
    Can any one suggest a logic for this.
    Helpful answers will be rewarded.
    Regards,
    Subodh

    *This program executes the logic to hide the parameters on radio button clicking.
    PARAMETERS : R1 RADIOBUTTON GROUP RG USER-COMMAND R DEFAULT 'X'.
    PARAMETERS : R2 RADIOBUTTON GROUP RG .
    PARAMETERS : R3 RADIOBUTTON GROUP RG .
    selection-screen begin of block b1 with frame.
    parameters : a(10) type c modif id abc.
    parameters : b(10) type c modif id abc.
    selection-screen end of block b1.
    selection-screen begin of block b2 with frame.
    parameters : c(40) type c modif id def.
    parameters : d(20) type c modif id def.
    selection-screen end of block b2.
    selection-screen begin of block b3 with frame.
    parameters : e(40) type c modif id ghi.
    parameters : f(20) type c modif id ghi.
    selection-screen end of block b3.
    at selection-screen output.
    IF R1 = 'X'.
    LOOP AT SCREEN.
    IF screen-group1 = 'DEF' or screen-group1 = 'GHI' .
    screen-active = '0'.
    MODIFY SCREEN.
    ENDIF.
    ENDLOOP.
    ENDIF.
    IF R2 = 'X'.
    LOOP AT SCREEN.
    IF screen-group1 = 'ABC' or screen-group1 = 'GHI'.
    screen-active = '0'.
    MODIFY SCREEN.
    ENDIF.
    ENDLOOP.
    ENDIF.
    IF R3 = 'X'.
    LOOP AT SCREEN.
    IF screen-group1 = 'ABC' or screen-group1 = 'DEF'.
    screen-active = '0'.
    MODIFY SCREEN.
    ENDIF.
    ENDLOOP.
    ENDIF.
    Br,
    Vij

  • Need Help in  Interactive ALV Report

    Hi guru's,
      I need sample code of Interactive ALV   when on selecting an particular field, it should open an another ALV windows or pop-up window. Please help me and points will be rewarded for the right code.
    Regards
    Rajiv Christopher

    hi,
    may b it will b helpful 2 u.
    INTERACTIVE ALV
    REPORT Z50651_ALV_INTERACTIVE MESSAGE-ID ZMSG_50651
    LINE-SIZE 100
    LINE-COUNT 60
    NO STANDARD PAGE HEADING.
    ******************TABLES DECLARATION*****************
    TABLES : VBAP,MARA.
    *****************TYPE POOLS**************************
    TYPE-POOLS : SLIS.
    ****************INTERNAL TABLES**********************
    DATA : BEGIN OF IT_VBAP OCCURS 0,
    VBELN LIKE VBAP-VBELN, "SALES DOCUMENT
    POSNR LIKE VBAP-POSNR, "SALES DOCUMENT ITEM
    MATNR LIKE VBAP-MATNR, "MATERIAL NUMBER
    END OF IT_VBAP.
    ****************TEMPORARY VARIABLES******************
    DATA : V_VBELN LIKE VBAP-VBELN."SALES DOCUMENT
    DATA : V_MTART LIKE MARA-MTART. "MATERIAL TYPE
    *****************FIELD CATALOG***********************
    DATA : IT_FIELDCAT TYPE SLIS_T_FIELDCAT_ALV,
    WA_FIELDCAT TYPE SLIS_FIELDCAT_ALV.
    ****************LAYOUT*******************************
    DATA : WA_LAYOUT TYPE SLIS_LAYOUT_ALV.
    ***************VARIANT*******************************
    DATA : G_VARIANT LIKE DISVARIANT.
    ****************SAVE*********************************
    DATA : G_SAVE(1) TYPE C.
    *****************EVENTS******************************
    DATA : XS_EVENTS TYPE SLIS_ALV_EVENT,
    G_EVENTS TYPE SLIS_T_EVENT.
    ******************PF STATUS**************************
    DATA : PF_STATUS TYPE SLIS_FORMNAME VALUE 'SET_PF_STATUS'.
    ******************USER COMMAND************************
    DATA : USER_COMMAND TYPE SLIS_FORMNAME VALUE 'SET_USER_COMMAND',
    R_UCOMM LIKE SY-UCOMM.
    ****************SELECTION SCREEN************************
    SELECT-OPTIONS : S_VBELN FOR VBAP-VBELN.
    ***************AT SELECTION SCREEN*********************
    AT SELECTION-SCREEN.
    PERFORM VALIDATE.
    **************START-OF-SELECTION**************************
    START-OF-SELECTION.
    PERFORM GET_DETAILS.
    PERFORM FIELDCAT.
    PERFORM LAYOUT.
    PERFORM VARIANT.
    PERFORM SAVE.
    PERFORM EVENTS.
    PERFORM ALV_DISPLAY.
    *********************FORMS*******************************************
    *& Form validate
    text
    --> p1 text
    <-- p2 text
    FORM VALIDATE .
    SELECT SINGLE VBELN
    FROM VBAP
    INTO V_VBELN
    WHERE VBELN IN S_VBELN.
    IF SY-SUBRC <> 0.
    MESSAGE E000 WITH 'enter valid vbeln'.
    ENDIF.
    ENDFORM. " validate
    *& Form get_details
    text
    --> p1 text
    <-- p2 text
    FORM GET_DETAILS .
    SELECT VBELN
    POSNR
    MATNR
    FROM VBAP
    INTO TABLE IT_VBAP
    WHERE VBELN IN S_VBELN.
    IF SY-SUBRC <> 0.
    MESSAGE E000 WITH 'no details found'.
    ENDIF.
    ENDFORM. " get_details
    *& Form fieldcat
    text
    --> p1 text
    <-- p2 text
    FORM FIELDCAT .
    WA_FIELDCAT-TABNAME = 'IT_VBAP'.
    WA_FIELDCAT-FIELDNAME = 'VBELN'.
    WA_FIELDCAT-OUTPUTLEN = 10.
    WA_FIELDCAT-SELTEXT_L = 'SALES DOC'.
    APPEND WA_FIELDCAT TO IT_FIELDCAT.
    CLEAR WA_FIELDCAT.
    WA_FIELDCAT-TABNAME = 'IT_VBAP'.
    WA_FIELDCAT-FIELDNAME = 'POSNR'.
    WA_FIELDCAT-OUTPUTLEN = 6.
    WA_FIELDCAT-SELTEXT_L = 'ITEM'.
    APPEND WA_FIELDCAT TO IT_FIELDCAT.
    CLEAR WA_FIELDCAT.
    WA_FIELDCAT-TABNAME = 'IT_VBAP'.
    WA_FIELDCAT-FIELDNAME = 'MATNR'.
    WA_FIELDCAT-OUTPUTLEN = 18.
    WA_FIELDCAT-SELTEXT_L = 'MATERIAL NO'.
    APPEND WA_FIELDCAT TO IT_FIELDCAT.
    CLEAR WA_FIELDCAT.
    ENDFORM. " fieldcat
    *& Form LAYOUT
    text
    --> p1 text
    <-- p2 text
    FORM LAYOUT .
    WA_LAYOUT-ZEBRA = 'X'.
    ENDFORM. " LAYOUT
    *& Form VARIANT
    text
    --> p1 text
    <-- p2 text
    FORM VARIANT .
    CLEAR G_VARIANT.
    G_VARIANT-REPORT = SY-REPID.
    ENDFORM. " VARIANT
    *& Form SAVE
    text
    --> p1 text
    <-- p2 text
    FORM SAVE .
    CLEAR G_SAVE.
    G_SAVE = 'A'.
    ENDFORM. " SAVE
    *& Form EVENTS
    text
    --> p1 text
    <-- p2 text
    FORM EVENTS .
    CLEAR XS_EVENTS.
    XS_EVENTS-NAME = SLIS_EV_TOP_OF_PAGE.
    XS_EVENTS-FORM = 'TOP_OF_PAGE'.
    APPEND XS_EVENTS TO G_EVENTS.
    ENDFORM. " EVENTS
    *& Form TOP_OF_PAGE
    text
    FORM TOP_OF_PAGE.
    WRITE :/ ' INTELLI GROUP'.
    ENDFORM. "TOP_OF_PAGE
    *& Form ALV_DISPLAY
    text
    --> p1 text
    <-- p2 text
    FORM ALV_DISPLAY .
    CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'
    EXPORTING
    I_INTERFACE_CHECK = ' '
    I_BYPASSING_BUFFER =
    I_BUFFER_ACTIVE = ' '
    I_CALLBACK_PROGRAM = SY-REPID
    I_CALLBACK_PF_STATUS_SET = PF_STATUS
    I_CALLBACK_USER_COMMAND = USER_COMMAND
    I_STRUCTURE_NAME =
    IS_LAYOUT = WA_LAYOUT
    IT_FIELDCAT = IT_FIELDCAT
    IT_EXCLUDING =
    IT_SPECIAL_GROUPS =
    IT_SORT =
    IT_FILTER =
    IS_SEL_HIDE =
    I_DEFAULT = 'X'
    I_SAVE = G_SAVE
    IS_VARIANT = G_VARIANT
    IT_EVENTS = G_EVENTS
    IT_EVENT_EXIT =
    IS_PRINT =
    IS_REPREP_ID =
    I_SCREEN_START_COLUMN = 0
    I_SCREEN_START_LINE = 0
    I_SCREEN_END_COLUMN = 0
    I_SCREEN_END_LINE = 0
    IMPORTING
    E_EXIT_CAUSED_BY_CALLER =
    ES_EXIT_CAUSED_BY_USER =
    TABLES
    T_OUTTAB = IT_VBAP
    EXCEPTIONS
    PROGRAM_ERROR = 1
    OTHERS = 2
    IF SY-SUBRC 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
    WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
    ENDIF.
    ENDFORM. " ALV_DISPLAY
    *& Form SET_PF_STATUS
    text
    FORM SET_PF_STATUS USING EXTAB TYPE SLIS_T_EXTAB.
    SET PF-STATUS 'Z50651_PFSTATUS' EXCLUDING EXTAB.
    ENDFORM. "SET_PF_STATUS
    *& Form SET_USER_COMMAND
    text
    FORM SET_USER_COMMAND USING R_UCOMM
    RS_SELFIELD TYPE SLIS_SELFIELD.
    CASE R_UCOMM.
    WHEN 'DC'.
    READ TABLE IT_VBAP INDEX RS_SELFIELD-TABINDEX.
    IF SY-SUBRC = 0.
    SELECT SINGLE MTART
    FROM MARA
    INTO V_MTART
    WHERE MATNR = IT_VBAP-MATNR.
    IF SY-SUBRC 0.
    MESSAGE E000 WITH 'NO MATERIAL DESCRIPTION FOR SELECTED MATERIAL NO'.
    ELSE.
    WRITE :/ 'MATERIAL NO :',IT_VBAP-MATNR.
    WRITE :/ 'MATERIAL TYPE :' , V_MTART.
    ENDIF.
    ENDIF.
    WHEN 'BACK'.
    LEAVE TO SCREEN 0.
    WHEN 'EXIT'.
    LEAVE TO SCREEN 0.
    WHEN 'CLOSE'.
    CALL TRANSACTION 'SE38'.
    ENDCASE.
    ENDFORM. "SET_USER_COMMAND
    Reward if useful...

  • HELP REQUIRED in ALV

    I am using function module ALV. I need a add a box on the side which comes in ALV. Second i need to control it such that the person can either select one record or mutilple. I know for getting the box there is a field in the layout. Help in this regards will be really helpful.
    Regards,
    Gurpreet

    Hi ,
    The internal table which you are passing to the Function module of ALV ,in that just put a field of character type with length 1 say SEL(1) type C.
    And in the layout just provide the fieldname for e.g. WA_LAYOUT-BOX_FIELDNAME  = 'SEL'.
    Below i am giving a sample code which gives ALV output , In this user can select the record and process it for the smartform . Observe the section of code carefully it will help you out.
    any difficulty you can get bact to me.
    Sample code:
    =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
    Project Name : SABIC Sustenance
    Copyright : SABIC
    *=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
    Program Name         : ZMSTR0022
    Program Type         : REPORT
    Development Class    : ZLE_MST
    Originator           : Nilesh Raut
    Initiated on         : 24 DEC 2007
    Completed on         : 30 DEc 2007
    Final Release on     :
    Developed by         : Sudeep Reddy Lingi
    Transport Request No : DS1K9A04GO
    *=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
    Program Description  :Report for application of permit
    *=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
    NOTES -----This report is used by Permit unit at SMO to develop the
               form of application of permit.
    No Authorization Check Required
    *=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
    REPORT  ZMSTR0022.
    CONSTANTS: C_FORM_NAME TYPE TDSFNAME VALUE 'ZMST_PER_APPL'.
    TABLES :ZMST_PERMIT.
    TYPE-POOLS: SLIS.
    TYPE-POOLS :VRM.                           "Value Request Manager
    TYPES:BEGIN OF STRU_ZMST_PERMIT,
         CHECKBOX(1) TYPE C,                    " Checkbox
         ZPIDNUM TYPE ZMST_PERMIT-ZPIDNUM,   " Permit ID No.
         ZARBDSC TYPE ZMST_PERMIT-ZARBDSC,   " Arabic description
         ZENGDSC TYPE ZMST_PERMIT-ZENGDSC,   " English description
         ZENQUAN TYPE ZMST_PERMIT-ZENQUAN,   " Qty in English
         ZARQUAN TYPE ZMST_PERMIT-ZARQUAN,   " Qty in Arabic
         ZENUOM  TYPE ZMST_PERMIT-ZENUOM,    " UoM
         ZTARIFF TYPE  ZMST_PERMIT-ZTARIFF,  " Tariff No
         ZARRPRT TYPE ZMST_PERMIT-ZARRPRT,   " Port code
         ZPRT_NAME(60) TYPE C,               " Port name in Arabic
         ZPERNUM TYPE ZMST_PERMIT-ZPERNUM,   " Reference No
         ZEFFDT  TYPE ZMST_PERMIT-ZEFFDT,    " Valid from
         ZEXPDT  TYPE ZMST_PERMIT-ZEXPDT,    " Valid to
         ZARB_DT(15) TYPE C,                 " Arabic Date of letter
         ZNAME_AUTH(50) TYPE C,              " Name of Authority
         ZPERM_MIN(50) TYPE C,               " Permit Ministry
         END OF STRU_ZMST_PERMIT.
    TYPES:BEGIN OF STRU_PERMIT,
          ZPIDNUM TYPE ZMST_PERMIT-ZPIDNUM,  " Permit ID No.
          ZENGDSC TYPE ZMST_PERMIT-ZENGDSC,  " English description
          ZARBDSC TYPE ZMST_PERMIT-ZARBDSC,  " Arabic description
          ZTARIFF TYPE  ZMST_PERMIT-ZTARIFF, " Tariff No
          ZPERNUM TYPE ZMST_PERMIT-ZPERNUM,  " Reference No
          ZARRPRT TYPE ZMST_PERMIT-ZARRPRT,  " Port code
          ZEFFDT  TYPE ZMST_PERMIT-ZEFFDT,   " Valid from
          ZEXPDT  TYPE ZMST_PERMIT-ZEXPDT,   " Valid to
          END OF STRU_PERMIT.
    TYPES: BEGIN OF STRU_FORM_PERMIT,
           ZARBDSC TYPE ZMST_PERMIT-ZARBDSC,   " Arabic description
           ZENGDSC TYPE ZMST_PERMIT-ZENGDSC,   " English description
           ZENQUAN TYPE ZMST_PERMIT-ZENQUAN,   " Qty in English
           ZARQUAN TYPE ZMST_PERMIT-ZARQUAN,   " Qty in Arabic
           ZENUOM  TYPE ZMST_PERMIT-ZENUOM,    " UoM
           ZTARIFF TYPE  ZMST_PERMIT-ZTARIFF,  " Tariff No
           ZPRT_NAME(60) TYPE C,               " Port name in Arabic
           END OF STRU_FORM_PERMIT.
    DATA: IT_PERMIT TYPE TABLE OF STRU_PERMIT.
    DATA: IT_ZMST_PERMIT TYPE TABLE OF STRU_ZMST_PERMIT,
          WA_ZMST_PERMIT LIKE LINE OF IT_ZMST_PERMIT,
          IT_FORM_PERMIT TYPE TABLE OF STRU_FORM_PERMIT,
          WA_FORM_PERMIT LIKE LINE OF IT_FORM_PERMIT.
    DATA: WA_LAYOUT   TYPE SLIS_LAYOUT_ALV,
          WA_FIELDCAT TYPE SLIS_FIELDCAT_ALV,
          IT_FIELDCAT TYPE TABLE OF SLIS_FIELDCAT_ALV.
    DATA: W_FORM TYPE RS38L_FNAM.
    DATA: W_NAME_AUTH(50),
          W_ZARBDT(15),
          W_ZENGDT(10),
         W_ZPRT_NAME(70).
    DATA: W_PARAM TYPE SSFCTRLOP.
    DATA:W_NAME1 TYPE DFIES-FIELDNAME,
          W_NAME2 TYPE HELP_INFO-DYNPROFLD .
    SELECTION-SCREEN BEGIN OF BLOCK B1 WITH FRAME TITLE TEXT-023.
    SELECT-OPTIONS:S_PIDNUM FOR ZMST_PERMIT-ZPIDNUM ,
                   S_ENGDSC FOR ZMST_PERMIT-ZENGDSC NO INTERVALS LOWER CASE,
                   S_ARBDSC FOR ZMST_PERMIT-ZARBDSC NO INTERVALS LOWER CASE,
                   S_TARIFF FOR ZMST_PERMIT-ZTARIFF NO INTERVALS,
                   S_PERNUM FOR ZMST_PERMIT-ZPERNUM NO INTERVALS,
                   S_ARRPRT FOR ZMST_PERMIT-ZARRPRT NO INTERVALS MATCHCODE OBJECT ZMST_PORTS.
    PARAMETER:P_PERTYP(2) TYPE C AS LISTBOX VISIBLE LENGTH 20.
    SELECTION-SCREEN END OF BLOCK B1.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_PIDNUM-LOW.
      W_NAME2 = 'S_PIDNUM-LOW'.
      W_NAME1 = 'ZPIDNUM'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_PIDNUM-HIGH.
      W_NAME2 = 'S_PIDNUM-HIGH'.
      W_NAME1 = 'ZPIDNUM'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_ENGDSC-LOW.
      W_NAME2 = 'S_ENGDSC'.
      W_NAME1 = 'ZENGDSC'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_ARBDSC-LOW.
      W_NAME2 = 'S_ARBDSC'.
      W_NAME1 = 'ZARBDSC'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_TARIFF-LOW.
      W_NAME2 = 'S_TARIFF'.
      W_NAME1 = 'ZTARIFF'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_PERNUM-LOW.
      W_NAME2 = 'S_PERNUM'.
      W_NAME1 = 'ZPERNUM'.
      PERFORM F4_HELP USING W_NAME1 W_NAME2 .         "calling subroutine to provide desired F4 help
    AT SELECTION-SCREEN.
      IF SY-UCOMM = 'ONLI'.
        PERFORM CHECK_INPUT.                            "calling subroutine to check inputs on selection screen
      ENDIF.
    INITIALIZATION.
      PERFORM VAL_PERTYP.
    START-OF-SELECTION.
      PERFORM FILL_FIELDCAT.                          "calling subroutine for filling fieldcatalog
    If Permit ministry is blank then fetch data from ZMST_PERMIT otherwise from ZMST_PERMITHI--
      IF P_PERTYP IS INITIAL.
        PERFORM FETCH_PERMIT.                         "calling subroutine to fetch data from ZMST_PERMIT
      ELSE.
        PERFORM FETCH_PERMITHI.                       "calling subroutine to fetch data from ZMST_PERMITHI
      ENDIF.
    END-OF-SELECTION.
    *&      Form  fill_fieldcat
          text
    -->  p1        text
    <--  p2        text
    FORM FILL_FIELDCAT .
    -passing the parameters of layout--
      WA_LAYOUT-ZEBRA = 'X'.
      WA_LAYOUT-COLWIDTH_OPTIMIZE = 'X'.
      WA_LAYOUT-BOX_FIELDNAME = 'CHECKBOX'.
      WA_LAYOUT-BOX_TABNAME = 'IT_ZMST_PERMIT'.
    -Passing the parameters of fieldcatalog--
      WA_FIELDCAT-FIELDNAME = 'ZPIDNUM'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-001.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZARBDSC'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-002.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      WA_FIELDCAT-OUTPUTLEN = 120.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZENGDSC'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-003.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      WA_FIELDCAT-OUTPUTLEN = 120.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZENQUAN'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-004.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZARQUAN'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-005.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZENUOM'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-006.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZTARIFF'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-007.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-OUTPUTLEN = 15.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZARB_DT'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_L = TEXT-013.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZNAME_AUTH'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-014.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-OUTPUTLEN = 50.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZPRT_NAME'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-009.
      WA_FIELDCAT-EDIT = 'X'.
      WA_FIELDCAT-OUTPUTLEN = 60.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZARRPRT'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-008.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZPERNUM'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-010.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZEFFDT'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-011.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZEXPDT'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-012.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
      WA_FIELDCAT-FIELDNAME = 'ZPERM_MIN'.
      WA_FIELDCAT-TABNAME = 'IT_ZMST_PERMIT'.
      WA_FIELDCAT-SELTEXT_M = TEXT-019.
      WA_FIELDCAT-OUTPUTLEN = 50.
      WA_FIELDCAT-LOWERCASE = 'X'.
      APPEND WA_FIELDCAT TO IT_FIELDCAT.
      CLEAR WA_FIELDCAT.
    ENDFORM.                    " fill_fieldcat
    *&      Form  alv_disp
          text
    -->  p1        text
    <--  p2        text
    FORM ALV_DISP .
      CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
        EXPORTING
          I_CALLBACK_PROGRAM       = 'ZMSTR0022'
          I_CALLBACK_PF_STATUS_SET = 'PF_STATUS'
          I_CALLBACK_USER_COMMAND  = 'USER_COMMAND'
          I_GRID_TITLE             = TEXT-015
          IS_LAYOUT                = WA_LAYOUT
          IT_FIELDCAT              = IT_FIELDCAT
          I_SAVE                   = 'A'
        TABLES
          T_OUTTAB                 = IT_ZMST_PERMIT
        EXCEPTIONS
          PROGRAM_ERROR            = 1
          OTHERS                   = 2.
      IF SY-SUBRC <> 0.
        MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                    " alv_disp
    *&      Form  PF_STATUS
          text
      This subroutine sets the GUI status
    FORM PF_STATUS USING RT_EXTAB TYPE SLIS_T_EXTAB.
      SET PF-STATUS 'ZSTANDARD_FULLSCREEN'.
    ENDFORM.                    "PF_STATUS
    *&      Form  USER_COMMAND
    FORM USER_COMMAND USING R_UCOMM TYPE SY-UCOMM  RS_SELFIELD TYPE SLIS_SELFIELD.
    *For Printing Smartform
      IF R_UCOMM = 'PRT'.
        CLEAR WA_FORM_PERMIT.
        REFRESH IT_FORM_PERMIT.
        LOOP AT IT_ZMST_PERMIT INTO WA_ZMST_PERMIT WHERE CHECKBOX = 'X'.
          MOVE-CORRESPONDING WA_ZMST_PERMIT TO WA_FORM_PERMIT.
          APPEND WA_FORM_PERMIT TO IT_FORM_PERMIT .
    *Check for First occurence of Name of authority
          IF WA_ZMST_PERMIT-ZNAME_AUTH NE SPACE.
            IF W_NAME_AUTH = ' '.
              W_NAME_AUTH = WA_ZMST_PERMIT-ZNAME_AUTH.
            ENDIF.
          ENDIF.
    *Check for First occurence of Arabic date
          IF WA_ZMST_PERMIT-ZARB_DT NE SPACE.
            IF W_ZARBDT = ' '.
              W_ZARBDT = WA_ZMST_PERMIT-ZARB_DT.
            ENDIF.
          ENDIF.
          IF WA_ZMST_PERMIT-ZPRT_NAME NE SPACE.
            IF W_ZPRT_NAME = ' '.
              MOVE WA_ZMST_PERMIT-ZPRT_NAME TO W_ZPRT_NAME.
              CONDENSE W_ZPRT_NAME.
            ENDIF.
          ENDIF.
          CLEAR : WA_FORM_PERMIT, WA_ZMST_PERMIT.
        ENDLOOP.
        CONCATENATE SY-DATUM0(4) '/' SY-DATUM4(2) '/' SY-DATUM+6(2) INTO W_ZENGDT.
    *Printing    Subroutine
        IF NOT IT_FORM_PERMIT[] IS INITIAL.
          PERFORM PRINT_FORM.
        ELSE.
          MESSAGE TEXT-018 TYPE 'I'.
        ENDIF.
      ENDIF.
    ENDFORM.                    "user_command
    *&      Form  F4_HELP
          text
    -->  p1        text
    <--  p2        text
    FORM F4_HELP USING: W_VAR TYPE DFIES-FIELDNAME
                        W_VAR1 TYPE HELP_INFO-DYNPROFLD .
    Fetching data from zmst_permit for F4 help on PERMIT ID No.--
      IF IT_PERMIT[] IS INITIAL.
        SELECT ZPIDNUM
               ZENGDSC
               ZARBDSC
               ZTARIFF
               ZPERNUM
               ZARRPRT
               ZEFFDT
               ZEXPDT
               FROM ZMST_PERMIT INTO CORRESPONDING FIELDS OF TABLE IT_PERMIT.
      ENDIF.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        EXPORTING
          RETFIELD        = W_NAME1 " 'ZPIDNUM'
          DYNPPROG        = 'ZMSTR0022'
          DYNPNR          = SY-DYNNR
          DYNPROFIELD     = W_NAME2 "'S_PIDNUM'
          VALUE_ORG       = 'S'
        TABLES
          VALUE_TAB       = IT_PERMIT
        EXCEPTIONS
          PARAMETER_ERROR = 1
          NO_VALUES_FOUND = 2
          OTHERS          = 3.
      IF SY-SUBRC <> 0.
        MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                                                    " F4_HELP
    *&      Form  check_input
          text
    -->  p1        text
    <--  p2        text
    FORM CHECK_INPUT .
      IF S_PIDNUM[] IS INITIAL AND
         S_ENGDSC[] IS INITIAL AND
         S_ARBDSC[] IS INITIAL AND
         S_TARIFF[] IS INITIAL AND
         S_PERNUM[] IS INITIAL AND
         S_ARRPRT[] IS INITIAL .
        MESSAGE TEXT-016 TYPE 'E'.
        LEAVE TO TRANSACTION 'ZMSTR022'.
      ENDIF.
    ENDFORM.                    " check_input
    *&      Form  print_form
          text
    -->  p1        text
    <--  p2        text
    FORM PRINT_FORM .
      CALL FUNCTION 'SSF_FUNCTION_MODULE_NAME'
        EXPORTING
          FORMNAME           = C_FORM_NAME
        IMPORTING
          FM_NAME            = W_FORM
        EXCEPTIONS
          NO_FORM            = 1
          NO_FUNCTION_MODULE = 2
          OTHERS             = 3.
      IF SY-SUBRC <> 0.
        MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
      W_PARAM-LANGU ='AR'.
      CALL FUNCTION W_FORM
        EXPORTING
          CONTROL_PARAMETERS = W_PARAM
          W_NAME_AUTH        = W_NAME_AUTH
          W_ZARBDT           = W_ZARBDT
          W_ZENGDT           = W_ZENGDT
          W_ZPRT_NAME        = W_ZPRT_NAME
        TABLES
          IT_FORM_PERMIT     = IT_FORM_PERMIT
        EXCEPTIONS
          FORMATTING_ERROR   = 1
          INTERNAL_ERROR     = 2
          SEND_ERROR         = 3
          USER_CANCELED      = 4
          OTHERS             = 5.
      IF SY-SUBRC <> 0.
        MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                    " print_form
    *&      Form  fetch_Permit
          text
    -->  p1        text
    <--  p2        text
    FORM FETCH_PERMIT .
    -Fetching data from zmst_permit based on the inputs on selection screen--
      SELECT
           ZPIDNUM
           ZARBDSC
           ZENGDSC
           ZENQUAN
           ZARQUAN
           ZENUOM
           ZTARIFF
           ZARRPRT
           ZPERNUM
           ZEFFDT
           ZEXPDT
           FROM ZMST_PERMIT INTO CORRESPONDING FIELDS OF TABLE IT_ZMST_PERMIT
           WHERE ZPIDNUM IN S_PIDNUM
           AND   ZENGDSC IN S_ENGDSC
           AND   ZARBDSC IN S_ARBDSC
           AND   ZTARIFF IN S_TARIFF
           AND   ZPERNUM IN S_PERNUM
           AND   ZARRPRT IN S_ARRPRT.
      IF SY-SUBRC <> 0.
        MESSAGE TEXT-017 TYPE 'I'.
        LEAVE TO TRANSACTION 'ZMSTR022'.
      ELSE.
        LOOP AT IT_ZMST_PERMIT INTO WA_ZMST_PERMIT.
          WA_ZMST_PERMIT-ZPERM_MIN = TEXT-020.
          MODIFY IT_ZMST_PERMIT INDEX SY-TABIX FROM WA_ZMST_PERMIT TRANSPORTING ZPERM_MIN .
        ENDLOOP.
        PERFORM ALV_DISP.        " calling subroutine for ALV display
      ENDIF.
    ENDFORM.                    " fetch_Permit
    *&      Form  fetch_permithi
          text
    -->  p1        text
    <--  p2        text
    FORM FETCH_PERMITHI .
    -Fetching data from zmst_permit based on the inputs on selection screen--
      SELECT
           ZPIDNUM
           ZARBDSC
           ZENGDSC
           ZENQUAN
           ZARQUAN
           ZENUOM
           ZTARIFF
           ZARRPRT
           ZPERNUM
           ZEFFDT
           ZEXPDT
           FROM ZMST_PERMITHI INTO CORRESPONDING FIELDS OF TABLE IT_ZMST_PERMIT
           WHERE ZPIDNUM IN S_PIDNUM
           AND   ZENGDSC IN S_ENGDSC
           AND   ZARBDSC IN S_ARBDSC
           AND   ZTARIFF IN S_TARIFF
           AND   ZPERNUM IN S_PERNUM
           AND   ZARRPRT IN S_ARRPRT
           AND  ZPERTYP  = P_PERTYP.
      IF SY-SUBRC <> 0.
        MESSAGE TEXT-017 TYPE 'I'.
        LEAVE TO TRANSACTION 'ZMSTR022'.
      ELSE.
        LOOP AT IT_ZMST_PERMIT INTO WA_ZMST_PERMIT.
          CASE P_PERTYP.
            WHEN 'I'.
              WA_ZMST_PERMIT-ZPERM_MIN = TEXT-021.
              MODIFY IT_ZMST_PERMIT INDEX SY-TABIX FROM WA_ZMST_PERMIT TRANSPORTING ZPERM_MIN .
            WHEN 'H'.
              WA_ZMST_PERMIT-ZPERM_MIN = TEXT-022.
              MODIFY IT_ZMST_PERMIT INDEX SY-TABIX FROM WA_ZMST_PERMIT TRANSPORTING ZPERM_MIN .
          ENDCASE.
        ENDLOOP.
        PERFORM ALV_DISP.        " calling subroutine for ALV display
      ENDIF.
    ENDFORM.                    " fetch_permithi
    *&      Form  val_PERTYP
          text
    -->  p1        text
    <--  p2        text
    FORM VAL_PERTYP .
      DATA: W_NAME TYPE VRM_ID,
            IT_LIST TYPE VRM_VALUES,
            WA_VALUE LIKE LINE OF IT_LIST.
      WA_VALUE-KEY = ' '.
      WA_VALUE-TEXT = TEXT-020.
      APPEND WA_VALUE TO IT_LIST.
      CLEAR WA_VALUE.
      WA_VALUE-KEY = 'I'.
      WA_VALUE-TEXT = TEXT-021.
      APPEND WA_VALUE TO IT_LIST.
      CLEAR WA_VALUE.
      WA_VALUE-KEY = 'H'.
      WA_VALUE-TEXT = TEXT-022.
      APPEND WA_VALUE TO IT_LIST.
      CLEAR WA_VALUE.
      W_NAME = 'P_PERTYP'.
      P_PERTYP = ' '.
      CALL FUNCTION 'VRM_SET_VALUES'
        EXPORTING
          ID              = W_NAME
          VALUES          = IT_LIST
        EXCEPTIONS
          ID_ILLEGAL_NAME = 1
          OTHERS          = 2.
      IF SY-SUBRC <> 0.
        MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                    " val_PERTYP

  • Help needed for ALV report

    Hi,
    i need to add coloums for the existing report which picks from G/L account.
    in this report I need to add some more columns from COSP-KSTAR, which shows the cost element details from G/L account.
    I need to restrict that cost element number according to the company code.
    Plz see this and let me know the things.
    1. I need to add FISCAL YEAR(COEP-GJAHR) in selection screen.
    2. I need to add column: Employee Cost (CSKS-KOSTL)
    3. add a column Staff Welfare (COSP-KSTAR) this is to restrict for the cost element 3000200 from G/L account
    4. add a column Recruitment restrict for the cost element(COSP-KSTAR) 3100040 from G/L account
    5. add a column Travels (suppressing some cost elements(COSP-KSTAR) and putting into Travels)
    6. add a column Subcontracts restrict for the cost element (COSP-KSTAR)3100360 from G/L account
    7. add a column Communication suppressing some cost elements and putting into Communication)
    8. add a column Rent restrict for the cost element (COSP-KSTAR)3100055 from G/L account
    9. add a column Back end Cost restrict for the cost element (COSP-KSTAR)3100065 from G/L account
    i can hardcode these cost elements.
    i did according to some of our sdn friends guidence but it is going to dump.
    hear i am sending the code what i changed.
    it is giving the error with the select.
    SELECT BUKRS KOKRS gjahr kstar OBJNR OBJNR_N1 PERIO  BEKNZ WKGBTR WOGBTR  FROM
    COEP  INTO TABLE
    IT_COEP FOR ALL ENTRIES IN IT_AUFK WHERE OBJNR = IT_AUFK-OBJNR and
    perio in S_PERIO.
    plz try to help me out in this issue.
    hear i am sending the complete code what i worte.
    *& Report  ZPROJECT_PROFIT2
    REPORT  ZPROJECT_PROFIT2.
    *********************MAIN DOCUMENTATION BLOCK*************************
    Project Code           :
    Program Name           :Zproject_profit1.
    Purpose of program     :This report will give the gross margin for a project as
    *a whole based on some selected input criteria.
    Author of program      :JAYA KRISHNA .B.
    INPUT/OUTPUT FILE      :nil
    TYPE-POOLS : SLIS."For ALV display.
    TABLES : COEP,  "CO Object: Line Items  (by period).
             AUFK,   "Order master data.
             csks,    "Cost center master data
             cosp.    "CO Objects
    *&  Include           ZSTRUCTURE
    types:    BEGIN OF TY_COEP ,            "structure of table COEP.
              BUKRS LIKE COEP-BUKRS,
              KOKRS LIKE COEP-KOKRS,
              OBJNR LIKE COEP-OBJNR,
               gjahr like coep-gjahr,
              kstar like coep-kstar,
              OBJNR_N1 LIKE COEP-OBJNR_N1,
              PERIO LIKE COEP-PERIO,
              BEKNZ LIKE COEP-BEKNZ,
              WKGBTR LIKE COEP-WKGBTR,
              WOGBTR LIKE COEP-WOGBTR,
              BELNR LIKE COEP-BELNR,
              END OF TY_COEP,
             BEGIN OF TY_AUFK ,             "structure of table AUFK.
             BUKRS LIKE AUFK-BUKRS,
             KOKRS LIKE AUFK-KOKRS,
             OBJNR LIKE AUFK-OBJNR,
             KTEXT LIKE AUFK-KTEXT,
             ANFAUFNR LIKE AUFK-ANFAUFNR,
             AUFEX LIKE AUFK-AUFEX,
             USER2 LIKE AUFK-USER2,
             USER0 LIKE AUFK-USER0,
             USER1 LIKE AUFK-USER1,
             USER3 LIKE AUFK-USER3,
             USER6 LIKE AUFK-USER6,
             USER7 LIKE AUFK-USER7,
             USER8 LIKE AUFK-USER8,
             ABKRS(10) TYPE C,
             USER9 LIKE AUFK-USER9,
             AUFNR LIKE AUFK-AUFNR,
           END OF TY_AUFK,
           begin of ty_csks,
           kokrs like csks-kokrs,
            kostl like csks-kostl,
            bukrs like csks-bukrs,
            objnr like csks-objnr,
                 end of ty_csks.
    DATA :   BEGIN OF IT_COSP occurs 100,
           OBJNR LIKE COSP-OBJNR,
           GJAHR LIKE COSP-GJAHR,
           KSTAR LIKE COSP-KSTAR,
           END OF IT_COSP.
    DATA : IT_COEP TYPE TABLE OF TY_COEP,     " Declaraton of tables COEP and AUFK.
           IT_AUFK TYPE TABLE OF TY_AUFK,
           IT_CSKS TYPE TABLE OF TY_CSKS.
          IT_COSP TYPE TABLE OF TY_COSP.
    DATA : WA_COEP LIKE LINE OF IT_COEP,      " Declaration of work areas for tables COEP and AUFK.
           WA_AUFK LIKE LINE OF IT_AUFK,
           WA_CSKS LIKE LINE OF IT_CSKS.
          WA_COSP LIKE LINE OF IT_COSP.
    DATA : BEGIN OF IT_DISPLAY OCCURS 0,      " Declaration of display table.
            OBJNR_N1 LIKE COEP-OBJNR_N1,
            OBJNR_N12 LIKE COEP-OBJNR_N1,
            KTEXT1 LIKE AUFK-KTEXT,
            WKGBTR LIKE COEP-WKGBTR,
            WOGBTR LIKE COEP-WOGBTR,
            WKGBTR1  LIKE COEP-WTGBTR,
            WOGBTR1 LIKE COEP-WOGBTR,
            ADDK LIKE COEP-WOGBTR,
            ADDO LIKE COEP-WOGBTR,
            ADDK1 LIKE COEP-WOGBTR,
            ADDO1 LIKE COEP-WOGBTR,
            PROFIT1 LIKE COEP-WOGBTR,
            PROFIT2 LIKE COEP-WOGBTR,
            BEKNZ LIKE COEP-BEKNZ,
            BUKRS LIKE AUFK-BUKRS,
            anfaufnr LIKE AUFK-anfaufnr,
            aufex like aufk-aufex,
            OBJNR LIKE AUFK-OBJNR,
            USER2 LIKE AUFK-USER2,
            USER0 LIKE AUFK-USER0,
            USER1 LIKE AUFK-USER1,
            USER3 LIKE AUFK-USER3,
            USER6 LIKE AUFK-USER6,
            USER7 LIKE AUFK-USER7,
            USER8 LIKE AUFK-USER8,
            ABKRS LIKE AUFK-ABKRS,
            USER9 LIKE AUFK-USER9,
            PERIO LIKE COEP-PERIO,
            AUFNR LIKE AUFK-AUFNR,
            STR(5) TYPE C,
            WORK(10) TYPE C,
           END OF IT_DISPLAY,
      : BEGIN OF IT_DISPLAY1 OCCURS 0,      " Declaration of second display table.
         OBJNR_N1 LIKE COEP-OBJNR_N1,
         OBJNR_N12 LIKE COEP-OBJNR_N1,
         KTEXT1 LIKE AUFK-KTEXT,
         WKGBTR LIKE COEP-WKGBTR,
         WOGBTR LIKE COEP-WOGBTR,
         WKGBTR1  LIKE COEP-WTGBTR,
         WOGBTR1 LIKE COEP-WOGBTR,
         ADDK LIKE COEP-WOGBTR,
         ADDO LIKE COEP-WOGBTR,
         ADDK1 LIKE COEP-WOGBTR,
         ADDO1 LIKE COEP-WOGBTR,
         PROFIT1 LIKE COEP-WOGBTR,
         PROFIT2 LIKE COEP-WOGBTR,
         BEKNZ LIKE COEP-BEKNZ,
         BUKRS LIKE AUFK-BUKRS,
         anfaufnr like aufk-anfaufnr,
         aufex like aufk-aufex,
         OBJNR LIKE AUFK-OBJNR,
         USER2 LIKE AUFK-USER2,
         USER0 LIKE AUFK-USER0,
         USER1 LIKE AUFK-USER1,
         USER3 LIKE AUFK-USER3,
         USER6 LIKE AUFK-USER6,
         USER7 LIKE AUFK-USER7,
         USER8 LIKE AUFK-USER8,
         ABKRS LIKE AUFK-ABKRS,
         USER9 LIKE AUFK-USER9,
         PERIO LIKE COEP-PERIO,
         AUFNR LIKE AUFK-AUFNR,
         STR(5) TYPE C,
         WORK(10) TYPE C,
        END OF IT_DISPLAY1.
    data : it_field type slis_fieldcat_alv,        " Declaration of ALV variables
           it_field_t type slis_t_fieldcat_alv,
            xlayout    TYPE slis_layout_alv.
    data : it_event type slis_t_event,
          wa_event like line of it_event.
    DATA : WA_TOP TYPE SLIS_LISTHEADER,
           IT_TOP TYPE SLIS_T_LISTHEADER.
    data:w_lines type i,
          w_occurs type i,
          STR(5) TYPE C,
          WORK(10) TYPE C.
          constants : c_selection type char20 value 'Selection based on'. " Declaration of a constant.
    selection-screen BEGIN OF BLOCK BLK WITH FRAME TITLE TEXT-000.
    SELECT-OPTIONS S_BUKRS FOR AUFK-BUKRS OBLIGATORY.
    SELECT-OPTIONS S_OBJNR FOR AUFK-AUFNR.
    SELECT-OPTIONS S_ANF FOR AUFK-ANFAUFNR.
    SELECT-OPTIONS S_AUFEX FOR AUFK-AUFEX.
    SELECT-OPTIONS S_USER2 FOR AUFK-USER2.
    SELECT-OPTIONS S_USER0 FOR AUFK-USER0.
    SELECT-OPTIONS S_USER1 FOR AUFK-USER1.
    SELECT-OPTIONS S_USER3 FOR AUFK-USER3.
    SELECT-OPTIONS S_USER6 FOR AUFK-USER6.
    SELECT-OPTIONS S_ABKRS FOR AUFK-ABKRS.
    SELECT-options s_gjahr for coep-gjahr obligatory.
    SELECT-OPTIONS S_PERIO FOR COEP-PERIO OBLIGATORY.
    SELECTION-SCREEN END OF BLOCK BLK .
    SELECTION-SCREEN BEGIN OF BLOCK BLK1 WITH FRAME TITLE TEXT-001.
    PARAMETERS : ONSITE RADIOBUTTON GROUP RADI.
    PARAMETERS : OFFSHORE RADIOBUTTON GROUP RADI.
    PARAMETERS : BOTH RADIOBUTTON GROUP RADI.
    SELECTION-SCREEN END OF BLOCK BLK1 .
    start-of-selection.
    *ZAUFK
                                  " Selection of records from aufk to internal table.
    IF ONSITE EQ 'X' .
    SELECT
    BUKRS
    KOKRS
    OBJNR
    KTEXT
    anfaufnr
    aufex
    USER2
    USER0
    USER1
    USER3
    USER6
    USER7
    USER8
    ABKRS
    USER9
    AUFNR
    FROM AUFK INTO TABLE IT_AUFK WHERE BUKRS IN S_BUKRS AND
    anfaufnr IN s_anf AND
    aufex in s_aufex and
    aufnr IN S_OBJNR AND
    USER2 IN S_USER2 AND
    USER0 IN S_USER0 AND
    USER1 IN S_USER1 AND
    USER3 IN S_USER3 AND
    USER6 IN S_USER6 AND
    ABKRS IN S_ABKRS AND
    USER9 EQ 'X' .
    ENDIF.
    IF OFFSHORE EQ 'X'.
    SELECT
    BUKRS
    KOKRS
    OBJNR
    KTEXT
    anfaufnr
    aufex
    USER2
    USER0
    USER1
    USER3
    USER6
    USER7
    USER8
    ABKRS
    USER9
    AUFNR
    FROM AUFK INTO TABLE IT_AUFK WHERE BUKRS IN S_BUKRS AND
    anfaufnr IN S_anf AND
    aufex in s_aufex and
    aufnR IN S_OBJNR AND
    USER2 IN S_USER2 AND
    USER0 IN S_USER0 AND
    USER1 IN S_USER1 AND
    USER3 IN S_USER3 AND
    USER6 IN S_USER6 AND
    ABKRS IN S_ABKRS AND
    USER9 <> 'X'.
    ENDIF.
    IF BOTH EQ 'X'.
    SELECT
    BUKRS
    KOKRS
    OBJNR
    KTEXT
    anfaufnr
    aufex
    USER2
    USER0
    USER1
    USER3
    USER6
    USER7
    USER8
    ABKRS
    USER9
    AUFNR
    FROM AUFK INTO TABLE IT_AUFK WHERE BUKRS IN S_BUKRS AND
    anfaufnr IN S_anf AND
    aufex in s_aufex and
    aufNR IN S_OBJNR AND
    USER2 IN S_USER2 AND
    USER0 IN S_USER0 AND
    USER1 IN S_USER1 AND
    USER3 IN S_USER3 AND
    USER6 IN S_USER6 AND
    ABKRS IN S_ABKRS.
    ENDIF.
    *&  Include           ZCOEP
                                  " Selection of records from coep to internal table.
    SELECT BUKRS KOKRS gjahr kstar OBJNR OBJNR_N1 PERIO  BEKNZ WKGBTR WOGBTR  FROM
    COEP  INTO TABLE
    IT_COEP FOR ALL ENTRIES IN IT_AUFK WHERE OBJNR = IT_AUFK-OBJNR and
    perio in S_PERIO.
    *&  Include           ZPROFIT_CALC
                                 " Calculations for income and Profit of the employee.
    if not it_coep[] is initial.
        select objnr gjahr wrttp versn kstar from cosp into TABLE It_cosp for
    all entries in it_coep where objnr = IT_COEP-objnr .
    endif.
      LOOP AT IT_coep INTO WA_coep.
        read table IT_aufk into WA_aufk with key OBJNR = wa_coep-OBJNR.
    case it_cosp-kstar.
    when '3000200'.
    it_cosp-kstar = cosp-kstar.
    when '3100040'.
    it_cosp-kstar = cosp-kstar.
    when '3100360'.
    it_cosp-kstar = cosp-kstar.
    when '3100055'.
    it_cosp-kstar = cosp-kstar.
    when '3100065'.
    it_cosp-kstar = cosp-kstar.
    when '3100115'.
    it_cosp-kstar = cosp-kstar.
    when '3100120'.
    it_cosp-kstar = cosp-kstar.
    when '3100130'.
    it_cosp-kstar = cosp-kstar.
    when '3100135'.
    it_cosp-kstar = cosp-kstar.
    when '3100140'.
    it_cosp-kstar = cosp-kstar.
    when '3100145'.
    it_cosp-kstar = cosp-kstar.
    when '3100150'.
    it_cosp-kstar = cosp-kstar.
    when '3100155'.
    it_cosp-kstar = cosp-kstar.
    when '3100160'.
    it_cosp-kstar = cosp-kstar.
    when '3100165'.
    it_cosp-kstar = cosp-kstar.
    when '3100170'.
    it_cosp-kstar = cosp-kstar.
    endcase.
        IT_DISPLAY-BUKRS = WA_AUFK-BUKRS.
        IT_DISPLAY-anfaufnr = WA_AUFK-anfaufnr.
        it_display-aufex  = wa_aufk-aufex.
        IT_DISPLAY-OBJNR = WA_AUFK-OBJNR.
        IT_DISPLAY-USER2 = WA_AUFK-USER2.
        IT_DISPLAY-USER0 = WA_AUFK-USER0.
        IT_DISPLAY-USER1 = WA_AUFK-USER1.
        IT_DISPLAY-USER3 = WA_AUFK-USER3.
        IT_DISPLAY-USER6 = WA_AUFK-USER6.
        IT_DISPLAY-USER7 = WA_AUFK-USER7.
        IT_DISPLAY-USER8 = WA_AUFK-USER8.
        IT_DISPLAY-ABKRS = WA_AUFK-ABKRS.
        IT_DISPLAY-USER9 = WA_AUFK-USER9.
        IT_DISPLAY-KTEXT1 =  WA_AUFK-KTEXT.
        if WA_AUFK-abkrs = 01.
          IT_DISPLAY-STR = 'TM'.
        ENDIF.
        IF WA_AUFK-ABKRS = 02.
          IT_DISPLAY-STR = 'FP'.
        ENDIF.
        IF WA_AUFK-USER9 = 'X'.
          IT_DISPLAY-WORK = 'ONSITE'.
        ENDIF.
        IF WA_AUFK-USER9 <> 'X'.
          IT_DISPLAY-WORK = 'OFFSHORE'.
        ENDIF.
        it_display-ABKRS = it_display-user7.
        IF wa_coep-BEKNZ = 'S'.
          IT_DISPLAY-WKGBTR = WA_COEP-WKGBTR.
          IT_DISPLAY-WOGBTR = WA_COEP-WOGBTR.
          IT_DISPLAY-ADDK = IT_DISPLAY-ADDK + IT_DISPLAY-WKGBTR.
          IT_DISPLAY-ADDO = IT_DISPLAY-ADDO + IT_DISPLAY-WOGBTR.
          IT_DISPLAY-ADDK1 = 0.
          IT_DISPLAY-ADDO1 = 0.
          IT_DISPLAY-PROFIT1 = IT_DISPLAY-ADDK1 +  IT_DISPLAY-ADDK.
          IT_DISPLAY-PROFIT2 = IT_DISPLAY-ADDO1 +  IT_DISPLAY-ADDO.
          APPEND IT_DISPLAY.
        ENDIF.
        IF WA_COEP-BEKNZ = 'H'.
          IT_DISPLAY-WKGBTR1 = WA_COEP-WKGBTR.
          IT_DISPLAY-WOGBTR1 = WA_COEP-WOGBTR.
          IT_DISPLAY-ADDK1 = IT_DISPLAY-ADDK + IT_DISPLAY-WKGBTR1.
          IT_DISPLAY-ADDO1 = IT_DISPLAY-ADDO + IT_DISPLAY-WOGBTR1.
          IT_DISPLAY-ADDK = 0.
          IT_DISPLAY-ADDO = 0.
          IT_DISPLAY-PROFIT1 = IT_DISPLAY-ADDK1 +  IT_DISPLAY-ADDK.
          IT_DISPLAY-PROFIT2 = IT_DISPLAY-ADDO1 +  IT_DISPLAY-ADDO.
          APPEND IT_DISPLAY.
        ENDIF.
        collect it_display into it_display1.
        clear it_display.
      ENDLOOP.
                        "calc
    *&  Include           ZPROFIT_DISPLAY
      LOOP AT IT_DISPLAY1.                                         "it_display.
        read table IT_COEP into WA_COEP with key OBJNR =
        IT_DISPLAY-OBJNR.
        read table IT_AUFK into WA_AUFK with key aufnr = IT_DISPLAY-aufnr.
        if WA_AUFK-abkrs = 01.
          STR = 'TM'.
        ENDIF.
        IF WA_AUFK-ABKRS = 02.
          STR = 'FP'.
        ENDIF.
        IF WA_AUFK-USER9 = 'X'.
          WORK = 'ONSITE'.
        ENDIF.
        IF WA_AUFK-USER9 <> 'X'.
          WORK = 'OFFSHORE'.
        ENDIF.
      endloop.
      clear it_field.
      it_field-col_pos = 1.
      it_field-fieldname = 'AUFNR'.
      it_field-seltext_l = 'project id.'.
      it_field-outputlen = 15.
      append it_field to it_field_t.
      CLEAR it_field.
      clear it_field.
      it_field-col_pos = 2.
      it_field-fieldname = 'KTEXT1'.
      it_field-seltext_l = 'Project Name'.
      it_field-outputlen = 20.
      append it_field to it_field_t.
      CLEAR it_field.
      clear it_field.
      it_field-col_pos = 3.
      it_field-fieldname = 'USER7'.
      it_field-seltext_l = 'Start Date'.
      it_field-do_sum = 'X'.
      it_field-outputlen = 20.
      append it_field to it_field_t.
      CLEAR it_field.
      clear it_field.
      it_field-col_pos = 4.
      it_field-fieldname = 'USER8'.
      it_field-seltext_l = 'End Date'.
      it_field-do_sum = 'X'.
      it_field-outputlen = 20.
      append it_field to it_field_t.
      CLEAR it_field.
      clear it_field.
      it_field-col_pos = 5.
      it_field-fieldname = 'USER2'.
      it_field-seltext_l = 'Location'.
      it_field-do_sum = 'X'.
      it_field-outputlen = 20.
      append it_field to it_field_t.
      CLEAR it_field.
      clear it_field.
      it_field-col_pos = 6.
      it_field-fieldname = 'USER0'.
      it_field-seltext_l = 'Vertical'.
      it_field-do_sum = 'X'.
      it_field-outputlen = 20.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 7.
      it_field-fieldname = 'USER1'.
      it_field-seltext_l = 'Sub_vertical'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 8.
      it_field-fieldname = 'USER3'.
      it_field-seltext_l = 'Technology'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 9.
      it_field-fieldname = 'USER6'.
      it_field-seltext_l = 'Department'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 10.
      it_field-fieldname = 'WORK'.
      it_field-seltext_l = 'Onsite/Offshore'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 11.
      it_field-fieldname = 'STR'.
      it_field-seltext_l = 'T&M/FP'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 12.
      it_field-fieldname = 'KOSTL'.
      it_field-seltext_l = 'EMP COST'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 13.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'STAFF WELFARE'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 14.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'RECRUITMENT'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 15.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'TRAVELS'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 16.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'SUBCONTRACT'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 17.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'COMMUNICATION'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 18.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'RENT'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 19.
      it_field-fieldname = 'KSTAR'.
      it_field-seltext_l = 'BACKEND COST (PROJECT EXP)'.
      it_field-outputlen = 10.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
    it_field-col_pos = 20.
      it_field-fieldname = 'ADDO'.
      it_field-seltext_l = 'Direct costs'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 21.
      it_field-fieldname = 'ADDO1'.
      it_field-seltext_l = 'Income'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 22.
      it_field-fieldname = 'PROFIT2'.
      it_field-seltext_l = 'Profit(income-costs)'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 23.
      it_field-fieldname = 'ADDK'.
      it_field-seltext_l = 'Direct costs(Grp cur)'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 24.
      it_field-fieldname = 'ADDK1'.
      it_field-seltext_l = 'Income(Grp Cur)'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      it_field-col_pos = 25.
      it_field-fieldname = 'PROFIT1'.
      it_field-seltext_l = 'Profit(income-costs)'.
      it_field-outputlen = 20.
      it_field-do_sum = 'X'.
      append it_field to it_field_t.
      CLEAR it_field.
      xlayout-zebra = 'X'.
      CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
       EXPORTING
      I_INTERFACE_CHECK                 = ' '
      I_BYPASSING_BUFFER                = ' '
      I_BUFFER_ACTIVE                   = ' '
         I_CALLBACK_PROGRAM                = 'ZPROJECT_PROFIT1'
      I_CALLBACK_PF_STATUS_SET          = ' '
         I_CALLBACK_USER_COMMAND           = 'USER_COMMAND'
         I_CALLBACK_TOP_OF_PAGE            = 'TOP_OF_PAGE_PROFIT'
      I_CALLBACK_HTML_TOP_OF_PAGE       = ' '
      I_CALLBACK_HTML_END_OF_LIST       = ' '
      I_STRUCTURE_NAME                  =
      I_BACKGROUND_ID                   = ' '
      I_GRID_TITLE                      =
      I_GRID_SETTINGS                   =
         IS_LAYOUT                         = xlayout
         IT_FIELDCAT                       =  it_field_t
      IT_EXCLUDING                      =
      IT_SPECIAL_GROUPS                 =
      IT_SORT                           =
      IT_FILTER                         =
      IS_SEL_HIDE                       =
         I_DEFAULT                         = 'X'
         I_SAVE                            = ' '
      IS_VARIANT                        =
      IT_EVENTS                         =
      IT_EVENT_EXIT                     =
      IS_PRINT                          =
      IS_REPREP_ID                      =
      I_SCREEN_START_COLUMN             = 0
      I_SCREEN_START_LINE               = 0
      I_SCREEN_END_COLUMN               = 0
      I_SCREEN_END_LINE                 = 0
      I_HTML_HEIGHT_TOP                 = 0
      I_HTML_HEIGHT_END                 = 0
      IT_ALV_GRAPHICS                   =
      IT_HYPERLINK                      =
      IT_ADD_FIELDCAT                   =
      IT_EXCEPT_QINFO                   =
      IR_SALV_FULLSCREEN_ADAPTER        =
    IMPORTING
      E_EXIT_CAUSED_BY_CALLER           =
      ES_EXIT_CAUSED_BY_USER            =
       TABLES
          T_OUTTAB                          = IT_DISPLAY1
    EXCEPTIONS
      PROGRAM_ERROR                     = 1
      OTHERS                            = 2
      IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
      clear it_field_t.
      "it_display.
    FORM USER_COMMAND using r_ucomm like sy-ucomm rs type slis_selfield.
      include zinteractive_profit."Secondary list for calling KO03.
    ENDFORM.                    "USER_COMMAND.
    Thanks & Regards,
    Lakshmi..

    Hi,
    i did according to ur suggession.
    now it is going dump.
    and it is telling like this.
    2629               i_event_name      = 'SUBTOTAL_TEXT'
    2630               is_subtottxt_info = ls_subtot_info
    2631               ip_subtot_line    = lr_data
    2632             changing
    2633               c_subtottxt       = l_subtottxt.
    2634           ls_lvc_data-value = l_subtottxt.
    2635
    2636           append ls_lvc_data to ct_lvc_data.
    2637         endif.
    2638
    2639 ************************************
    2640 * Column per Fieldcat Entry
    2641 ************************************
    2642         clear ls_lvc_data-style.
    2643         loop at it_fcat_local assigning <ls_fcat>
    2644                 where tech ne 'X' and no_out ne 'X'.
    2645           if l_invisible eq 'X'.
    2646             clear l_invisible.
    2647             if <ls_fcat>-do_sum is initial.
    2648               continue.
    2649             else.
    2650               clear ls_lvc_data-col_pos.
    2651             endif.
    2652           endif.
    2653
    2654           add 1 to ls_lvc_data-col_pos.
    2655
    2656           assign component <ls_fcat>-fieldname
    2657                            of structure <ls_data> to <l_field_val
    2658           if sy-subrc ne 0.
    >>>>>             message x000(0k).
    2660           endif.
    2661
    2662 *... work on average
    2663           if <ls_fcat>-do_sum eq 'C'.
    2664             clear l_entries.
    2665
    2666             assign space to <l_unit>.
    2667             if not <ls_fcat>-cfieldname is initial.
    2668               assign component <ls_fcat>-cfieldname
    2669                      of structure <ls_data> to <l_unit>.
    2670             endif.
    2671             if not <ls_fcat>-qfieldname is initial.
    2672               assign component <ls_fcat>-qfieldname
    2673                      of structure <ls_data> to <l_unit>.
    2674             endif.
    2675
    2676             l_from = ls_grpl-index_from.
    2677             l_to   = ls_grpl-index_to.
    2678             if ls_grpl-index_from is initial and
    plz any of u help me to come out with solution.
    Thanks & Regards,
    Lakshmi..

  • Help required on APO report

    Hi.. I m developing an APO object for the first time. It's a Report.
    Please explain me the logic... it's an APO development.
    First answer a few questions of mine, before getting into the logic.
    1. how do we fetch data from APO database? Using normal SELECT query, or.. ?? Please give an example.
    2. what does " Characteristic ‘ZTIL’ for MPOS ‘ZB_TRL’ STRUCTURE: /BIC/VZB_TRL2 " mean?? It's given in the Source System Table column of Func. Spec., from where I have to Select the field ZTIL.
    3. Can u give me a comparison of normal R/3 dbase, and the APO database? And, in what fashion the data is stored.
    4. Please give me useful links that will help me in APO development.
    To explain you a bit about the Data Element Cross Reference section of the report..
    There are 2 tables given for each field, one related to RL and other related to TC planning area, except those fields whose Source Table is " Characteristic ‘ZTIL’ for MPOS ‘ZB_TRL’ STRUCTURE: /BIC/VZB_TRL2 ". So, the Data Element Cross Reference section is a combination of fields that come from 2 tables each & and fields that come from " Characteristic ‘ZTIL’ for MPOS ‘ZB_TRL’ STRUCTURE: /BIC/VZB_TRL2 ".
    Q: Can u tell me why 2 tables are given for a single field?
    Q: How do we work with a single field from 2 tables?
    Now, coming to the logic of the development..
    Logic required wherein IDENTICAL Material numbers in both RL / TC planning areas are flagged as exceptions.
    The logic has to be written for a field, which comes from two source tables. In the output of the report, this field should show 'RL' if it comes from the table related to RL planning area, and should show 'TC', if it comes from the TC planning area table. Now, we have MATNR in " Characteristic ‘ZMT’ for MPOS ‘ZB_TRL’ STRUCTURE: /BIC/VZB_TRL2 ". So, what logic should be applied so that it shows identical MATNRs in RL and TC rows, in output??
    Thanks a lot in advance.

    Thanks so much for replying to my Query, Priya...
    The functional Consultant is saying that MPOS is not a table, also, the terms which I had referred to as TABLES in my post, are not tables, it seems. These are Live Cache data, he says.
    Do you have any idea what Live Cache is, and how to deal with it(access data from it)?
    When I searched for Live Cache access related info today. I found out that, to read data from Live Cache, you need to use SAP delivered Standard BAPIs. Please share some knowledge about it.
    Priya, it would be good if you could give me your Yahoo Chat ID, as I m badly in need of help. I will be online 9 - 6 PM, India Standard Time. My Yahoo ID is puerto_rico_thug555
    Thanks again..

  • Pls help me in alv reports

    Hi FRiends,
    Here goes my code.
    Now the client want some description to be displayed in the output like
    TOTAL QUANTITY:(VALUE)
    QAUNTITY REQ:SOOME CALC
    Is it possible to have descriptions
    Please help me.
    REPORT  ZTRST1.
    *& Report  ZTRST
    *REPORT  ZTRST no standard page heading line-size 200 line-count 200.
    &&&& Tables Declaration &&&& *
    Tables:S012.
    type-pools: slis.
    data: i_fldcat type slis_t_fieldcat_alv,
           w_fldcat type slis_fieldcat_alv,
            i_sort TYPE  slis_t_sortinfo_alv,
             wa_sort TYPE slis_sortinfo_alv,
             wa_layout     TYPE slis_layout_alv.
    *data : ls_layout TYPE slis_layout_alv.
    *ls_layout-colwidth_optimize = 'X'.
    &&&&& Internal Table Declaration &&&&&
    DATA: BEGIN OF GT_GOODS OCCURS 0,
          EKORG LIKE S012-EKORG,
          MATNR LIKE S012-MATNR,
          WERKS LIKE S012-WERKS,
          SPMON LIKE S012-SPMON,
          SPTAG LIKE S012-SPTAG,
          SPWOC LIKE S012-SPWOC,
          SPBUP LIKE S012-SPBUP,
          BASME LIKE S012-BASME,
          WEMNG LIKE S012-WEMNG,
          FINAL TYPE p decimals 3,
          END OF GT_GOODS.
    DATA: BEGIN OF GT_MARM OCCURS 0,
          MATNR LIKE MARM-MATNR,
          UMREN LIKE MARM-UMREN,
          END OF GT_MARM.
    *DATA:TOTAL LIKE VBAP-NETPR.
    * &&&&  SELECTION SCREEN &&&&& * *
    SELECTION-SCREEN BEGIN OF BLOCK BLK1 WITH FRAME TITLE TEXT-001.
    SELECT-OPTIONS:S_EKORG FOR S012-EKORG,
                    S_MATNR FOR S012-MATNR,
                    S_WERKS FOR S012-WERKS,
                    S_SPMON FOR S012-SPMON,
                    S_SPTAG FOR S012-SPTAG,
                    S_SPWOC FOR S012-SPWOC,
                    S_SPBUP FOR S012-SPBUP,
                    S_BASME FOR S012-BASME.
    SELECTION-SCREEN END OF BLOCK BLK1 .
    START-OF-SELECTION.
    ***Performing Goods Information***
    PERFORM FETCH_DATA.
    PERFORM PROCESS_DATA.
    PERFORM DISPLAY_DATA.
    perform build_sort.
    END-OF-SELECTION.
    perform list_display.
    &&& Fetch Data &&&**
    *&      Form  FETCH_DATA
          text
    -->  p1        text
    <--  p2        text
    FORM FETCH_DATA .
    REFRESH GT_GOODS.
    CLEAR GT_GOODS.
    SELECT EKORG
           MATNR
           WERKS
           SPMON
           SPTAG
           SPWOC
           SPBUP
           BASME
           WEMNG
           FROM S012
           INTO TABLE GT_GOODS
           WHERE EKORG IN S_EKORG
                 AND MATNR IN S_MATNR
                 AND WERKS IN S_WERKS
                 AND SPMON IN S_SPMON
                 AND SPTAG IN S_SPTAG
                 AND SPWOC IN S_SPWOC
                 AND SPBUP IN S_SPBUP
                 AND BASME IN S_BASME.
    SORT GT_GOODS BY MATNR.
    IF GT_GOODS[] IS NOT INITIAL.
    SELECT MATNR
           UMREN
           FROM MARM
           INTO TABLE GT_MARM
           FOR ALL ENTRIES IN GT_GOODS
           WHERE MATNR = GT_GOODS-MATNR.
    SORT GT_MARM BY MATNR.
    ENDIF.
    ENDFORM.                    " FETCH_DATA
    *&      Form  DISPLAY_DATA
          text
    -->  p1        text
    <--  p2        text
    FORM DISPLAY_DATA .
    w_fldcat-fieldname = 'EKORG'.
    *w_fldcat-ref_tabname = 'S012'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 1.
    w_fldcat-seltext_s = 'Purchase Org'.
    w_fldcat-seltext_l = 'Purchase Organisation'.
    w_fldcat-OUTPUTLEN = '30'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'MATNR'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 2.
    w_fldcat-seltext_s = 'Materail no'.
    w_fldcat-seltext_l = 'Material Number'.
    w_fldcat-OUTPUTLEN = '30'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'WERKS'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 3.
    w_fldcat-seltext_s = 'Plant'.
    w_fldcat-seltext_l = 'Plant'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'SPMON'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 4.
    w_fldcat-seltext_s = 'Month'.
    w_fldcat-seltext_l = 'Month'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'SPTAG'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 5.
    w_fldcat-seltext_s = 'Date'.
    w_fldcat-seltext_l = 'Date'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'SPWOC'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 6.
    w_fldcat-seltext_s = 'Week'.
    w_fldcat-seltext_l = 'Week'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'SPBUP'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 7.
    w_fldcat-seltext_s = 'Period'.
    w_fldcat-seltext_l = 'Period'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'BASME'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 8.
    w_fldcat-seltext_s = 'Unit'.
    w_fldcat-seltext_l = 'Unit'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'WEMNG'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 9.
    w_fldcat-do_sum = 'X'.
    w_fldcat-no_zero = 'X'.
    w_fldcat-seltext_s = 'Quantity of Goods Recieved'.
    w_fldcat-seltext_l ='Quantity of Goods Recieved'.
    w_fldcat-OUTPUTLEN = '30'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    w_fldcat-fieldname = 'FINAL'.
    w_fldcat-tabname = 'GT_GOODS'.
    w_fldcat-col_pos = 10.
    w_fldcat-seltext_s = 'Final Value'.
    w_fldcat-seltext_l = 'Final Value'.
    w_fldcat-OUTPUTLEN = '10'.
    w_fldcat-do_sum = 'X'.
    wa_LAYOUT-TOTALS_TEXT = 'TOTAL'.
    append w_fldcat to i_fldcat.
    clear w_fldcat.
    wa_layout-subtotals_text = 'Sub Totals'.
       wa_LAYOUT-TOTALS_TEXT = 'TOTAL'.
    *SORT GT_GOODS BY EKORG..
    *LOOP AT GT_GOODS.
    *AT FIRST.
    *WRITE:/ 'Purchasing Organisation',
    *50 'Material Number',
    *70 'Plant',
    *90 'Month',
    *100 'Current Date',
    *130 'Week',
    *179 'Gr Account'.
    *ENDAT.
    *AT NEW EKORG.
    *WRITE:/ GT_GOODS-EKORG.
    *ENDAT.
    *WRITE:/50 GT_GOODS-MATNR,
    *70 GT_GOODS-WERKS,
    *90 GT_GOODS-SPMON,
    *100 GT_GOODS-SPTAG,
    *130 GT_GOODS-SPWOC,
    *160 GT_GOODS-SPBUP,
    *170 GT_GOODS-WEMNG.
    **TOTAL = TOTAL + GT_GOODS-WEWRT.
    *AT END OF EKORG.
    *sum .
    *ULINE.
    *WRITE:110 'TOTAL = ', gt_goods-WEMNG no-zero.
    *ULINE.
    *SKIP.
    *CLEAR TOTAL.
    *ENDAT.
    *ENDLOOP.
    ENDFORM.                    " DISPLAY_DATA
    *&      Form  build_sort
    FORM build_sort .
       wa_sort-fieldname = 'EKORG'.
       wa_sort-up = 'X'.
       wa_sort-subtot = 'X'.
       append wa_sort to i_sort.
    ENDFORM.                    " build_sort
    *&      Form  list_display
    FORM list_display .
                    CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
                     EXPORTING
                      I_INTERFACE_CHECK                 = ' '
                      I_BYPASSING_BUFFER                = ' '
                      I_BUFFER_ACTIVE                   = ' '
                       I_CALLBACK_PROGRAM                = sy-repid
                      I_CALLBACK_PF_STATUS_SET          = ' '
                      I_CALLBACK_USER_COMMAND           = ' '
                      I_CALLBACK_TOP_OF_PAGE            = ' '
                      I_CALLBACK_HTML_TOP_OF_PAGE       = ' '
                      I_CALLBACK_HTML_END_OF_LIST       = ' '
                      I_STRUCTURE_NAME                  =
                      I_BACKGROUND_ID                   = ' '
                       I_GRID_TITLE                      = 'GOODS RECIEPT'
                      I_GRID_SETTINGS                   =
                       IS_LAYOUT                         = wa_layout
                       IT_FIELDCAT                       = i_fldcat
                      IT_EXCLUDING                      =
                      IT_SPECIAL_GROUPS                 =
                       IT_SORT                           =  i_sort
                      IT_FILTER                         =
                      IS_SEL_HIDE                       =
                      I_DEFAULT                         = 'X'
                      I_SAVE                            = ' '
                      IS_VARIANT                        =
                      IT_EVENTS                         =
                      IT_EVENT_EXIT                     =
                      IS_PRINT                          =
                      IS_REPREP_ID                      =
                      I_SCREEN_START_COLUMN             = 0
                      I_SCREEN_START_LINE               = 0
                      I_SCREEN_END_COLUMN               = 0
                      I_SCREEN_END_LINE                 = 0
                      I_HTML_HEIGHT_TOP                 = 0
                      I_HTML_HEIGHT_END                 = 0
                      IT_ALV_GRAPHICS                   =
                      IT_HYPERLINK                      =
                      IT_ADD_FIELDCAT                   =
                      IT_EXCEPT_QINFO                   =
                      IR_SALV_FULLSCREEN_ADAPTER        =
                    IMPORTING
                      E_EXIT_CAUSED_BY_CALLER           =
                      ES_EXIT_CAUSED_BY_USER            =
                      TABLES
                        T_OUTTAB                          = GT_GOODS
                     EXCEPTIONS
                       PROGRAM_ERROR                     = 1
                       OTHERS                            = 2
                    IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
                    ENDIF.
    *CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'
    EXPORTING
      I_INTERFACE_CHECK              = ' '
      I_BYPASSING_BUFFER             =
      I_BUFFER_ACTIVE                = ' '
      I_CALLBACK_PROGRAM             = sy-repid
      I_CALLBACK_PF_STATUS_SET       = ' '
      I_CALLBACK_USER_COMMAND        = ' '
      I_STRUCTURE_NAME               =
      IS_LAYOUT                      = wa_layout
      IT_FIELDCAT                    = i_fldcat
      IT_EXCLUDING                   =
      IT_SPECIAL_GROUPS              =
      IT_SORT                        =  i_sort
      IT_FILTER                      =
      IS_SEL_HIDE                    =
      I_DEFAULT                      = 'X'
      I_SAVE                         = ' '
      IS_VARIANT                     =
      IT_EVENTS                      =
      IT_EVENT_EXIT                  =
      IS_PRINT                       =
      IS_REPREP_ID                   =
      I_SCREEN_START_COLUMN          = 0
      I_SCREEN_START_LINE            = 0
      I_SCREEN_END_COLUMN            = 0
      I_SCREEN_END_LINE              = 0
      IR_SALV_LIST_ADAPTER           =
      IT_EXCEPT_QINFO                =
      I_SUPPRESS_EMPTY_DATA          = ABAP_FALSE
    IMPORTING
      E_EXIT_CAUSED_BY_CALLER        =
      ES_EXIT_CAUSED_BY_USER         =
    TABLES
       T_OUTTAB                       = GT_GOODS
    EXCEPTIONS
      PROGRAM_ERROR                  = 1
      OTHERS                         = 2
    *IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
    *ENDIF.
    ENDFORM.                    " list_display
    *&      Form  PROCESS_DATA
          text
    -->  p1        text
    <--  p2        text
    FORM PROCESS_DATA .
    LOOP AT GT_GOODS.
    READ TABLE GT_MARM WITH KEY MATNR = GT_GOODS-MATNR
                                         BINARY SEARCH.
    IF SY-SUBRC EQ 0.
    GT_GOODS-FINAL = GT_GOODS-WEMNG * GT_MARM-UMREN.
    modify GT_GOODS.
    ENDIF.
    ENDLOOP.
    ENDFORM.                    " PROCESS_DATA

    Description where??? I think u want to add some description at Top of page! If yes the Create a subroutine using 'REUSE_ALV_COMMENTARY_WRITE' function module,assign heading using parameters.Just See this link U will get it :
    [http://www.sap-img.com/abap/sample-alv-heading-in-alv.htm|http://www.sap-img.com/abap/sample-alv-heading-in-alv.htm]

  • Help required - For ALV program

    Hi Guys,
    I have created an ALV  (using containers) with , say , 10 fields. As the container size is not large enough to accomodate all the 10 fields, it is getting displayed as
    field1, field2,field8, field9 and field10.
    When I click on the horizontal scrollbar, the fields getting displayed should change as follows.
    First click: Field2, Field3, Field8,Field9, Field10
    Second click: Field3,Field4, 8, 9,10
    Third click: Field4,Field5,8,9,10
    This is for one of my friends.Can you provide me with good ideas as to how to approach this problem and if any one has worked on similar problem, please provide the code for it.
    I will check the code and will award points to all helpful answers.
    Have a nice day .
    Regards,
    SP.

    Hello Sylendra
    As developer of ALV lists we do not care that much about the layout of the list because the user has all the options available to adjust it to her specific needs.
    Your requirement is to be able to "freeze" columns at the right border of the ALV list. This is, as far as I know, not possible, only at the left border.
    When you call the context menu for a column heading you will see the options
    - Freeze to Column
    - Unfreeze Columns
    If you freeze a column all columns to its left side remain fixed. Thus, in your case you have to change the order of your columns that the fixed columns (field8 - field10) appear on the left side of the ALV list.
    Regards
      Uwe

  • Help need on ALV Report Program

    Hi all.....
    im facing problem in the following code....it shows 'No records found' (as same as my coding generated)whenever i give wrong vendor no:(lifnr), but if i gives the correct one(as in table lfa1)...it shows Runtime error as <b>"the occupied line length in the program text must not exceed the width of the internal table"</b>..
    pls verify...
    just go thru my code and revert me the feedback of what i did wrong and pls i dont want any example codes from u guys since i've seen so much and couldnt solve it with that...
    hope u understand......what i need
    Rewards based on the above reuirements....only
    *******************************CODING***********************************************
    REPORT ZALV_MERGE.
    TABLES:lfa1.
    DATA:BEGIN OF itab OCCURS 100,
    lifnr LIKE lfa1-lifnr,
    land1 LIKE lfa1-land1,
    name1 LIKE lfa1-name1,
    ort01 LIKE lfa1-ort01,
    regio LIKE lfa1-regio,
    sortl LIKE lfa1-sortl,
    END OF itab.
    data: i_repid like sy-repid,
          i_tabix like sy-tabix.
    TYPE-POOLS: slis.
    DATA: fcat TYPE slis_t_fieldcat_alv.
    SELECT-OPTIONS: LIFNR FOR LFA1-LIFNR.
    SELECT * FROM LFA1 INTO CORRESPONDING FIELDS OF TABLE itab WHERE lifnr IN LIFNR.
    clear i_tabix.
    describe table itab lines i_tabix.
    if i_tabix lt 1.
    write:/ 'No materials found'.
    exit.
    endif.
    i_repid = sy-repid.
    CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
    EXPORTING
       I_PROGRAM_NAME               = i_repid
       I_INTERNAL_TABNAME           = 'ITAB'
      I_STRUCTURE_NAME             =
      I_CLIENT_NEVER_DISPLAY       = 'X'
      I_INCLNAME                   = I_REPID
      I_BYPASSING_BUFFER           =
      I_BUFFER_ACTIVE              =
      CHANGING
        CT_FIELDCAT                  = fcat
      EXCEPTIONS
       INCONSISTENT_INTERFACE       = 1
       PROGRAM_ERROR                = 2
       OTHERS                       = 3.
    IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
    ENDIF.
    CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'
    EXPORTING
       I_CALLBACK_PROGRAM             = i_repid
      I_CALLBACK_PF_STATUS_SET       = ' '
      I_CALLBACK_USER_COMMAND        = ' '
       I_STRUCTURE_NAME               = 'ITAB'
      IS_LAYOUT                      =
       IT_FIELDCAT                    = fcat
       I_SAVE                         = 'A'
      TABLES
        T_OUTTAB                       = ITAB
    EXCEPTIONS
       PROGRAM_ERROR                  = 1
       OTHERS                         = 2
    IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
    ENDIF.

    Hi,
    think inthis program in the function module REUSE_ALV_FIELDCATALOG_MERGE
    in exporting parameter you are using -->
    I_INTERNAL_TABNAME = <itab_name>
    this <itab_name> is not like any physical structure .So make a structure through SE11 like <itab_name>.
    u have to create a structure in SE11 with the fields, and then pass that structure into the REUSE_ALV_FIELDCATALOG_MERGE , in the parameter
    I_internal_tabname = ' structure name '.
    even though u create a structure, u need to pass it to the table parameter.
    then it will work.
    Otherwise manually build the fieldcatalog.
    find the following code as an example.
    DATA : l_pos TYPE i VALUE 1.
      ist_fieldcat-fieldname = 'POSID'.
      ist_fieldcat-tabname   = 'IT_FINAL'.
      ist_fieldcat-outputlen = 24.
      ist_fieldcat-col_pos   = l_pos.
    ist_fieldcat-ddictxt = 'L'.
      ist_fieldcat-key = 'X'.
      ist_fieldcat-seltext_l = 'Appropriation Request Number'.
      APPEND ist_fieldcat.
      CLEAR ist_fieldcat.
      l_pos = l_pos + 1.
      ist_fieldcat-fieldname = 'TXT04'.
      ist_fieldcat-tabname   = 'IT_FINAL'.
      ist_fieldcat-outputlen = 4.
      ist_fieldcat-col_pos   = l_pos.
      ist_fieldcat-ddictxt = 'L'.
    ist_fieldcat-key = 'X'.
      ist_fieldcat-seltext_l = 'Status'.
      ist_fieldcat-EMPHASIZE = 'C400'.
      APPEND ist_fieldcat.
      CLEAR ist_fieldcat.
      l_pos = l_pos + 1.
      ist_fieldcat-fieldname = 'UDATE'.
      ist_fieldcat-tabname   = 'IT_FINAL'.
      ist_fieldcat-outputlen = 8.
      ist_fieldcat-col_pos   = l_pos.
      ist_fieldcat-ddictxt = 'L'.
      ist_fieldcat-key = 'X'.
      ist_fieldcat-seltext_l = 'Status Date'.
    IST_FIELDCAT-EMPHASIZE = 'C600'.
      APPEND ist_fieldcat.
      CLEAR ist_fieldcat.
    <i><b>Reward point if find helpful
    Debjani</b></i>

  • Help required in ALV Tree Control

    Hi All,
    I am using OO ALV tree Control in my Project every thing is working fine.
    in treecontrol  'If we double click on Node I con it displays resultant screen'- its fine for us
    'If we double click on Node Text it is displaying nothing means no Event is triggering.
    my Requirement is tha 'it should work even if we click on Node Text' . Like in standard Applications SE15 .
    Suggest some Methods regarding this. Note All these nodes are Dynamic Nodes comes from Data Base table.
    Thanks in Adv.
    Murthy

    Just check Tcode: DWDM.
    Good no of example programs for oops tree are available there

  • Hi all,Help Required fin ALV,Thnx in Advance

    Hi All,
    Can you please share me some detailed material regarding ALV.
    All the function Modules used and the purpose of them.
    Thnk you very much .
    Regards,
    Amith

    Hi Amith,
    Welcome to SDN :).
    refer below link
    http://www.sapdevelopment.co.uk/reporting/alvhome.htm
    Regards,
    Atish

  • Help require to migrate Report Manager(FSG)Excel Templates across Instances

    In R12.1.3, we are creating new custom MS Excel templates for Standard FSG Reports.
    We understand to create these templates with Report Manager using “Financial Report Template Editor”, edit them, download and upload back.
    These templates created in Test Instance needs to be moved to multiple instances.
    How can we migrate these custom Excel templates from one instance to another? , as when we select Oracle-->Upload from Excel template, it expects to upload back to the same instance where from it was downloaded originally, but our requirement is to migrate these templates across instances rather than to recreate it on each instance
    Please suggest how to migrate these Excel templates from one instance to another.
    Thanks,
    Amit

    hi,
    sorry, but currently there is no such option, the templates need to be rebuilt.
    Enhancement Request
    Bug 6710387 'COPY REPORT TEMPLATES FROM ONE INSTANCE TO AN OTHER'
    was raised on the issue but it was not implemented yet.
    Please monitor this enhancement on 'My Oracle Support' to get news on its implementation.
    For further information on Report Manager, please check theses notes:
    (Doc ID 726774.1) - Report Manager - Master Note
    (Doc ID 726958.1) - Report Manager (FRM) List of Patches
    (Doc ID 858505.1) - Report Manager Troubleshooting
    kind regards, Martin

Maybe you are looking for