I’ll explain how to add (Me21n/Me22n/Me23n) customer fields for sales order on item basis.
1. Adding a New Field to the Database
i) Go to the CI_EKPODB table from the Se11 transaction code and add new field with the Append Structure button.
data:image/s3,"s3://crabby-images/ec4bd/ec4bdd8665214f2822387e261aee3b377daf8f84" alt=""
data:image/s3,"s3://crabby-images/3561e/3561e18b908126c7a8a7e1e291b25b72b3de195c" alt=""
ii) After activating the created Append Structure, the field will be added to the CI_EKPODB table.
data:image/s3,"s3://crabby-images/7e356/7e35675e85f5fc9eecb634239a296e09bb3568d5" alt=""
data:image/s3,"s3://crabby-images/8d556/8d556eaaaafd44404fb508e192338bb830c477d2" alt=""
2. Creating Tables and Structures to Use
i) From transaction code Se11 create a table like this;
- MANDT
- EBELN
- EBELP
- NEW FIELD
data:image/s3,"s3://crabby-images/a509f/a509fa935df15d6aa9b08b1a896043cff23686aa" alt=""
ii) From transaction code Se11 create a structure like this;
NEW FIELD
data:image/s3,"s3://crabby-images/935d0/935d0a6da382d4ee76f4090d5775ef302f73d96f" alt=""
3. Creating the Screen to Add to the Tab
i) A copy of the SAPLMEPOBADIEX Function Pool program from the SAP sample programs is created from the Se38 transaction code.
data:image/s3,"s3://crabby-images/63429/63429284e90e45a80a45389813a388d1a459e531" alt=""
ii) Create a screen for new field in the Function Pool program that created in the Se51 transaction code.
data:image/s3,"s3://crabby-images/9e9c2/9e9c277d08dda5a8c6a9f29d280ad430bd41c06f" alt=""
data:image/s3,"s3://crabby-images/feddc/feddc5565e2a5db0bafd878ab231343beeb82589" alt=""
-> Attention should be paid to the created screen is subscreen in the attributes tab.
data:image/s3,"s3://crabby-images/daa61/daa61d1024215097885ccf99a42291fa6b0b4597" alt=""
-> Event_pbo and event_pai modules are created from the Flow Logic tab.
data:image/s3,"s3://crabby-images/3a660/3a6602190d9a511e79b6b31b8d0a04858a7c1135" alt=""
iii) Organize the global data in the top include of the Function Pool program as follows.
data:image/s3,"s3://crabby-images/8fa6d/8fa6d8be1f13cc1b38d24518beb6bb35b3238685" alt=""
-> In lines 4 and 8, new definitions are given to the table created in Step 2.
-> In line 2, the structure created in Step 2 is given.
data:image/s3,"s3://crabby-images/80242/80242bd63d4bf4338b335fbdc5ca0e9ce6d606f0" alt=""
iv) Function Modules are organized by taking samples from the SAPLMEPOBADIEX Function Pool program that we copied.
data:image/s3,"s3://crabby-images/49554/495543c0d3a5c9d7dfb5e73b78bb8919f4dfde71" alt=""
a) MEPOBADIEX_GET_DATA
Import Parameter
- IM_EBELN type EBELN
- IM_EBELP type EBELP
Export parameter
1. EX_DATA type the table created in Step 2
-> The module copied for Source Code is used exactly, and the data of the field want to add is added by pulling it.
data:image/s3,"s3://crabby-images/11999/11999041326fd0386e7127f4fcd321df11a30aab" alt=""
CLEAR ex_data.
CHECK NOT im_ebelp IS INITIAL.
READ TABLE gt_data INTO ex_data WITH TABLE KEY mandt = sy-mandt
ebeln = im_ebeln
ebelp = im_ebelp.
IF NOT sy-subrc IS INITIAL.
SELECT SINGLE fiscal_year FROM ekpo INTO @DATA(lv_fiscal)
WHERE ebeln EQ @im_ebeln AND ebelp EQ @im_ebelp.
ex_data-mandt = sy-mandt.
ex_data-ebeln = im_ebeln.
ex_data-ebelp = im_ebelp.
ex_data-fiscal_year = lv_fiscal.
INSERT ex_data INTO TABLE gt_data.
ENDIF.
b) MEPOBADIEX_PUSH
Import Parameter
1. IM_DYNP_DATA type the structure created in Step 2
-> Source Code: Filled with the structure created in Step 2.
data:image/s3,"s3://crabby-images/54f7a/54f7afb67dfbde0cde57c1aa55f46603ac3d495e" alt=""
ZUD_FISCAL_YEAR_ST = im_dynp_data.
c) MEPOBADIEX_POP
Export Parameter
1. EX_DYNP_DATA type 2. Adımdaki Structure
-> Source Code: Export parameter filled with the structure created in Step 2.
data:image/s3,"s3://crabby-images/8bc69/8bc696c60d60ba55b1b2a37b0aa8c86c5d26e187" alt=""
ex_dynp_data = ZUD_FISCAL_YEAR_ST.
d) MEPOBADIEX_SET_DATA
-> Source Code; On line 30 it is mapped to new field.
data:image/s3,"s3://crabby-images/cf99b/cf99bd7747a8d2da311227e9454333e0bf74d5eb" alt=""
DATA: ls_data LIKE LINE OF gt_data.
FIELD-SYMBOLS: <data> LIKE LINE OF gt_data.
CHECK NOT im_data-ebelp IS INITIAL.
IF NOT im_physical_delete_request IS INITIAL.
DELETE TABLE gt_data WITH TABLE KEY mandt = sy-mandt
ebeln = im_data-ebeln
ebelp = im_data-ebelp.
ELSE.
READ TABLE gt_data ASSIGNING <data> WITH TABLE KEY
mandt = sy-mandt
ebeln = im_data-ebeln
ebelp = im_data-ebelp.
IF sy-subrc IS INITIAL.
<data>-fiscal_year = im_data-fiscal_year.
ELSE.
ls_data = im_data.
ls_data-mandt = sy-mandt.
INSERT ls_data INTO TABLE gt_data.
ENDIF.
ENDIF.
4. BadI Implemantation
i) From Se18 transaction code to ME_GUI_PO_CUST (classical) BadI;
Display -> Implementation -> Overview
-> If it does not exist, it is created or the existing one is used.
data:image/s3,"s3://crabby-images/7a7ad/7a7ad9cad546e5d59af6a2d3dd623618e13dbd98" alt=""
data:image/s3,"s3://crabby-images/ddeea/ddeea0b6c0cb9c1818183a15f58bdaaceabdde63" alt=""
ii) Changes are made for the class.
data:image/s3,"s3://crabby-images/0d66e/0d66e94dc3a416a97647c16cba0515612060c4cc" alt=""
Attribute:
- SUBSCREEN1 / Level: Constant / Visibility: Public / Type: MEPO_NAME / Initial Value ‘ITEMSCREEN1’
- DYNP_DATA_PBO / Level Instance Attribute / Visibility Private / Associated Type the structure created in Step 2
- DYNP_DATA_PAI / Level Instance Attribute / Visibility Private / Associated Type the structure created in Step 2
data:image/s3,"s3://crabby-images/312b6/312b6ba341dc22719c33b6e1101bad0827e30851" alt=""
iii) Necessary changes are made to show our new tab in the SUBSCRIBE method.
data:image/s3,"s3://crabby-images/66527/66527014420e84a4c76023259b353a86464e0160" alt=""
ls_subscriber-name = Attribute created
ls_subscriber-dynpro = Number of Screen Created in Se51
ls_subscriber-program = Name of Function Pool Program
ls_subscriber-struct_name = Structure in Step 2
ls_subscriber-label = Name to Display in Tab
ls_subscriber-position = Tab Position
data:image/s3,"s3://crabby-images/78c24/78c249beca77cf1dd9ed9c61b2279fcdc33d5469" alt=""
DATA: ls_subscriber LIKE LINE OF re_subscribers.
CHECK im_application = 'PO'.
CHECK im_element = 'ITEM'.
CLEAR re_subscribers[].
ls_subscriber-name = subscreen1.
ls_subscriber-dynpro = '0002'.
ls_subscriber-program = 'SAPLZMEPOBADIEX'.
ls_subscriber-struct_name = 'ZUD_FISCAL_YEAR_ST'.
ls_subscriber-label = 'Fiscal Year'.
ls_subscriber-position = 24.
ls_subscriber-height = 7.
APPEND ls_subscriber TO re_subscribers.
iv) MAP_DYNPRO_FIELDS Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/463cf/463cfdc54607037e3b1f833bd1bdcfa16fc81701" alt=""
-> In line 7, add the new field
-> In line 8, add the mapping field
data:image/s3,"s3://crabby-images/47ba7/47ba7d184a42844868900c822005d8ad6c7dcbde" alt=""
FIELD-SYMBOLS: <mapping> LIKE LINE OF ch_mapping.
LOOP AT ch_mapping ASSIGNING <mapping>.
CASE <mapping>-fieldname.
WHEN 'FISCAL_YEAR'.
<mapping>-metafield = mmmfd_cust_08.
ENDCASE.
ENDLOOP.
v) TRANSPORT_FROM_MODEL Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/61401/61401717b0101b8f994072602f03cafd80fc21e7" alt=""
-> In line 23, Add the created Function Module.
-> In line 32, Do the necessary changes for the new field
DATA: l_item TYPE REF TO if_purchase_order_item_mm,
ls_mepoitem TYPE mepoitem,
ls_customer TYPE ZUD_FISCAL_Y_T.
CASE im_name.
WHEN subscreen1.
mmpur_dynamic_cast l_item im_model.
CHECK NOT l_item IS INITIAL.
ls_mepoitem = l_item->get_data( ).
CALL FUNCTION 'ZMEPOBADIEX_GET_DATA'
EXPORTING
im_ebeln = ls_mepoitem-ebeln
im_ebelp = ls_mepoitem-ebelp
IMPORTING
ex_data = ls_customer.
MOVE-CORRESPONDING ls_mepoitem TO dynp_data_pbo.
MOVE ls_customer-fiscal_year TO dynp_data_pbo-fiscal_year.
WHEN OTHERS.
ENDCASE.
vi) TRANSPORT_TO_DYNP Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/58e9f/58e9fdc783a3720a6fa7541dfdce5fd615c77acf" alt=""
-> In line 7, Add the created Function Module.
data:image/s3,"s3://crabby-images/870dd/870dd6f35f7bb1fbd473a9a71e430dbf8ac333f2" alt=""
CASE im_name.
WHEN subscreen1.
CALL FUNCTION 'ZMEPOBADIEX_PUSH'
EXPORTING
im_dynp_data = dynp_data_pbo.
WHEN OTHERS.
ENDCASE.
vii) TRANSPORT_FROM_DYNP Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/2bef9/2bef9a7401105b6bcad7c6b2fd1bd2e9bbf3c01e" alt=""
-> In line 7, Add the created Function Module.
data:image/s3,"s3://crabby-images/3a092/3a092ff4534633d9408e0f6ce7241e8e7a799920" alt=""
CASE im_name.
WHEN subscreen1.
CALL FUNCTION 'ZMEPOBADIEX_POP'
IMPORTING
ex_dynp_data = dynp_data_pai.
IF dynp_data_pai NE dynp_data_pbo.
re_changed = mmpur_yes.
ENDIF.
WHEN OTHERS.
ENDCASE.
viii) TRANSPORT_TO_MODEL Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/ef42a/ef42a69cb5b91b5edaecfe059fce5c170f3e506a" alt=""
-> In line 21, 31 and 37, Do the necessary changes for the new field
-> In line 24 and 33, Add the created Function Module.
data:image/s3,"s3://crabby-images/275ff/275ff3043f13819a471c98f607d153808b8992c6" alt=""
DATA: l_item TYPE REF TO if_purchase_order_item_mm,
ls_mepoitem TYPE mepoitem,
ls_customer TYPE ZUD_FISCAL_Y_T.
CASE im_name.
WHEN subscreen1.
mmpur_dynamic_cast l_item im_model.
CHECK NOT l_item IS INITIAL.
ls_mepoitem = l_item->get_data( ).
IF dynp_data_pbo-fiscal_year NE dynp_data_pai-fiscal_year.
CALL FUNCTION 'ZMEPOBADIEX_GET_DATA'
EXPORTING
im_ebeln = ls_mepoitem-ebeln
im_ebelp = ls_mepoitem-ebelp
IMPORTING
ex_data = ls_customer.
ls_customer-fiscal_year = dynp_data_pai-fiscal_year.
CALL FUNCTION 'ZMEPOBADIEX_SET_DATA'
EXPORTING
im_data = ls_customer.
MOVE dynp_data_pai-fiscal_year TO ls_mepoitem-fiscal_year.
CALL METHOD l_item->set_data
EXPORTING
im_data = ls_mepoitem .
ENDIF.
WHEN OTHERS.
ENDCASE.
4. BadI Enhancement
i) Enhancement is done to ME_PROCESS_PO_CUST (enhancement spot) BadI from Se18 transaction code.
data:image/s3,"s3://crabby-images/cf560/cf5606dbca15094e184eec8175220aa34d0b7455" alt=""
-> For example codes, the class named CL_EXM_IM_ME_PROCESS_PO_CUST is used.
data:image/s3,"s3://crabby-images/79465/794657c6faf3e41dc2fd311193fa2edc7da2a4de" alt=""
-> A new enhancement is made or an existing one is used.
data:image/s3,"s3://crabby-images/ea794/ea794d1d9e6439b03673b58bd40a0d22cc5b8c95" alt=""
ii) FIELDSELECTION_ITEM Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/67482/6748287b402e67d8208dd88b56f5bddbc8b9ea64" alt=""
-> In line 22, add the mapping field
data:image/s3,"s3://crabby-images/4757f/4757f035ad5ca72c189324316cfd2b2d08561405" alt=""
DATA: l_changeable TYPE mmpur_bool.
FIELD-SYMBOLS:<fs_f> LIKE LINE OF ch_fieldselection.
l_changeable = im_header->is_changeable( ).
READ TABLE ch_fieldselection ASSIGNING <fs_f> WITH TABLE KEY metafield = mmmfd_cust_08.
IF sy-subrc = 0.
IF l_changeable = 'X'.
<fs_f>-fieldstatus = '.'.
ELSE.
<fs_f>-fieldstatus = '*'.
ENDIF.
ENDIF.
iii) PROCESS_ITEM Necessary changes are made in the method.
data:image/s3,"s3://crabby-images/6d91c/6d91c9c038698d1e845250a21bf7727ca1cffc58" alt=""
-> Make a selection according to the field added and edit the 94th line.
data:image/s3,"s3://crabby-images/bbabd/bbabdfaa1a15270fa1b807b31a775d92df2d2eeb" alt=""
DATA: lwa_mepoitem TYPE mepoitem.
DATA ls_ekpo TYPE uekpo.
DATA ls_eban TYPE eban.
DATA lt_eban TYPE TABLE OF eban.
DATA: gt_conn TYPE TABLE OF toav0,
gt_conn_av TYPE TABLE OF toav0,
gs_conn TYPE toav0,
gs_toa01 TYPE toa01,
lw_banfn TYPE banfn.
CALL METHOD im_item->get_data
RECEIVING
re_data = lwa_mepoitem.
SELECT SINGLE fiscal_year FROM ZUD_FISCAL_Y_T
INTO @lwa_mepoitem-fiscal_year
WHERE ebeln = @lwa_mepoitem-ebeln
AND ebelp = @lwa_mepoitem-ebelp.
IF sy-subrc EQ 0 AND lwa_mepoitem-fiscal_year IS NOT INITIAL.
CALL METHOD im_item->set_data
EXPORTING
im_data = lwa_mepoitem.
ENDIF.