NgHeroicons just it is a Angular components to use Heroicons in your projects. I hope that could be useful.
If you want to know how is working Angular CLI follow this https://cli.angular.io/.
Live demo: https://ng-heroicons.dimaslz.dev
This package has compatibility with Angular version from 11 to 18.
angular version | package version | |
---|---|---|
11.x.x | ^11 |
|
12.x.x | ^12 |
|
13.x.x | ^13 |
|
14.x.x | ^14 |
|
15.x.x | ^15 |
|
16.x.x | ^16 |
|
17.x.x | ^17 |
|
17.x.x | ^18 |
default |
$ yarn add @dimaslz/ng-heroicons@^XX
$ npm install @dimaslz/ng-heroicons@^XX
// app.module.ts
import { NgHeroiconsModule } from "@dimaslz/ng-heroicons";
// ...
@NgModule({
// ...
imports: [
CommonModule,
NgHeroiconsModule,
],
// ...
})
//...
Go to https://ng-heroicons.dimaslz.dev and get the name of the icon and use in your tag html following suffix {outline|solid}-icon
. For example: academic cap
should be <academic-cap-outline-icon></academic-cap-outline-icon>
for outline or <academic-cap-solid-icon></academic-cap-solid-icon>
for solid icons.
You can use your style in line, css or just pass color and size.
<!-- using style in line (style for color will affect to svg) -->
<academic-cap-outline-icon style="color: red;"></academic-cap-outline-icon>
<!-- using css classes (class for color will affect to svg) -->
<academic-cap-outline-icon class="text-red-400"></academic-cap-outline-icon>
<!-- pass color or size -->
<academic-cap-outline-icon size="48" color="red"></academic-cap-outline-icon>
<!-- To apply specific style to the SVG, use `svgStyle` -->
<academic-cap-outline-icon svgStyle="color: red;"></academic-cap-outline-icon>
<!-- To apply specific css to the SVG, use `svgClass` -->
<academic-cap-outline-icon svgClass="your-class-for-the-svg"></academic-cap-outline-icon>
This is a monorepo to build the icon components for multiple Angular versions. To avoid conflics with compatibility from Angular 11 to 14, we are not using workspaces
, only separated folder per Angular setup.
Landing page is the common landing https://ng-heroicons.dimaslz.dev/ which is using the last Angular version.
- Build the Angular 14 lib:
$ yarn --cwd=packages/angular-v14 build lib -c production
- Refresh the distribution content in
dist/v14
:$ yarn v14-copy-release
- Install Landing packages:
$ yarn --cwd=landing install
- Run project:
$ yarn --cwd=landing start
- Join the page in http://localhost:4200
Keep in mind, first you should build the lib
package
angular version | command |
---|---|
angular 11 | $ yarn --cwd=packages/angular-v11 build lib -c production |
angular 12 | $ yarn --cwd=packages/angular-v12 build lib -c production |
angular 13 | $ yarn --cwd=packages/angular-v13 build lib -c production |
angular 14 | $ yarn --cwd=packages/angular-v14 build lib -c production |
angular 15 | $ yarn --cwd=packages/angular-v15 build lib -c production |
angular 16 | $ yarn --cwd=packages/angular-v16 build lib -c production |
angular 17 | $ yarn --cwd=packages/angular-v17 build lib -c production |
angular 18 | $ yarn --cwd=packages/angular-v18 build lib -c production |
Keep in mind, first you should build the lib
package. This playgrounds does not have any special, is a demo page to test the library is working as expected.
angular version | command |
---|---|
angular 11 | $ yarn --cwd=packages/angular-v11 start playground |
angular 12 | $ yarn --cwd=packages/angular-v12 start playground |
angular 13 | $ yarn --cwd=packages/angular-v13 start playground |
angular 14 | $ yarn --cwd=packages/angular-v14 start playground |
angular 15 | $ yarn --cwd=packages/angular-v15 start playground |
angular 16 | $ yarn --cwd=packages/angular-v16 start playground |
angular 17 | $ yarn --cwd=packages/angular-v17 start playground |
angular 18 | $ yarn --cwd=packages/angular-v18 start playground |
$ yarn generate
This will generate the new angular components in projects/ng-heroicons/src/lib/heroicons/outline
and projects/ng-heroicons/src/lib/heroicons/solid
, and the templated in playground as projects/playground/src/app/icons/outline-icons.html
and projects/playground/src/app/icons/solid-icons.html
$ yarn build --prod ng-heroicons
{
name: "Dimas López",
role: "FullStack Software development",
alias: "dimaslz",
twitter: "https://twitter.com/dimaslz",
site: "https://dimaslz.com",
linkedin: "https://www.linkedin.com/in/dimaslopezzurita"
}
- https://randomdata.loremapi.io: API mock data (no open source)
- https://svg-icon-2-fw-component.dimaslz.dev: SVG to Framework component (open source soon)
- https://ng-heroicons.dimaslz.dev: Use Heroicons.com in you Angular projects (open source)