wissel.net

Usability - Productivity - Business - The web - Singapore & Twins

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

Dynamic Lookup

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 image
  • background-position puts the image in the upper right corner. You could put it into the left corner when you mirror it
  • background-repeat ensures that the image gets painted once only
  • background-color isn't needed for the image, it is just to make clearer what exactly got selected. You might opt for a border property instead
  • background-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 on 18 April 2019 | Comments (0) | categories: Lightning Salesforce

Comments

  1. No comments yet, be the first to comment