Skip to content

Latest commit

 

History

History

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

Exercise 5 - Adding a Micro Chart to the Table Building Block

In this exercise, we will add a micro chart column to the table building block.
The micro chart shall show the Customer VIP Status per booking, based on all cumulated bookings for the corresponding airline.
While the flexible programming model offers the means to adding it by using the building block micro chart and a custom column fragment,
the table per standard supports pure annotation based micro charts columns, which perfectly fits this use case.
As a rule of thumb, leveraging standard functionality should always be the preferred way of enhancing the UI, using extensions should be
the option of choice where the standard doesn't offer a certain functionality.
You can find an example implementation for a custom column and the building block micro chart in the Flexible Programming Model Explorer.

Exercise 5.1 Add Annotations UI.Chart and UI.DataPoint

The data required for the micro chart are already provided in the service model in file db/schema.cds (1) as an extension to the Booking entity (2).

mydevspace - SAP Business Application Studio - Google Chrome

The properties are annotated with @Core.Computed, which means that the values are calculated in a read handler implementation for entity Booking in file srv/travel-service.js (3), section Exercise 5: Data for Bookings table micro chart (4).

mydevspace - SAP Business Application Studio - Google Chrome

mydevspace - SAP Business Application Studio - Google Chrome

With the optional property Criticality, the coloring of the radial chart is defined.
In order to add a micro chart to a table, you have to define an annotation of type @UI.DataPoint. Its mandatory properties are value and a target value.
The data point needs to be referenced in the measure attributes of annotation @UI.Chart.
Chart type #Donut displays a radial chart. Properties Measures and MeasureAttributes are mandatory.

(5) Open file app/layouts.cds.

Scroll down to section Exercise 5: Booking entity Chart annotation and add the following code snippet:

annotate TravelService.Booking with @(
   UI: {
      Chart #RadialCriticalityPath            : {
          $Type             : 'UI.ChartDefinitionType',
          Title : 'Customer VIP Status',
          Description : 'VIP Customers are Eligible for Lounge Access',
          ChartType         : #Donut,
          Measures          : [BookedFlights],
          MeasureAttributes : [{
              $Type     : 'UI.ChartMeasureAttributeType',
              Measure   : BookedFlights,
              Role      : #Axis1,
              DataPoint : '@UI.DataPoint#RadialValuePath'
          }]
      },
      DataPoint #RadialValuePath              : {
          Value       : BookedFlights,
          TargetValue : to_Carrier.VIPCustomerBookings,
          Criticality : EligibleForPrime
      } 
  }
);

The screenshot shows annotations @UI.Chart (6) and @UI.DataPoint (7)

mydevspace - SAP Business Application Studio - Google Chrome

Exercise 5.2 Enhance UI.LineItem Annotation via Code Completion

With annotation @UI.Chart in place, we will now add it to annotation @UI.LineItem of entity Bookings.
For this, we will add a record of type DataFieldForAnnotation.
In file app/layouts.cds, scroll to section Exercise 5: add chart table column.

(8) Trigger code completion by pressing ctrl+space and select icon.

mydevspace - SAP Business Application Studio - Google Chrome

The annotation is added along with its basic structural elements.
(9) With the cursor inside the quotes ' ' of property Target, trigger code completion (ctrl+space) and select icon.

mydevspace - SAP Business Application Studio - Google Chrome .

Use code completion to add property Label and put Customer VIP Status inside the quotes.

(10) Trigger code completion again in order to add inline annotation ![@UI.Importance] : #High.

mydevspace - SAP Business Application Studio - Google Chrome

Annotation @UI.Importance makes sure that table columns are always displayed inline in case of small screen sizes.

The entered code snippet should match the following:

     {
         $Type : 'UI.DataFieldForAnnotation',
         Target : '@UI.Chart#RadialCriticalityPath',
         Label : 'Customer VIP Status',
         ![@UI.Importance] : #High,
     },

Exercise 5.3 Add Header Facet to Booking Supplements Page

We will now add the same chart as a header facet in sub object page Booking Supplements.
(11) In file app/layouts.cds, scroll to section Exercise 5: add chart header facet.

mydevspace - SAP Business Application Studio - Google Chrome

You can use code completion to add the following code snippet as shown in the above screenshot:

  HeaderFacets  : [
      {
          $Type : 'UI.ReferenceFacet',
          Target : '@UI.Chart#RadialCriticalityPath',
          Label : 'Customer VIP Status'
      },
  ],

Switch to the preview browser tab.
(12) On the Object Page, the table now shows the micro chart column.
(13) Click on a table line in order to navigate to the bookings supplement page.

Travel - Google Chrome

(14) The sub object page header now shows the same micro chart.

Bookings - Google Chrome

Summary

We've now successfully added a chart annotation to the service and added a micro chart column to the table
and a micro chart header facet to the sub object page.

Continue to - Exercise 6 - Flexible Programming Model:Using the Chart Building Block