메뉴 건너뛰기

SAP 한국 커뮤니티

REPORT z18_022

sapjoy 2007.03.17 00:50 조회 수 : 2464


REPORT  z18_022                                                     .
TABLES : sflight.


DATA : con1_ref TYPE REF TO cl_gui_custom_container.


 


TYPES : t_sflight TYPE sflight.


DATA: BEGIN OF gt_sflight OCCURS 0.
        INCLUDE STRUCTURE sflight.


DATA:   light TYPE c. "to display exceptions
DATA:   cellcolor TYPE lvc_t_scol. "Table for colors
DATA: END OF gt_sflight.



DATA : grid1  TYPE REF TO cl_gui_alv_grid,
       gs_variant     LIKE disvariant,
       gs_cs_variant  LIKE disvariant,
       gs_layout     TYPE lvc_s_layo,
       gs_toolbar    TYPE ui_functions,
       gt_sort       TYPE lvc_t_sort,
       gt_fieldcat   TYPE lvc_t_fcat.


 


*       gt_sflight    TYPE TABLE OF sflight.


TYPE-POOLS: icon.


*---------------------------------------------------------------------*
*       CLASS lcl_event_receiver DEFINITION
*---------------------------------------------------------------------*
*
*---------------------------------------------------------------------*
CLASS lcl_event_receiver DEFINITION.


  PUBLIC SECTION.
    METHODS:


    handle_double_click
        FOR EVENT double_click OF cl_gui_alv_grid
            IMPORTING e_row e_column.


    METHODS : handle_toolbar
                 FOR EVENT toolbar OF cl_gui_alv_grid
                 IMPORTING e_object e_interactive.



    METHODS : handle_command
                 FOR EVENT user_command OF cl_gui_alv_grid
                 IMPORTING e_ucomm.


  PRIVATE SECTION.


ENDCLASS.                    "lcl_event_receiver DEFINITION


*---------------------------------------------------------------------*
*       CLASS lcl_event_receiver IMPLEMENTATION
*---------------------------------------------------------------------*
*
*---------------------------------------------------------------------*
CLASS lcl_event_receiver IMPLEMENTATION.


  METHOD handle_double_click.
    LEAVE TO SCREEN 0.
  ENDMETHOD.                           "handle_double_click


*-- Add ToolBar
  METHOD handle_toolbar.


    DATA: ls_toolbar  TYPE stb_button.


    CLEAR ls_toolbar.
    ls_toolbar-butn_type = 3.
    APPEND ls_toolbar    TO e_object->mt_toolbar.


    CLEAR ls_toolbar.
    ls_toolbar-function  = 'RESH'.
    ls_toolbar-icon      = icon_refresh.
    ls_toolbar-quickinfo = 'Refresh'.
    ls_toolbar-text      = ' '.
    ls_toolbar-disabled  = ' '.
    APPEND ls_toolbar    TO e_object->mt_toolbar.


  ENDMETHOD.                    "handle_toolbar



  METHOD handle_command.
    DATA : l_scroll TYPE lvc_s_stbl.


    CASE e_ucomm.
*-  REFRESH
      WHEN 'RESH'.


        SELECT * FROM sflight
        INTO CORRESPONDING FIELDS OF TABLE gt_sflight.
        l_scroll-row = 'X'.
        l_scroll-col = 'X'.
        CALL METHOD grid1->refresh_table_display
          EXPORTING
            i_soft_refresh = ''
            is_stable      = l_scroll.
    ENDCASE.
  ENDMETHOD.                    "handle_user_command



ENDCLASS.                    "lcl_event_receiver IMPLEMENTATION
*


DATA :     event_receiver TYPE REF TO lcl_event_receiver.



START-OF-SELECTION.
  SELECT * FROM sflight INTO CORRESPONDING FIELDS OF TABLE gt_sflight.


  LOOP AT gt_sflight.


    IF gt_sflight-seatsocc <= 0.
      gt_sflight-light = '1'.
    ELSEIF gt_sflight-seatsocc <= 50.
      gt_sflight-light = '2'.
    ELSE.
      gt_sflight-light = '3'.
    ENDIF.


 


    MODIFY gt_sflight.


  ENDLOOP.



  CALL SCREEN 100.



