Creating VOFM custom routine, functionality same as SAP standard routine 103 with Additional Functionality
1.1 Document Purpose
1.2 This is the document helps you to create custom routine for sales order for below specific requirement:
In case of sale order with the SD document category ‘K’ or ‘L’ or ‘H’ related to an invoice, we need to fill the fixed value date (VBKD_VALDT) with the billing reference date (VBRK_FKDAT).
Invoice 90001111, the billing date is 22.07.2013
If we create a sale order related to this invoice, we want the fixed value date equal to the billing reference date.
As per the requirement:
Sap standard routine ‘103’ triggers whenever sales order is being created with reference. Sap standard routine is configured in VOFM transaction as:
Sap standard routine ‘103’ has the functionality of copying the billing document header data and billing document line item data into the sales order header data, whenever sales order is being created using reference document.
Note: To achieve this requirement we can also enhance the SAP standard routine 103 but here they need the custom routine because it will be configured on demand basis by client whenever they need it.
About VOFM Transaction:
Transaction VOFM is a tool that was developed in R/3 to facilitate the definition of both SAP delivered as well as customer defined routines/rules used in the system during various business processes. VOFM routines are ABAP code written in Forms. VOFM provides the user with the benefit of choosing from one of the standard delivered R/3 routines or writing their own. VOFM is intended for the implementation team when configuring the system. It is not intended for the end user.
Here we have four important menus:
i) Copying requirements
ii) Data transfer
Steps to create the custom routine:
1) Go to transaction VOFMàData transferà Orders
2) Provide a custom routine name
VOFM routines are organized using the Group Indicator Code. The VOFMprogram uses
the group indicator to determine the program include and subroutine names when it
dynamically creates these objects. The assignment of these names is hard coded in the program.
The valid group indicator codes are defined in data base domain GRPZE using a value range.
Go to transaction ‘VOFN’ place the cursor on class input and press ‘F1’ key.
Now double click on data element and see the domain values as:
All the fixed values are Group Indicator Code.
· Standard SAP routine name starts from 1 to 599.
· So all custom name starts from 600 to 999.
Now provide the custom routine name and press enter, it will ask for access key:
Once the access key provided a include program get generated with transport request as:
All include program generated from Routine has an entry in table TFRM (Form Routines for Requirements/Formulas/Data Transports) and TFRMT (FORM Routines for Reqs./Formulae/Data Transports: Texts).
1) Double click on the custom routine 901
A modification message appears as:
Now place the cursor at the end of the ENDFORM and click on the insert button to write our own code as shown below:
On clicking insert button we have the area for writing our code with *(INSERT,, *) INSERT as:
Along with code for standard routine 103, the code marked in red is the additional for this specific scenario has been used.
The billing date has been copied also in VBRK value date which also gets copied into VBKD.
The standard SAP program for creating the sales order using reference document checks for all values and if found any difference between CVBRK and VBKD, it creates an additional entry for VBKD. For that reason in this scenario fixed value date is also copied into CVBRK.
Once the coding is over we need to activate the custom routine 901 and include program generated.
For confirming the same we need to check the entries in TFRM table as:
The Billing Document ’90000112’ has been used to create the Sales order :
It has the fixed value date : 22.07.2013
Now following steps has been taken to create the sales order using billing document as follows:
In VA01 transaction for a given order type(ZRD) when sales order has been created with Reference
Reference document has been taken as billing document(9000112) as mentioned above.
After clicking on the copy option, a screen will open having the information of the sales order.
Program RV80HGEN can be used to re-generate all VOFM routines. Whenever VOFM
routines are transported this program should be executed in all target systems. It is
possible to include an automatic execution of the program in the transport request by
applying OSS note 598475.
It can be added to the transport request of the custom routine include as:
Double click on the transport request
Open it in change mode and provide input as shown below:
And press enter and save.
So when this transport is sent to target system then it gets executed automatically.
Even if it does not work then we need to run SAP standard program ‘RV80HGEN’ manually in the target system.
Activation OR Deactivation Of Custom Routine:
Sometimes while transporting the entries in table TFRM or TFRMT does not exists in target system. In this case we need to run the standard SAP program RV80HGEN first and then Standard SAP program SDINVOFM used to identify and repair missing table entries in the VOFM control tables TFRM and TFRMT.
We can also activate and deactivate our custom routine from VOFM as: