Monday, 25 June 2012

Program to download multiple internal table data into multiple excel tabs


*&---------------------------------------------------------------------*
*& Report  ZSJ_TESTING12
*&
*&---------------------------------------------------------------------*
*& Author  :
*& Date    : 05-04-2012
*& Purpose :
*&---------------------------------------------------------------------*
*& Date Changed by Tag Description
*&
*&---------------------------------------------------------------------*
REPORT  yidic_jk.
*&---------------------------------------------------------------------*
*& Report  ZUTL_IDOC_DOWNLOAD_TEST
*&
*&---------------------------------------------------------------------*
*& Author  :
*& Date    : 12-01-2012
*& Purpose :
*&---------------------------------------------------------------------*
*& Date Changed by Tag Description
*&
*&---------------------------------------------------------------------*
* Global Data Declaration
* Table
TABLES: edidc, edid4,sscrfields.
* type-pool declaration
TYPE-POOLS: slis, ole2.
* Constants
CONSTANTS: time_0 LIKE edidc-updtim VALUE '000000',
           time_24 LIKE edidc-updtim VALUE '235959'.
* Type Declaration
TYPES: BEGIN OF typ_excel,
        line(5000) TYPE c,
       END OF typ_excel.
DATA: gv_dy_line  TYPE REF TO data.
* Data declaration to have dynamic workarea
FIELD-SYMBOLS: <gs_dyn_tab> TYPE ANY.
* Internal Tables Declaration.
DATA: gt_edidc TYPE TABLE OF edidc,
      gs_edidc TYPE edidc.
DATA: gt_edid4 TYPE TABLE OF edid4,
      gs_edid4 TYPE edid4.
DATA: gt_edids TYPE TABLE OF edids,
      gs_edids TYPE edids.
DATA: gt_excel TYPE TABLE OF typ_excel,
      gs_excel TYPE typ_excel.
DATA: gt_edimsg TYPE TABLE OF edimsg,
      gs_edimsg TYPE edimsg.
* OLE objects Declarations
DATA: gs_exc        TYPE ole2_object,
      gs_workbook   TYPE ole2_object,
      gs_worksheet  TYPE ole2_object,
      gs_columns    TYPE ole2_object,
      gs_int        TYPE ole2_object,
      gs_range      TYPE ole2_object,
      gs_sheet      TYPE ole2_object,
      gv_rc         TYPE i,
      gv_count     TYPE i VALUE 0,
      gv_string    TYPE string.
DATA : flag.
TYPES: BEGIN OF typ_idocsyn,
        sel_flag(1),
        segtyp TYPE dd02t-tabname,
       END OF typ_idocsyn.
TYPES: BEGIN OF typ_edisegt,
         sel_flag(1),
         segtyp TYPE dd02t-tabname,
         langua TYPE edisegt-langua,
         descrp TYPE edisegt-descrp,
        END OF typ_edisegt.

TYPES : BEGIN OF ty_fields,
        key TYPE c,
        seg_name TYPE dd02t-tabname,
        fields TYPE slis_fieldname,
        END OF ty_fields.
***************JK *******************************************************
TYPES : BEGIN OF ty_fields2,
*        key type c,
        seg_name TYPE dd02t-tabname,
        fields TYPE dd02t-tabname,"slis_fieldname,
        END OF ty_fields2.
DATA : it_sel_idocsyn TYPE TABLE OF  typ_edisegt WITH HEADER LINE,
       wa_sel_idocsyn TYPE typ_edisegt,
       gdf_flag TYPE i.
DATA: ls_fieldcat_1 TYPE slis_fieldcat_alv,
      lt_fieldcat_1 TYPE TABLE OF slis_fieldcat_alv.
**************JK********************************************************
DATA : gt_idocsyn TYPE TABLE OF typ_edisegt,
      wa_gt_idocsyn TYPE typ_edisegt.

DATA:    lt_fieldcat TYPE TABLE OF slis_fieldcat_alv,
         wa_fieldcat TYPE slis_fieldcat_alv.
DATA : ls_fieldcat TYPE STANDARD TABLE OF ty_fields,
*         ls_fieldcat type TABLE OF slis_fieldcat_alv,
         wa_ls_fieldcat TYPE ty_fields.

DATA ls_fieldcat2 TYPE STANDARD TABLE OF ty_fields2.
DATA ldf_strname TYPE dd02l-tabname.
* Selection Screen
SELECTION-SCREEN BEGIN OF BLOCK sb1 WITH FRAME TITLE text-sb1.
SELECT-OPTIONS: s_cretim FOR edidc-cretim  DEFAULT time_0   TO time_24,
                s_credat FOR edidc-credat  DEFAULT sy-datum TO sy-datum,
                s_updtim FOR edidc-updtim,
                s_upddat FOR edidc-upddat,
                s_direct FOR edidc-direct NO-EXTENSION NO INTERVALS,
                s_docnum FOR edidc-docnum,
                s_status FOR edidc-status.
