Search...Search plugins and themes...
⌘K
Sign in
  • Get started
  • Download
  • Pricing
  • Enterprise
  • Account
  • Obsidian
  • Overview
  • Sync
  • Publish
  • Canvas
  • Mobile
  • Web Clipper
  • CLI
  • Learn
  • Help
  • Developers
  • Changelog
  • About
  • Roadmap
  • Blog
  • Resources
  • System status
  • License overview
  • Terms of service
  • Privacy policy
  • Security
  • Community
  • Plugins
  • Themes
  • Discord
  • Forum / 中文论坛
  • Merch store
  • Brand guidelines
Follow us
DiscordTwitterBlueskyThreadsMastodonYouTubeGitHub
© 2026 Obsidian

Add Custom Icons

riffaellsriffaells874 downloads

Load custom SVG icons from icons folder and restart plugins automatically.

Add to Obsidian
  • Overview
  • Scorecard
  • Updates5

A plugin for Obsidian that loads custom SVG icons from the icons folder and automatically restarts selected plugins. The icons folder can be located either in .obsidian or in the plugin root.

Project Structure

├── main.ts                    # Main plugin file
├── manifest.json              # Plugin manifest
├── icons/                     # SVG icons folder
│   └── example-icon.svg       # Example icon
├── src/
│   ├── lang/                  # Built-in translations
│   │   ├── en.ts             # English translations
│   │   ├── ru.ts             # Russian translations
│   │   └── index.ts          # Translation exports
│   ├── types/
│   │   └── index.ts          # TypeScript types and interfaces
│   ├── utils/
│   │   ├── constants.ts      # Constants and default settings
│   │   └── helpers.ts        # Helper functions
│   ├── services/
│   │   ├── IconLoader.ts     # Icon loading service
│   │   ├── PluginManager.ts  # Plugin management service
│   │   └── I18nService.ts    # Localization service
│   └── ui/
│       └── SettingsTab.ts    # Settings interface
└── autobuild.py              # Development sync script

Features

  • SVG Icon Loading: Automatically scans the icons folder and loads all SVG files
  • Caching: Uses cache for fast loading of unchanged icons
  • SVG Normalization: Automatically adapts icons to Obsidian theme
  • Automatic Restart: Can restart selected plugins or entire Obsidian
  • Recursive Scanning: Supports subfolders in the icons directory
  • Batch Processing: Processes icons in batches for better performance
  • Multilingual: Support for Russian and English with auto-detection
  • Modern UI: Compact settings interface with convenient plugin management
  • Built-in Translations: All translations are compiled into the plugin code

Usage

  1. Place SVG files in the icons folder in the plugin root or in the .obsidian folder
  2. The plugin will automatically load icons on startup
  3. Use the "Reload custom icons" command for manual reload
  4. Configure automatic restart in plugin settings

Settings

  • Enable Auto Restart: Automatically restart plugins after loading icons
  • Restart Target: What to restart (selected plugins, entire Obsidian, or nothing)
  • Plugin Selection: Convenient interface for adding/removing plugins from restart list

Development

# Install dependencies
npm install

# Build for development
npm run dev

# Build for production
npm run build

Automatic Build and Sync

For convenient development, a Python auto-build script is included:

# Install Python dependencies
pip install watchdog rich

# Run auto-build
python autobuild.py --vault "path/to/obsidian/vault"

The script automatically monitors changes in main.js, styles.css, and manifest.json, copying them to the plugin folder in Obsidian.

Architecture

The plugin is divided into logical modules:

  • main.ts: Main plugin class, coordinates all services
  • IconLoader: Handles icon loading, caching, and processing
  • PluginManager: Manages plugin and Obsidian restarts
  • SettingsTab: User interface for settings
  • I18nService: Localization service with built-in translations
  • types: Common TypeScript types
  • utils: Constants and helper functions

Translation System

The plugin uses a built-in translation system:

  • All translations are compiled into the main plugin code
  • No external language files needed
  • Automatic language detection based on Obsidian settings
  • Currently supports English and Russian

License

MIT License - see LICENSE file for details.

88%
HealthExcellent
ReviewSatisfactory
About
Load custom SVG icons from your icons folder, scanning subfolders and normalizing them to match your Obsidian theme. Use cached, batched processing for fast loads and optionally restart selected plugins or entire Obsidian after icons update.
IconsThemingAppearance
Details
Current version
1.0.9
Last updated
Last week
Created
10 months ago
Updates
5 releases
Downloads
874
Compatible with
Obsidian 0.15.0+
Platforms
Desktop, Mobile
License
MIT
Report bugRequest featureReport plugin
Author
riffaellsriffaells
GitHubriffaells
  1. Community
  2. Plugins
  3. Icons
  4. Add Custom Icons

Related plugins

Callout Manager

Easily create and customize callouts.

Minimal Theme Settings

Control the colors and fonts in Minimal Theme.

Hider

Hide interface elements such as tooltips, status bar, titlebar, and more.

Style Settings

Adjust theme, plugin, and snippet CSS variables.

Link Favicons

See the favicon for a linked website.

Inline Callouts

Add inline callouts/badges/icons to notes.

Contextual Typography

Add a data-tag-name attribute to all top-level divs in preview mode containing the child's tag name, allowing contextual typography styling.

Iconize

Add icons to anything in Obsidian, including files, folders, and text.

Background Image

Specify a remote URL as the background image, and a few settings to tweak the experience.

Iconic

Customize your icons and their colors directly from the UI, including tabs, files & folders, bookmarks, tags, properties, and ribbon commands.