While <fa-icon>
component provides a convenient way to render a Font Awesome icon in the Angular app, there are situations where you can't use it. This guide describes such situations and how to use Font Awesome JavaScript API to deal with them.
The Font Awesome JavaScript API is distributed as the @fortawesome/fontawesome-svg-core
package. The documentation for the JavaScript API is available on the official website.
Problem: You have an Angular application, but you need to replace <i>
tags used by the vanilla Font Awesome in the arbitrary markup, which is not part of the Angular templates. This often happens when the custom HTML markup is loaded from the backend and inserted into the page with innerHTML
.
In this case, markup is not part of the Angular template, and you can't use <fa-icon>
component outside the Angular template (see this SO answer for more details). Because of this limitation, the angular-fontawesome
library is not really useful.
The first step is to add all icons which need to be replaced to the library used by the fontawesome-svg-core
package. This should be done early to make sure that icons are in the library by the time you attempt to replace <i>
tags. For example, you can choose to put the below code in the main.ts
:
import { library } from '@fortawesome/fontawesome-svg-core'
import { faCamera } from '@fortawesome/free-solid-svg-icons'
library.add(faCamera)
Once icons are added to the library you have two options:
-
When custom markup is inserted into the page in a controlled way, it is better to call
dom.i2svg()
method once the custom markup has been added to the page. It will replace all<i>
tags with the icon<svg>
elements.This approach is more performant.
-
When custom markup is inserted into the page in multiple places or by the third-party code (so you can't hook into it), then you can use
dom.watch()
method, which will utilizeMutationObserver
to listen to any markup changes and replace<i>
tags with the icon<svg>
elements.Note that depending on the size of the application, this option may cause performance problems as the dynamic Angular application will trigger a lot of events even when icons don't need to be re-rendered. Also, note that in some situations
MutationObserver
may cause an infinite change detection loop (observed as a frozen application). To prevent this from happening, you should calldom.watch()
outside of Angular zone by either putting it in themain.ts
or wrapping it intoNgZone.runOutsideAngular()
call.
Problem: You have an Angular application where you use some library, which accepts custom markup as a string parameter and injects it somewhere in the DOM (tooltip, Google Maps, etc). You want to include Font Awesome icon in this custom markup and tried to include <fa-icon>
component, but it didn't work.
Such markup is not part of the Angular template, and you can't use <fa-icon>
component outside the Angular template (see this SO answer for more details). Because of this limitation, the angular-fontawesome
library is not really useful.
While you can use dom.i2svg()
or dom.watch()
calls described in the previous scenario to handle this, it's often an overkill. As you control the markup, you can render icons into SVG strings using icon()
function and concatenate them with the rest of the markup. See the below example.
import { icon } from '@fortawesome/fontawesome-svg-core';
import { faChevronLeft, faChevronRight } from '@fortawesome/free-solid-svg-icons';
myTooltipLib({
content: `<p><b>Hint:</b> You can navigate items with ${icon(faChevronLeft).html.join('')} and ${icon(faChevronRight).html.join('')} buttons.</p>`
})