Technical Articles
SAP S/4HANA Business Partner Field Enhancement
In most of my Business Partner workshops I was asked the question: How shall we handle our Z-Fields from Customer/Vendor Master Data in Business Partner transaction.
Short Answer: You have to rebuild the fields in Business Partner transaction.
In this Cookbook I’ll guide you step by step to implement a Z-Field from table KNA1 into Business Partner transaction.
How to add a bunch of Z-Fields on a custom tab in BP transaction, you can learn at blog post SAP S/4HANA BP screen enhancement with custom tab written by Badrinath Ravi.
Introduction
Purpose and target
The purpose of this document is to describe how to implement a BDT enhancement. A field from table KNA1 has to be re-implemented in Business Partner transaction as well to ensure availability in SAP S/4HANA.
Remark: This procedure can be used for all the single fields from Customer or Vendor tables. This Cookbook is not made for fields related to Table Controls as of partner assignment for example from KNVP.
Foundation for this document is SAP note
Target audience: Functional expert, Development expert
Version: SAP S/4HANA On premise 1610 and higher
There is a field in table KNA1 which was available in XDxx transaction.
In case you are adding this field completely new, don’t forget to mark for Change Document at Data Element level to track changes at this field.
This field has to be re-implemented in SAP S/4HANA to be available in transaction Business Partner with customer role.
Implementation
Determine Area in Business Partner transaction where to place the new field
In this example the field should be placed in customer role, tab (Screen) ‘Customer: General Data’, Section ’ Additional General Data’
- Run transaction BP and navigate to role ‘Customer’->tab ‘Customer: General Data ’New field should be placed directly below the field ‘Plant’. To determine screen control settings of BDT, place the cursor into field plant and enter OK-Code BDT_ANALYZER into transaction field
- BDT_ANALYZER is starting and gives information about screen control. For later assignment of new view the following information is important:Navigate to
Section CVIC45- Additional General Data
and open folder viewsNote down section number (for example CVIC45) - To get View details navigate into view CVIC62 by clicking on name CVIC62Note down
Application: CVIC
Differentiation Type: 0
Data Set: CVIC11
Create Technical Objects
Create Function Group
- Run Object Navigator with transaction SE80
Create PBO Function Module
- From context menu of new Function Group choose Create-> Function Module
- Enter name, Function Group and Short Text of new Function Module
- Enter Coding
function z_cvic_bupa_pbo_zvic01. *"---------------------------------------------------------------------- *"*"Local Interface: *"---------------------------------------------------------------------- data: lt_kna1 type table of kna1, table_name_kna1 type fsbp_table_name value 'KNA1'. * step 1: request data from xo for dynpro structure cvi_bdt_adapter=>data_pbo( exporting i_table_name = table_name_kna1 importing e_data_table = lt_kna1[] ). if lt_kna1[] is initial. clear gs_kna1. else. read table lt_kna1 into gs_kna1 index 1. endif. endfunction.
Save and activate
Create PAI Function Module
- From context menu of new Function Group choose Create-> Function Module
- Enter name, Function Group and Short Text of new Function Module
- Enter Coding
FUNCTION z_cvic_bupa_pai_zvic01. *"---------------------------------------------------------------------- *"*"Local Interface: *"---------------------------------------------------------------------- DATA: false TYPE boole-boole VALUE ' ', lt_kna1 TYPE TABLE OF kna1, table_name_kna1 TYPE fsbp_table_name VALUE 'KNA1'. FIELD-SYMBOLS: <kna1> LIKE LINE OF lt_kna1. CHECK cvi_bdt_adapter=>is_direct_input_active( ) = false. * step 1: update xo memory from technical screen structure cvi_bdt_adapter=>get_current_bp_data( EXPORTING i_table_name = table_name_kna1 IMPORTING e_data_table = lt_kna1[] ). IF lt_kna1[] IS INITIAL. IF gs_kna1 IS NOT INITIAL. gs_kna1-kunnr = cvi_bdt_adapter=>get_current_customer( ). APPEND gs_kna1 TO lt_kna1. ENDIF. ELSE. READ TABLE lt_kna1 ASSIGNING <kna1> INDEX 1. <kna1>-zcust = gs_kna1-zcust. ENDIF. cvi_bdt_adapter=>data_pai( i_table_name = table_name_kna1 i_data_new = lt_kna1[] i_validate = false ). * step 2: check fields CHECK cvi_bdt_adapter=>get_activity( ) <> cvi_bdt_adapter=>activity_display. * SPACE to implement own PAI checks ENDFUNCTION.
Save and activate.
Create Technical Screen
- From context menu of new Function Group choose Create-> Function Module
- Enter screen number
- Enter screen attributes
Short Text and type Subscreen - Navigate to Layout (Screen Painter)
- Create Text Field ‘End-Customers’
- Accept dictionary reference proposal
- Create Input field at position 25
- Define Field as NUMC via double click at field!!! Pay attention to field format. This must fit to format of field in table KNA1. !!!
- Activate the new object and close Screen PainterNavigate to screen Flow Logic
- Assign PBO Module
- Create PBO Module with double click at pbo
Enter sub routine pbo - Create sub routine pbo with double click at pbo
Enter coding*&---------------------------------------------------------------------* *& Form PBO *&---------------------------------------------------------------------* *& text *&---------------------------------------------------------------------* *& --> p1 text *& <-- p2 text *&---------------------------------------------------------------------* FORM pbo . call FUNCTION 'BUS_PBO'. ENDFORM.
- Assign PAI Module
- Create PAI Module with double click at paiEnter sub routine pai
- Create sub routine pai with double click at paiEnter coding
*&---------------------------------------------------------------------* *& Form PAI *&---------------------------------------------------------------------* *& text *&---------------------------------------------------------------------* *& --> p1 text *& <-- p2 text *&---------------------------------------------------------------------* FORM pai . call FUNCTION 'BUS_PAI'. ENDFORM.
Extend Complex Interface CVIS_EI_EXTERN
To ensure data transportation from Business Partner to Customer master data the complex interface of CVI has to extended by the additional field.
- Open ABAP Dictionary run transaction SE11 and enter data type CVIS_EI_EXTERN
- Use forward navigation to reach customer’s central data using double click
- Both structures DATA and DATAX needs to get an append
- Create append to DATA structure typeNavigate into structure with double click
- Create Append structure ZKNA1_ENH
- Add structure component and component type as definition in KNA1
- Save and Activate changes
- Navigate back to Structure CMDS_EI_CMD_CENTRAL
- Create append to DATAX structure typeNavigate into structure CMDS_EI_VMD_CENTRAL_DATA_XFLAG with double click
- Create an Append Structure ZKNA1_ENHX
- Add structure component ZCUST component type BAPIUPDATE
- Save and activate changes
- Leave transaction SE11
Customizing settings in BDT
Create Field Group
- Open BDT menu using BUPT in OK-Code field
- Navigate to Screen Layout section and open Field Groups
- Create a new Field Group in Customer Name space
- Create Field Group 600
Function Module CVIC_BUPA_EVENT_FMOD2_ENH is used to determine field control (mandatory, hidden, …) from customizing - Assign fields from technical screen to field group
Save your changes
Create View
- Navigate to Screen Layout section and open Views
- Create a new View and take Values from Chapter ‘Determine Area in BP transaction where to place the new field’. Use technical screen program name and number from chapter ‘Create Technical Screen’ Use PBO and PAI function module names from chapters ‘Create PAI Function Module’ and ‘Create PBO Function Module’
- Assign Field Group to View
- Save your changes
Assign View to Section
- Navigate to Screen Layout section and open Sections
- Position Cursor on Section determined in Chapter ‘Determine Area in BP transaction where to place the new field’
- Mark Section and choose Section->View Assignment from navigation tree
- Choose New Entries
- Enter data for new assignmentUse View number from Chapter ‘Create View’
Save the data
Test
- Start Transaction BP
- Search for a customer
- Display the customer
- Select role ‘Customer’
- Navigate to tab ‘Customer: General Data’
Conclusion
With this guidance you are able to implement additional fields at Business Partner transaction on your own.
Fiori App Extension
To Extent Fiori Apps please have a look at following blog posts:
Create Custom fields for Business Partner SAP Fiori screens in SAP S/4HANA
SAP Fiori for SAP S/4HANA – How to extend a SAP Fiori app in SAP S/4HANA
Hmm, back to the BP bare-bones... Whatever happened to the "Easy Enhancement Workbench, (no less)" 🙂
Hi Andi,
I have a question around BP datasets missing in ERP SAP_APPL 617 Sp 0018. I see that a lot of standard Customer and Vendor fields are missing from the datasets / field groups / views and are not available on the BP. Is there any add_on / Note / SP which can help with the bringing this content into the our environment?
Hi Andi,
is there a cookbook also to do the same for BP IC Web Client views? How can I add KNA1 fields to the BP master data table BUT000? In our current project, the SAP GUI is no longer used by the IC agents, they use the IC Web Client instead.
Thanks!
Mireille
how can we implement the same using in-app extensibility ? any pointer please
Hi jyothir,
please have a look into https://blogs.sap.com/2018/01/10/leading-s4hana-ux-how-to-extend-a-sap-fiori-app-in-sap-s4hana/comment-page-1/#comment-501965
Best Regards
Andi
Hi Andi,
Nice blog.
Point 2 is not clear, "Create a new ViewTake Values from Chapter ‘Determine Area in BP transaction where to place the new field’" . From where are you referring these chapters.
Regards
Mohinder
Hi Mohinder,
Application is a given one due to customer integration.
Dataset is given by the other views closed to the place of new view.
Best Regards
Andi
Hi Experts,
I have some problem here, i already enhanced custom field following all of step above, but when i change / update data with existing BP, the data from custom field can not be change. Please help.
Thank you,
Indro
Hello Andi,
I tried to implement z-fields following your guide ahead. But I get an error when creating PBO / PAI function modules as the global structure gs_kna1 is not available. And as the function modules do not have any import parameters I am wondering how this can work. Can you please advice?
Thanks in advance,
best regards, Stefan
Just go in that function group to the “Includes” section in the object list.
There must be a “TOP-Include”. In that top-include you can declare these structures.
DATA declarations in top-include
KR,
Steffen
Hi Andi,
I have created a custom field in BP transaction against Company code > Customer: Payment Transaction screen . I have done all the configuration through BUPT. Issue is that the custom field is not getting saved in KNB1 table.(KNB1 table is enhanced with custom field)
Could you please help me .
Thanks,
Karuna
Is your issue resolved, i am also facing same issue
Hi Andi,
Thanks for your effors. It was a very enlightening article. I also adapted it for the KNVV table and succeeded.
Thanks.
Omer
Hi Andi Mauersberger,
Thanks for wonder document. It helped me a lot to add a field in BP.
Thanks,
Vadivuckarasi
Hello Andi, please look at my question here.
CVI between BP and Customer. | SAP Community
Thank you.
Andi Mauersberger
Thank you for details step. I would like to update the custom field in table UKMBP_CMS (SAP Credit Management: Credit Master Data for Partner) in BP transaction. I have added field on screen and tried but no luck to get it update.
Do you have any input on this how to update the credit profile tab custom fields.
Your response will be highly appreciated.
Thanks in Advanced,
Thanks & Regards,
Yogesh Bagul
Hi Yogesh,
Is your issue resolved? i am also facing same issue
Hi Andi,
I need a requirement to add couple of Z fields to Table control in BP .
Exactly to say in BP--> Credit management--> Control Data--> External credit information
Can you please let me know how can we add those Z-fields using BDT.
Regards
Raghavendra
Hi Raghavendra,
I need to do the same but in Payment Transactions folder, at Bank Details table control. If you solve it can you share some guidelines with me?
Thanks in advance and kind regards.
Marcela.
Nice blog. It worked 100% for me when I was adding a custom field in Billing tab for BP role Customer. Thanks for sharing.
In section Customizing settings in BDT, item 5 (Assign fields from technical screen to field group), please be aware that the system will issue warnings that these fields do not exist in screen. And if you insist the warnings become error messages. I got stuck there for some time without knowing how to get passed, but I managed to save it and get by.
Are you able to update the data?
Hi Andi and everybody else,
I have the need to add two fields to the section Conditions on the Purch. org. data screen.
It was easy to follow Andi's instruction and I think I have defined the view correctly - I can click on the "Screen painter" button there and see my Dynpro. I think I also linked the view correctly - the same application CVIV and the data set CVIV06 as for the view CVIV76 Purchase order currency which also exists in the section Conditions.
If I put a break-point in the PBO module of my custom screen, the dubugger gets there. The Dynpro is also generated correctly.
But still the new fields won't show on the BP screen. Any idea what can be wrong please? Maybe the fields need to be activated in some "Field status" option in IMG?
TIA
Raf
Hi Andi,
thank you very much 🙂
Vasek
Hi Andi ,
I followed all the steps in order and the z field was added, but it does not detect the changes I have made, it gives the message "no changes have been made" and it does not write to the kna1 table, what am I doing wrong?
Hi Hüseyin,
it seems that your changed field data was not 'transported' into table structure. Please double check blog section 'Create PAI Function Module' and check assignment to your view definition.
Andi
thank you very much i solved the problem my own fault
Hi Huseyin,
Please let me know how the issue was fixed. I am stuck with the same. Made changes as per blog, Data not updated to LFM1 table. Suggest your inputs
Hi Andi,
I am facing issue with saving data from bp with custom fields. Please suggest
Excellent article, thank you so much!
I made the implementation, but the Z field is open for change, even though it is in the display module. What can it be?
Please, check the settings in customizing under:
Cross-Application Components > SAP Business Partner > Business Partner > Field Groupings:
- Configure Field Attibutes per BP Role