197 lines
5.6 KiB
Markdown
197 lines
5.6 KiB
Markdown
# memos.nvim
|
|
English | [简体中文](./README.md#memosnvim-简体中文)
|
|
A Neovim plugin to interact with [Memos](https://github.com/usememos/memos) right inside the editor. List, create, edit, and delete your memos without leaving Neovim.
|
|
|
|
## ✨ Features
|
|
|
|
- **List Memos**: View, search, and paginate through your memos.
|
|
- **Create & Edit**: Create new memos or edit existing ones in a dedicated buffer with `markdown` filetype support.
|
|
- **Delete Memos**: Delete memos directly from the list.
|
|
- **Customizable**: Configure API endpoints, keymaps, and more.
|
|
|
|
## 📦 Installation
|
|
|
|
Requires [plenary.nvim](https://github.com/nvim-lua/plenary.nvim).
|
|
|
|
Install with [lazy.nvim](https://github.com/folke/lazy.nvim):
|
|
|
|
```lua
|
|
{ "Elflare/memos.nvim", dependencies = { "nvim-lua/plenary.nvim" } },
|
|
```
|
|
|
|
## 🚀 Usage
|
|
|
|
### Commands
|
|
|
|
- `:Memos`: Opens a floating window to list and search your memos.
|
|
- `:MemosCreate`: Opens a new buffer to create a new memo.
|
|
- `:MemosSave`: (Available in the memo buffer) Saves the memo you are currently creating or editing.
|
|
|
|
### Default Keymaps
|
|
|
|
#### Global
|
|
|
|
| Key | Action |
|
|
| ------------ | ------------------- |
|
|
| `<leader>mm` | Open the Memos list |
|
|
|
|
#### In the Memo List Window
|
|
|
|
| Key | Action |
|
|
| ----------- | ---------------------------------- |
|
|
| `a` | Add a new memo |
|
|
| `d` or `dd` | Delete the selected memo |
|
|
| `<CR>` | Edit the selected memo |
|
|
| `<Tab>` | Edit the selected memo in a vsplit |
|
|
| `s` | Search your memos |
|
|
| `r` | Refresh the memo list |
|
|
| `.` | Load the next page of memos |
|
|
| `q` | Quit the list window |
|
|
|
|
#### In the Edit/Create Buffer
|
|
|
|
| Key | Action |
|
|
| ------------ | --------------------- |
|
|
| `<leader>ms` | Save the current memo |
|
|
|
|
## ⚙️ Configuration
|
|
|
|
You can override the default settings by passing a table to the `setup()` function.
|
|
|
|
```lua
|
|
-- lua/plugins/memos.lua
|
|
require("memos").setup({
|
|
-- REQUIRED: Your Memos host URL
|
|
host = "https://your-memos-host.com",
|
|
|
|
-- REQUIRED: Your Memos API token
|
|
token = "your-super-secret-token",
|
|
|
|
-- Number of memos to fetch per page
|
|
pageSize = 50,
|
|
|
|
-- Set to false or nil to disable a keymap
|
|
keymaps = {
|
|
-- Keymap to open the memos list. Default: <leader>mm
|
|
start_memos = "<leader>mm",
|
|
|
|
-- Keymaps for the memo list window
|
|
list = {
|
|
add_memo = "a",
|
|
delete_memo = "d",
|
|
delete_memo_visual = "dd",
|
|
edit_memo = "<CR>",
|
|
vsplit_edit_memo = "<Tab>",
|
|
search_memos = "s",
|
|
refresh_list = "r",
|
|
next_page = ".",
|
|
quit = "q",
|
|
},
|
|
-- Keymaps for the editing/creating buffer
|
|
buffer = {
|
|
save = "<leader>ms",
|
|
},
|
|
},
|
|
})
|
|
```
|
|
|
|
---
|
|
|
|
# memos.nvim (简体中文)
|
|
|
|
[English](./README.md#memosnvim) | 简体中文
|
|
|
|
一个 Neovim 插件,让你在编辑器内部直接与 [Memos](https://github.com/usememos/memos) 进行交互。无需离开 Neovim 即可列表、创建、编辑和删除你的 memos。
|
|
|
|
## ✨ 功能
|
|
|
|
- **列表 Memos**: 查看、搜索和翻页你的 memos。
|
|
- **创建与编辑**: 在专用的、支持 `markdown` 文件类型的缓冲区中创建新 memo 或编辑现有 memo。
|
|
- **删除 Memos**: 直接从列表中删除 memo。
|
|
- **可定制**: 可配置 API 地址、快捷键等。
|
|
|
|
## 📦 安装
|
|
|
|
需要 [plenary.nvim](https://github.com/nvim-lua/plenary.nvim) 插件。
|
|
|
|
使用 [lazy.nvim](https://github.com/folke/lazy.nvim) 安装:
|
|
|
|
```lua
|
|
{ "Elflare/memos.nvim", dependencies = { "nvim-lua/plenary.nvim" } },
|
|
```
|
|
|
|
## 🚀 使用方法
|
|
|
|
### 命令
|
|
|
|
- `:Memos`: 打开一个浮动窗口,列出并搜索你的 memos。
|
|
- `:MemosCreate`: 打开一个新的缓冲区来创建 memo。
|
|
- `:MemosSave`: (在 memo 编辑缓冲区中可用) 保存你正在创建或编辑的 memo。
|
|
|
|
### 默认快捷键
|
|
|
|
#### 全局快捷键
|
|
|
|
| 按键 | 功能 |
|
|
| ------------ | --------------- |
|
|
| `<leader>mm` | 打开 Memos 列表 |
|
|
|
|
#### 在 Memo 列表窗口中
|
|
|
|
| 按键 | 功能 |
|
|
| ----------- | --------------------------- |
|
|
| `a` | 新增一个 memo |
|
|
| `d` 或 `dd` | 删除所选的 memo |
|
|
| `<CR>` | 编辑所选的 memo |
|
|
| `<Tab>` | 在垂直分屏中编辑所选的 memo |
|
|
| `s` | 搜索你的 memos |
|
|
| `r` | 刷新 memo 列表 |
|
|
| `.` | 加载下一页 memos |
|
|
| `q` | 退出列表窗口 |
|
|
|
|
#### 在编辑/创建缓冲区中
|
|
|
|
| 按键 | 功能 |
|
|
| ------------ | ------------- |
|
|
| `<leader>ms` | 保存当前 memo |
|
|
|
|
## ⚙️ 配置
|
|
|
|
你可以通过向 `setup()` 函数传递一个 table 来覆盖默认设置。
|
|
|
|
```lua
|
|
-- lua/plugins/memos.lua
|
|
require("memos").setup({
|
|
-- 必填: 你的 Memos 服务地址
|
|
host = "https://your-memos-host.com",
|
|
|
|
-- 必填: 你的 Memos API 令牌
|
|
token = "your-super-secret-token",
|
|
|
|
-- 每页获取的 memo 数量
|
|
pageSize = 50,
|
|
|
|
-- 设置为 false 或 nil 可以禁用某个快捷键
|
|
keymaps = {
|
|
-- 用于打开 Memos 列表的快捷键。默认值: <leader>mm
|
|
start_memos = "<leader>mm",
|
|
|
|
-- memo 列表窗口的快捷键
|
|
list = {
|
|
add_memo = "a",
|
|
delete_memo = "d",
|
|
delete_memo_visual = "dd",
|
|
edit_memo = "<CR>",
|
|
vsplit_edit_memo = "<Tab>",
|
|
search_memos = "s",
|
|
refresh_list = "r",
|
|
next_page = ".",
|
|
quit = "q",
|
|
},
|
|
-- 编辑/创建窗口的快捷键
|
|
buffer = {
|
|
save = "<leader>ms",
|
|
},
|
|
},
|
|
})
|