This package allows you to use the Feather Icons in your angular applications. The icons are designed by Cole Bemis. Import only the icons that you need.
1. Install the package
npm install angular-feather-icons
2. Generate a module to host the icons you'll import
ng generate module icons
3. Import assets
You need to import:
- FeatherModule, as it contains the
<i-feather>
component - The SVGs that you need
We put this in IconsModule for modularity. See example below:
file: icon.module.ts
import { NgModule } from "@angular/core";
import { FeatherModule } from "angular-feather-icons";
import { Camera, Heart, Github } from "angular-feather-icons/icons";
// Select some icons (use an object, not an array)
const icons = {
Camera,
Heart,
Github,
};
@NgModule({
imports: [FeatherModule.pick(icons)],
exports: [FeatherModule],
})
export class IconsModule {}
// NOTES:
// 1. We add FeatherModule to the 'exports', since the <i-feather> component will be used in templates of parent module
// 2. Don't forget to pick some icons using FeatherModule.pick({ ... })
3. Use it in template
After importing the IconsModule in your feature or shared module, use the icons as follows:
<i-feather name="github" class="someclass"></i-feather>
<i-feather name="heart" style="color: green;"></i-feather>
<i-feather name="camera"></i-feather>
<i-feather name="heart" class="big fill-red"></i-feather>
.big {
height: 50px;
width: 50px;
}
.fill-red {
fill: red;
}
Refer to the table below for the list of all available icons.
1. Is there a way to pick all the icons at once?
Yes, by importing allIcons
from 'angular-feather-icons/icons'
:
import { allIcons } from "angular-feather-icons/icons";
@NgModule({
imports: [FeatherModule.pick(allIcons)],
exports: [FeatherModule],
})
export class IconsModule {}
However, keep in mind that by doing this, all icons will end up in your application bundle. While this may not be much of an issue for prototyping, it is not recommended for any application that you plan to release.
Do not confuse with angular-feather This project is its spiritual successor, and all credit goes to the angular feather team and his fellow contributors which will remain in this project's contributing list.
The intention of this project is to maintain and evolve the solution due to the specific needs of the projects I am working on.