PARAMETERS:     p_idoctp LIKE edidc-idoctp.
*Begin of change Siji 04.05.2012 15:33:15
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN PUSHBUTTON 2(10) text-090 USER-COMMAND but1.
SELECTION-SCREEN END OF LINE.
*End of change Siji 04.05.2012 15:33:15
PARAMETERS:     p_cimtyp LIKE edidc-cimtyp,
                p_mestyp LIKE edidc-mestyp.
SELECT-OPTIONS: s_mescod FOR edidc-mescod,
                s_mesfct FOR edidc-mesfct,
                s_rcvpor FOR edidc-rcvpor,
                s_rcvprn FOR edidc-rcvprn,
                s_rcvprt FOR edidc-rcvprt,
                s_rcvpfc FOR edidc-rcvpfc,
                s_segnam FOR edid4-segnam.
PARAMETERS:     p_rec TYPE sy-tabix DEFAULT '500' OBLIGATORY.
SELECTION-SCREEN END OF BLOCK sb1.
SELECTION-SCREEN BEGIN OF BLOCK sb2 WITH FRAME TITLE text-sb2.
SELECT-OPTIONS: s_refint FOR edidc-refint,
                s_refgrp FOR edidc-refgrp,
                s_refmes FOR edidc-refmes,
                s_arckey FOR edidc-arckey,
                s_std FOR edidc-std,
                s_stdvrs FOR edidc-stdvrs,
                s_stdmes FOR edidc-stdmes.
SELECTION-SCREEN END OF BLOCK sb2.
DATA wa_segnam LIKE LINE OF s_segnam.
DATA: lv_cond TYPE string,
       lt_idocsyn_tmp TYPE TABLE OF edi_iapi02,
       ls_idocsyn_tmp TYPE edi_iapi02,
       lt_idocsynext_tmp TYPE TABLE OF edi_iapi06,
       ls_idocsynext_tmp TYPE edi_iapi06,
       ls_idocsyn TYPE typ_idocsyn,
       lt_idocsyn TYPE TABLE OF typ_idocsyn,
       lt_edisegt TYPE TABLE OF typ_edisegt.
DATA it_return TYPE STANDARD TABLE OF ddshretval.
DATA it_return1 TYPE STANDARD TABLE OF ddshretval.
DATA it_return2 TYPE STANDARD TABLE OF ddshretval.
DATA it_return3 TYPE STANDARD TABLE OF ddshretval.
DATA wa_return LIKE LINE OF it_return.
DATA it_fieldtab TYPE STANDARD TABLE OF dfies.
DATA: is_return1 TYPE ddshretval,
      gs_idocsyn TYPE typ_edisegt.

TYPES: BEGIN OF ty_filter,
  fieldname TYPE fieldname,
  fieldval  TYPE shvalue_d,
  flag TYPE flag,
  END OF ty_filter.
DATA: it_filter TYPE TABLE OF ty_filter,
      wa_filter TYPE ty_filter.
AT SELECTION-SCREEN.
* Get Idoc Type from Config
  CLEAR: lv_cond.
  IF p_mestyp IS NOT INITIAL.
    lv_cond = 'mestyp = p_mestyp'.
  ENDIF.
  IF p_idoctp IS NOT INITIAL.
    IF lv_cond IS NOT INITIAL.
      CONCATENATE lv_cond 'AND'
                  'idoctyp = p_idoctp'
                  INTO lv_cond
                  SEPARATED BY space.
    ELSE.
      lv_cond = 'idoctyp = p_idoctp'.
    ENDIF.
  ENDIF.
  IF p_cimtyp IS NOT INITIAL.
    IF lv_cond IS NOT INITIAL.
      CONCATENATE lv_cond 'AND'
                  'cimtyp = p_cimtyp'
                  INTO lv_cond
                  SEPARATED BY space.
    ELSE.
      lv_cond = 'cimtyp = p_cimtyp'.
    ENDIF.
  ENDIF.
* Check if selection is present
  CHECK lv_cond IS NOT INITIAL.
* Collect IDOC Types
  SELECT * INTO TABLE gt_edimsg
           FROM edimsg
           WHERE (lv_cond).
* Loop and collect IDOC segments
  REFRESH: lt_idocsyn.
  LOOP AT gt_edimsg INTO gs_edimsg.
* Check if Extension is used
    IF gs_edimsg-cimtyp IS INITIAL.
* Read IDOC structure
      REFRESH: lt_idocsyn_tmp.
      CALL FUNCTION 'IDOCTYPE_READ'
        EXPORTING
          pi_idoctyp         = gs_edimsg-idoctyp
          pi_check_authority = ' '
          pi_read_devc       = 'X'
        TABLES
          pt_syntax          = lt_idocsyn_tmp[]
        EXCEPTIONS
          object_not_found   = 1
          db_error           = 2
          no_authority       = 3
          OTHERS             = 4.
      IF sy-subrc = 0.
        LOOP AT lt_idocsyn_tmp INTO ls_idocsyn_tmp.
          ls_idocsyn-segtyp = ls_idocsyn_tmp-segtyp.
          APPEND ls_idocsyn TO lt_idocsyn.
        ENDLOOP.
      ENDIF.
    ELSE.
