Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/askfiy/nvim-picgo

🥳🥳 A neovim plugin based on picgo-core, written in Lua. 🌲 Allows you to add pictures to various picture beds at any time, and they can be accessed from any corner of the Internet. 🎆
https://github.com/askfiy/nvim-picgo

image lua neovim plugin

Last synced: 3 months ago
JSON representation

🥳🥳 A neovim plugin based on picgo-core, written in Lua. 🌲 Allows you to add pictures to various picture beds at any time, and they can be accessed from any corner of the Internet. 🎆

Awesome Lists containing this project

README

        

____ _ ____
| _ \(_) ___ / ___| ___
| |_) | |/ __| | _ / _ \
| __/| | (__| |_| | (_) |
|_| |_|\___|\____|\___/

· picgo plugin for neovim ·

![](https://img.shields.io/badge/Perfect-neovim%20picgo-green)

**nvim-picgo** is a picture uploading tool based on Lua language. You can quickly upload images to various image beds through it, and it will also generate links in markdown format 🔗. and store it in the clipboard.

In the coc ecosystem, there is a plugin called **[coc-picgo](https://github.com/PLDaily/coc-picgo)** that does the same thing.
The **[coc-picgo](https://github.com/PLDaily/coc-picgo)** plugin is really enviable for those who use nvim's built-in LSP, because we don't need coc,so I created this project and hope it will help you.

## Features

- Written in pure Lua, less than 300 lines of code
- No default key bindings, I won't take up your precious keys
- Quickly upload disk files or clipboard images to the image bed, allowing you to access your images anywhere on the Internet

## demo

Upload an image from the clipboard:

![](./demo/demo1.gif)

Upload an image from the file system:

![](./demo/demo2.gif)

## Dependencies

I recommend you to use **neovim-0.7**.

Besides that, you need to download **[picgo-core](https://github.com/PicGo/PicGo-Core)**, which is a command line tool.

```
$ npm install picgo -g
```

## Configure picgo image bed

First of all, you need to manually fill in your image bed configuration, and enter:

> Note, not in neovim's cmd mode

```
$ picgo set uploader
? Choose a(n) uploader (Use arrow keys)
smms
❯ tcyun
github
qiniu
imgur
aliyun
upyun
(Move up and down to reveal more choices)
```

Or you can also configure manually:

- Linux and Mac:`~/.config/.picgo/config.json`
- Windows:`C:\Users\youername\.picgo\config.json`

Below is my picgo config file:

```
$ cat $HOME/.picgo/config.json

{
"picBed": {
"uploader": "tcyun",
"current": "tcyun",
"tcyun": {
"secretId": "..",
"secretKey": "..",
"bucket": "images-1302522496",
"appId": "1302522496",
"area": "ap-nanjing",
"path": "img/",
"customUrl": "",
"version": "v5"
}
},
"picgoPlugins": {}
}
```

## Using plugins

It is recommended to use Packer to manage **nvim-picgo**:

```
use {
"askfiy/nvim-picgo",
config = function()
-- it doesn't require you to do any configuration
require("nvim-picgo").setup()
end
}
```

Default configuration items:

```
{
-- method to informe
-- 1. notify
-- 2. echo
notice = "notify",
-- Whether the generated markdown link saves the upload name of the image
-- boolean
image_name = false,
-- debug mode
debug = false,
}
```

## plugin command

viml:

```
:UploadClipboard
:UploadImagefile
```

lua:

```
lua require'nvim-picgo'.upload_clipboard()
lua require'nvim-picgo'.upload_imagefile()
```

## related resources

- [picgo-core](https://github.com/PicGo/PicGo-Core)
- [coc-picgo](https://github.com/PLDaily/coc-picgo)
- [picgo-doc](https://picgo.github.io/PicGo-Doc/en/guide/)