Thursday, September 20, 2018

SALV 5 : SALV Double Click

*&---------------------------------------------------------------------*
*& Report  ZOOPS_SALV_ALV1
*&
*&---------------------------------------------------------------------*
*&  This code will show you when we double click on Any record then
*&  it go to perticular Transaction
*&---------------------------------------------------------------------*

REPORT ZSALV_DOUBLE_CLICK.

*& Constant Declaration.
DATA LV_EBELN TYPE EKKO-EBELN.

*& Selection Screen
SELECTION-SCREEN BEGIN OF BLOCK A1 WITH FRAME TITLE TEXT-001.
SELECT-OPTIONS S_EBELN FOR LV_EBELN.
SELECTION-SCREEN END OF BLOCK A1.

CLASS CL_DATA DEFINITION.

  PUBLIC SECTION.

*& Structure for Purchasing Document Header Table
    TYPES BEGIN OF TY_EKKO,
                      EBELN  TYPE EBELN,   "Purchasing Document Number
                      BUKRS  TYPE BUKRS,   "Company Code
                      BSTYP  TYPE EBSTYP,  "Purchasing Document Category
                      BSART  TYPE ESART,   "Purchasing Document Type
                      BEDAT  TYPE EBDAT,   "Purchasing Document Date
                   END OF TY_EKKO,

*& Structure for Purchasing Document Item Table
                  BEGIN OF TY_EKPO,
                     EBELN  TYPE EBELN,   "Purchasing Document Number
                     EBELP  TYPE EBELP,   "Item Number of Purchasing Document
                     MATNR  TYPE MATNR,   "Material Number
                     MENGE  TYPE BSTMG,   "Purchase Order Quantity
                     MEINS  TYPE BSTME,   "Purchase Order Unit of Measure
                     NETPR  TYPE BPREI,   "Net Price in Purchasing Document 
                 END OF TY_EKPO.

*& Final Output stucture
    TYPES BEGIN OF TY_FINAL,
                       EBELN TYPE EBELN,   "Purchasing Document Number
                       BSART TYPE ESART,   "Purchasing Document Type
                       BEDAT TYPE EBDAT,   "Purchasing Document Date
                       MATNR TYPE MATNR,   "Material Number
                       MENGE TYPE BSTMG,   "Purchase Order Quantity
                       MEINS TYPE BSTME,   "Purchase Order Unit of Measure
                       NETPR TYPE BPREI,   "Net Price in Purchasing Document 
                    END OF TY_FINAL.

*& Internal Table Declration
    DATA GT_EKKO  TYPE TABLE OF TY_EKKO INITIAL SIZE 1,
                  GT_EKPO  TYPE TABLE OF TY_EKPO INITIAL SIZE 1,
                  GT_FINAL TYPE TABLE OF TY_FINAL INITIAL SIZE 1.

*& Workarea Declaration.
    DATA GS_FINAL TYPE TY_FINAL,
                  GS_EKKO  TYPE TY_EKKO,
                  GS_EKPO  TYPE TY_EKPO.

*& Declare Variable for Class.
    DATA LO_ALV     TYPE REF TO CL_SALV_TABLE,
                  LO_COLUMNS TYPE REF TO CL_SALV_COLUMNS,
                  LO_COLUMN  TYPE REF TO CL_SALV_COLUMN_LIST,
                  LO_LAYOUT  TYPE REF TO CL_SALV_LAYOUT,
                  LO_DISPLAY TYPE REF TO CL_SALV_DISPLAY_SETTINGS,
                  LO_EVENT   TYPE REF TO CL_SALV_EVENTS_TABLE,
                  LS_KEY     TYPE SALV_S_LAYOUT_KEY.

*& Declare Methods for Get Data and Display Data
    METHODS GET_DATA,     "Get data from Data base.
                         GET_POP_DATA"Populate Final Display Data
                         DISPLAY.      "Display Data

ENDCLASS.

