Create Fiori List App Report with ABAP CDS view – PART 1
From Create Fiori List App Report with ABAP CDS view – PART 1
In this blog, I am going to show How CDS view can be used to generate a Fiori List App Report. Below are the steps that need to be implemented to generate Fiori List App Report.
- CDS annotations for Fiori List Report.
- How to create a Gateway service from ABAP CDS view
- How to create a Fiori List App report in Web IDE.
- How to Deploy the Fiori Application.
- Create a Custom Semantic Object.
- Create a Tile in Fiori.
- Adding Tile from Catalogs –> Groups.
So Lets Begin with….
1. CDS view with Annotations for Fiori List Report:
Make sure you set @OData.publish annaotation set to True in order to enable the service to Fiori.
Also you can set below CDS view annotation for UI interface.
@UI.HeaderInfo – to display the header information for the list report.
@UI.selectionField.position – this is for filter option
@UI.lineItem.position – This is for Positioning the filed in the Report Layout
@UI.hidden – If you want to hide the filed in Fiori side
@UI.lineItem.exclude – If you want to exclude the filed in Report Layout by default.
and many more…..
You must use Associations in order to bring Value help feature in filters.
Below is the sample CDS view code with UI Annotations, OData, Associations etc.,
@AbapCatalog.sqlViewName: 'ZDEMOCOMPWHR'
@AbapCatalog.compiler.compareFilter: true
@VDM.viewType: #CONSUMPTION
@OData.publish: true
@EndUserText.label: 'Fiori - Demo List Report App' @UI.headerInfo: {
typeName : 'Demo List Report App' ,
typeNamePlural: 'Demo List Report App' } define view ZDEMO_COMP as select from ZDEMO_COMPWHR association [0..1] to I_Material as _Material on $projection.KMAT = _Material.Material
association [0..1] to ZCX1_PRO_OWNER as _OWNER on $projection.Owner = _OWNER.owner { @UI.selectionField.position: 20
@Consumption.valueHelp: '_OWNER'
//@UI.lineItem.position: 10
@EndUserText.label:'Owner'
Owner, _OWNER, @UI.selectionField.position: 30
@Consumption.valueHelp: '_Material'
//@UI.lineItem.position: 20
@EndUserText.label:'KMAT (Material)'
KMAT, _Material, //@UI.lineItem.position: 30
@EndUserText.label:'Sequence'
sequence, //@UI.lineItem.position: 40
@EndUserText.label:'Characteristic 1'
Characteristic1, //@UI.lineItem.position: 50
@EndUserText.label:'Characteristic Value 1'
CharacteristicValue1, @UI.selectionField.position: 70
//@UI.lineItem.position: 510
@EndUserText.label:'Valid To'
@UI.lineItem.exclude: true
@Semantics.businessDate.to: true
//validto,
case when validto = '' then '00000000'
else validto end as validto, @UI.hidden: true
//@UI.lineItem.position: 520
@DefaultAggregation: #MAX
1 as counter }
If you want ValueHelp in the List report filters to select the Prompts, then you need to implement the associations in the CDS view as mentioned in the above code, I have implemented ValueHelp for Material & Owner.
2. How to create GateWay Service for CDS view:
- Make sure you enabled the OData annotation is set to “true” in the CDS view.
- Go to tcode – /IWFND/MAINT_SERVICE in SAP and click on Add Service.

- Give Local in the system Alias and click on Get Services button. Once you see all the list, find your service which starts with CDS view name from the list below and Click Add Selected Services button.

Give Package Assignment and click on Continue.
- It will prompt for a Transport request for the Gateway service. Select the Transport request or create a new TR and Click on Continue.
- Now, go back to main page and find the Service that starts with CDS view name. Select the service and Make sure the status of ICF Node status is Active. Also you can click on Load Metadata button to refresh the Metadata.

- To test the service is working or not, Select the service and click on SAP Gateway Client.

- Click on Execute button and you can see the status reason is OK.

3. How to create Fiori List Report in Web IDE:
- Login into SAP Cloud Platform Web IDE.
Go to Development -> Workspace -> New -> Project from Template.

- Select List Report Application, select the current UI5 Version and Click “Next”.

Give Project Name and Title and Description for the New List report App and Click “Next”.
Select the SAP system from the Service Catalog. In this case, I select system and select the Gateway service which is based on CDS View and Click “Next”.

- Click Next, and then select OData Collection as ZDEMO_COMP (CDS view) and click Finish.

- Now, you can see the List report Application is created under Workspace. You can test the List report app within Web IDE by clicking the “Run” button.

- You can choose the file to run the List report application. In this case, I selected the flpSandbox.html.

- It will open new window from the Web IDE with a tile for testing. Click on the tile.

- You can test if the report is working fine. By clicking the settings button, you can select the columns you want to show in the report layout and click Go button to run the report.

4. How to deploy the Fiori Application:
- Logon to SAP Cloud Platform Web IDE and go to your project -> Deploy -> Deploy to SAPUI5 ABAP Repository.

