In the Neptune DXP platform it’s possible to give dynamic informations to the user by creating for example a NumericContent tile. We are also able to run a custom application in card with the Live application type.
Today I want to share how I created a custom tile showing the actual number of Purchase Orders, the time remaining for the next sync with the relative progress bar.
data:image/s3,"s3://crabby-images/0f941/0f94135cb6f0615c638016aa9b077cf8eae08fb7" alt="Dynamic Numeric Tile with sync countdown timer"
- Open the App Designer and create a new application
- Inside the HTML5 Document element insert the following elements: sap.m.VBox > sap.m.ObjectHeader > sap.m.ObjectAttribute
- Inside the sap.m.ObjectHeader insert a new sap.m.HBox
- In the Resource element create a new Script (initialize)
data:image/s3,"s3://crabby-images/5be22/5be2299be45b09fc11d51dd91b5716233e0b07c8" alt="App Designer Structure"
- Select the sap.m.ObjectHeader and set the icon and numberUnit properties (in my case sap-icon://sales-quote and orders)
- Assign a css styleClass
data:image/s3,"s3://crabby-images/24ca8/24ca8f49a3cd94acee5b5e5e8df5dedd3acf3c14" alt="Object Header CSS class"
- Select now the sap.m.HBox element and also here assign the styleClass
data:image/s3,"s3://crabby-images/a951f/a951fcc8732162110c022419eae2c660e2350de6" alt="HBox CSS class"
- In the initialize Script use the following JavaScript code
sap.ui.getCore().attachInit(function (data, navObj) {
let intervalSeconds = 15; // seconds
let countdownCounter = intervalSeconds;
// test data
let tileCounter = 593; // tile number
objectHeader.setNumber(tileCounter);
// countdown interval (each second)
setInterval(function () {
objectAttribute.setText("Sync in " + countdownCounter + " seconds");
$(".hboxProgress").css(
"width",
(countdownCounter * 100) / intervalSeconds + "%"
);
// when reach 0 reset the countdown
if (countdownCounter === 0) {
tileCounter++;
objectHeader.setNumber(tileCounter);
countdownCounter = intervalSeconds;
} else {
countdownCounter--;
}
}, 1000);
});
- Open now the Stylesheet section and paste the following css
.objectHeader .sapMOH {
padding: 1rem;
}
.objectHeader .sapUiIcon {
color: #27ae60;
}
.hboxProgress {
background: #e67e22;
height: 5px;
transition: 1s width;
width: 100%;
}
- Open the Neptune Cockpit and go to the Tile section
- Create a new tile with the following properties
data:image/s3,"s3://crabby-images/3e06d/3e06d6a5d8284bc88a84b0f7596526ec814ea696" alt="Tile properties"
- In the layout section you can set those flags
data:image/s3,"s3://crabby-images/c32f4/c32f412c4a6186887d1a56962cd444cbad9a9e20" alt="Tile layout properties"
- And the Tile Size
data:image/s3,"s3://crabby-images/c15de/c15dec66724ff46cd849d924c9bf743f819b156a" alt="Tile layout properties"
- You can now assign the tile to a tilegroup and use it on your own launchpad
Here a GIF:
Open GIF- Implement a new Ajax in the application for read data from the backend
- Change the CSS style
- Edit the countdown seconds
You can find more details here:
Tile - Guide - Neptune Software CommunityHappy coding!