Quantcast
Channel: SCN : Blog List - SAP Fiori
Viewing all articles
Browse latest Browse all 230

Currency example - how Smart field works

$
0
0

What is smart field


According to SAP help, "Smart controls are a specific category of SAPUI5 controls that have some special features in addition to the standard SAPUI5 features and thus make it easier to use the control in certain scenarios. One important building block of smart controls is the SmartField control that, depending on the OData metadata defined, allows you to renders other controls and, for example, define fields with certain attributes based on the metadata."


All the source code of this example could be found from this link.


In xml view definition, only one SmartLabel and one SmartField are declared.

clipboard1.png

However, in rendered UI, there is additional currency field displayed as well. This is the meaning of "Smart".

clipboard2.png

How SmartField works

 

1. SmartField which is bound to Price field is rendered as usual:

clipboard3.png

2. The mock data, Products.json, will be loaded by Mock server and once it is available, success callback is triggered.

clipboard4.png

3. In callback, setElementBindingContext will trigger initialization logic of SmartField:

clipboard5.png

clipboard6.png

4. Here ODataControlFactory will try to get all sap defined annotation from OData Metadata,

clipboard7.png

The picture above highlights some of sap annotations. For a complete list of them, please refer to this link.

Parse logic of all annotations could be find from AnnotationHelper.get<Annotation name>. The example below introduces how sap:unit annotation is parsed.

clipboard9.png

clipboard10.png

The string "CurrencyCode" is returned:

clipboard11.png

At this time, metadata for currency UI element is available and it is ready for creation:


clipboard12.png

5. UI element for currency code display is created here:

clipboard13.png

And CSS class sapUiCompSmartFieldUnit is added:

clipboard14.png


Viewing all articles
Browse latest Browse all 230

Latest Images

Trending Articles



Latest Images

<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>