CLASS CL_DOUBLE DEFINITION.

  PUBLIC SECTION.
  METHODS DOUBLE_CLICK
                    FOR EVENT DOUBLE_CLICK OF CL_SALV_EVENTS_TABLE
                                                      IMPORTING ROW COLUMN.

ENDCLASS.

*& Start of Selection
START-OF-SELECTION.

*& Refence for Cl_DATA
  DATA LO_CL_DATA TYPE REF TO CL_DATA.

*& Object for CL_DATA Class.
  CREATE OBJECT LO_CL_DATA.

*& Call the GET_DATA Method.
  LO_CL_DATA->GET_DATA).

*& Call the GET_POP_DATA Method.
  LO_CL_DATA->GET_POP_DATA).

*& Call the DISPLAY Method.
  LO_CL_DATA->DISPLAY).


CLASS CL_DATA IMPLEMENTATION.

*&This Method is used to Get data from Data base
  METHOD GET_DATA.

    SELECT EBELN
                  BUKRS
                  BSTYP
                  BSART
                  BEDAT
       FROM EKKO INTO TABLE GT_EKKO WHERE EBELN IN S_EBELN.

    IF GT_EKKO[] IS NOT INITIAL.
      SORT GT_EKKO BY EBELN.
    ELSE.
      MESSAGE 'Data not Found' TYPE 'E'.
    ENDIF.

    IF GT_EKKO[] IS NOT INITIAL.

      SELECT EBELN
                    EBELP
                    MATNR
                    MENGE
                    MEINS
                    NETPR
        FROM EKPO INTO TABLE GT_EKPO FOR ALL ENTRIES IN GT_EKKO
        WHERE EBELN EQ GT_EKKO-EBELN.

    ENDIF.

  ENDMETHOD.

*& This Method is used to Populate final display Data
  METHOD GET_POP_DATA.

    LOOP AT GT_EKPO INTO GS_EKPO.

      GS_FINAL-EBELN GS_EKPO-EBELN.
      GS_FINAL-MATNR GS_EKPO-MATNR.
      GS_FINAL-MENGE GS_EKPO-MENGE.
      GS_FINAL-MEINS GS_EKPO-MEINS.
      GS_FINAL-NETPR GS_EKPO-NETPR.

      CLEAR GS_EKKO.
      READ TABLE GT_EKKO INTO GS_EKKO WITH KEY EBELN GS_EKPO-EBELN.
      IF SY-SUBRC EQ 0.
        GS_FINAL-BSART GS_EKKO-BSART.
        GS_FINAL-BEDAT GS_EKKO-BEDAT.
      ENDIF.

      APPEND GS_FINAL TO GT_FINAL.
      CLEAR GS_FINAL.

    ENDLOOP.

  ENDMETHOD.

*& This Method is used to Display Data
  METHOD DISPLAY.

*& We call the Factory Method to get the instance of the ALV.

    TRY.
        CALL METHOD CL_SALV_TABLE=>FACTORY
*      EXPORTING
*        LIST_DISPLAY   = IF_SALV_C_BOOL_SAP=>FALSE
*        R_CONTAINER    =
*        CONTAINER_NAME =
      IMPORTING
        R_SALV_TABLE    LO_ALV
          CHANGING
            T_TABLE     GT_FINAL
            .
      CATCH CX_SALV_MSG .
    ENDTRY.

*& Get the all columns
    LO_COLUMNS LO_ALV->GET_COLUMNS).

*& Set Column Optimization.
    LO_COLUMNS->SET_OPTIMIZE'X' ).

*& Displaying toolbar on alv
    LO_ALV->GET_FUNCTIONS)->SET_ALL).

*& get layout object.
    LO_LAYOUT LO_ALV->GET_LAYOUT).

*& Set Layout Save Restriction.
*& Set Layout Key
  LS_KEY-REPORT SY-REPID.
  LO_LAYOUT->SET_KEYLS_KEY ).

*& Remove Save Layout the Restriction.
  LO_LAYOUT->SET_SAVE_RESTRICTIONIF_SALV_C_LAYOUT=>RESTRICT_NONE ).