* Read IDOC structure
      REFRESH: lt_idocsynext_tmp.
      CALL FUNCTION 'EXTTYPE_READ'
        EXPORTING
          pi_cimtyp          = gs_edimsg-cimtyp
          pi_check_authority = ' '
          pi_read_devc       = 'X'
        TABLES
          pt_int_syntax      = lt_idocsynext_tmp[]
        EXCEPTIONS
          object_not_found   = 1
          db_error           = 2
          no_authority       = 3
          OTHERS             = 4.
      IF sy-subrc = 0.
        LOOP AT lt_idocsynext_tmp INTO ls_idocsynext_tmp.
          ls_idocsyn-segtyp = ls_idocsynext_tmp-segtyp.
          APPEND ls_idocsyn TO lt_idocsyn.
        ENDLOOP.
      ENDIF.
    ENDIF.
  ENDLOOP.
  SELECT tabname AS segtyp
           ddlanguage AS langua
           ddtext AS descrp
           INTO CORRESPONDING FIELDS OF  TABLE lt_edisegt
           FROM dd02t
           FOR ALL ENTRIES IN lt_idocsyn
           WHERE tabname = lt_idocsyn-segtyp AND
                 ddlanguage = sy-langu.
  MOVE  lt_edisegt TO gt_idocsyn.
*Begin of change Siji 04.05.2012 14:50:38
  CASE sscrfields.
    WHEN 'BUT1'.
      flag = '1'.
*      import gt_idocsyn FROM MEMORY id 'ZS1'.
****************Start Of Change JK 5/11/2012******************************
DATA : L_EXIT,
      ls_private  TYPE slis_data_caller_exit.
  ls_private-columnopt = 'X'.
CALL FUNCTION 'REUSE_ALV_POPUP_TO_SELECT'
  EXPORTING
*   I_TITLE                       =
   I_SELECTION                   = 'X'
*   I_ALLOW_NO_SELECTION          =
*   I_ZEBRA                       = 'X'
*   I_SCREEN_START_COLUMN         = 0
*   I_SCREEN_START_LINE           = 0
*   I_SCREEN_END_COLUMN           = 0
*   I_SCREEN_END_LINE             = 0
   I_CHECKBOX_FIELDNAME          = 'SEGTYP'
*   I_LINEMARK_FIELDNAME          =
*   I_SCROLL_TO_SEL_LINE          = 'X'
    I_TABNAME                     = 'GT_IDOCSYN'
   I_STRUCTURE_NAME              = 'DDSHRETVAL'"ldf_strname
   IT_FIELDCAT                   =  LT_FIELDCAT
*   IT_EXCLUDING                  =
*   I_CALLBACK_PROGRAM            =
*   I_CALLBACK_USER_COMMAND       =
   IS_PRIVATE                    = ls_private
 IMPORTING
*   ES_SELFIELD                   =
   E_EXIT                        = L_EXIT
  TABLES
    T_OUTTAB                      = it_return1
* EXCEPTIONS
*   PROGRAM_ERROR                 = 1
*   OTHERS                        = 2
          .
CHECK L_EXIT = SPACE.
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 'F4IF_INT_TABLE_VALUE_REQUEST'
        EXPORTING
          retfield        = 'SEGTYP'
          window_title    = 'Segment Type'
          value_org       = 'S'
          multiple_choice = 'X'  "allows you select multiple entries from the popup
        TABLES
          value_tab       = gt_idocsyn
          return_tab      = it_return1
        EXCEPTIONS
          parameter_error = 1
          no_values_found = 2
          OTHERS          = 3.
  APPEND LINES OF it_return1 TO it_return.
*start of Priya
*LOOP AT it_return1 INTO is_return1.
*  if is_return1-recordpos IS NOT INITIAl.
*     READ TABLE gt_idocsyn INTO gs_idocsyn WITH KEY segtyp = is_return1-fieldval.
*     if sy-subrc = 0.
*       gs_idocsyn-sel_flag = 'X'.
*       MODIFY gt_idocsyn FROM gs_idocsyn INDEX sy-tabix.
*     endif.
*  endif.
*ENDLOOP.
*export gt_idocsyn TO MEMORY id 'ZS1'.
*end of Priya
      REFRESH ls_fieldcat[].

      LOOP AT it_return INTO wa_return.
        CONDENSE wa_return-fieldval NO-GAPS.
        MODIFY  it_return FROM wa_return TRANSPORTING fieldval.
        ldf_strname = wa_return-fieldval.
        CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
          EXPORTING
            i_structure_name       = ldf_strname
          CHANGING
            ct_fieldcat            = lt_fieldcat
          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.
        CLEAR ls_fieldcat2.
        LOOP AT lt_fieldcat INTO wa_fieldcat .
          wa_ls_fieldcat-seg_name = wa_return-fieldval.
          wa_ls_fieldcat-fields = wa_fieldcat-fieldname.
          APPEND wa_ls_fieldcat TO ls_fieldcat2.
          CLEAR wa_fieldcat.
        ENDLOOP.
        refresh lt_fieldcat .
        CLEAR: wa_return,lt_fieldcat.
      ENDLOOP.
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        EXPORTING
          retfield        = 'FIELDS'
          window_title    = 'Segment Fields'
          value_org       = 'S'
          multiple_choice = 'X'  "allows you select multiple entries from the popup
        TABLES
          value_tab       = ls_fieldcat2
