Friday, 31 August 2012

Drop down, F4 help, hot spot, editable fields in ALV Grid


This program describes how to include Drop down, F4 help, hot spot, editable fields in ALV Grid.

  • Create report ZALV_EXAMPLE. 
  • Create screen 100 and press layout button for screen painting.
  • Create custom control and adjust according to your screen area. 
  • Create GUI status for screen 100 'STATUS_100'
  • Create message class ZFLIGHT and enter 'Total price for Air line & of plane type & is & &' in message 001 
  • Then paste below code in the report and activate it.
=====================================================================


REPORT  ZALV_EXAMPLE MESSAGE-ID ZFLIGHT.

type-pools: SLIS.

DATA:
  begin of IT_SFLIGHT,
    carrid type sflight-carrid,
    connid type sflight-connid,
    FLDATE type sflight-FLDATE,
    PRICE type sflight-PRICE,
    CURRENCY type sflight-CURRENCY,
    PLANETYPE type sflight-planetype,
    comments TYPE char250,
  end of IT_SFLIGHT.
DATA:
  BEGIN OF PLNTYPEF4,
    PLANETYPE TYPE CHAR10,
  END OF PLNTYPEF4.

DATA :G_CONTAINER TYPE SCRFNAME VALUE 'GRID',
      ALV_GRID  TYPE REF TO CL_GUI_ALV_GRID,
      G_CUSTOM_CONTAINER TYPE REF TO CL_GUI_CUSTOM_CONTAINER,
      WA_SFLIGHT LIKE  TABLE OF IT_SFLIGHT WITH HEADER LINE,
      GT_FIELDCAT TYPE LVC_T_FCAT WITH HEADER LINE,
      WA_PLNTYPEF4 LIKE STANDARD TABLE OF PLNTYPEF4 WITH HEADER LINE.

CALL SCREEN 100.

" create class to handle f4 and hotspot clic events.

CLASS LCL_EVENT_HANDLER DEFINITION.
  PUBLIC SECTION.
    METHODS ON_F4 FOR EVENT ONF4 OF CL_GUI_ALV_GRID
      IMPORTING E_FIELDNAME
                ES_ROW_NO
                ER_EVENT_DATA
                ET_BAD_CELLS
                E_DISPLAY.
    METHODS HOTSPOT_CLICK FOR EVENT HOTSPOT_CLICK OF CL_GUI_ALV_GRID
      IMPORTING ES_ROW_NO
                E_ROW_ID
                E_COLUMN_ID.
ENDCLASS.

CLASS LCL_EVENT_HANDLER IMPLEMENTATION.
METHOD ON_F4.
PERFORM ON_F4_HELP USING E_FIELDNAME
                         ES_ROW_NO-ROW_ID
                         ER_EVENT_DATA
                         ET_BAD_CELLS
                         E_DISPLAY.
ER_EVENT_DATA->M_EVENT_HANDLED 'X'.
ENDMETHOD.

METHOD HOTSPOT_CLICK.
PERFORM HOTSPOT_CLICK USING ES_ROW_NO
                            E_ROW_ID
                            E_COLUMN_ID.
ENDMETHOD.
ENDCLASS.

DATA :GO_HANDLE TYPE REF TO LCL_EVENT_HANDLER.

FORM ON_F4_HELP USING P_E_FIELDNAME ROW_ID P_ER_EVENT_DATA TYPE REF TO CL_ALV_EVENT_DATA P_ET_BAD_CELLS P_E_DISPLAY.
  DATA :LINE TYPE CHAR10,
        RETURN_TAB TYPE TABLE OF DDSHRETVAL WITH HEADER LINE.
  REFRESH WA_PLNTYPEF4.
  CLEAR WA_PLNTYPEF4.
  SELECT DISTINCT PLANETYPE FROM SFLIGHT INTO LINE.
    APPEND LINE TO WA_PLNTYPEF4.
    ENDSELECT.
    CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
      EXPORTING
        RETFIELD        'PLANETYPE'
        VALUE_ORG       'S'
        DYNPPROG        SY-REPID
        DYNPNR          SY-DYNNR
      TABLES
        VALUE_TAB WA_PLNTYPEF4
        RETURN_TAB RETURN_TAB
      EXCEPTIONS
        PARAMETER_ERROR 1
        NO_VALUES_FOUND 2
        OTHERS          3.
    READ TABLE WA_SFLIGHT INDEX ROW_ID.
    IF RETURN_TAB-FIELDVAL IS NOT INITIAL.
      WA_SFLIGHT-PLANETYPE RETURN_TAB-FIELDVAL.
    ENDIF.
    MODIFY WA_SFLIGHT INDEX ROW_ID.
    CALL METHOD ALV_GRID->REFRESH_TABLE_DISPLAY.
ENDFORM.

FORM HOTSPOT_CLICK USING ES_ROW_NO
                         E_ROW_ID
                         E_COLUMN_ID.
READ TABLE WA_SFLIGHT INDEX E_ROW_ID.
MESSAGE S001 WITH WA_SFLIGHT-CONNID WA_SFLIGHT-PLANETYPE  WA_SFLIGHT-PRICE WA_SFLIGHT-CURRENCY.
ENDFORM.

