LWC components with self contained images
When you create your LWC components, it is easy to include Salesforce predefined icons using lightning-icon
. However once you need a custom icon, you point to an external URL, breaking the self containment. Unless you use url(data:)
. Here is what I did
A scalable check mark
For a list selection component I wanted a green check mark, like the picture above, indicate a selected record (more on the component in a later post). Since LWC doesn't allow (yet?) to store image assets inside a bundle and I wanted the component to be self contained.
The solution is to use ');
background-position: top right;
background-repeat: no-repeat;
background-size: contain;
background-color: #eeffee;
}
What the CSS parameters do:
background-image
sets the background to the inline image. You can copy and paste the content into the Base64Decoder to get back the original imagebackground-position
puts the image in the upper right corner. You could put it into the left corner when you mirror itbackground-repeat
ensures that the image gets painted once onlybackground-color
isn't needed for the image, it is just to make clearer what exactly got selected. You might opt for aborder
property insteadbackground-size
defines the size of the image. SVG by nature doesn't have a size and it will fill the available height of the container. In conjunction with the viewbox value,contain
will hence show the image exactly on half of div height. This might not work for all use cases. When your container is very long, you get a big big big check mark. There you would specify a discrete size
Enjoy! As usual YMMV!
Posted by Stephan H Wissel on 18 April 2019 | Comments (0) | categories: Lightning Salesforce