vscode-file-explorer-tools

File Explorer Tools

File Explorer Tools

Color-coded file scopes, recursive folder expand, and automatic symbol rename on file rename — power tools for the VS Code Explorer

File Explorer Tools

Why I Built This

I work on a large monorepo with hundreds of folders and thousands of files. Every day I’d find myself collapsing and expanding the same subtrees, losing track of which files belong to the feature I’m working on, and manually renaming classes after renaming files. Small frictions, but they add up to real time lost.

VS Code’s built-in Explorer is surprisingly barebones for a tool developers live in all day. There’s no way to bookmark a subset of files, no recursive expand button, and renaming a file doesn’t touch the symbols inside it. I looked at what’s out there — extensions like File Nesting Updater or Explorer Exclude solve narrow problems but don’t address the broader workflow. Peacock colors your workspace, not your files. Nothing gave me a way to say “these 12 files are my current scope” and just hide everything else.

So I built File Explorer Tools — a small, focused set of power-ups for the Explorer panel that I actually needed every day:

Why File Explorer Tools?


Scopes Manager

Assign files and folders to named, color-coded scopes directly from the Explorer context menu. When a scope is selected, the native File Explorer filters down to show only the files that belong to it — powered by files.exclude under the hood.

Commands

Name Description
Scopes Manager: Create Scope Create a new named, color-coded scope
Scopes Manager: Add to Scope Add selected files/folders to a scope
Scopes Manager: Remove from Scope Remove selected files/folders from a scope
Scopes Manager: Delete Scope Delete an existing scope
Scopes Manager: Rename Scope Rename an existing scope
Scopes Manager: Change Scope Color Change the color of an existing scope
Scopes Manager: Clear Scope Patterns Remove all patterns from a scope

Keybindings

Keybindings are active when the File Explorer is focused.

Name Description Keybinding
Scopes Manager: Add to Scope Add selected files/folders to a scope Alt+S
Scopes Manager: Remove from Scope Remove selected files from a scope Alt+D

Context Menus

Settings

Name Description Default
scopesManager.localScopes Locally stored scopes (not committed to VCS). Managed automatically by the extension. []

Shared scopes are stored in .vscode/scopes.json and can be committed to version control.

How It Works

Scope filtering uses the native VS Code files.exclude workspace setting. When you select a scope, the extension computes which files and folders are not part of the scope and temporarily adds them to files.exclude. Deselecting the scope restores the original exclude list. This means filtering works with the built-in File Explorer — no custom tree views needed.


Expand Recursively

One-click recursive expansion of all folders in the File Explorer. Appears as an icon in the Explorer title bar.

Commands

Name Description
File Explorer: Expand Recursively Recursively expand all folders in the File Explorer

Context Menus

Settings

Name Description Default
fileExplorer.expandRecursively.excludePatterns Folder names or glob patterns to skip during recursive expansion .git, .svn, .vs, .vscode, .cache, __pycache__, node_modules, dist, packages, build, target, Release, Debug, bin, obj

How It Works

Walks the directory tree using the VS Code filesystem API, expanding each folder via revealInExplorer and list.expand. Folders matching the exclude patterns are skipped automatically.

Rename Cascade

When you rename a file in the Explorer, the matching class or export inside it is automatically renamed too (using the language server’s rename provider), cascading the change across the entire project.

Examples

File rename Symbol rename
foo-entity.tsbar-entity.ts FooEntityBarEntity
bar-entity.tsbar-entity.component.ts BarEntityBarEntityComponent
FooService.javaBarService.java FooServiceBarService

Settings

Name Description Default
fileExplorer.renameCascade.mode "always" auto-rename, "prompt" ask first, "never" disable entirely "prompt"

How It Works

Listens for onDidRenameFiles events, strips the language extension, derives the old and new PascalCase symbol names from the remaining file name (including compound parts like .component, .module), finds the old symbol in the file content, and invokes vscode.executeDocumentRenameProvider to rename it project-wide.