Field Extensions in a Fiori Applications is the most common requirements in many S/4 HANA projects. However this blog will focus on the RAP based Standard Fiori app Extensions for the Custom /Standard Fields.
The below flow charts will illustrate the different decisions and possibilities in extending the custom fields/standard for a RAP based Fiori applications
data:image/s3,"s3://crabby-images/1ff35/1ff357ea2450e74ade2dcb75dbd423faae3bfcd0" alt=""
data:image/s3,"s3://crabby-images/9df1d/9df1d85f652ebb0e7c9bab3cd9bd30fa281fb7b2" alt=""
Custom field extension for a Managed Scenario:
Let us extend a custom field for the below Fiori application.
https://fioriappslibrary.hana.ondemand.com/sap/fix/externalViewer/#/detail/Apps(‘F4710’)/S24OP
- As per the above flow chart check if there is any business context available for this application, if found create a custom field as shown below and enable the app context in any available
data:image/s3,"s3://crabby-images/a3fb1/a3fb168122852e4ea54b7e0f56d34884cece4813" alt=""
data:image/s3,"s3://crabby-images/72d7d/72d7d86dad760aad604612882ccd51a80f91c2ba" alt=""
data:image/s3,"s3://crabby-images/b223b/b223be614c2538b725b6fa21ba1d903c54449efb" alt=""
- Now go and Verify the CDS Entity if the Extended Custom field is visible as a CDS extension ?
- Navigate to the CDS View entity from the Service Binding UI_PROMISETOPAY_MANAGE
data:image/s3,"s3://crabby-images/37ded/37ded04f62f151e0e8a4d10b32950c742cbbbe76" alt=""
data:image/s3,"s3://crabby-images/04102/041026be64ffd0667214a30d44a01303cb5bf855" alt=""
- Now verify if the field is available in the Fiori application Manage Promises to Pay
data:image/s3,"s3://crabby-images/fa2a9/fa2a9bf79dda56b18f860a7f8ae0bbd4d4f38395" alt=""
Thus you can extend the custom field in Managed scenario of RAP
Standard field Extension in an Un Managed Scenario:
Let us extend the below Un-Managed Application Process Receivables ( Version 2 )
https://fioriappslibrary.hana.ondemand.com/sap/fix/externalViewer/#/detail/Apps(‘F0106A’)/S24OP
Let us try to add some additional fields which are missing in the below Invoices tab in the object page of the application:
data:image/s3,"s3://crabby-images/df4c2/df4c2ebdbdb361e1f289ade2ee431cdf205183a8" alt=""
- Now let us verify the CDS Entity behind the Invoices tab and extend it with the missing standard field as shown in the below example
data:image/s3,"s3://crabby-images/e9f96/e9f96dbce5587b23a0c6c1cae487479a8c8cd4ec" alt=""
extend view entity R_CollectionsInvoiceTP with
{
_OperationalAcctgDocItem.PaymentTerms as paymenterms
}
- Now lets test if this CDS extension works in case of Un-Managed Scenario. As we see below the field is extended however the value is filled as empty as this is a implemented via a query class.
data:image/s3,"s3://crabby-images/1962f/1962fa2a968c9dddbdda6d596094b3b36c9c2af8" alt=""
and the Fiori app is extended now to show the standard field
data:image/s3,"s3://crabby-images/746aa/746aa04758c0ad9acb4369396155336c7f30d74c" alt=""
- Now let us verify if this is a dynamic or a static/BAPI call in the query class to fetch the data.
data:image/s3,"s3://crabby-images/f7a7c/f7a7c923b6d779b60bf11a1216df708c7fed04c9" alt=""
data:image/s3,"s3://crabby-images/d20a8/d20a88b30a0a752802067c2e35ba9a36a11023f5" alt=""
data:image/s3,"s3://crabby-images/79765/79765bf46122c3f38dabad783f9debbc294e9dfb" alt=""
- From the above screenshots its evident that the query is class is using a CDS view P_COLLECTIONSINVOICEMEMORY to fetch the data and fill the fields that is the reason why table @rt_Data is not filled with data even tough the custom entity shown the field.
- Next step is extend the P_COLLECTIONSINVOICEMEMORY CDS view to get the payment terms field.
@AbapCatalog.sqlViewAppendName: 'ZI_invmem'
@EndUserText.label: 'CDS Extension for Invoice'
extend view I_CollectionsInvoiceMemory with Zi_collinvmem
{
_OperationalAcctgDocItem.PaymentTerms as PaymentTerms
}
@AbapCatalog.sqlViewAppendName: 'zp_collext'
@EndUserText.label: 'CDS Extension for Invoice'
extend view P_CollectionsInvoiceMemory with ZP_coll_Ext
{
PaymentTerms
}
After Extended the Query CDS view with the required field now the Fiori Application shows the values during the execution after refresh:
data:image/s3,"s3://crabby-images/e49fb/e49fbbb6619b1c354587b62b692ef3fbfc27373c" alt=""
Thus you can extend RAP based application for both custom /standard fields for both Managed and Un-managed scenarios