*---------------------------------------------------------------------*
*  MODULE init_con OUTPUT
*---------------------------------------------------------------------*
*
*---------------------------------------------------------------------*
MODULE init_con OUTPUT.


  IF con1_ref IS INITIAL.
    CREATE OBJECT con1_ref
    EXPORTING container_name = 'CON1'.



    CREATE OBJECT grid1
           EXPORTING
                i_parent = con1_ref.


    PERFORM setting_layout.
    PERFORM getting_catalog.
    PERFORM setting_catalog.
    PERFORM setting_cell.
    PERFORM setting_toolbar.
    PERFORM setting_sort.
    PERFORM setting_event.


    CALL METHOD grid1->set_table_for_first_display
      EXPORTING
*        i_structure_name     = 'SFLIGHT'
        i_save               = 'A'
        is_variant           = gs_variant  " variant display
        i_default            = ' '
        is_layout            = gs_layout
        it_toolbar_excluding = gs_toolbar
      CHANGING
        it_outtab            = gt_sflight[]
        it_fieldcatalog      = gt_fieldcat[]
        it_sort              = gt_sort.


 



  ENDIF.
ENDMODULE.                 " init_con  OUTPUT
*&---------------------------------------------------------------------*
*&      Module  STATUS_0100  OUTPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE status_0100 OUTPUT.
  SET PF-STATUS 'G100'.
*  SET TITLEBAR 'xxx'.


ENDMODULE.                 " STATUS_0100  OUTPUT


*&---------------------------------------------------------------------*
*&      Module  USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE user_command_0100 INPUT.


  CASE sy-ucomm.
    WHEN 'BACK' OR 'EXIT' OR 'CANC'.
      LEAVE TO SCREEN 0.
  ENDCASE.


ENDMODULE.                 " USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
*&      Form  setting_layout
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_GS_LAYOCAT  text
*----------------------------------------------------------------------*
FORM setting_layout .
*- General display options
  gs_layout-cwidth_opt = 'X'.
* TITLE BAR
  gs_layout-grid_title = 'Coloring Cell TEST'.
* Selection modes for SEL_MODE
  gs_layout-sel_mode = 'D'.


* exception
  gs_layout-excp_fname = 'LIGHT'.


* coloring row
  gs_layout-ctab_fname = 'CELLCOLOR'.
* Grid pattern
*  gs_layout-zebra      = 'X'.
ENDFORM.                    " setting_layout
*&---------------------------------------------------------------------*
*&      Form  setting_toolbar
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_GS_TOOLBAR  text
*----------------------------------------------------------------------*
FORM setting_toolbar.
  DATA: l_exclude TYPE ui_func.


  l_exclude = cl_gui_alv_grid=>mc_fc_save_variant.
  APPEND l_exclude TO gs_toolbar.


  l_exclude = cl_gui_alv_grid=>mc_fc_maintain_variant.
  APPEND l_exclude TO gs_toolbar.


ENDFORM.                    " setting_toolbar
*&---------------------------------------------------------------------*
*&      Form  setting_sort
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM setting_sort .


  DATA : ls_sort TYPE lvc_s_sort.


  ls_sort-spos = '1'.
  ls_sort-fieldname = 'CARRID'.
  ls_sort-up = 'X'.
  ls_sort-subtot = 'X'.
  APPEND ls_sort TO gt_sort.


 



ENDFORM.                    " setting_sort
*&---------------------------------------------------------------------*
*&      Form  setting_event
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM setting_event .
  CREATE OBJECT event_receiver.
  SET HANDLER event_receiver->handle_double_click FOR grid1.
  SET HANDLER event_receiver->handle_toolbar       FOR grid1.
  SET HANDLER event_receiver->handle_command       FOR grid1.


ENDFORM.                    " setting_event
*&---------------------------------------------------------------------*
*&      Form  setting_catalog
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM setting_catalog .
  DATA ls_fieldcat  TYPE lvc_s_fcat.


  LOOP AT gt_fieldcat INTO ls_fieldcat.



    IF  ls_fieldcat-fieldname = 'PRICE'.
      ls_fieldcat-coltext = 'AIR PRICE'.
      ls_fieldcat-just = 'C'.
      ls_fieldcat-emphasize = 'X'.
      ls_fieldcat-tech = 'X'.


      MODIFY gt_fieldcat FROM ls_fieldcat.
    ENDIF.


  ENDLOOP.
