@baybreezy/file-extension-icon
v0.0.4
Published
Modern, lightweight package for folder and file extension specific Material icons and VSCode icons
Downloads
287
Maintainers
Readme
@baybreezy/file-extension-icon

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.
✨ 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 nameopen(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 nameopen(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" --copyCLI 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
📊 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
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";Use modern bundlers with tree-shaking support (Vite, Rollup, esbuild, webpack 5+)
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
- Original Author: MD. Minhazul Islam
- Original Package: file-extension-icon-js
- License: MIT
Icon Sources
- Material Icon Theme by Philipp Kief
- VSCode Icons by VSCode Icons Team
Inspiration
- vscode-icons-js by Dominik Dereǰanik
- file-icons-js by Web Semantics
