Using UI5 elements like Input or ComboBox we could have the requirement to change the standard icon.
It can be done using Javascript, example:
sap.ui.getCore().attachInit(function (startParams) {
ComboBox.addEventDelegate({
onAfterRendering: function () {
ComboBox.getIcon().setSrc("sap-icon://drill-down");
},
});
});
Today I want to share instead how achieve the same result using CSS as alternative.
- In my case I created a new app with a SimpleForm with inside the Label and the ComboBox
data:image/s3,"s3://crabby-images/878b0/878b08ff1bbe7145d6d9bbb79d93e28dc51c8530" alt="App Designer Structure"
- Select the Combobox element and assign a new CSS class in the styleClass property (in my case comboCustomIcon)
data:image/s3,"s3://crabby-images/a3644/a364438e78e17b098835925aeff88395e4f74702" alt="StyleClass Property"
- Open the application in a new window and inspect the icon we want to change
data:image/s3,"s3://crabby-images/e4e1d/e4e1d6f773e327cee51e026b716a317a765ee686" alt="Application DOM Inspect"
- The ComboBox standard icon is inside the before pseudo-element, in the content property
data:image/s3,"s3://crabby-images/0f2c6/0f2c64c50b291b15b4d481bbfcf9ffdd2a6762dc" alt="ComboBox CSS property"
- Open now the UI5 Icon Explorer website and choose an icon, in my case I will use the sap-icon//arrow-bottom
- Click on the icon in order to get the Unicode in the right side of the page
data:image/s3,"s3://crabby-images/e7a6a/e7a6aeea03600d929a633fc6e08f6cf7b616e6ed" alt="UI5 Icon Explorer"
- In the StyleSheet section of the App Designer we combine our custom css class with .sapUiIcon::before, then inside the content property we insert the Unicode replacing the x character with backslash
.comboCustomIcon .sapUiIcon::before {
content: '\e04e';
}
Here we can see the new icon:
data:image/s3,"s3://crabby-images/67e60/67e600b12ccc97ccb5f8cbbfc2f435ef91c3cee9" alt="ComboBox with the new icon changed with CSS"
Hope this helps
Happy CSS coding!