*          field_tab       = it_fieldtab
          return_tab      = it_return3
        EXCEPTIONS
          parameter_error = 1
          no_values_found = 2
          OTHERS          = 3.
APPEND LINES OF it_return3 TO it_return2.
  ENDCASE.
****************End Of Change JK 5/11/2012******************************
  CLEAR: gv_string.
  CONCATENATE p_idoctp p_cimtyp p_mestyp INTO gv_string.
  IF gv_string IS INITIAL.
    MESSAGE: 'Please enter Basic Type, Extension or Message Type'(001) TYPE 'E'.
  ELSE.
    CONCATENATE gv_string '.XLS' INTO gv_string.
    CONDENSE gv_string NO-GAPS.
  ENDIF.
START-OF-SELECTION.
****************Start Of Change JK 5/11/2012******************************
  LOOP AT it_return2 INTO wa_return.
    CONDENSE wa_return-fieldval NO-GAPS.
    MODIFY  it_return2 FROM wa_return TRANSPORTING fieldval.
    wa_filter-fieldname = wa_return-fieldname .
    wa_filter-fieldval = wa_return-fieldval .
    APPEND wa_filter TO it_filter.
    CLEAR wa_return.
  ENDLOOP.
  LOOP AT it_return INTO wa_return.
    wa_segnam-sign = 'I'.
    wa_segnam-option = 'EQ'.
    wa_segnam-low = wa_return-fieldval.
    APPEND wa_segnam TO s_segnam.
    CLEAR wa_return.
  ENDLOOP.
****************End Of Change JK 5/11/2012******************************
*  Refresh all global variables
  PERFORM refresh_global_data.
*  Collect data
  PERFORM collect_data.
*  Process data
  PERFORM process_data.
*&---------------------------------------------------------------------*
*&      Form  REFRESH_GLOBAL_DATA
*&---------------------------------------------------------------------*
*       Refresh global variables.
*----------------------------------------------------------------------*
FORM refresh_global_data.
  REFRESH: gt_edidc,
           gt_edids,
           gt_edid4,
           gt_excel,
           gt_edimsg.
ENDFORM.                    " REFRESH_GLOBAL_DATA
*&---------------------------------------------------------------------*
*&      Form  COLLECT_DATA
*&---------------------------------------------------------------------*
*       Collect data.
*----------------------------------------------------------------------*
FORM collect_data.
* Local data declaration
  DATA: lr_idoctp TYPE RANGE OF edidc-idoctp,
        ls_idoctp LIKE LINE OF lr_idoctp,
        lr_cimtyp TYPE RANGE OF edidc-cimtyp,
        ls_cimtyp LIKE LINE OF lr_cimtyp,
        lr_mestyp TYPE RANGE OF edidc-mestyp,
        ls_mestyp LIKE LINE OF lr_mestyp.
* Build range tables
  REFRESH: lr_idoctp, lr_cimtyp, lr_mestyp.
  IF p_idoctp IS NOT INITIAL.
    ls_idoctp-sign = 'I'.
    ls_idoctp-option = 'EQ'.
    ls_idoctp-low = p_idoctp.
    APPEND ls_idoctp TO lr_idoctp.
  ENDIF.
  IF p_cimtyp IS NOT INITIAL.
    ls_cimtyp-sign = 'I'.
    ls_cimtyp-option = 'EQ'.
    ls_cimtyp-low = p_cimtyp.
    APPEND ls_cimtyp TO lr_cimtyp.
  ENDIF.
  IF p_mestyp IS NOT INITIAL.
    ls_mestyp-sign = 'I'.
    ls_mestyp-option = 'EQ'.
    ls_mestyp-low = p_mestyp.
    APPEND ls_mestyp TO lr_mestyp.
  ENDIF.

