npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@baybreezy/file-extension-icon

v0.0.4

Published

Modern, lightweight package for folder and file extension specific Material icons and VSCode icons

Downloads

287

Readme

@baybreezy/file-extension-icon

Demo Cover Image

Modern, TypeScript-first package for file and folder extension-specific Material and VSCode icons

A complete rewrite of file-extension-icon-js using modern TypeScript, ESM-first approach, and the UnJS ecosystem for optimal performance and developer experience.

npm version npm bundle size License: MIT

✨ Features

  • 🎨 Two icon themes: Material Icon Theme & VSCode Icons
  • 🔷 TypeScript: Full type safety with comprehensive type definitions
  • 📦 Zero dependencies: No runtime dependencies
  • 🌳 Tree-shakeable: Only bundle what you use
  • 🔄 Dual format: ESM and CommonJS support
  • 🚀 Modern build: Built with Unbuild for optimal output
  • Well-tested: Comprehensive test coverage
  • 📝 Well-documented: Full JSDoc comments and examples
  • 🖥️ CLI included: Interactive terminal tool for browsing and exporting icons

📦 Installation

# @antfu/ni
npx ni @baybreezy/file-extension-icon

🚀 Usage

Basic Usage

import {
  getMaterialFileIcon,
  getMaterialFolderIcon,
  getVSIFileIcon,
  getVSIFolderIcon,
} from "@baybreezy/file-extension-icon";

// Get Material Design file icon
const jsIcon = getMaterialFileIcon("index.js");
// Returns: "data:image/svg+xml;base64,..."

// Get Material Design folder icon (closed)
const folderIcon = getMaterialFolderIcon("components");

// Get Material Design folder icon (open)
const openFolderIcon = getMaterialFolderIcon("components", true);

// Get VSCode file icon
const tsIcon = getVSIFileIcon("app.ts");

// Get VSCode folder icon
const vsiFolderIcon = getVSIFolderIcon("src", true);

Framework Examples

React / Vue / Svelte

import { getMaterialFileIcon } from "@baybreezy/file-extension-icon";

function FileIcon({ fileName }: { fileName: string }) {
  const icon = getMaterialFileIcon(fileName);

  return <img src={icon} alt={fileName} width={24} height={24} />;
}

HTML

<script type="module">
  import { getMaterialFileIcon } from "@baybreezy/file-extension-icon";

  const icon = getMaterialFileIcon("index.html");
  document.getElementById("icon").src = icon;
</script>

<img id="icon" alt="html" width="24" height="24" />

Advanced Usage

import {
  convertToBase64,
  createDataUri,
  findIconInCollection,
  getIconFromMap,
  getMaterialFileIcon,
} from "@baybreezy/file-extension-icon";

// The package intelligently matches file names
getMaterialFileIcon("app.component.ts"); // Matches Angular component
getMaterialFileIcon("test.spec.ts"); // Matches test file
getMaterialFileIcon("package.json"); // Matches package.json
getMaterialFileIcon("Dockerfile"); // Matches Docker

// Works with any file extension
getMaterialFileIcon("script.py");
getMaterialFileIcon("style.scss");
getMaterialFileIcon("README.md");

📚 API Reference

Material Icons

getMaterialFileIcon(fileName: string): string

Returns a base64-encoded SVG data URI for the given file name using the Material Icon theme.

Parameters:

  • fileName (string): The file name with or without path (e.g., "index.js", "src/app.ts")

Returns: Base64-encoded data URI string

Example:

const icon = getMaterialFileIcon("index.js");
// => "..."

getMaterialFolderIcon(folderName: string, open?: boolean): string

Returns a base64-encoded SVG data URI for the given folder name using the Material Icon theme.

Parameters:

  • folderName (string): The folder name
  • open (boolean, optional): Whether to return the open folder icon. Default: false

Returns: Base64-encoded data URI string

Example:

const closedIcon = getMaterialFolderIcon("components");
const openIcon = getMaterialFolderIcon("components", true);

VSCode Icons

getVSIFileIcon(fileName: string): string

Returns a base64-encoded SVG data URI for the given file name using the VSCode Icon theme.

Parameters:

  • fileName (string): The file name with or without path

Returns: Base64-encoded data URI string

getVSIFolderIcon(folderName: string, open?: boolean): string

Returns a base64-encoded SVG data URI for the given folder name using the VSCode Icon theme.

Parameters:

  • folderName (string): The folder name
  • open (boolean, optional): Whether to return the open folder icon. Default: false

Returns: Base64-encoded data URI string

Utility Functions

The package also exports utility functions for advanced use cases:

import {
  convertToBase64,
  createDataUri,
  findIconInCollection,
  getIconFromMap,
} from "@baybreezy/file-extension-icon";

🖥️ CLI Tool

This package includes an interactive CLI tool for browsing and exporting icons!

# Run interactively
npx file-icon

# Or with flags for quick export
npx file-icon -t material -y file -n "index.js" --copy

CLI Features

  • 🎨 Browse Material and VSCode icon themes
  • 🔍 Search by file/folder name or browse all icons
  • 📋 Copy to clipboard, save to file, or display in terminal
  • ⚡ Fast and beautiful UI powered by Clack

📖 Full CLI Documentation

📊 Bundle Size

This package contains comprehensive icon data for both Material and VSCode icon themes.

  • Package size (compressed): ~2.6 MB
  • Unpacked size: ~8.6 MB
  • Includes: Thousands of file and folder icons

Note: Modern bundlers with tree-shaking can significantly reduce the final bundle size by including only the icons you use. Ensure your bundler is configured for tree-shaking to optimize bundle size.

Optimization Tips

  1. Import only what you need:

    // ✅ Good - Tree-shakeable
    import { getMaterialFileIcon } from "@baybreezy/file-extension-icon";
    // ❌ Avoid - Imports everything
    import * as Icons from "@baybreezy/file-extension-icon";
  2. Use modern bundlers with tree-shaking support (Vite, Rollup, esbuild, webpack 5+)

  3. Consider code splitting if you support multiple icon themes

🛠️ Development

# Install dependencies
npm install

# Build the package
npm run build

# Run tests
npm test

# Run tests with coverage
npm run test:coverage

# Run tests in UI mode
npm run test:ui

# Type check
npm run typecheck

# Lint code
npm run lint

🧪 Testing

This package includes comprehensive test coverage:

# Run tests in watch mode
npm test

# Generate coverage report
npm run test:coverage

# Open test UI
npm run test:ui

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

📄 License

MIT © Behon Baker

🙏 Credits & Acknowledgments

This package is a complete TypeScript rewrite of file-extension-icon-js by MD. Minhazul Islam.

Original Package

Icon Sources

Inspiration

🔗 Links