*& get object for ZIGZAG Format .
   LO_DISPLAY LO_ALV->GET_DISPLAY_SETTINGS).

*& Display Data in ZIGZAG Format.
   LO_DISPLAY->SET_STRIPED_PATTERN'X' ).

*& Change the Column Heading.
    TRY.

      "Getting Column Column
      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'EBELN' ).
      "Set Column Long Text @"here we can give up to 40 charecter
      LO_COLUMN->SET_LONG_TEXT'Purchase Number' ).
      "Set Column Medium Text @"here we can give up to 20 charecter
      LO_COLUMN->SET_MEDIUM_TEXT'Pur. Number' ).
      "Set Column Short Text @"here we can give up to 10 charecter
      LO_COLUMN->SET_SHORT_TEXT'PO Number' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'MATNR' ).
      LO_COLUMN->SET_LONG_TEXT'Material Code' ).
      LO_COLUMN->SET_MEDIUM_TEXT'Material Number' ).
      LO_COLUMN->SET_SHORT_TEXT'Material' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'BSART' ).
      LO_COLUMN->SET_LONG_TEXT'Document Type' ).
      LO_COLUMN->SET_MEDIUM_TEXT'Document Type' ).
      LO_COLUMN->SET_SHORT_TEXT'Doc.Type' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'BEDAT' ).
      LO_COLUMN->SET_LONG_TEXT'Document Date' ).
      LO_COLUMN->SET_MEDIUM_TEXT'Document Date' ).
      LO_COLUMN->SET_SHORT_TEXT'Doc. Date' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'MEINS' ).
      LO_COLUMN->SET_LONG_TEXT'Unit of Mesure' ).
      LO_COLUMN->SET_MEDIUM_TEXT'UOM' ).
      LO_COLUMN->SET_SHORT_TEXT'UOM' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'MENGE' ).
      LO_COLUMN->SET_LONG_TEXT'Po Quantity' ).
      LO_COLUMN->SET_MEDIUM_TEXT'Quantity' ).
      LO_COLUMN->SET_SHORT_TEXT'Qty' ).

      LO_COLUMN ?= LO_COLUMNS->GET_COLUMN'NETPR' ).
      LO_COLUMN->SET_LONG_TEXT'PO Price' ).
      LO_COLUMN->SET_MEDIUM_TEXT'Price' ).
      LO_COLUMN->SET_SHORT_TEXT'Price' ).

      CATCH CX_SALV_NOT_FOUND.
    ENDTRY.

*  Get the event object
   LO_EVENT LO_ALV->GET_EVENT).

*  Instantiate the event handler object
   DATA LO_DOUBLE TYPE REF TO CL_DOUBLE.

*& Create Object for Double Click Class
   CREATE OBJECT LO_DOUBLE.

*  Event handler
   SET HANDLER LO_DOUBLE->DOUBLE_CLICK FOR LO_EVENT.

*& Here we will call the display method to get the output on the screen
    LO_ALV->DISPLAY).

  ENDMETHOD.

ENDCLASS.

*& Implement Double Click Class
CLASS CL_DOUBLE IMPLEMENTATION.

  METHOD DOUBLE_CLICK.

    FIELD-SYMBOLS <FS_DATA> LIKE LINE OF LO_CL_DATA->GT_FINAL.
    READ TABLE LO_CL_DATA->GT_FINAL ASSIGNING <FS_DATA> INDEX ROW.
    IF SY-SUBRC EQ 0.

      IF COLUMN EQ 'EBELN'.
        "Set Parameter for ME23N Transaction
        SET PARAMETER ID 'BES' FIELD <FS_DATA>-EBELN.
        "Call ME23N Transaction
        CALL TRANSACTION 'ME23N'.

      ENDIF.

    ENDIF.

  ENDMETHOD.

ENDCLASS.


OutPut:




Download source code PDF Format.

Download Source code Text Format.

No comments:

Post a Comment