Skip to content

Latest commit

 

History

History
 
 

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

solution demo

Exercise 3 - Show Sensor Content

In this exercise you'll add a local data service to the application and display the data on the enhanced UI5 view.

Exercise 3.1 - Import Sensor Data

To simulate a source providing sensor data, you'll now add some sensor data to your application.

  1. Go to folder sensormanager/webapp/localService.

  2. Right-click on the localService folder.

  3. Select New File.



  4. Enter sensors.json as file name.



  5. Copy and paste the content of sensors.json into the newly created file.

Exercise 3.2 - Configure a Data Service

After adding the sensor data to your application, you'll need to configure the data service which provides the sensor data.

  1. Open the manifest.json file located under sensormanager/webapp.

  2. Go to the section sap.app. Here, you add a new dataSources section containing a data source with name sensorSource, which points to the sensor data.

sensormanager/webapp/manifest.json

    "sap.app": {
        ...,
        "dataSources": {
            "sensorSource": {
                "type": "JSON",
                "uri": "./localService/sensors.json"
            }
        }
    }
  1. Go to the section sap.ui5. Here, you add a new JSONModel with name sensorModel, which points to the newly created data source.

sensormanager/webapp/manifest.json

    "sap.ui5": {
        "models": {
	        ...,
            "sensorModel": {
                "type": "sap.ui.model.json.JSONModel",
                "dataSource": "sensorSource"
            }
        }
    }

Exercise 3.3 - Add a GridList

After configuring the data service, it's now time to enrich your Sensors.view.xml with some fancy UI5 controls!

  1. Open the Sensors.view.xml located under sensormanager/webapp/view.

  2. Add sap.f and sap.ui.layout.cssgrid to the xml namespace declarations to make sure that the required resources are available in your view.

sensormanager/webapp/view/Sensors.view.xml

<mvc:View
    xmlns:mvc="sap.ui.core.mvc"
    xmlns="sap.m"
    xmlns:grid="sap.ui.layout.cssgrid"
    xmlns:f="sap.f"
    displayBlock="true">
  1. Add sap.f.GridList to the content aggregation of the IconTabBar. An aggregation is a relation between two UI elements. It is used to define the parent-child relationship within the tree structure. The child end of the relation may have cardinality 0..1 or 0..*. The elements' API offers convenient and consistent methods to deal with aggregations (e.g. to get, set, or remove child elements). Examples are table rows and cells, or the content of a table cell.

sensormanager/webapp/view/Sensors.view.xml

                    <f:GridList id="sensorsList" noDataText="No sensors">
                        <f:customLayout>
                            <grid:GridBoxLayout/>
                        </f:customLayout>
                        <f:items>
                            <CustomListItem>
                            </CustomListItem>
                        </f:items>
                    </f:GridList>
  1. Switch browser tabs and refresh to see the updated UI5 application.



Exercise 3.4 - Add Data Binding

After adding the sap.f.GridList control, you'll need to connect the control to the sensor data. For this, UI5 provides a mechanism called Data Binding.

  1. Open the Sensors.view.xml located under sensormanager/webapp/view.

  2. Bind the items aggregation of the sap.f.GridList to the path sensorModel>/sensors. Here, sensorModel is the name of your recently defined data model, and /sensors points to a property inside it. As this is an array with several entries, you'd probably like to define sorting and grouping as well. In the sorter you can configure this by using the properties available:

sensormanager/webapp/view/Sensors.view.xml

                    <f:GridList
                        id="sensorsList"
                        items="{path: 'sensorModel>/sensors', sorter: {path:'customer', group:true, descending: false}}"
                        noDataText="No sensors">
  1. The list items are defined once as a template, which is then repeated multiple times to represent each entry of the sensors array. We also add some location details to our sap.m.CustomListItem. Here, location references the location property of each of the displayed sensor items.

sensormanager/webapp/view/Sensors.view.xml

                            <CustomListItem>
                                <Title text="{sensorModel>location}"/>
                            </CustomListItem>
  1. Let's see if our UI5 application displays the correct sensor data. Switch to the browser tab with the opened application preview and reload the page.



Summary

Congratulations! You've completed successully Exercise 3 - Show Sensor Content.

Continue to Exercise 4 - Introduce Localization.

Further Information