From icons
Add a Font Awesome icon to the user's project, generating the correct code for their integration method
How this skill is triggered — by the user, by Claude, or both
Slash command
/icons:add-iconThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Add a Font Awesome icon to the user's project. This skill handles icon name resolution, project detection, and code generation for every Font Awesome integration method.
Add a Font Awesome icon to the user's project. This skill handles icon name resolution, project detection, and code generation for every Font Awesome integration method.
Scripts referenced from suggest-icon are relative to plugins/icons/skills/suggest-icon/. Scripts referenced from add-icon are relative to plugins/icons/skills/add-icon/. Run them from their respective directories.
First, determine the Font Awesome version. If the user specifies one, use that. Otherwise run ./scripts/latest-version.py (in the suggest-icon skill directory) to get the latest.
Then verify the icon exists by running:
./scripts/icon-exists.py --version <version> --icon-name <icon>
/suggest-icon skill internally with the user's icon argument as the use-case. Auto-accept the top recommendation and continue with that icon name. Do not ask the user to confirm — a working icon is better than a broken one.Check for a .font-awesome.md file in the project root.
.font-awesome.md existsRead it and use the configuration it describes. Skip discovery and proceed to step 3. However, keep the file's contents in mind — if any later step reveals information that is missing or incomplete in the file (e.g., a new import pattern, a family not listed, a wrapper component not documented), you will update it at the end (see step 6).
.font-awesome.md does not existRun a discovery process to figure out how the project uses Font Awesome. Use a subagent (via the Agent tool with subagent_type: "Explore") to perform this discovery. The subagent should search for the following sources (in order of specificity) and return a structured summary of what it found:
package.json / lock files — look for Font Awesome packages:
@fortawesome/react-fontawesome → React component integration@fortawesome/vue-fontawesome → Vue component integration@fortawesome/fontawesome-svg-core → SVG core (used by React/Vue)@fortawesome/fontawesome-free or @fortawesome/fontawesome-pro → general SVG+JS or web font@fortawesome/free-solid-svg-icons, @fortawesome/pro-solid-svg-icons, etc. → individual icon packages (note the style and license)HTML files / templates — look for:
<script src="https://kit.fontawesome.com/XXXXXX.js"...> → Kit (SVG+JS). Extract the kit ID (the token before .js).<link> tags: cdnjs.cloudflare.com/ajax/libs/font-awesome/ or use.fontawesome.com → Web Fonts+CSS via CDN<i class="fa-solid fa-..."> or <i class="fas fa-..."> usage patterns → class-based (Web Fonts+CSS or SVG+JS)Import statements in source files — scan for:
import { FontAwesomeIcon } → React componentimport { library } from @fortawesome/fontawesome-svg-core → library approachimport { faCoffee } → individual import approachSVG sprite sheets — look for <use href="...sprites/..."> patterns or sprite SVG files.
Web Components — look for <fa-icon> custom elements.
Other frameworks — look for Angular (angular.json, FontAwesomeModule), Svelte, etc.
The subagent should return: which Font Awesome packages are installed (with versions), any kit IDs found, CDN URLs, the framework integration method, import patterns observed in source files, the license (free vs pro), and any project conventions (wrapper components, default sizing, etc.).
After the subagent returns, if a kit ID was found, run ./scripts/fetch-kit.py --kit-id <id> (in the add-icon skill directory) to get the kit's version, license, method, and available families.
After discovery, determine:
free or pro. Detect from: kit config (via fetch-kit.py), npm package names (fontawesome-free vs fontawesome-pro, free-*-svg-icons vs pro-*-svg-icons), or CDN URL patterns.solid.classic.fetch-kit.py. For npm, infer from installed packages. For free users, only classic is available.Write the results to .font-awesome.md in the project root using this format:
# Font Awesome Configuration
Detected by the Font Awesome agent tools. Commit this file so the whole team benefits.
## Integration
- **Method:** [e.g., React components via @fortawesome/react-fontawesome]
- **Version:** [e.g., 7.2.0]
- **License:** [Free or Pro]
- **Kit ID:** [if applicable, or omit]
- **CDN URL:** [if applicable, or omit]
- **Families:** [e.g., classic, duotone, sharp, sharp-duotone — list all available families]
## Defaults
- **Style:** [e.g., solid]
- **Family:** [e.g., classic]
## Import Pattern
[Describe how icons are imported/used in this project. Examples:]
- Individual imports: `import { faCartShopping } from '@fortawesome/pro-solid-svg-icons'`
- Component: `<FontAwesomeIcon icon={faCartShopping} />`
## Conventions
[Any project-specific patterns observed, e.g.:]
- Icons are wrapped in a custom `<Icon>` component at `src/components/Icon.tsx`
- Default size is `lg`
Tell the user: "I've written .font-awesome.md with your project's Font Awesome configuration. You should commit this file so the team benefits and future icon additions are faster."
Do not proceed to the next step until .font-awesome.md has been written. The remaining steps depend on this file. If discovery fails to produce enough information to write a meaningful .font-awesome.md, stop and ask the user to clarify their Font Awesome setup before continuing.
Style — use this precedence:
style argument, use that..font-awesome.md.solid.Family — use this precedence:
.font-awesome.md.classic.Verify the icon is available in the chosen style and family by checking the output from icon-exists.py (it prints available families and styles). If the icon is not available in the requested style or family, tell the user and suggest available alternatives. Also check that the chosen family is in the project's available families list — if not, warn the user.
Based on the integration method from .font-awesome.md, generate the correct code. Below are the patterns for each method. Match the conventions observed in the project — don't introduce a new pattern if the project already has an established one.
@fortawesome/react-fontawesome)Individual imports (preferred when project uses this pattern):
import { faCartShopping } from '@fortawesome/pro-solid-svg-icons'
// or @fortawesome/free-solid-svg-icons for free icons
<FontAwesomeIcon icon={faCartShopping} />
The import name is the icon name in camelCase prefixed with fa. For example: cart-shopping → faCartShopping.
The package name follows the pattern: @fortawesome/{free|pro}-{style}-svg-icons. For example:
@fortawesome/free-solid-svg-icons@fortawesome/pro-regular-svg-icons@fortawesome/pro-duotone-svg-icons@fortawesome/sharp-solid-svg-icons@fortawesome/sharp-duotone-solid-svg-iconsLibrary approach (when project registers icons globally):
// In the library setup file:
import { library } from '@fortawesome/fontawesome-svg-core'
import { faCartShopping } from '@fortawesome/pro-solid-svg-icons'
library.add(faCartShopping)
// In components — use string reference:
<FontAwesomeIcon icon="cart-shopping" />
// or with explicit prefix for non-solid styles:
<FontAwesomeIcon icon={['far', 'cart-shopping']} />
Style prefixes: fas (solid), far (regular), fal (light), fat (thin), fad (duotone), fass (sharp solid), fasr (sharp regular), fasl (sharp light), fast (sharp thin), fasd (sharp duotone).
@fortawesome/vue-fontawesome)Similar to React but with Vue component syntax:
<font-awesome-icon :icon="['fas', 'cart-shopping']" />
Imports follow the same package/naming conventions as React.
<script src="https://kit.fontawesome.com/...">)<i class="fa-solid fa-cart-shopping"></i>
Class pattern depends on the family:
fa-{style} fa-{icon-name}
<i class="fa-solid fa-cart-shopping"></i>fa-sharp fa-{style} fa-{icon-name}
<i class="fa-sharp fa-regular fa-cart-shopping"></i>fa-sharp-duotone fa-{style} fa-{icon-name}
<i class="fa-sharp-duotone fa-solid fa-cart-shopping"></i>fa-duotone fa-{style} fa-{icon-name}
<i class="fa-duotone fa-solid fa-cart-shopping"></i>fa-{family} fa-{style} fa-{icon-name}
<i class="fa-slab fa-solid fa-cart-shopping"></i><i class="fa-jelly fa-regular fa-cart-shopping"></i>No imports needed — the kit handles loading.
Same class syntax as SVG+JS Kit:
<i class="fa-solid fa-cart-shopping"></i>
Family prefixes work the same way (e.g., fa-sharp fa-solid fa-cart-shopping). Ensure the appropriate CSS file is loaded (all.css or individual style sheets).
<svg class="icon">
<use href="/path/to/sprites/solid.svg#cart-shopping"></use>
</svg>
Match the sprite path used elsewhere in the project.
<fa-icon [icon]="faCartShopping"></fa-icon>
With the corresponding import in the component's TypeScript file.
<fa-icon>)<fa-icon class="fa-solid fa-cart-shopping"></fa-icon>
If the user provided a location argument:
Find the specified location in the code. Insert the icon code there, including any necessary import statements at the top of the file. Follow the project's existing patterns for formatting and placement.
If no location was provided:
Present the code snippet in a fenced code block with the appropriate language tag. If imports are needed, show them separately so the user knows what goes where.
Example output:
Add this import (if not already present):
import { faCartShopping } from '@fortawesome/pro-solid-svg-icons'Then use the component:
<FontAwesomeIcon icon={faCartShopping} />
If the icon is Pro-only and the project is using the free tier (based on .font-awesome.md license field or discovered packages), warn the user:
Note:
cart-shoppingrequires a Font Awesome Pro subscription. Your project appears to be using Font Awesome Free.
.font-awesome.md if neededReview whether any information discovered during this run is missing from .font-awesome.md. Examples of things that might be incomplete:
If anything is missing or outdated, update .font-awesome.md with the new information — keep the same format, just fill in the gaps. Do not rewrite sections that are already accurate. Let the user know what was updated so they can commit the change.
Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.
npx claudepluginhub fortawesome/fontawesome-agent-tools --plugin icons