The icon library approach provides convenient usage in the templates, but the icons have to be managed separately from the components. This has long-term maintenance implications, specifically, this means that there is no easy way to tell if any given icon is in use. Therefore, if someone accidentally removes an icon from the icon library, the application will build just fine, but the component that needs this icon will break at runtime.
Icons should be registered only once in the AppModule
's constructor using FaIconLibrary.addIcons()
or FaIconLibrary.addIconPacks()
calls. Icons added to the library will be available everywhere in the application and can be referenced just by their name. This eliminates the need to explicitly import icons and assign them to a property of every individual component to be able to use them in the template as with the explicit reference approach.
src/app/app.component.html
<!-- simple name only that assumes the default prefix -->
<fa-icon icon="coffee"></fa-icon>
<!-- ['fas', 'coffee'] is an array that indicates the [prefix, iconName] -->
<fa-icon [icon]="['fas', 'coffee']"></fa-icon>
src/app/app.module.ts
-
Import
{ FontAwesomeModule, FaIconLibrary } from '@fortawesome/angular-fontawesome'
. -
Add
FontAwesomeModule
toimports
.Note that you need to add
FontAwesomeModule
to theimports
of every module where you want to usefa-icon
component, because of Angular module encapsulation. You can read more about it in this blog post. -
Inject
FaIconLibrary
into constructor of the module. -
Import an icon like
{ faCoffee } from '@fortawesome/free-solid-svg-icons'
. -
Add icon to the library with
library.addIcons(faCoffee)
.
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FontAwesomeModule, FaIconLibrary } from '@fortawesome/angular-fontawesome';
import { faCoffee } from '@fortawesome/free-solid-svg-icons';
import { AppComponent } from './app.component';
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, FontAwesomeModule],
bootstrap: [AppComponent]
})
export class AppModule {
constructor(library: FaIconLibrary) {
// Add an icon to the library for convenient access in other components
library.addIcons(faCoffee);
}
}
You can also import entire icon styles. But be careful! This way of importing icons does not support tree-shaking, so all icons from the imported package will end up in the bundle.
import { fas } from '@fortawesome/free-solid-svg-icons';
import { far } from '@fortawesome/free-regular-svg-icons';
export class AppModule {
constructor(library: FaIconLibrary) {
library.addIconPacks(fas, far);
}
}
The default prefix, fas
, can be adjusted by injecting the FaConfig
and modifying the defaultPrefix
property.
import { FaConfig } from '@fortawesome/angular-fontawesome';
export class AppComponent {
constructor(faConfig: FaConfig) {
faConfig.defaultPrefix = 'far';
}
}
The fixed width class, fa-fw
, can be applied globally by injecting the FaConfig
and modifying the fixedWidth
property.
import { FaConfig } from '@fortawesome/angular-fontawesome';
export class AppComponent {
constructor(faConfig: FaConfig) {
faConfig.fixedWidth = true;
}
}