A Framework-Agnostic PHP Library for Rendering SVG Icons
- Access 200,000+ icons from 200+ Iconify sets, downloadable via CLI (no Node.js required)
- Load icons from local SVG directories, the Iconify API, JSON collections, or a hybrid of local files with API fallback
- Style icons with an immutable fluent API:
size(),class(),fill(),stroke(),rotate(),flip(), and more - Integrates with Twig, Laravel Blade, Slim, and CommonMark
- Deduplicate repeated icons on a page using SVG sprite sheets with
<symbol>/<use>references - Layer multiple icons into a single composite SVG with icon stacking
- Decorative icons get
aria-hidden="true"automatically; labeled icons getrole="img" - SVG content is sanitized: scripts, event handlers, and external resources are stripped
- PSR-16 file-based caching with configurable TTL
composer require frostybee/swarm-iconsRequires PHP 8.2+ and psr/simple-cache ^3.0.
Download icon sets and render:
php bin/swarm-icons json:download mdi tabler heroiconsuse Frostybee\SwarmIcons\SwarmIcons;
use Frostybee\SwarmIcons\SwarmIconsConfig;
$manager = SwarmIconsConfig::create()
->discoverJsonSets()
->cachePath('/var/cache/icons')
->build();
SwarmIcons::setManager($manager);
echo swarm_icon('mdi:home', ['class' => 'w-6 h-6']);
// <svg class="w-6 h-6" aria-hidden="true">...</svg>You can also register local SVG directories or fetch from the Iconify API at runtime:
$manager = SwarmIconsConfig::create()
->addDirectory('custom', '/path/to/svgs')
->addIconifySet('heroicons')
->defaultAttributes(['class' => 'icon'])
->prefixAttributes('heroicons', ['stroke' => 'currentColor'])
->fallbackIcon('heroicons:question-mark-circle')
->build();For detailed guides on configuration, providers, CLI commands, framework integrations, and advanced options, visit the full documentation.
composer install| Command | Description |
|---|---|
composer test |
Run PHPUnit tests |
composer phpstan |
Run PHPStan (level 8) |
composer cs-check |
Check code style (dry-run) |
composer cs-fix |
Auto-fix code style |
composer test-all |
PHPStan + CS check + tests |
This project is licensed under the MIT License. See LICENSE for details.