Technical Articles
Add and Use SAPUI5 Elements in SAP Analytics Cloud Custom Widget
In this tutorial, I would like to share how you can add and use SAPUI5 elements in SAP Analytics Cloud. In this case, is add and use sap.m.Input – Password.
From my trials and errors experience, not all UI5 elements can be added and used in the custom widget. It depends on which version of UI5 libraries that are being loaded and used in SAP Analytics Cloud itself. For my case, is version 1.60.13 for SAC version 2020.8.9. See below screenshot.
I can use sap.m.Input in custom widget since it is available from version 1.10. Unlike sap.ui.integration.widgets.Card, I can’t use it since the minimum version is 1.62.
Let’s wait and see if we can use this integration card element once SAC libraries are upgraded to version 1.62 or higher.
Build Web Components
Let’s start by building the Web Components and its properties.
Create the inputpassword.json property file to define the properties, methods and events in Web Components. You may refer to my blog in References section below for more details. Don’t forget to update the URL link http://localhost to your localhost accordingly.
{
"id": "com.fd.djaja.sap.sac.inputpassword",
"version": "0.0.2",
"name": "inputPassword",
"description": "Input Password",
"newInstancePrefix": "inputPassword",
"icon": "",
"vendor": "Ferry Djaja",
"eula": "",
"license": "",
"imports": [ "input-controls" ],
"webcomponents": [
{
"kind": "main",
"tag": "com-fd-djaja-sap-sac-inputpassword",
"url": "http://localhost/SAC/sacinputpassword/inputpassword.js",
"integrity": "",
"ignoreIntegrity": true
}
],
"properties": {
"metadata": {
"type": "string",
"description": "For internal use",
"default": ""
},
"password": {
"type": "string",
"description": "password",
"default": ""
}
},
"methods": {
"getPassword": {
"returnType": "string",
"description": "Get password",
"parameters": [],
"body": "return this.password;"
},
"setPassword": {
"description": "Set password",
"parameters": [
{
"name": "value",
"type": "string",
"description": "The new password"
}
],
"body": "this.password = value;"
}
},
"events": {
"onStart": {
"description": "onStart events trigger"
}
}
}
Create inputpassword.js to put the app logic. I will walk through it for each section.
- The HTML template object is created to construct the input password UI element. If you see from line 14 to 31, it is actually an XML view of the sap.m.Input element with controller name myView.Template and livechange event onButtonPress.
- On constructor() method, The super() function is called, then the shadow DOM root element is created. The copy of the template element is added as a child element to the shadow DOM root element. And finally, initialize the variable to store the password information.
- On connectedCallback() method, it is populated the available widgets in SAC Analytics Application. It is not currently being used anywhere in this app, but I have put it here for future use.
- On onCustomWidgetAfterUpdate() method, is the entry point of this app. It loads the function loadthis().
- The following functions is to fire the custom event propertiesChanged, and implement Getters and Setters Property password.
- The loadthis() function is the main logic of the app. It has the SAPUI5 controller myView.Template and XMLView that is rendered in _oView. onButtonPress() function will be triggered from the livechange event.
The onStart() custom event will be triggered to expose the password information so it can be retrieved by standard SAC widget.
Usage
Create an SAC Analytics Application and insert the inputPassword custom widget.
On custom widget inputPassword_1- onStart() event, put the below code to get the password information and print it in InputField standard widget.
InputField_1.setValue(inputPassword_1.getPassword());
Short Demo Video
That’s all that you need to do. Do let me know if you have questions.
Dear Ferry,
Thank you very much for the blog. I have been waiting for this from you. This opens up lot of opportunities to develop various custom widgets.
Thanks.
Raja
Hi Durairaj Athavan Raja
Great! Happy to share what I have done. Looking forward for your custom widget creations!!
Cheers,
Ferry
Sure, will share them here. I am trying to get data from backend (SSO is taken care) using the json model
durl = "https://hhh.ddd.com:8888/sap/bc/bsp/sap/ybl_data_se/flightdata" ;
fmodel = new sap.ui.model.json.JSONModel(durl);
sap.ui.getCore().setModel(fmodel, "listofflights"); not sure this will work if i am doing this from inside shadow DOM
Although i have set the below http header at bsp page response (ybl_data_se/flightdata)
CALL METHOD response->if_http_entity~set_header_field
EXPORTING
name = `Access-Control-Allow-Origin`
value = `*`.
within SAC when i tried to connect i always get "No 'Access-Control-Allow-Origin' header is present on the requested resource", but if i call the bsp outside in browser i can see the headers i have set.
Do you know how i can handle this?
Thanks.
Raja
I think you need to set that in Trusted Origins. See this blog: https://blogs.sap.com/2018/04/20/sap-analytics-cloud-apis-getting-started-guide/
Regards,
Ferry
Thanks. I thought that was for the other way around scenario (embedding SAC in custom web apps)
I have set that up but didn't help. Will explore further and if i succeed will update here.
Regards
Raja
the CORS setting at the back end system has to be updated (live data connection - CORS config) . Earlier i had only allowed sap/bw/ina and sap/opu/odata for sac. will have to add sap/bc/bsp/sap as well. Will test and confirm.
Regards
Raja
Confirm that after adjusting the CORS configuration to allow sap/bc/bsp/sap its working fine.
Great!!!
I've been very much enjoying your series. Thank you! regards, H
Thank you !!
Regards,
Ferry
This is helpful. Thank you for sharing Ferry!.
Thanks,
Jothi
Thank you Jyothirmayee A !
Hi Ferry,
I am trying to create a Date picker custom widget using https://sapui5.hana.ondemand.com/#/entity/sap.m.DatePicker
However, I am getting an error that xmlns: URI sap.m is not absolute
what can the reason be? I copied the View from here https://sapui5.hana.ondemand.com/#/entity/sap.m.DatePicker/sample/sap.m.sample.DatePicker/code
thanks
Dania
Well this problem is solved now, however, I have a new problem.
I am not able to get the value of the date at all !!!
I made the same as your code I have the loadthis() function and in sap.m.DatePicker
there is the Event change https://sapui5.hana.ondemand.com/#/api/sap.m.DatePicker%23events/change
so actually onButtonPressed function should work!!
I tried to debug and find that it is not entering the function onButtonPressed at all.
In the Photos you can see the code
Thank you
Dania
Hi Dania,
Sorry for late reply. Could you provide the full source code so I can check ?
Thanks,
Ferry
Hey Ferry,
please check if you can see the code in github
https://github.wdf.sap.corp/i070041/SAC-Custom-Widgets
Or:
https://github.com/Dania94/SAC-Custom-Widgets
Thanks,
Dania
Hey Ferry,
I know you may be busy.
Did you the chance to look at my code?
Thanks,
Dania
Hi Dania,
I am looking at your code now. Sorry for late reply
Regards,
Ferry
Hi Dania Almadani
I checked your code. I think you have forgotten to add the change button event for change="onButtonPressed"
See this updated code:
Regards,
Ferry Djaja
Hi Ferry,
thank you for sharing this, your tutorial is really helpful, appreciate your efforts so much ^^ !
Huimin