While developing a library you may want to certain assets that are being used inside your components gets embedded into the outputted css as otherwise it can get rather tricky to implement something that will work for all module formats.
A way to overcome this and include certain assets, is to use background images inside css and embed the assets with data URIs.
Something like the below:
background: url('logo.png');
During build it will be resolved and the asset will be encoded into base64 format:
background: url(data:image/png;base64, YSBzbGlnaHRseSBsb25nZXIgdGVzdCBmb3IgdGV2ZXIK);
Note: it is important to keep the amount of embeeded file to a minimum and only embed small files. As this will increase in the final bundle size.
More information in the CSS tricks website and MDN web docs.
You can embed assets such as fonts and images inside the outputted css by using the cssUrl
option.
Valid values: none
or inline
.
{
"ngPackage": {
"lib": {
"cssUrl": "inline"
}
}
}