ENDFORM.                    " setting_catalog
*&---------------------------------------------------------------------*
*&      Form  getting_catalog
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM getting_catalog .
  DATA : lt_fieldcat TYPE kkblo_t_fieldcat.
  CALL FUNCTION 'K_KKB_FIELDCAT_MERGE'
    EXPORTING
      i_callback_program     = sy-repid
      i_tabname              = 'GT_SFLIGHT'
*      i_strucname            = i_structure
      i_inclname             = sy-repid
    CHANGING
      ct_fieldcat            = lt_fieldcat[]
    EXCEPTIONS
      inconsistent_interface = 1
      OTHERS                 = 2.
  IF sy-subrc EQ 0.
    CALL FUNCTION 'LVC_TRANSFER_FROM_KKBLO'
      EXPORTING
        it_fieldcat_kkblo = lt_fieldcat[]
      IMPORTING
        et_fieldcat_lvc   = gt_fieldcat[].
  ENDIF.


ENDFORM.                    " getting_catalog
*&---------------------------------------------------------------------*
*&      Form  SETTING_CELL
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM setting_cell .
* SETTING CELL
  DATA : lt_color    TYPE lvc_t_scol,
         ls_color    TYPE lvc_s_scol,
         ls_fieldcat TYPE lvc_s_fcat,
         l_mode      TYPE raw4,
         l_type(4)   TYPE c,
         index       TYPE i.


  CLEAR index.
  LOOP AT gt_sflight.
     index = index + 1.
    CLEAR: lt_color[].
    LOOP AT gt_fieldcat INTO ls_fieldcat.


      CLEAR ls_color.
      ls_color-fname = ls_fieldcat-fieldname.
      IF ls_color-fname EQ 'PLANETYPE'.
        CASE gt_sflight-planetype.
          WHEN '747-400'.
            ls_color-color-col = 5.
            ls_color-color-int = 0.
          WHEN 'A319'.
            ls_color-color-col = 3.
            ls_color-color-int = 0.
          WHEN 'A310-300'.
            ls_color-color-col = 6.
            ls_color-color-int = 0.
          WHEN OTHERS.
*      ls_color-color-col = 1.
*      ls_color-color-int = 0.
        ENDCASE.


        INSERT ls_color INTO TABLE lt_color.
      ENDIF.
    ENDLOOP.


    CLEAR: gt_sflight-cellcolor[].
    INSERT LINES OF lt_color   INTO TABLE gt_sflight-cellcolor.
    MODIFY gt_sflight INDEX index.
    CLEAR  gt_sflight.


  ENDLOOP.


ENDFORM.                    " SETTING_CELL

번호 제목 글쓴이 날짜 조회 수
91 REPORT z19_003 sapjoy 2007.03.27 2473
90 REPORT z19_002 sapjoy 2007.03.24 2362
89 REPORT z19_001 sapjoy 2007.03.23 2552
» REPORT z18_022 sapjoy 2007.03.17 2464
87 REPORT z18_019 sapjoy 2007.03.13 2473
86 REPORT z18_018 [4] sapjoy 2007.03.12 2463
85 REPORT z18_014 sapjoy 2007.03.10 2844
84 REPORT z18_013 [1] sapjoy 2007.03.09 2585
83 REPORT z18_012 [1] sapjoy 2007.03.09 2404
82 REPORT Z15_045 sapjoy 2007.03.09 2388
81 REPORT z18_011 [1] sapjoy 2007.03.08 2326
80 REPORT z18_008 sapjoy 2007.03.07 2359
79 REPORT z18_007 sapjoy 2007.03.07 2206
78 REPORT z18_006 sapjoy 2007.03.06 2423
77 REPORT z18_005 sapjoy 2007.03.06 2157
76 REPORT z18_004 [1] sapjoy 2007.03.06 2348
75 REPORT Z18_002 sapjoy 2007.03.06 3083
74 Z18_001_PBO sapjoy 2007.03.03 2585
73 REPORT Z18_001 sapjoy 2007.03.03 2774
72 REPORT Z02_016 sapjoy 2007.02.27 2294