Font Awesome 5 Aurelia component using SVG with JS
Inspired by: react-fontawesome and vue-fontawesome
Visit fontawesome.com/icons to search for free and Pro icons
$ npm i --save @fortawesome/fontawesome-svg-core
Select one or all icon libraries
$ npm i --save @fortawesome/free-solid-svg-icons
$ npm i --save @fortawesome/free-regular-svg-icons
$ npm i --save @fortawesome/free-brands-svg-icons
Aurelia Plugin
$ npm i --save aurelia-fontawesome
In your Aurelia bootstrap file, add the plugin:
import { PLATFORM } from "aurelia-framework";
export function configure(aurelia) {
aurelia.use
.standardConfiguration()
.plugin(PLATFORM.moduleName("aurelia-fontawesome"));
// other code ...
return aurelia
.start()
.then(() => aurelia.setRoot(PLATFORM.moduleName("app")));
}
import { PLATFORM } from 'aurelia-framework';
import { fab } from "@fortawesome/free-brands-svg-icons";
import {
faCircle,
faHome,
faSpinner,
faCoffee,
faMugHot
} from "@fortawesome/free-solid-svg-icons";
export function configure(aurelia) {
aurelia.use
.standardConfiguration()
.plugin(PLATFORM.moduleName('aurelia-fontawesome'), {
iconOptions: { /* bindable property defaults here (e.g rotation: 0) */ },,
icons: [ fab, faCircle, faHome, faSpinner, faCoffee, faMugHot ]
});
// other code ...
return aurelia.start().then(() => aurelia.setRoot(PLATFORM.moduleName('app')));
}
Explicitly import the icon(s) into your view model(s)
foobar.js
import { faCoffee } from "@fortawesome/free-solid-svg-icons";
export class FooBarViewModel {
coffeeIcon = faCoffee;
}
foobar.html
<template>
<font-awesome-icon icon.bind="coffeeIcon"></font-awesome-icon>
</template>
Explicitly importing icons like this allows us to subset Font Awesome's thousands of icons to include only those you use in your final bundled file. for an alternative approach check out webpack loader aurelia-fontawesome-loader
foobar.js
export class FooBarViewModel {}
foobar.html
<template>
<font-awesome-icon icon.bind="['fab', 'apple']"><font-awesome-icon>
<font-awesome-icon icon.bind="['fab', 'microsoft']"><font-awesome-icon>
<font-awesome-icon icon.bind="['fab', 'google']"><font-awesome-icon>
</template>
The
"check-square"
icon is getting a default prefix offas
here too, which is what we want, because that icon also lives in the@fortawesome/free-solid-svg-icons
package.
However, the
"apple"
,"microsoft"
, and"google"
brand icons live in the package@fortawesome/free-brands-svg-icons
. So we need to specify a different prefix for them—not the defaultfas
, butfab
, for Font Awesome
- The icon can be an icon object, like
icon.bind=${faCoffee}
. - The icon can be a string, like
icon="coffee"
. - The icon can be an
Array
of strings, where the first element is a prefix, and the second element is the icon name:icon.bind="['fab', 'apple']"
- The prefix can be bound, the default is
fas
:prefix="fab" icon="apple"
- A default prefix can be setup in the plugin configuration:
{ prefix="fab" }
To build the code, follow these steps.
- From the project folder, execute the following command:
npm install
- To build the production files, run:
npm run build
- You will find the compiled code in the
dist
folder, available in various module formats.
To run the unit tests, first ensure that you have followed the steps above in order to install all dependencies and successfully build the library. Once you have done that, proceed with these additional steps:
- For single execution run:
npm run test
- For continuous tdd style:
npm run test:watch
- From the project folder, execute the following command:
npm start