* Collecting data from edidc table
  SELECT * FROM edidc INTO TABLE gt_edidc UP TO p_rec ROWS
            WHERE    upddat IN s_upddat
            AND      docnum IN s_docnum
            AND      status IN s_status
            AND      direct IN s_direct
            AND      idoctp IN lr_idoctp
            AND      cimtyp IN lr_cimtyp
            AND      mestyp IN lr_mestyp
            AND      mescod IN s_mescod
            AND      mesfct IN s_mesfct
            AND      rcvpor IN s_rcvpor
            AND      rcvprt IN s_rcvprt
            AND      rcvpfc IN s_rcvpfc
            AND      rcvprn IN s_rcvprn
            AND      status IN s_status
            AND      credat IN s_credat
            AND      cretim IN s_cretim
            AND      upddat IN s_upddat
            AND      updtim IN s_updtim
            AND      refint IN s_refint
            AND      refgrp IN s_refgrp
            AND      refmes IN s_refmes
            AND      arckey IN s_arckey
            AND      std IN s_std
            AND      stdvrs IN s_stdvrs
            AND      stdmes IN s_stdmes
            ORDER BY PRIMARY KEY.
  IF gt_edidc IS NOT INITIAL.
* Collect segment data
    SELECT * FROM edid4
           INTO TABLE gt_edid4
           FOR ALL ENTRIES IN gt_edidc
           WHERE docnum = gt_edidc-docnum AND
                 segnam IN s_segnam.
* Collect status records
    SELECT * FROM edids
             INTO TABLE gt_edids
             FOR ALL ENTRIES IN gt_edidc
             WHERE docnum = gt_edidc-docnum.
  ENDIF.
ENDFORM.                    " COLLECT_DATA
*&---------------------------------------------------------------------*
*&      Form  PROCESS_DATA
*&---------------------------------------------------------------------*
*       Process Data.                                                  *
*----------------------------------------------------------------------*
FORM process_data.
* Local data declaration
  DATA: lt_edid4 LIKE TABLE OF edid4,
        ls_edid4 LIKE LINE OF lt_edid4,
        lv_noofsheets TYPE sy-tabix,
        lv_fval TYPE string,
        lv_count TYPE i,
        lv_nooflines TYPE i.
  FIELD-SYMBOLS: <lv_field> TYPE ANY.
* Check if any data found for current selection
  IF gt_edid4 IS NOT INITIAL.
* Get no of worksheets to be created
    SORT gt_edid4 BY segnam ASCENDING.
    lt_edid4[] = gt_edid4[].
    DELETE ADJACENT DUPLICATES FROM lt_edid4 COMPARING segnam.
    DESCRIBE TABLE lt_edid4 LINES lv_noofsheets.
* Build excel file
    CHECK gs_exc-handle = 0.
    CHECK gs_exc-header = space.
    CREATE OBJECT gs_exc 'Excel.Application'.              "Create object for Excel
    SET PROPERTY OF gs_exc  'Visible' = 1.                 "In background Mode
    CALL METHOD OF gs_exc 'Workbooks' = gs_workbook.
    CALL METHOD OF gs_workbook 'ADD'.
    SET PROPERTY OF gs_exc 'SheetsInNewWorkbook' = 1.
* Add two worksheets for Control & Status records
    lv_noofsheets = lv_noofsheets + 2.
* Add required number of worksheets
    DO lv_noofsheets TIMES.
      IF sy-index > 1.
        CALL METHOD OF gs_exc 'WORKSHEETS' = gs_sheet.
        CALL METHOD OF gs_sheet 'ADD'.
        FREE OBJECT gs_sheet.
      ENDIF.
    ENDDO.
* Build worksheet for Control Record
* Get header line
    PERFORM get_header_line USING 'EDIDC' 'X'.
* Check and append header line
    IF gs_excel IS NOT INITIAL.
      APPEND gs_excel TO gt_excel.
    ENDIF.
    LOOP AT gt_edidc INTO gs_edidc.
* Delete current line
      DELETE gt_edidc INDEX sy-tabix.
* Build excel table with Tab Delimited character
      CLEAR: gs_excel.
      DO.
        CHECK sy-index <> 1.
        UNASSIGN <lv_field>.
        ASSIGN COMPONENT sy-index OF STRUCTURE gs_edidc
               TO <lv_field>.
        IF <lv_field> IS ASSIGNED.
          CLEAR: lv_fval.
          lv_fval = <lv_field>.
* Perform transformation based on the column type
          PERFORM transform_colval USING lv_fval <lv_field>.
          IF gs_excel-line IS NOT INITIAL.
            CONCATENATE gs_excel-line lv_fval
                        INTO gs_excel-line
                        SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
          ELSE.
            gs_excel-line = lv_fval.
          ENDIF.
        ELSE.
          EXIT.
        ENDIF.
      ENDDO.
      APPEND gs_excel TO gt_excel.
    ENDLOOP.
* Check if there are any entries in excel table
    IF gt_excel[] IS NOT INITIAL.
      PERFORM download_sheet TABLES gt_excel USING gv_count 'EDIDC'.
      GET PROPERTY OF gs_exc 'ActiveSheet' = gs_worksheet.
    ENDIF.
