Easy Copy

by Moy
5
4
3
2
1
Score: 52/100

Description

Category: Productivity Tools

The Easy Copy plugin simplifies the process of copying specific types of content within Obsidian by smartly detecting the context around the cursor. It allows users to instantly copy inline code, bold text, highlighted sections, italicized words, block IDs, and heading links without manually selecting text. Users can fine-tune which types of content to target and adjust link formats for copied headings.

Reviews

No reviews yet.

Stats

39
stars
6,532
downloads
4
forks
374
days
11
days
11
days
14
total PRs
1
open PRs
1
closed PRs
12
merged PRs
21
total issues
3
open issues
18
closed issues
0
commits

Latest Version

12 days ago

Changelog

What's Changed

✨ Features

  • Added "Strict heading match" option under link simplification settings. When disabled (default), filenames containing the heading as a substring will also be simplified (e.g. "260422_note" → "note"). When enabled, only exact matches are simplified.

🐛 Bug Fixes

  • Heading links now correctly handle special characters (# | ^ : %% [[ ]]) — matching Obsidian's autocomplete behavior
  • Fixed false-positive note-link simplification when filename contains heading as substring (e.g. "JavaScript" + "Java")

♻️ Refactor

  • Extracted link-building logic into pure functions for better testability
  • Added vitest with 86 tests

改动内容

✨ 新功能

  • 新增"严格匹配"选项(在"文件名匹配标题时简化链接"设置下方)。关闭时(默认),文件名包含标题子串也会简化(如 "260422_note" 匹配标题 "note")。开启时,仅完全匹配才会简化。

🐛 Bug 修复

  • 标题链接现在正确处理特殊字符(# | ^ : %% [[ ]] )——与 Obsidian 自动补全行为一致
  • 修复了文件名包含标题子串时的误判(如文件名 "JavaScript" + 标题 "Java" 不再被错误简化)

♻️ 重构

  • 将链接构建逻辑提取为纯函数,提升可测试性
  • 新增 vitest 测试框架,86 个测试用例

New Contributors

Full Changelog: https://github.com/Moyf/easy-copy/compare/1.5.2...1.5.3

README file from

Github

Easy Copy - Make Copying Smart and Simple!

English | 中文文档

Obsidian Download Total Downloads GitHub Issues GitHub Last Commit

Easy Copy can smartly copy content based on your cursor position (e.g. code text inside inline code, without formatting symbols).
Besides, it also supports quickly generating and copying links to headings or paragraphs(blocks) in your notes.

✨ Features

  • 🚀 Easy to Use - You only need one command to complete various copy operations
  • 🧙‍♂️ Smart Detection - Automatically identifies and copies different types of content based on cursor position
  • 🔍 Multiple Format Support - Copy inline code, bold text, highlighted text, italic text, block linkss, and heading links
  • 📝 Auto Generate - Automatically generate heading links, or generate a new block ID for the current paragraph and copy the block link
  • 🌐 Multilingual Support - Full support for English, Simplified Chinese, and Traditional Chinese

🤔 Why use this plugin

📝 Copy the text inside Inline Code

I often use inline code for debug commands or keywords and need to quickly copy the content inside the ` symbols. In the past, I had to carefully select the text wrapped inside... which was quite tedious! I want to directly copy the text inside the inline code
So I created this plugin - just place your cursor inside the inline code, and copy with a single keystroke!

Just like this:

demo

It also supports copying bold text, highlighted text, italic text. (If you don't need these features, you can disable them in the settings)

[!IMPORTANT] Due to the limitations of Obsidian plugins, the default does not assign a shortcut key,
you need to assign a shortcut key in Obsidian's keyboard settings for the "Easy Copy: Contextual Copy" command.
I personally recommend using Ctrl+Alt+C.

Even more surprisingly, if you place the cursor on the heading line and press the same "Contextual Copy" shortcut key, you can copy the internal link pointing to the heading!

copy-heading

[!TIP] You can choose between markdown link format ([]()) and wiki link format ([[]]) in the plugin settings.

Not only that, it will use the heading text as the display text, effectively reducing the length of the link.

From [[Note Name#Heading Text]] to [[Note Name#Heading Text|Heading Text]], the text content is longer, but the visual effect is shorter!

The difference looks like this:

heading-compare

If the current text contains an existing block link, the plugin will copy the link pointing to this block, just like it does with the title.

After version 1.2.0, the plugin also supports automatically generating block links for the current text (you need to enable the Auto generate block ID option in the settings):

When there is no content at the cursor position to copy, it will automatically generate a random block ID for the current paragraph and copy the link to the clipboard.
Moreover, the copied link will use the text's summary as the display text, so you won't have to deal with the confusing random characters of the Block ID!

copy-block-id

If you prefer, you can also enable "Manually enter Block ID" in the settings (only letters, numbers, hyphens (-) and underscores (_) are supported).

🪄 How to Use

  1. Basic Usage: Place the cursor at the position you want to copy, and use the Contextual Copy command to copy.
  2. You can also assign a hotkey, and press it to copy with one click. hotkey
  3. The plugin also provides a right-click menu operation menu-item

🔧 Settings

General

  • Add to Menu - Add the command to the right-click menu.
  • Show Notifications - Show a notification when content is copied.
  • Use Title as Display Text - Use the title text as the display text in the link.

Format

  • Link Format - The format used when copying title links (Markdown link or Wiki link).
    • Markdown link: (Display Text)[Link]
    • Wiki link: [[Link|Display Text]]

Block ID

  • Auto-generate Block ID - When enabled, if there is no content at the cursor position to copy, it will automatically generate a random block ID for the current paragraph and copy the link to the clipboard.
  • Manually enter Block ID - When enabled, you can manually enter a new block ID (in this case, the display text will directly use the text you entered)

Copy Target

  • Custom Copy Target - When enabled, you can customize which elements can be copied, allowing you to exclude specific types (such as bold or italic text) to avoid copying them.

🛠️ Installation

The plugin is now available in the community plugins list, you can search for "Easy Copy" to install it.

(Alternatively, you can also use the BRAT plugin to install it)

🤝 Contribution

Issues and feature requests are welcome! If you'd like to contribute to this project, feel free to submit a PR.

This plugin really improved my workflow, and I hope it can help you too! 🌟