메뉴 건너뛰기

SAP 한국 커뮤니티

REPORT Z15_20

가능 2025.09.22 01:19 조회 수 : 0

REPORT z15_20.

DATA : BEGIN OF gt_empcert OCCURS 0.
         INCLUDE STRUCTURE zempcert.
DATA :   count TYPE p LENGTH 3, " 자격증 개수 필드 추가
         light TYPE c. " EXCEPTION 필드 추가
DATA : END OF gt_empcert.

DATA : BEGIN OF gt_empcert_cnt OCCURS 0,
         empcd TYPE zempcert-empcd,
         count TYPE p LENGTH 3. " 자격증 개수 필드 추가
DATA : END OF gt_empcert_cnt.

DATA : con1_ref    TYPE REF TO    cl_gui_custom_container.
DATA : g_grid      TYPE REF TO    cl_gui_alv_grid.
DATA : gs_variant  TYPE disvariant.
DATA : gs_layout   TYPE lvc_s_layo.
DATA : gt_toolbar  TYPE ui_functions.
DATA : gt_sort     TYPE lvc_t_sort.
DATA : gt_fieldcat TYPE lvc_t_fcat.

DATA : ok_code  TYPE sy-ucomm.

TYPE-POOLS: icon.
*----------------------------------------------------------------------*
*       CLASS lcl_event_receiver DEFINITION
*----------------------------------------------------------------------*
*
*----------------------------------------------------------------------*
CLASS lcl_event_receiver DEFINITION.
  PUBLIC SECTION.
    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.

ENDCLASS.                    "lcl_event_receiver DEFINITION

*----------------------------------------------------------------------*
*       CLASS lcl_event_receiver IMPLEMENTATION
*----------------------------------------------------------------------*
*
*----------------------------------------------------------------------*
CLASS lcl_event_receiver IMPLEMENTATION.
  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.
      WHEN 'RESH'.
        SELECT empcd, certid, CNUM,  COUNT( certid ) AS count
          FROM zempcert
          GROUP BY empcd, certid, CNUM
          INTO CORRESPONDING FIELDS OF TABLE @gt_empcert.
        l_scroll-row = 'X'.
        l_scroll-col = 'X'.

        CALL METHOD g_grid->refresh_table_display
          EXPORTING
            i_soft_refresh = ''
            is_stable      = l_scroll.
    ENDCASE.
  ENDMETHOD.                    "handle_command

ENDCLASS.                    "lcl_event_receiver IMPLEMENTATION


PARAMETERS: p_vari LIKE disvariant-variant.

AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_vari.
  gs_variant-report = sy-repid.
  CALL FUNCTION 'REUSE_ALV_VARIANT_F4'
    EXPORTING
      is_variant    = gs_variant
      i_save        = 'A'
    IMPORTING
      es_variant    = gs_variant
    EXCEPTIONS
      not_found     = 1
      program_error = 2
      OTHERS        = 3.

  IF sy-subrc EQ 0.
    p_vari = gs_variant-variant.
  ENDIF.

START-OF-SELECTION.
  SELECT empcd, certid, CNUM
    FROM zempcert
    INTO CORRESPONDING FIELDS OF TABLE @gt_empcert.

  IF sy-subrc EQ 0.
    SORT gt_empcert BY empcd cnum.
  ENDIF.

  SELECT empcd, COUNT( certid ) AS count
    FROM zempcert
    GROUP BY empcd
    INTO TABLE @gt_empcert_cnt.

  LOOP AT gt_empcert.  "자격증 개수에 따라 신호등 색의 변화
    READ TABLE gt_empcert_cnt WITH KEY empcd = gt_empcert-empcd
      TRANSPORTING count.
    CHECK sy-subrc EQ 0.

    IF gt_empcert_cnt-count >= 3.    " Green.
      gt_empcert-light = '3'.
    ELSEIF gt_empcert_cnt-count = 2. " Yellow.
      gt_empcert-light = '2'.
    ELSEIF gt_empcert_cnt-count = 1. " Blue.
      gt_empcert-light = '1'.
    ENDIF.
    gt_empcert-count = gt_empcert_cnt-count.

    MODIFY gt_empcert.
  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 g_grid
      EXPORTING
        i_parent = con1_ref.
  ENDIF.

  gs_variant-report = sy-repid.
  gs_variant-username = sy-uname.

  PERFORM setting_layout CHANGING gs_layout.
  PERFORM setting_toolbar.
  PERFORM setting_sort.
  PERFORM getting_catalog.
  PERFORM setting_catalog.

  DATA :  event_receiver TYPE REF TO lcl_event_receiver.

  CREATE OBJECT event_receiver.
  SET HANDLER event_receiver->handle_toolbar FOR g_grid.


  CALL METHOD g_grid->set_table_for_first_display
    EXPORTING