* Loop at all segments and build segmentwise worksheets
    LOOP AT lt_edid4 INTO ls_edid4.
* Unassign field symbols
      UNASSIGN: <gs_dyn_tab>.
* Build dynamic work area
      CREATE DATA gv_dy_line TYPE (ls_edid4-segnam).
      ASSIGN gv_dy_line->* TO <gs_dyn_tab>.
* Check if field-symbols is assigned
      IF <gs_dyn_tab> IS ASSIGNED.
****************Start Of Change JK 5/11/2012******************************
* Get header line for current segment
        PERFORM get_header_line2 USING ls_edid4-segnam space.
****************End Of Change JK 5/11/2012******************************
* Add IDOC Number as a first column
        CONCATENATE text-h01 gs_excel-line
                    INTO gs_excel-line
                    SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
* Check and append header line
        IF gs_excel IS NOT INITIAL.
          APPEND gs_excel TO gt_excel.
        ENDIF.
      ENDIF.
      LOOP AT gt_edid4 INTO gs_edid4 FROM 1
              WHERE segnam = ls_edid4-segnam.
* Delete current line
        DELETE gt_edid4 INDEX sy-tabix.
* Get segment data in dynamic structure
        <gs_dyn_tab> = gs_edid4-sdata.
* Build excel table with Tab Delimited character
        CLEAR: gs_excel.
        CONCATENATE '="' gs_edid4-docnum '"'
                    INTO gs_excel-line.
*        DO. Commented by JK
*          UNASSIGN <lv_field>.
*          ASSIGN COMPONENT sy-index OF STRUCTURE <gs_dyn_tab>
*                 TO <lv_field>.
*
*          IF <lv_field> IS ASSIGNED.
*            CLEAR: lv_fval.
*            lv_fval = <lv_field>.
*
** Perform transformation based on the column type
*            PERFORM transform_colval USING lv_fval <lv_field>.
*
*            CONCATENATE gs_excel-line lv_fval
*                        INTO gs_excel-line
*                        SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
*          ELSE.
*            EXIT.
*          ENDIF.
*        ENDDO. Commented by JK
**********************************************************************
        CLEAR lv_count .
        DO  .
          lv_count = lv_count + 1.
          UNASSIGN <lv_field>.
          ASSIGN COMPONENT sy-index OF STRUCTURE <gs_dyn_tab>
                 TO <lv_field>.
          IF <lv_field> IS ASSIGNED.
            CLEAR: lv_fval.
            lv_fval = <lv_field>.
*IF wa_filter-flag = sy-tabix.
****************Start Of Change JK 5/11/2012******************************
            CLEAR :ls_fieldcat_1,wa_return.
            PERFORM transform_colval USING lv_fval <lv_field>.

            READ TABLE lt_fieldcat_1 INTO ls_fieldcat_1 INDEX lv_count.
            IF sy-subrc IS INITIAL.
             DESCRIBE TABLE it_return2 LINES lv_nooflines.
             IF lv_nooflines eq 0.
                CONCATENATE gs_excel-line lv_fval
                          INTO gs_excel-line
                            SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
                ELSE.
              READ TABLE it_return2 INTO wa_return WITH KEY fieldval = ls_fieldcat_1-fieldname.
              IF sy-subrc IS INITIAL.
* Perform transformation based on the column type
                CONCATENATE gs_excel-line lv_fval
                            INTO gs_excel-line
                            SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
              ENDIF.
            ENDIF.
            ENDIF.
****************End Of Change JK 5/11/2012******************************
          ELSE.
            EXIT.
          ENDIF.

*          ENDIF.
        ENDDO.
*ENDLOOP.
**********************************************************************

        APPEND gs_excel TO gt_excel.
      ENDLOOP.
* Check if there are any entries in excel table
      IF gt_excel[] IS NOT INITIAL.
        PERFORM download_sheet TABLES gt_excel USING gv_count gs_edid4-segnam.
        GET PROPERTY OF gs_exc 'ActiveSheet' = gs_worksheet.
      ENDIF.
    ENDLOOP.
* Build worksheet for Status Record
    PERFORM get_header_line USING 'EDIDS' 'X'.
* Check and append header line
    IF gs_excel IS NOT INITIAL.
      APPEND gs_excel TO gt_excel.
    ENDIF.
    LOOP AT gt_edids INTO gs_edids.
* Delete current line
      DELETE gt_edids INDEX sy-tabix.
* Build excel table with Tab Delimited character
      CLEAR: gs_excel.
      DO.
        CHECK sy-index <> 1.
        UNASSIGN <lv_field>.
        ASSIGN COMPONENT sy-index OF STRUCTURE gs_edids
               TO <lv_field>.
        IF <lv_field> IS ASSIGNED.
          CLEAR: lv_fval.
          lv_fval = <lv_field>.
