This article is in continuation with the https://www.amarmn.com/sap-appgyver-display-list-consuming-northwind-odata-service/ where we displayed the products list. In this example we will add another page, detail page and navigate from list page to detail page when clicking on a product.
- In the UI Canvas tab, click empty page and choose ADD NEW PAGE to create a new page.
data:image/s3,"s3://crabby-images/50bf5/50bf5fe8cb15f1673f53c9ead88300c45b9fe78d" alt=""
- enter name Detail and click ok
- We get a new page Detail. In the UI Canvas tab, drag and drop some text UI into the canvas.
- Next, toggle from View to Variables. We will create PAGE PARAMETERS to receive data from list page to detail page. Click ADD PARAMETER to create a page parameter.
data:image/s3,"s3://crabby-images/8a9e5/8a9e5956a7873630a8f6b4d3d558b6f91f42d7d1" alt=""
- Based on the value of Page parameter, we will fetch data from OData service. So we need to create a Data variable that will store the data fetched from the Odata service.
- Choose Data variables, click ADD DATA VARIABLE, and choose Products. A data variable Products1 is created. Change the Data variable type to Single data record (we intend this data variable to fetch a single record from the odata service).
data:image/s3,"s3://crabby-images/d707f/d707f0cc6040c205bc7a728f7fc08e2b108160a8" alt=""
- Next we need to bind ProductID with the page parameter. Based on this data, the product details will be fetched from the odata service.
- Click on Product ID, in the binding window, choose Data and variables -> Page parameter.
- Here we see that we cannot do this binding, because the type text is incompatible with the type number.
data:image/s3,"s3://crabby-images/3bca6/3bca63a40a35f28c1d1065481d4c7ee1a9ef6f50" alt=""
- In order to solve this, we will have to apply formula. Hit back twice to come back to the first page of binding wizard. Choose formula, click Create formula.
- In the search box, type number to get the number function. Choose number function. For value, click Page parameters, choose params.parameter1. Click Save to create the binding.
data:image/s3,"s3://crabby-images/515a9/515a9b1606cdb3fcba9b6fa6ede76cf196bf32bd" alt=""
- We see that the binding is created. Click Save to save the development.
data:image/s3,"s3://crabby-images/7d127/7d12790adc6fd9231a614c49522ad661e2d2feba" alt=""
- Toogle to view. In the Detail page canvas, drag and drop text UI element. Make sure that you have at least 4 text UI elements in the detail page.
- Choose the first text UI element. Under Content, click icon to create binding. In the binding window, choose Data and Variables -> Data variable -> Products1 -> ProductID to do binding with ProductID. Click Save to complete the binding.
data:image/s3,"s3://crabby-images/93453/93453028988b0276aeace7113cda4f76c2ab3cce" alt=""
- Similarly, bind other text UI elements with ProductName, UnitPrice and UnitsInStock respectively. Click Save to save the development.
- Next, switch the list page.
- We need to add a logic, if anyone taps a record on the list, then we must navigate to the detail page.
- Choose list.item1. At the bottom, click Add logic to LIST ITEM1.
- The logic window expands. We see event Component tab. From left, under navigation section, drag and drop Open page in to the logic canvas.
- Connect dot from Event Component tap to Navigation Open page.
data:image/s3,"s3://crabby-images/f7404/f7404a079504fdec14e0e2b2a3e5627558def82f" alt=""
- Also, check that the Open page is connected to Detail page.
- Next, the parameter of detail page is to be binded to the list ProductID so that the ProductID value flows from the list to the detail page parameter.
- Click paramter1 binding, in the binding window, choose current ProductID. If you get incompatible error, click back in the binding window. Choose formula -> create formula.
- Type string to get the string formula. For value choose Currently repeated data items -> repeated.current.ProductID. Click Save to save the binding.
data:image/s3,"s3://crabby-images/41b23/41b23056758f11c07d77f9862f7ba4495c0a2dcc" alt=""
- String formula converts number to text.
- Save the development.
Now, we can test the output of the above app. When we tap on the list, we see the detail page.
data:image/s3,"s3://crabby-images/26a42/26a42d4dae619841cd5f4d4dcb37f7d7afe68bae" alt=""