- If it’s a new application to Deploy, then click the Deploy a new application or click on Update an existing application and then click “Next”.

- Give the application a Name which starts with ‘Z’ otherwise it won’t create the application, also give the package and click “Next”.

- Select transport request if asked and then click “Next”.
- Click Finish.

You can see the status of the Deployment in main screen of the Web IDE ( top right corner).

After the Deployment of the Application is complete to Repository , you can create custom semantic object and a tile in Fiori which we can discuss this in PART 2 of this blog.
Thanks!!
Create Fiori List App Report with ABAP CDS view – PART 1的更多相关文章
- Create Fiori List App Report with ABAP CDS view – PART 2
In the Part 1 blog, we have discussed below topics CDS annotations for Fiori List Report. How to cre ...
- CDS测试框架介绍:如何为ABAP CDS Entities写测试
动机 现在大家都知道单元测试对我们代码的好处.并且我们都承认它是开发过程中不可或缺的一部分.但是在把代码切换到数据库的模式下的时候,我们被粗暴地打回了软件测试的黑暗年代...我们现在面临着逻辑下推到A ...
- ABAP-Eclipse ADT中创建ABAP CDS视图
Create an ABAP Project in ABAP Development Tools (ADT): https://developers.sap.com/tutorials/abap-cr ...
- Jerry的通过CDS view + Smart Template 开发Fiori应用的blog合集
S4/HANA里有一个新的UI框架叫做Smart template, 配合ABAP后台的CDS view技术,能够让developer以Metadata driven的方式来开发Fiori应用, 这种 ...
- ABAP CDS - Syntax
The syntax of the DDL and of the DCL of the ABAP CDS comprises elements of the general DDL and DCL o ...
- 如何在SAP云平台ABAP编程环境里把CDS view暴露成OData服务
Jerry 2016年在学习SAP CDS view时,曾经写过一个CDS view的自学系列,其中有一篇提到了一个很方便的注解: @OData.publish: true 加上这个注解的CDS vi ...
- HANA CDS与ABAP CDS
如果你在网络或者SCN上面搜索CDS,即SAP的Core Data Services,你会很容易地找到类似“Core Data Services(CDS)是一个在SAP HANA中用于定义和消费富语义 ...
- ABAP CDS Table Function介绍与示例
Core data services(以下简称CDS)可以指两样东西,一个是HANA CDS,一个是ABAP CDS. 如我们所知,HANA CDS只支持HANA数据库,ABAP CDS理论上支持多种 ...
- 使用ABAP CDS视图创建服务
介绍本文介绍使用ABAP Core Data Services创建OData服务的最快方法. 给出了有关@ OData.publish注释利用率,对数据源CDS实体的引用和从DDIC结构导入的详细信息 ...
随机推荐
- asp.net超过字数限制用省略号...表示
显示8个字,多于8个字, 用...表示 <asp:Repeater runat="server" ID="MsgLists"> ...
- May 20th 2017 Week 20th Saturday
The true nobility is in being superior to your previous self. 真正的高贵在于超越过去的自己. Every night before I w ...
- *92. Reverse Linked List II (follow up questions)
Reverse a linked list from position m to n. Do it in one-pass and in-place Note: 1 ≤ m ≤ n ≤ length ...
- 欢迎来到“火龙族智者”的blog
本blog里有每天更新的比赛感想,新技术体会以及日语学习相关事宜. 主要研究方向是算法,信息安全以及日语. 希望各位能常来看看.
- Jmeter入门10 jmeter加密串处理方式2:BeanShell PreProcessor
上一个博客讲了方式一:函数助手__digest加密,BeanShell PreProcessor也可以用java代码进行处理 线程组.参数.请求都直接使用上一个博客的. 第一步 添加BeanShell ...
- html5 ajax Java接口 上传图片
html5图片上传[文件上传]在网上找了很多资料,主要也就2种 1.from表单提交的方式 <form action="pushUserIcon" method=" ...
- 【luogu P2863 [USACO06JAN]牛的舞会The Cow Prom】 题解
题目链接:https://www.luogu.org/problemnew/show/P2863 求强连通分量大小>自己单个点的 #include <stack> #include ...
- javascript之Window 对象
一.说明:他是JS中最大的对象,它描述的是一个浏览器窗口,一般要引用他的属性和方法时,不需要用“Window.XXX”这种形式,而是直接使用“XXX”.一个框架页面也是一个窗口. 二.Window窗口 ...
- MySQL存储引擎与索引
引言: MySQL存储引擎主要分为 InnoDB 存储引擎与 MyISAM 存储引擎.都采用B+数的存储结构. 应用场景: InnoDB适合:(1)可靠性要求比较高,要求事务:(2)大量 insert ...
- GET&&POST请求编码过程
编码.解码 我们在开发过程中不可避免的一个话题就是编码和解码,那么什么是编码什么是解码呢?为什么要进行编码和解码呢?下面我们一一分析! 编码和解码的概念 编码是信息从一种形式或格式转换为另一种形式的过 ...