* Perform transformation based on the column type
          PERFORM transform_colval USING lv_fval <lv_field>.
          IF gs_excel-line IS NOT INITIAL.
            CONCATENATE gs_excel-line lv_fval
                        INTO gs_excel-line
                        SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
          ELSE.
            gs_excel-line = lv_fval.
          ENDIF.
        ELSE.
          EXIT.
        ENDIF.
      ENDDO.
      APPEND gs_excel TO gt_excel.
    ENDLOOP.
* Check if there are any entries in excel table
    IF gt_excel[] IS NOT INITIAL.
      PERFORM download_sheet TABLES gt_excel USING gv_count 'EDIDS'.
      GET PROPERTY OF gs_exc 'ActiveSheet' = gs_worksheet.
    ENDIF.
    MESSAGE s208(00) WITH text-s02.
    FREE OBJECT: gs_worksheet, gs_exc.
  ELSE.
    MESSAGE s208(00) WITH text-s01.
    LEAVE LIST-PROCESSING.
  ENDIF.
ENDFORM.                    " PROCESS_DATA
*&---------------------------------------------------------------------*
*&      Form  DOWNLOAD_SHEET
*&---------------------------------------------------------------------*
*       Download data to Worksheet.
*----------------------------------------------------------------------*
FORM download_sheet TABLES p_tab
                    USING p_sheet TYPE i
                          p_name TYPE any.
  p_sheet = p_sheet + 1.
  CALL METHOD OF gs_exc 'WORKSHEETS' = gs_worksheet
    EXPORTING
    #1 = p_sheet.
  CALL METHOD OF gs_worksheet 'ACTIVATE'.
  SET PROPERTY OF gs_worksheet 'NAME' = p_name.
  CALL METHOD OF gs_exc 'Range' = gs_range
    EXPORTING
    #1 = 'A1'
    #2 = 'Z1'.
  CALL METHOD OF gs_range 'INTERIOR' = gs_int.
  SET PROPERTY OF gs_int 'ColorIndex' = 6.
  SET PROPERTY OF gs_int 'Pattern' = 1.
* Initially unlock all the columns( by default all the columns are locked )
  CALL METHOD OF gs_exc 'Columns' = gs_columns.
  SET PROPERTY OF gs_columns 'Locked' = 0.
* Export the contents in the internal table to the clipboard
  CALL METHOD cl_gui_frontend_services=>clipboard_export
    IMPORTING
      data                 = p_tab[]
    CHANGING
      rc                   = gv_rc
    EXCEPTIONS
      cntl_error           = 1
      error_no_gui         = 2
      not_supported_by_gui = 3
      OTHERS               = 4.
* Paste the contents in the clipboard to the worksheet
  CALL METHOD OF gs_worksheet 'Paste'.
* Autofit the columns according to the contents
  CALL METHOD OF gs_exc 'Columns' = gs_columns.
  CALL METHOD OF gs_columns 'AutoFit'.
  FREE OBJECT: gs_columns, gs_range, gs_int, gs_worksheet.
  REFRESH: p_tab[].
ENDFORM.                    "download_sheet
*&---------------------------------------------------------------------*
*&      Form  GET_HEADER_LINE
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
FORM get_header_line USING pi_tabname TYPE dd02l-tabname
                           pi_skipmandt TYPE char1.
* Local data declaration
  DATA: ls_fieldcat TYPE slis_fieldcat_alv,
        lt_fieldcat TYPE TABLE OF slis_fieldcat_alv.
  REFRESH: lt_fieldcat,
           gt_excel.
  CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
    EXPORTING
      i_structure_name       = pi_tabname
    CHANGING
      ct_fieldcat            = lt_fieldcat[]
    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.
  ELSE.
    CLEAR: gs_excel.
    LOOP AT lt_fieldcat INTO ls_fieldcat.
      IF pi_skipmandt = 'X' AND
         sy-tabix = 1.
        CONTINUE.
      ENDIF.
      IF ls_fieldcat-reptext_ddic IS INITIAL.
        ls_fieldcat-reptext_ddic = ls_fieldcat-fieldname.
      ELSE.
        CONCATENATE ls_fieldcat-fieldname '-'
                    ls_fieldcat-reptext_ddic
                    INTO ls_fieldcat-reptext_ddic.
      ENDIF.
      IF gs_excel-line IS NOT INITIAL.
        CONCATENATE gs_excel-line ls_fieldcat-reptext_ddic
        INTO gs_excel-line
        SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
      ELSE.
        gs_excel-line = ls_fieldcat-reptext_ddic.
      ENDIF.
    ENDLOOP.
  ENDIF.
ENDFORM.                    " GET_HEADER_LINE
*&---------------------------------------------------------------------*
*&      Form  TRANSFORM_COLVAL
*&---------------------------------------------------------------------*
*       Perform transformation based on the column type.               *
*----------------------------------------------------------------------*
FORM transform_colval USING pi_fval TYPE string
                            pi_fieldsym TYPE any.
