Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brianpetro/smart-context-obsidian


https://github.com/brianpetro/smart-context-obsidian

Last synced: 1 day ago
JSON representation

Awesome Lists containing this project

README

        

# Smart Context Plugin for Obsidian

**Smart Context** is an Obsidian plugin that helps you copy contents from folders and open files to your clipboard, with advanced configuration options—such as excluding specific heading sections. This streamlined copy functionality is particularly useful if you regularly work with AI tools like ChatGPT. You can quickly gather multiple files’ contents and feed them as "context" into ChatGPT to improve its understanding and responses.

By copying a set of files (including linked references), you can easily provide ChatGPT with a holistic set of project notes, research materials, or documentation, enabling it to give you more context-aware suggestions, summaries, or to generate more accurate answers.

## Features

- **Copy Folder Contents:**
Copy all Markdown and Canvas files from a selected folder to your clipboard, including a tree-like folder structure and their contents. This enables you to quickly provide entire project contexts to AI models at once.

- **Copy Visible Open Files:**
Copies content from only the currently visible open files. For instance, if you have multiple panes open with different notes, you can easily provide just those visible notes to ChatGPT, helping it understand your current focus area.

- **Copy All Open Files:**
Copies content from all open files in the workspace, regardless of visibility. Perfect for quickly gathering a broad context or a research set to feed into ChatGPT at once.

- **Exclude Sections by Heading:**
Configure specific headings that should be excluded from the copied output. This is helpful if you have confidential or irrelevant sections (e.g., “Secret”) that you don’t want to share with ChatGPT or other tools.

- **Copy With Linked Files:**
For either visible or all open files, there are commands to also include any files linked within them. This lets you provide ChatGPT with an entire knowledge graph subset—an interconnected set of notes—giving the AI a more comprehensive understanding of your vault’s context.

- **Visual Notifications and Summaries:**
After copying, you’ll see a notification summarizing how many files were copied and how many sections were excluded. This helps you verify the integrity of the context before feeding it into an AI model.

## Usage

**The following commands are available via the Command Palette (`Ctrl/Cmd + P`):**

- **Copy Folder Contents to Clipboard:**
1. Run **"Copy Folder Contents to Clipboard"**.
2. A modal will appear allowing you to select a folder.
3. Confirm to copy the folder’s structure and contents.
4. Useful for providing a large context (e.g., an entire project’s files) to ChatGPT.

- **Copy Visible Open Files Content to Clipboard:**
1. Run **"Copy Visible Open Files Content to Clipboard"**.
2. Only the content from currently visible (active) tabs is copied.
3. Great for focused prompts—copy just the notes you’re currently working on and give them to ChatGPT.

- **Copy All Open Files Content to Clipboard:**
1. Run **"Copy All Open Files Content to Clipboard"**.
2. Copies all open files, providing a broad context. Ideal for feeding multiple related notes to ChatGPT at once.

- **Copy Visible Open Files Content (With Linked Files) to Clipboard:**
1. Run **"Copy Visible Open Files Content (With Linked Files) to Clipboard"**.
2. The plugin not only copies the currently visible open files but also recursively includes all files they link to.
3. This allows you to give ChatGPT a richer, more connected context from your vault.

- **Copy All Open Files Content (With Linked Files) to Clipboard:**
1. Run **"Copy All Open Files Content (With Linked Files) to Clipboard"**.
2. Like the above command, but starting from all open files, pulling in their entire network of linked files.
3. Ideal for providing ChatGPT with a complete knowledge graph excerpt.

**Context Menu on Folders:**
1. Right-click on a folder in the File Explorer.
2. Select **"Copy folder contents to clipboard"** for a quick one-step copy.

## External File Browser (Desktop Only)

