Please check here my post on building SAP Fiori Elements Analytical List Page(ALP) in SAP Business Application Studio (BAS) and as a service I have used SAP’s ES5 demo gateway system service.
ALP consists of:
data:image/s3,"s3://crabby-images/9f4b5/9f4b56c4d7a0b713a5d09b9b2f1525c054f7bfa9" alt=""
Service used: https://sapes5.sapdevcenter.com//sap/opu/odata/IWBEP/GWSAMPLE_BASIC/ProductSet
Create a project using ALP template in BAS.
data:image/s3,"s3://crabby-images/ebc40/ebc40467e1de556c3a1677048db2bb5e5a308495" alt=""
Project Structure:
data:image/s3,"s3://crabby-images/60ae6/60ae6305757ff0288910a05dbeb494fc1c01f09b" alt=""
Right click on the project and open SAP Fiori tools – Open Guided Development.
data:image/s3,"s3://crabby-images/8520e/8520e044e8af723c2f4cba5140abe2ba1af2bcf1" alt=""
This would open up the guided development that can be performed wrt to ALP.
In this demo, i have explained on below highlighted annotations in filter and content areas of ALP.
data:image/s3,"s3://crabby-images/f3d01/f3d014cc4aadd129e109e4e55785c16f166ce048" alt=""
1. Add a new column to a table
data:image/s3,"s3://crabby-images/01ce7/01ce7c545778ff2a26f2f75818373b3f0a7418bd" alt=""
data:image/s3,"s3://crabby-images/349e5/349e5b697b37c1cbcf2e6c51d72fe1cbff2f2917" alt=""
data:image/s3,"s3://crabby-images/80f26/80f26872c0fdb40fab2050bb23f0442f938b3ff4" alt=""
This will add a new column to the table in content area of ALP.
Please repeat the same process to add more columns and check the annotations.
annotation.xml:
<Annotation Term="UI.LineItem">
<Collection>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="ProductID"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="Category"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="TypeCode"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="SupplierID"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="SupplierName"/>
</Record>
</Collection>
</Annotation>
2. Add an interactive chart:
data:image/s3,"s3://crabby-images/72a89/72a894bfc3b9f5e1c60cac89ca32d0db99429ac5" alt=""
data:image/s3,"s3://crabby-images/28f33/28f333bc90beb4280cb7c87cfb75c0821513c626" alt=""
data:image/s3,"s3://crabby-images/9bde2/9bde2c43294d6de56177aaa6dd188febf7b78ea6" alt=""
data:image/s3,"s3://crabby-images/7d902/7d902bee5387b6c2fa5260f4cf2e06dec51204f1" alt=""
annotation.xml:
<Annotation Term="UI.Chart">
<Record Type="UI.ChartDefinitionType">
<PropertyValue Property="Title" String="Products"/>
<PropertyValue Property="Description" String="Products and Suppliers"/>
<PropertyValue Property="ChartType" EnumMember="UI.ChartType/Column"/>
<PropertyValue Property="Dimensions">
<Collection>
<PropertyPath>SupplierName</PropertyPath>
</Collection>
</PropertyValue>
<PropertyValue Property="Measures">
<Collection>
<PropertyPath>TaxTarifCode</PropertyPath>
</Collection>
</PropertyValue>
</Record>
</Annotation>
3. Add a new filter field to the Filter Bar:
data:image/s3,"s3://crabby-images/10a00/10a006046995292a2c12c8e9a62378b1cd4010a1" alt=""
data:image/s3,"s3://crabby-images/edab3/edab30c2b8b7a7785345fb7abe9c884ab87098bd" alt=""
data:image/s3,"s3://crabby-images/5f787/5f787fbdb77e88233239a9604d4c6a0d4a77320e" alt=""
This will add a new filter to the filter area of ALP.
Please repeat the same process to add more filters and check the annotations.
annotation.xml:
<Annotation Term="UI.SelectionFields">
<Collection>
<PropertyPath>ProductID</PropertyPath>
<PropertyPath>SupplierID</PropertyPath>
<PropertyPath>SupplierName</PropertyPath>
</Collection>
</Annotation>
Here comes my end of blog. Below are the whole annotation.xml code and application preview.
annotation.xml:
<edmx:Edmx xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx" Version="4.0">
<edmx:Reference Uri="https://sap.github.io/odata-vocabularies/vocabularies/UI.xml">
<edmx:Include Namespace="com.sap.vocabularies.UI.v1" Alias="UI"/>
</edmx:Reference>
<edmx:Reference Uri="/sap/opu/odata/iwbep/GWSAMPLE_BASIC/$metadata">
<edmx:Include Namespace="GWSAMPLE_BASIC"/>
</edmx:Reference>
<edmx:DataServices>
<Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="sap.demo">
<Annotations Target="GWSAMPLE_BASIC.Product">
<Annotation Term="UI.LineItem">
<Collection>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="ProductID"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="Category"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="TypeCode"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="SupplierID"/>
</Record>
<Record Type="UI.DataField">
<PropertyValue Property="Value" Path="SupplierName"/>
</Record>
</Collection>
</Annotation>
<Annotation Term="UI.Chart">
<Record Type="UI.ChartDefinitionType">
<PropertyValue Property="Title" String="Products"/>
<PropertyValue Property="Description" String="Products and Suppliers"/>
<PropertyValue Property="ChartType" EnumMember="UI.ChartType/Column"/>
<PropertyValue Property="Dimensions">
<Collection>
<PropertyPath>SupplierName</PropertyPath>
</Collection>
</PropertyValue>
<PropertyValue Property="Measures">
<Collection>
<PropertyPath>TaxTarifCode</PropertyPath>
</Collection>
</PropertyValue>
</Record>
</Annotation>
<Annotation Term="UI.SelectionFields">
<Collection>
<PropertyPath>ProductID</PropertyPath>
<PropertyPath>SupplierID</PropertyPath>
<PropertyPath>SupplierName</PropertyPath>
</Collection>
</Annotation>
</Annotations>
</Schema>
</edmx:DataServices>
</edmx:Edmx>
Output
data:image/s3,"s3://crabby-images/46e22/46e2247680b5609543747bc3e195c76c9bfb25b2" alt=""