* Local data declaration
  DATA: lv_type TYPE c,
        lv_datechar(10) TYPE c,
        lv_timechar(8) TYPE c,
        lv_pchar(15) TYPE c,
        lv_date LIKE sy-datum,
        lv_time LIKE sy-uzeit.
  CONSTANTS: lc_datetype VALUE 'D',
             lc_packtype VALUE 'P',
             lc_timetype VALUE 'T',
             lc_chartyp  VALUE 'C',
             lc_numtyp   VALUE 'N'.
* Get the component type
  CLEAR: lv_type.
  DESCRIBE FIELD pi_fieldsym TYPE lv_type.
* If data type is DATE
  IF lv_type = lc_datetype.
    lv_date = pi_fval.
    WRITE lv_date TO lv_datechar MM/DD/YYYY.
    pi_fval = lv_datechar .
  ENDIF.
* If data type is TIME
  IF lv_type = lc_timetype.
    lv_time = pi_fval.
    WRITE lv_time TO lv_timechar.
    pi_fval = lv_timechar.
  ENDIF.
* If data type is Packed Decimal, then pad negative sign
* in front by moving it to character variable
  IF lv_type = lc_packtype.
    IF pi_fieldsym < 0.
      pi_fval = pi_fval * ( -1 ).
      lv_pchar = pi_fval.
      CONDENSE lv_pchar NO-GAPS.
      CONCATENATE '-' lv_pchar INTO lv_pchar.
      WRITE lv_pchar TO lv_pchar RIGHT-JUSTIFIED.
    ELSE.
      CONDENSE pi_fval NO-GAPS.
      WRITE pi_fval TO lv_pchar RIGHT-JUSTIFIED.
    ENDIF.
    CLEAR: pi_fval.
    pi_fval = lv_pchar.
  ENDIF.
* If data type is characters, retain zeros if
* required
  IF lv_type = lc_chartyp OR
     lv_type = lc_numtyp.
    IF pi_fval IS NOT INITIAL.
      IF pi_fval CO '0123456789 '.
        CONCATENATE '="' pi_fval '"'
                    INTO pi_fval.
      ENDIF.
    ENDIF.
  ENDIF.
ENDFORM.                    " TRANSFORM_COLVAL

*&---------------------------------------------------------------------*
*&      Form  get_header_line2
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->PI_TABNAME    text
*      -->PI_SKIPMANDT  text
*----------------------------------------------------------------------*
FORM get_header_line2 USING pi_tabname TYPE dd02l-tabname
                           pi_skipmandt TYPE char1.
* Local data declaration
  DATA: ls_fieldcat TYPE slis_fieldcat_alv,
        lt_fieldcat TYPE TABLE OF slis_fieldcat_alv,
        l_tabix TYPE sy-tabix,
        lv_nooflines TYPE i.
  REFRESH: lt_fieldcat,
           gt_excel.
  CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
    EXPORTING
      i_structure_name       = pi_tabname
    CHANGING
      ct_fieldcat            = lt_fieldcat[]
    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.
  ELSE.

    lt_fieldcat_1[] =  lt_fieldcat[].
    LOOP AT lt_fieldcat INTO ls_fieldcat.
      l_tabix = sy-tabix .
      DESCRIBE TABLE it_return2 LINES lv_nooflines.
       IF lv_nooflines GT 0.
      READ TABLE it_return2 TRANSPORTING NO FIELDS WITH KEY fieldval = ls_fieldcat-fieldname.
      IF sy-subrc NE 0.
        DELETE lt_fieldcat WHERE fieldname = ls_fieldcat-fieldname.
      ELSE.
*        wa_filter-flag = l_tabix .
*        MODIFY it_filter FROM wa_filter INDEX sy-tabix TRANSPORTING flag .
      ENDIF.
      ENDIF.
      CLEAR: ls_fieldcat,l_tabix.
    ENDLOOP.
    CLEAR: gs_excel.
    LOOP AT lt_fieldcat INTO ls_fieldcat.
      IF pi_skipmandt = 'X' AND
         sy-tabix = 1.
        CONTINUE.
      ENDIF.
      IF ls_fieldcat-reptext_ddic IS INITIAL.
        ls_fieldcat-reptext_ddic = ls_fieldcat-fieldname.
      ELSE.
        CONCATENATE ls_fieldcat-fieldname '-'
                    ls_fieldcat-reptext_ddic
                    INTO ls_fieldcat-reptext_ddic.
      ENDIF.
      IF gs_excel-line IS NOT INITIAL.
        CONCATENATE gs_excel-line ls_fieldcat-reptext_ddic
        INTO gs_excel-line
        SEPARATED BY cl_abap_char_utilities=>horizontal_tab.
      ELSE.
        gs_excel-line = ls_fieldcat-reptext_ddic.
      ENDIF.
    ENDLOOP.
  ENDIF.
ENDFORM.                    " GET_HEADER_LINE2

No comments:

Post a Comment