*     i_structure_name     = 'ZEMPCERT'
      is_variant           = gs_variant
      i_save               = 'A'
      i_default            = ''
      is_layout            = gs_layout
      it_toolbar_excluding = gt_toolbar
    CHANGING
      it_outtab            = gt_empcert[]
      it_fieldcatalog      = gt_fieldcat
      it_sort              = gt_sort.

ENDMODULE.                 " INIT_CON  OUTPUT
*&---------------------------------------------------------------------*
*&      Module  USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
MODULE user_command_0100 INPUT.
  IF ok_code = 'BACK'.
    DATA: l_row   TYPE i,
          l_value TYPE c,
          l_col   TYPE i,
          ls_row  TYPE lvc_s_row,
          ls_col  TYPE lvc_s_col,
          ls_roid TYPE lvc_s_roid.

    CALL METHOD g_grid->get_current_cell
      IMPORTING
        e_row     = l_row
        e_value   = l_value
        e_col     = l_col
        es_row_id = ls_row
        es_col_id = ls_col
        es_row_no = ls_roid.
    LEAVE PROGRAM.
  ENDIF.
ENDMODULE.                 " USER_COMMAND_0100  INPUT
*&---------------------------------------------------------------------*
*&      Module  STATUS_0100  OUTPUT
*&---------------------------------------------------------------------*
MODULE status_0100 OUTPUT.
  SET PF-STATUS '100_STATUS'.
*  SET TITLEBAR 'xxx'.

ENDMODULE.                 " STATUS_0100  OUTPUT
*&---------------------------------------------------------------------*
*&      Form  SETTING_LAYOUT
*&---------------------------------------------------------------------*
FORM setting_layout   CHANGING  p_layout TYPE lvc_s_layo.

  p_layout-cwidth_opt = 'X'.  "칼럼 길이 자동조절
  p_layout-grid_title = 'Exception Test'.  "타이틀 바
  p_layout-sel_mode = 'B'.  "선택모드 : 멀티 선택 가능
  p_layout-zebra      = 'X'.  "Sripe 속성 지정
  p_layout-excp_fname = 'LIGHT'. " Exceptions 필드 설정
*  p_layout-info_fname = 'LINECOLOR'. " Exceptions 필드 설정

ENDFORM.                    " setting_layout
*&---------------------------------------------------------------------*
*&      Form  SETTING_TOOLBAR
*&---------------------------------------------------------------------*
FORM setting_toolbar .
  DATA: l_exclude TYPE ui_func.

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

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

ENDFORM.                    " SETTING_TOOLBAR
*&---------------------------------------------------------------------*
*&      Form  SETTING_SORT
*&---------------------------------------------------------------------*
FORM setting_sort .
  DATA : ls_sort TYPE lvc_s_sort.

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

ENDFORM.                    " SETTING_SORT
*&---------------------------------------------------------------------*
*&      Form  SETTING_CATALOG
*&---------------------------------------------------------------------*
FORM setting_catalog .
  FIELD-SYMBOLS: <ls_fcat> TYPE lvc_s_fcat.

  LOOP AT gt_fieldcat ASSIGNING <ls_fcat>.

    IF <ls_fcat>-fieldname EQ 'MANDT'
    OR <ls_fcat>-fieldname EQ 'LIGHT'.
      <ls_fcat>-tech = 'X'.
    ENDIF.

    IF <ls_fcat>-fieldname EQ 'COUNT'.
      <ls_fcat>-coltext = '자격증 개수'.
    ENDIF.

  ENDLOOP.
ENDFORM.                    " SETTING_CATALOG
*&---------------------------------------------------------------------*
*&      Form  GETTING_CATALOG
*&---------------------------------------------------------------------*
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_EMPCERT'
      i_inclname         = sy-repid
    CHANGING
      ct_fieldcat        = lt_fieldcat[].

  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

번호 제목 글쓴이 날짜 조회 수
443 REPORT Z15_22 가능 2025.09.22 0
442 REPORT Z15_21 가능 2025.09.22 0
» REPORT Z15_20 가능 2025.09.22 0
440 REPORT Z15_19 가능 2025.09.22 0
439 REPORT Z15_18 가능 2025.09.22 0
438 REPORT Z15_17 가능 2025.09.22 0
437 REPORT Z15_16 가능 2025.09.22 1
436 REPORT Z15_15 가능 2025.09.22 0
435 REPORT Z15_14 가능 2025.09.22 0
434 REPORT Z15_13 가능 2025.09.22 0
433 REPORT Z15_12 가능 2025.09.22 1
432 REPORT Z15_11 가능 2025.09.22 0
431 REPORT Z15_10 가능 2025.09.22 0
430 REPORT Z15_09 가능 2025.09.22 1
429 INCLUDE Z15_08F01 가능 2025.09.22 1
428 INCLUDE Z15_08O01 가능 2025.09.22 0
427 INCLUDE Z15_08TOP 가능 2025.09.22 0
426 REPORT Z15_08 가능 2025.09.22 2
425 INCLUDE Z15_07F01 가능 2025.09.22 0
424 INCLUDE Z15_07O01 가능 2025.09.22 1