Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/atiladefreitas/lazyclip

The laziest clipboard manager for Neovim
https://github.com/atiladefreitas/lazyclip

neovim neovim-plugin

Last synced: about 1 month ago
JSON representation

The laziest clipboard manager for Neovim

Awesome Lists containing this project

README

        

# LazyClip

LazyClip is a powerful yet minimalist clipboard manager for Neovim, designed with simplicity and efficiency in mind. It integrates seamlessly with your Neovim setup and provides an intuitive floating window to browse and paste clipboard history. LazyClip is especially crafted for users of **Lazy.nvim** and works great with popular Neovim distributions.

https://github.com/user-attachments/assets/80bcd017-0657-43f7-8f85-509f687eaad7

## 🚀 Features

- 📋 View up to **9 clipboard items** per page in a **floating window**.
- 🔢 Fixed numbered slots `[1]` to `[9]` for quick reference.
- 🌟 **Paste with ease**: Use number keys or `` to paste items directly into your editor.
- ⏮️ Navigate clipboard history with `H` (previous page) and `L` (next page).
- 🛠️ Compatible with **Lazy.nvim** for effortless installation.

---

## 📦 Installation

### Prerequisites

- Neovim `>= 0.10.0`
- [Lazy.nvim](https://github.com/folke/lazy.nvim) as your plugin manager.

### Using Lazy.nvim

```lua
return {
"atiladefreitas/lazyclip",
config = function()
require("lazyclip").setup({
-- your custom config here (optional)
})
end,
keys = {
{ "Cw", desc = "Open Clipboard Manager" },
},
-- Optional: Load plugin when yanking text
event = { "TextYankPost" },
}
```

Run the following commands in Neovim to install LazyClip:

```vim
:Lazy sync
```

### Default Configuration

LazyClip comes with sensible defaults that you can override:

```lua
{
-- Core settings
max_history = 100, -- Maximum number of items to keep in history
items_per_page = 9, -- Number of items to show per page
min_chars = 5, -- Minimum characters required to store item

-- Window appearance
window = {
relative = "editor",
width = 70, -- Width of the floating window
height = 12, -- Height of the floating window
border = "rounded", -- Border style
},

-- Internal keymaps for the lazyclip window
keymaps = {
close_window = "q", -- Close the clipboard window
prev_page = "h", -- Go to previous page
next_page = "l", -- Go to next page
paste_selected = "", -- Paste the selected item
move_up = "k", -- Move selection up
move_down = "j", -- Move selection down
delete_item = "d" -- Delete selected item
}
}
```
---

## 🛠️ Usage

1. **Yank text** in Neovim as usual using commands like `y`, `yy`, or `yank`.
2. Open LazyClip with `Cw`.
3. Browse through the last **9 copied items** in a floating window.
4. **Paste an item**:
- Press the corresponding **number key** (`1-9`).
- Or, navigate to the desired item with `j`/`k` and press ``.
5. Use `h` and `l` to navigate pages when you have more than 9 items.
6. Press `q` to close the window.

---

## 📥 Backlog

Planned features and improvements for future versions of LazyClip:

#### Core Features

- [ ] System Clipboard Integration.
- [ ] Persistent Clipboard History.
- [ ] Search Clipboard History
- [ ] Clipboard Size Configuration

#### UI Enhancements

- [ ] Customizable Floating Window.
- [ ] Highlight Current Item.
- [ ] Multi-Item Paste.

#### Quality of Life

- [x] Keybinding Configurability.
- [ ] Better Error Messages.
- [ ] Performance Optimization.

---

## 📝 License

This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.

---

## 🔖 Versioning

We use [Semantic Versioning](https://semver.org/) for versioning. For the available versions, see the [tags on this repository](https://github.com/atiladefreitas/lazyclip/tags).

---

## 🤝 Contributing

Contributions are welcome! If you'd like to improve LazyClip, feel free to:
- Submit an issue for bugs or feature requests.
- Create a pull request with your enhancements.

---

## 🌟 Acknowledgments

LazyClip was built with the Neovim community in mind. Special thanks to all the developers who contribute to the Neovim ecosystem and plugins like [Lazy.nvim](https://github.com/folke/lazy.nvim).

---

## My All plugins
| Repository | Description | Stars |
|------------|-------------|-------|
| [LazyClip](https://github.com/atiladefreitas/lazyclip) | A Simple Clipboard Manager | ![Stars](https://img.shields.io/github/stars/atiladefreitas/lazyclip?style=social) |
| [Dooing](https://github.com/atiladefreitas/dooing) | A Minimalist Todo List Manager | ![Stars](https://img.shields.io/github/stars/atiladefreitas/dooing?style=social) |
| [TinyUnit](https://github.com/atiladefreitas/tinyunit) | A Practical CSS Unit Converter | ![Stars](https://img.shields.io/github/stars/atiladefreitas/tinyunit?style=social) |

---

## 📬 Contact

If you have any questions, feel free to reach out:
- [LinkedIn](https://linkedin.com/in/atilafreitas)
- Email: [email protected]