MODULE STATUS_0100 OUTPUT.
  SET PF-STATUS 'STATUS_100'.
  SELECT FROM SFLIGHT INTO CORRESPONDING FIELDS OF TABLE WA_SFLIGHT.
  REFRESH GT_FIELDCAT.
  PERFORM BUILD_FIELDCAT USING 'CARRID' 'WA_SFLIGHT' 'Airline Code'.
  PERFORM BUILD_FIELDCAT USING 'CONNID' 'WA_SFLIGHT' 'Flight Conn No'.
  PERFORM BUILD_FIELDCAT USING 'FLDATE' 'WA_SFLIGHT' 'Flight date'.
  PERFORM BUILD_FIELDCAT USING 'PRICE' 'WA_SFLIGHT' 'Airfare'.
  PERFORM BUILD_FIELDCAT USING 'CURRENCY' 'WA_SFLIGHT' 'Local currency'.
  PERFORM BUILD_FIELDCAT USING 'PLANETYPE' 'WA_SFLIGHT' 'Aircraft Type'.
  PERFORM BUILD_FIELDCAT USING 'COMMENTS' 'WA_SFLIGHT' 'Comments'.

  IF G_CUSTOM_CONTAINER IS INITIAL.
    CREATE OBJECT G_CUSTOM_CONTAINER
      EXPORTING CONTAINER_NAME G_CONTAINER.
    CREATE OBJECT ALV_GRID
      EXPORTING I_PARENT G_CUSTOM_CONTAINER.
    PERFORM DROPDOWN_TABLE CHANGING ALV_GRID.
    CALL METHOD ALV_GRID->SET_TABLE_FOR_FIRST_DISPLAY
      CHANGING  IT_OUTTAB       WA_SFLIGHT[]
                IT_FIELDCATALOG GT_FIELDCAT[].
    CALL METHOD ALV_GRID->REGISTER_EDIT_EVENT
      EXPORTING
      I_EVENT_ID CL_GUI_ALV_GRID=>MC_EVT_MODIFIED.
    CREATE OBJECT GO_HANDLE.
    SET HANDLER :GO_HANDLE->ON_F4 FOR ALV_GRID,
                 GO_HANDLE->HOTSPOT_CLICK FOR ALV_GRID.
  ELSE.
    CALL METHOD ALV_GRID->REFRESH_TABLE_DISPLAY.
  ENDIF.
ENDMODULE.

MODULE USER_COMMAND_0100 INPUT.
  IF sy-ucomm 'BACK' OR
     sy-ucomm 'EXIT' OR
     sy-ucomm 'CANCEL'.
    LEAVE PROGRAM.
  ENDIF.
ENDMODULE.

FORM BUILD_FIELDCAT USING POS FIELD TABLE TEXT.
CLEAR GT_FIELDCAT.
GT_FIELDCAT-COL_POS POS.
GT_FIELDCAT-FIELDNAME FIELD.
GT_FIELDCAT-TABNAME TABLE.
GT_FIELDCAT-COL_OPT 'X'.
GT_FIELDCAT-OUTPUTLEN 50.
IF POS OR POS ).
  GT_FIELDCAT-EDIT 'X'.
ENDIF.
IF POS 6.
  GT_FIELDCAT-F4AVAILABL 'X'.
ENDIF.
IF POS 2.
  GT_FIELDCAT-HOTSPOT 'X'.
ENDIF.
GT_FIELDCAT-SELTEXT TEXT.
GT_FIELDCAT-COLTEXT TEXT.
APPEND GT_FIELDCAT.
ENDFORM.

FORM DROPDOWN_TABLE CHANGING ALV_GRID TYPE REF TO CL_GUI_ALV_GRID.
DATA :LT_DROPDOWN TYPE LVC_T_DROP WITH HEADER LINE.
DATA: GS_F4 type LVC_S_F4,
      GT_F4 type LVC_T_f4.
LOOP AT GT_FIELDCAT.
  IF GT_FIELDCAT-FIELDNAME 'CURRENCY'.
    GT_FIELDCAT-DRDN_HNDL '1'.
    GT_FIELDCAT-OUTPUTLEN 20.
    MODIFY GT_FIELDCAT.
  ENDIF.
ENDLOOP.
CLEAR GT_F4.
  GS_F4-FIELDNAME  'PLANETYPE'.
  GS_F4-REGISTER   'X'.
  GS_F4-GETBEFORE  'X'.
  GS_F4-CHNGEAFTER 'X'.
  APPEND GS_F4 to GT_F4.
  CALL METHOD ALV_GRID->REGISTER_F4_FOR_FIELDS
    EXPORTING
      IT_F4 GT_F4.
LT_DROPDOWN-HANDLE '1'.
LT_DROPDOWN-VALUE 'CAD'.
APPEND LT_DROPDOWN.
LT_DROPDOWN-HANDLE '1'.
LT_DROPDOWN-VALUE 'EUR'.
APPEND LT_DROPDOWN.
LT_DROPDOWN-HANDLE '1'.
LT_DROPDOWN-VALUE 'DEM'.
APPEND LT_DROPDOWN.
LT_DROPDOWN-HANDLE '1'.
LT_DROPDOWN-VALUE 'USD'.
APPEND LT_DROPDOWN.
LT_DROPDOWN-HANDLE '1'.
LT_DROPDOWN-VALUE 'LIT'.
APPEND LT_DROPDOWN.
CALL METHOD ALV_GRID->SET_DROP_DOWN_TABLE
  EXPORTING
    IT_DROP_DOWN LT_DROPDOWN[].
ENDFORM.

===================================================================
The output will be look like below. In here you can find hot spot in column 2, drop down in column 5, f4 help column 6 and editable fields in column 7.



F4 help can get from clicking f4 help buttun from any of the field from 6th column.
Then popup will diaplay with possible values for that field.

Once you selected required field ALV grid will change accordingly.

And if click on any hotspot from 2nd column status message of the row will be displayed.