- **Open External File Browser Command:**
1. Run **"Open External File Browser"** from the Command Palette.
2. A fuzzy suggest modal opens, showing files and folders _outside_ your Obsidian vault.
3. The first item in the list (``) takes you up one directory level.
4. Press **CTRL + Enter** or the **Right Arrow** key on a folder to open it in place (refreshing the modal’s scope).
5. Selecting a file or folder inserts its vault-relative path into a `smart-context` codeblock (explained below).
- If the `smart-context` codeblock doesn’t exist in your active file, it is created right below your current cursor line.
- If it does exist, new paths are appended to the block.
6. If you select a file, its relative path (including file extension) is inserted. If you select a folder, its relative path is inserted as well (using `../` if needed).
7. Navigation instructions appear at the top of the modal for reference.
8. A notice appears in Obsidian confirming the inserted path.

Since this feature uses Node’s `fs` library, it will only work on Obsidian Desktop. It returns false on mobile devices.

## Using `smart-context` Codeblocks

A `smart-context` codeblock is a code-fenced section within your active file:

```smart-context

path/to/someFolder
path/to/someFile.md
```

When you run any **copy** command (e.g., "Copy Folder Contents to Clipboard"), the plugin checks if the _active file_ contains a `smart-context` codeblock. If it does, all paths listed inside that codeblock are included in the copied context. That means you can declare extra paths or entire folders that you want to include, regardless of which vault notes or commands you select.

- **Folder Paths**: If you specify a directory (e.g., `path/to/myFolder`), the plugin includes all `.md` and `.canvas` files from that folder—respecting `.scignore` or `.gitignore` patterns if present in that directory.
- **File Paths**: If you specify a single file (e.g., `exampleNote.md`), it will be pulled in directly.
- **Automatic Creation**: Selecting a file or folder from the External File Browser command will create or append lines to this codeblock, making it easy to gather external references all in one place.
- **Inline with Main Context**: The final text you copy to the clipboard merges these `smart-context` references with whatever else you’re copying (e.g., open files, folder contents, etc.).

## Settings

In **Settings > Community Plugins > Smart Context**, you’ll find the following options:

- **Excluded Headings** (array of strings):
Headings to exclude from copied content. For example, setting `Secret` will exclude sections beginning with `# Secret`, `## Secret`, etc.

- **Link Depth** (number):
When using the “with linked” copy commands, this defines how many link hops to follow. For example, if `link_depth` is `2`, a file that links to another file which itself links to another file will be pulled in.

- **Include File Tree** (toggle):
If enabled, the folder structure for “Copy Folder Contents” is included in the final output before each file’s contents. Turn off if you’d prefer not to see the ASCII tree representation.

- **Max Linked Files** (number, default 0 = no limit):
Caps how many files are pulled in via BFS expansions when using “with linked” commands. If you set this to a positive integer, once that limit is reached, the plugin won’t pull in additional linked files.

- **Before Prompt (once)** (text):
Inserts text at the top of the final copied content. Can include placeholders like `{{FILE_PATH}}` or `{{FILE_NAME}}` but is typically used as an overall introduction or heading.

- **Before Each File** (text):
Inserts text right before each file’s content is appended. By default, this is ``.

- **After Each File** (text):
Inserts text immediately after each file’s content. By default, this is ``.

- **After Prompt (once)** (text):
Inserts text at the very bottom of the final copied content. Often used for a closing remark or markdown delimiter.

## Formatting

The copied content uses a standardized format:

For folders:
```
Folder Structure:

File Contents:
----------------------
/
-----------------------

-----------------------
```

For open files:
```
Open Files Contents:
----------------------
/
-----------------------

-----------------------
```

## Example

If you have a file with the following content:
```
# Notes
Some general notes here.

## Secret
This should be excluded.

## Visible
This will be included.
```
And you’ve configured the excluded heading as `Secret`, the `## Secret` section won’t appear in the clipboard output.

## Contributing

Feel free to open issues or submit pull requests to improve this plugin.

## License

This plugin is distributed under the [MIT License](LICENSE).