* [CL-1009] button style updates (#18301) * add new button styles * update disabled styles * updated size stories * update disabled button story names * updated button stories * add more explicit screenshots * make class list a computed signal * updated button docs * allow unstyled button to inherit color * use unstyled button in callouts until callout updates * base button directive WIP * add base button directive * fix focus and hover styles * fix lint error * remove commented code that moved to base directive * ensure buttonStype defaults correctly * migrate legacy icon button types * contrast button wips * pull in latest and fix disabled with attr * fix legacy variant * add back nav contrast button variant * updated icon button docs * rename nav contrast variant and fix contrast focus * fix button sizing * fix product switcher button classes * add contrast icon button story * fix border color * update to primaryGhost variant * [CL-1025] icon font refresh (#18727) * adding new icons * migrate to new icon names * updated icon build docs * resolve conflicts and re-run migration * add icons deps to uif ownership * fix incorrect migration * fix misnamed icon * create filter icon and fix mapping error * updated readme and add migration script to package.json * fix prettier warnings * remove browser alt from definition list * add missing icon types * fix image name migrated in error and update regex to not change these * ensure icon array is updated automatically * updated build comment * remove unnecessary direct execution command * remove direct run command * allow legacy icon names to map to new icons * [CL-1025] Icon font refresh - Temporary migration state with legacy names (#18948) * Revert icon name migrations, preserve migration tooling Reverted all icon name changes that were applied by the migration scripts, while preserving: - New icon SVG files in libs/assets/src/material-icons/ - Icon font files in libs/angular/src/scss/bwicons/ - Migration scripts in scripts/material-icons/ - NPM scripts and dependencies for icon tooling This allows running the migration fresh when ready. Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com> * Build icon font with bidirectional legacy/new name mapping Ran icons:build to generate bidirectional icon mappings: - SCSS now includes 155 icons (both Figma and legacy BWI names) - TypeScript icon.ts updated with all 155 names - All legacy names (e.g., bwi-question-circle, bwi-plus) point to new icon assets - All new names (e.g., bwi-help, bwi-add) also available - Codebase can continue using legacy names with new icon designs This enables the temporary migration state where code uses existing legacy icon names but displays the new refreshed icon assets. Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com> * Fix: revert bwi-filter back to bwi-grid across codebase bwi-grid is the correct new icon name and should not be reverted. The changes from bwi-filter to bwi-grid were manual corrections, not part of the automated migration. Updated 16 files to restore bwi-grid icon references. Addresses feedback from Bryan Cunningham on PR #18948 --------- Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com> * remove duplicate key and add back dep ownership change * fix formatting errors --------- Co-authored-by: Will Martin <contact@willmartian.com> Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com> * fix button variant * [CL-1040] updated palette colors (#19401) * [CL-973] chip component (#18798) * wip * WIP * create chip filter component * trying to get truncation to work * fix truncation * create chip-action component * fix type errors * add chip component * add shared story args * have chips take label input * fix test template and imports * fixing arg types and disabled states * simplify disabled logic * fix dimssis button alignment * update menu focus color * updated chip docs * update chip-select usage to chip-filter * fix full width icon layout * remove commited code * export chip component * remove commented code * expose full width * chip component should not go full width * use bit-icon in filter template * remove commented code * updated chip docs * remove extra truncate class * fix dupe input definitions * move import to correct line * read base chip values directly * remove standlaone as it's the default * forward size correctly * create full width arg type * let type be infered * updated jsdoc comments * use more modern angular syntax * rename components to use kebab case * remove redundant docs * remove inaccurate link docs * remove enum like types * remove dead code * remove unused spec * remove host bindings * restructure chips folders * add max width class * remove full width docs * add internal comment * bind to missing controls * fixing docs * replace disabled verbiage with inactive * remove unnecessary comment * default to primary * do not allow end icon in action chip * take chip action screenshots in both themes * use selected input for base directive * fix width error * coerce to boolean * fixed end icon reference * fix code reference to endIcon * fixing chip filter specs * fix missing input transform * fix docs * fix input and add truncate * ensure chip content truncates * updated slot naming * updated example to use new flow control * fix typing for option.icon * fix failing test, fix filter type, and support colored icons in filter options * fix failing test * doc updates * change dismissed event name * remove standalone * fix selector * fix docs * remove unused fvw data property and fix docs links * use base as host directive in chip * fix spec button selectors * fix duplicate class binding * fix incorrect variant resolution * handle undefined size * fix signal type * remove duplicate input * fix failing spec * updated styles for trailing icon spacing and font size * padding tweaks for visual design * make variant a writable model * use logical text align * update slot names * remove dismissible input * add back missing import * remove ability to set chip filter to small size * create size arg type --------- Co-authored-by: Vicki League <vleague@bitwarden.com> * [CL-987] Update Nav Group and Nav Item components (#18965) * updated side nav `nav-group` and `nav-item` components * - added focus states - set cursor pointer for nav-item - updated arrow orientations * - updated `navItemIndentationPadding` - reverted `[treeDepth]` for `nav-group` - removed placeholder arrow * - removed text style from starting slot container - fixed routes in story * created shared container classes var * fixes from rebase, override `border-radius` for collapse arrow button * updated `tw-theme`: reverted `--color-bg-hover` and added `--color-bg-sidenav-hover` * removed end slot `div` styles from rebase, updated `buttonType` in `nav-group` story * added dark mode `--color-bg-sidenav-hover` * added `xsmall` size variant to 'Icon Button' * - updated navs to use 'xsmall' button - fixed container padding - removed custom arrow button styles * fixed type error * fixed focus-visible state by adding `tw-outline-none` to `nav-item` * fixed type error * placed arrow button directly in start slot * defined `containerClasses` in template * renamed 'item-active-hover' to 'active-item-hover' for consistency * missed renaming from `item-active-hover` to `active-item-hover` * fixed 'hover' and 'active' colors, added colors for arrow hover states * - separated buttons sizes for 'Button' and 'Icon Button' from `BaseButtonDirective` into respective components - moved `border-radius` style from Directive into own components * fixed/simplified focus colors, added sidenav specific focus colors * updated 'arrow' icon size for nav group, updated 'xsmall' font size * trigger Claude review * removed `tw-text-2xl` in nav-group for arrow button * removed unused `NgClass` import * more cleanup, removed unused `Ng` imports * converted `_isActive` to signal and `showActiveStyles` to computed * removed instances of `variant="tree"` * renamed color variables from `admin-sidenav` to `sidenav-secondary` --------- Co-authored-by: Will Martin <contact@willmartian.com> * fix lint * [CL-1096] Fix icon button width shrinking in flex containers (#19529) Add tw-shrink-0 to prevent icon buttons from shrinking below their fixed size when placed inside flex containers. * [CL-1101] Fix chip dismiss button hover style and add interaction state stories (#19530) Use the correct bg-bg-hover token for dismiss button hover background, matching the Figma spec. The previous hover-contrast token was invisible on light backgrounds. Add InteractionStates story showing Default, Hover, Focus, and Inactive states for both large and small sizes. * [CL-1098] Fix danger icon button color in form field suffix (#19532) * [CL] Fix danger icon button color in form field suffix Don't apply tw-text-muted to icon button suffixes — icon buttons manage their own text color via buttonType, so the muted class was overriding danger/primary colors (e.g. blue icon on red background in Cipher Form). * [CL] Fix danger icon button color in form field suffix Don't apply tw-text-muted to icon button suffixes — icon buttons manage their own text color via buttonType, so the muted class was overriding danger/primary colors (e.g. blue icon on red background in Cipher Form). Also adds a DangerButtonInputGroup story to capture this case. * [CL-1094] Update icon button default variant to primaryGhost (#19534) * [CL-1094] Update icon button default variant to primaryGhost Change buttonType from input to model in BaseButtonDirective, and set the default to primaryGhost in the icon button constructor. * [CL-1094] Fix icon button default variant using own input + effect Using model.set() in the constructor is overridden by Angular's input initialization lifecycle. Instead, own buttonType as an input directly on BitIconButtonComponent with primaryGhost as the default, and sync to the base directive via effect. * [CL-959] update badge component styles (#19026) * badge wip * dynamic truncated badge tooltip * support legacy variants for now * add deprecation types and remove hover styles * updated story docs * add default icons for badges * fix incorrect color mapping * add ability to hide start icon * take snapshot in both themes * add icon size styles * remove tooltip code * update at risk password to use actual buttons * more specific badge truncation docs * remove badge module from imports * use chip action for link * fix missing import * use chip in multi-select inputs * update org badge to use primary chip * update premium badge to accent primary action chip * use chip action for vault item fill * remove unnecessary icon in badge * update obsolete notification variant * replace usage of bitBadge on button in stories * remove explicit input to hide startIcon * use berry instead of badge * fix type error * fixing imports and badge usage * use logical text align * remove dead code and update jsdoc comment * add back ability to not truncate * remove default icon for accent-primary * add missing translation keys to multi select story * allow null as default icon type * add element selector and update stories to use it * conditionally apply truncate class * conditionally apply title text * migrate badge to berry * use correct input for content * use berry in toggle group stories * remove unused template reference * remove unused import of badge * remove unused custom color code * remove unused service injection * [CL-1102] Fix help icon size in bit-label (#19533) * [CL-1102] Fix help icon size in bit-label Target bwi icons inside bit-label with [&_.bwi]:tw-text-xl to restore correct icon sizing after recent icon style changes. * [CL-1102] Fix text alignment regression in bit-label Add tw-leading-none to bwi icons to prevent the line-height from tw-text-xl from disrupting baseline alignment. * remove bwi-sm from label icon --------- Co-authored-by: Bryan Cunningham <bryan.cunningham@me.com> * [CL-964] Update Callout Component (#19424) * updated callout component * renamed consumer bit-callout `type` from 'default' to 'subtle' * updated callout 'end' slot * migrated spotlight to callout, deleted spotlight * - updated `title` comment - updated stories and mdx * removed `useAlertRole` * added `CommonModule` import and updated `buttonType` in stories * updated 'Accessibility' guidelines * updated 'close' button * - updated stories for clearer code - set `(onDismiss)` only for WithCloseButton story * added boolean switch for `persistent` to story * fixed tests * prettier fix * - updated `bit-callout` instances of `buttonType="unstyled"` to use appropriate `buttonType` - updated story for correct usage of button styles * fixed `type` in `vault-list` * updated to use `bit-icon` * - fixed vertical centering of icon and text - updated to 'OnPush' change detection * fixed error: added 'close' to `mockLayoutI18n` * updated `bit-callout` jsdoc comment and mdx * fixed `persistent` callout in `admin-settings` * removed "interrupt" language * reverted fix for `bit-callout` `persistent` * fixed type error * added `close` translation to stories utilizing `bit-callout` * converted to JSDoc comments * updated 'close' button to check if `dismiss` output is bound * fix: removed `readonly` from `isDismissible` * converted `isDismissble` to signal * added translation to `phishing-warning' story * added bottom margin back in to callout component * fixed type error, fixed `icon` values * revert subscription-card callout icon to default if not defined * fix: update 'bit-callout' type to 'subtle' * updated colors in `tw-theme` * added conditional check to compute vertical alignment class * updated more colors, slight restructure to match design * fixed vertical alignment with 'close button', avoid long text crowding/overflowing * remove default icons on non-semantic variants (#19614) * remove default icons on non-semantic variants * add back info icon to info variant * remove info icon again * [CL-1095] add expanded state for disclosure button (#19637) * add brand stronger colors * add aria-expanded styling for primary ghost button * make all variants aria-expanded style match hover styles * update orage-600 color value to fix contrast * minor spacing update to account for expanded button style * do not show expanded state on sidenav buttons * no expanded style on toggle width button * remove extra letter spacing and update story copy (#19668) * [CL-1123] fix ghost button inactive styles (#19669) * fix ghost button inactive styles * remove type declaration * [CL-1119] toggle berry update (#19609) * update toggle groups to use berry * set berry variant based on selected state * fix failing spec * add spec to test berry variant set correctly * fix import errors caused by bad merge conflict resolution * remove unnecessary variant delaration * update kitchen sink stories to use berry * [CL-1122] BUG FIX: Migrated Icon Buttons with button type 'danger' to 'dangerGhost' (#19677) * migrated `bitIconButton` with 'danger' `buttonType` to 'dangerGhost' * reverted icon-button story * fix button variant from merge * [CL-1117] BUG FIX: Side nav collapse arrow is placed too far left (#19623) * - updated spacing for side-nav collapse arrow button - updated collapsed nav-item button spacing and dimensions - moved individual nav-item wrapper padding into side-nav component - added button to 'WithLongText' nav-item story * added sidenav specific hover style to toggle collapse button * - set horizontal padding back to 'nav-item' - updated 'bit-divider' color to 'bg-border-brand' * updated hover styles for interactive trailing elements * added '4px' more end padding to trailing buttons * updated 'bit-divider' colors for secondary and dark theme * moved button hover styles into 'side-nav' button variant * updated sidenav-divider color for dark theme * removed `tw-w-10` on nav-item collapsed * updated inline padding to `12px` for both collapse and expanded states * [CL-1117] cleaned up, renamed, and organized sidenav color variables (#19665) * - unified 'strong' styles and `showActiveStyles` into `[style]` - updated 'side-nav' button variant's `aria-expanded` and `focus-visible` styles * - inherit bg and fg from parent `sidenav` - allow trailing buttons set own fg * updated nav group story for trailing elements * updated nav-logo 'focus' to nav focus style * let toggle width arrow inherit 'aria-expanded' style from 'side-nav' buttontype * removed danger button variants from nav group story --------- Co-authored-by: Bryan Cunningham <bcunningham@bitwarden.com> Co-authored-by: Vicki League <vleague@bitwarden.com> Co-authored-by: Leslie Xiong <lxiong@livefront.com> |
2 months ago | |
|---|---|---|
| .. | ||
| README.md |
…
|
|
| build-with-bwi-names.ts |
…
|
|
| migrate-icon-names.ts |
…
|
|
| migration-map.ts |
…
|
|
| reverse-migrate-icon-names.ts |
…
|
|
README.md
Icon Font Management
This directory contains scripts and resources for managing the Bitwarden icon font (BWI).
Overview
The icon system uses Figma-exported SVG files that are converted into a web font using Fantasticon. SVG filenames directly become CSS class names (with the bwi- prefix added automatically), making the workflow simple and straightforward.
Adding a New Icon
Follow these steps to add a new icon to the icon font:
1. Export the Icon from Figma
- Open the Figma icon file
- Select the icon you want to export
- Export as SVG with these settings:
- Outline stroke: Enabled
- Include "id" attribute: Disabled
- Simplify stroke: Enabled
- Name the file using kebab-case (e.g.,
help.svg,star-filled.svg,add-circle.svg) - Save the SVG file to
libs/assets/src/material-icons/
Important: The SVG filename directly becomes the CSS class name. For example, help.svg will generate the class bwi-help, and star-filled.svg will generate bwi-star-filled. Choose your filename carefully as it determines how developers will use the icon.
2. Generate the Icon Font
Run the build script:
npm run icons:build
This script will:
- ✅ Generate the icon font files from all SVGs (woff2, woff, ttf, svg)
- ✅ Update the SCSS with the new icon mappings
- ✅ Automatically update
libs/components/src/shared/icon.tswith the new icon - ✅ Clean up temporary build artifacts
Output files:
libs/angular/src/scss/bwicons/fonts/bwi-font.*- Font fileslibs/angular/src/scss/bwicons/styles/style.scss- Updated with new iconlibs/components/src/shared/icon.ts- Auto-generated TypeScript icon list (do not edit manually)
Note: The TypeScript icon array is now auto-generated during the build process. You no longer need to manually add icons to icon.ts.
3. Add to Storybook Documentation
Add your icon to the appropriate category in libs/components/src/stories/icons/icon-data.ts:
// Choose the appropriate category:
// - statusIndicators
// - bitwardenObjects
// - actions
// - directionalMenuIndicators
// - miscObjects
// - platformsAndLogos
const actions = [
// ... existing icons ...
{
id: "bwi-your-new-icon",
usage: "Detailed description of when and how to use this icon.",
},
];
Usage description guidelines:
- Start with what the icon indicates or does
- Include context-specific guidance (mobile, desktop, toggle states, etc.)
- Mention any variants or related icons
- Note any accessibility considerations
4. Test Your Icon
-
Visual verification: Run Storybook to see your icon
npm run storybookNavigate to "Documentation / Icons" to verify your icon appears correctly
-
Type checking: Ensure TypeScript compiles without errors
npm run test:types -
Usage test: Try using the icon in a component
<bit-icon icon="bwi-your-new-icon"></bit-icon>
Migrating Icon Names
Use the migration script when you need to rename icon references across the entire codebase. This is different from adding a new icon—it's for bulk-renaming existing icon class names.
When to Use Migration
- You're standardizing icon names to match new Figma conventions
- You're replacing a legacy icon name with a new one
- You need to update icon references in dozens or hundreds of files
Important: This is NOT for adding new icons. Use the "Adding a New Icon" workflow above for that.
How to Migrate Icon Names
1. Add the mapping to migration-map.ts
Open scripts/material-icons/migration-map.ts and add your mapping to the BWI_TO_FIGMA object:
export const BWI_TO_FIGMA: Record<string, string> = {
// ... existing mappings ...
// Add your migration here
"old-icon-name": "new-icon-name",
};
Example:
// Rename bwi-question-circle to bwi-help
"question-circle": "help",
// Rename bwi-spinner to bwi-loading
"spinner": "loading",
Note: Do not include the bwi- prefix—the script adds it automatically.
2. Preview the changes (recommended)
Run the migration script in dry-run mode to see what will be changed:
npm run icons:migrate -- --dry-run
This shows you all files and occurrences that will be updated without actually modifying anything.
3. Run the migration
Once you've verified the preview, run the actual migration:
npm run icons:migrate
4. Review the migration report
After migration completes, check scripts/material-icons/migration-report.json for a detailed report of all changes:
[
{
"file": "apps/web/src/app/components/icon.component.html",
"oldName": "bwi-question-circle",
"newName": "bwi-help",
"occurrences": 3
}
// ... more entries
]
What Gets Updated
The migration script searches and replaces icon names in:
- TypeScript files (
.ts) - HTML templates (
.html) - SCSS/CSS files (
.scss,.css) - Markdown documentation (
.md,.mdx)
In the following directories:
apps/libs/bitwarden_license/
Excluding build/cache directories like node_modules, dist, .git, etc.
Migration Workflow Example
Complete workflow for renaming an icon:
# 1. Add mapping to migration-map.ts
# "spinner": "loading"
# 2. Preview changes
npm run icons:migrate -- --dry-run
# 3. Run migration
npm run icons:migrate
# 4. Review migration-report.json
# 5. Commit the changes
git add .
git commit -m "Migrate bwi-spinner to bwi-loading"
File Structure
scripts/material-icons/
├── build-with-bwi-names.ts # Main build script
├── migrate-icon-names.ts # Migration script for bulk renames
├── migration-map.ts # Configuration for migration
├── migration-report.json # Generated migration report
└── README.md # This file
libs/assets/src/material-icons/
├── help.svg # Figma-exported SVG files
├── star-filled.svg
└── ... (all source SVG files)
libs/angular/src/scss/bwicons/
├── fonts/
│ ├── bwi-font.woff2 # Generated font files
│ ├── bwi-font.woff
│ ├── bwi-font.ttf
│ └── bwi-font.svg
└── styles/
└── style.scss # Generated SCSS with icon mappings
libs/components/src/
├── shared/
│ └── icon.ts # TypeScript icon types
└── stories/icons/
└── icon-data.ts # Storybook documentation
Icon Naming Conventions
The icon system uses a direct naming approach: the SVG filename becomes the CSS class name (with bwi- prefix added automatically).
Naming Guidelines
- Use kebab-case:
star-filled.svg, notstarFilled.svgorstar_filled.svg - Be descriptive: Choose names that clearly indicate the icon's purpose
- Follow Figma: Use names from the Figma design system when possible
- Consider usage: The filename determines how developers reference the icon
Examples
| SVG Filename | Generated CSS Class | Usage Example |
|---|---|---|
help.svg |
.bwi-help |
Help/question icons |
star-filled.svg |
.bwi-star-filled |
Filled star for favorites |
add-circle.svg |
.bwi-add-circle |
Add button with circle background |
arrow-filled-down.svg |
.bwi-arrow-filled-down |
Dropdown indicators |
visibility-off.svg |
.bwi-visibility-off |
Hide password toggle |
Legacy Mappings
Some icons have legacy mappings documented in migration-map.ts for historical reference. For example:
bwi-question-circlewas migrated tobwi-helpbwi-spinnerwas migrated tobwi-loadingbwi-pluswas migrated tobwi-add
These mappings are only relevant if you're running migrations. New icons don't need any mappings.
Troubleshooting
Icon not appearing after build
- Verify the SVG file is in
libs/assets/src/material-icons/ - Check that your SVG filename uses kebab-case and has the
.svgextension - Run
npm run icons:buildagain - Clear browser cache
Wrong icon displaying
- Verify the SVG filename matches what you expect (it becomes the CSS class)
- Ensure you're using the correct
bwi-class name in your component - Check for duplicate SVG files with similar names
Font not updating
- Delete the generated font files and rebuild:
rm libs/angular/src/scss/bwicons/fonts/bwi-font.* npm run icons:build
TypeScript errors
- Ensure you added the icon to
libs/components/src/shared/icon.ts - Check that the icon name format matches:
bwi-icon-name
Advanced Usage
Icon Sizing Classes
Available utility classes (defined in style.scss):
.bwi- Base class (required).bwi-sm- Small (0.875em).bwi-lg- Large (~1.33em).bwi-2x- 2x size.bwi-3x- 3x size.bwi-4x- 4x size.bwi-fw- Fixed width (~1.3em)
Rotation & Animation
.bwi-rotate-270- Rotate 270 degrees.bwi-spin- Animated spinning (for loading spinners)
Example Usage
<!-- Basic icon -->
<i class="bwi bwi-help"></i>
<!-- Large icon -->
<i class="bwi bwi-help bwi-lg"></i>
<!-- Fixed width icon (useful in lists) -->
<i class="bwi bwi-help bwi-fw"></i>
<!-- Spinning icon -->
<i class="bwi bwi-loading bwi-spin"></i>
Best Practices
- Icon Consistency: Follow the existing Figma design system naming
- Semantic Naming: Use descriptive filenames that clearly indicate the icon's purpose
- Documentation: Always add usage guidelines to Storybook
- Accessibility: Include proper ARIA labels when using icons without text
- SVG Optimization: Export from Figma with strokes outlined
- Testing: Verify icons in Storybook before committing
Resources
- Fantasticon Documentation
- Icon Font Best Practices
- Internal Figma Icon Library: [Link to your Figma file]
Support
For questions or issues:
- Check the troubleshooting section above
- Review existing icons in
libs/assets/src/material-icons/ - Consult the design team for icon naming conventions