vyfor / cord.nvim

🚀 Discord Rich Presence plugin for Neovim written in Rust
Apache License 2.0
87 stars 8 forks source link
discord lua neovim nvim plugin rich-presence rpc rust

🧩 Cord

Stargazers Apache-2.0 License Forks

🚀 Cord is a Discord Rich Presence plugin designed for Neovim, written in Rust.

Cord Banner

💎 Features

🔌 Requirements

📦 Installation

lazy.nvim ```lua { 'vyfor/cord.nvim', build = './build', event = 'VeryLazy', opts = {}, } ```
pckr.nvim ```lua { 'vyfor/cord.nvim', run = './build', } ```
other

Same steps apply to other plugin managers. Just make sure to add or run this build command:

```sh ./build ```

[!NOTE] If you are on a Windows Command Prompt, you may need to use a backslash as the path separator:

build = '.\\build'

🔧 Configuration

Note: setup() has to be called to initialize the plugin.

require('cord').setup {
usercmds = true,                              -- Enable user commands
log_level = 'error',                          -- One of 'trace', 'debug', 'info', 'warn', 'error', 'off'
timer = {
interval = 1500,                            -- Interval between presence updates in milliseconds (min 500)
reset_on_idle = false,                      -- Reset start timestamp on idle
reset_on_change = false,                    -- Reset start timestamp on presence change
},
editor = {
image = nil,                                -- Image ID or URL in case a custom client id is provided
client = 'neovim',                          -- vim, neovim, lunarvim, nvchad, astronvim or your application's client id
tooltip = 'The Superior Text Editor',       -- Text to display when hovering over the editor's image
},
display = {
show_time = true,                           -- Display start timestamp
show_repository = true,                     -- Display 'View repository' button linked to repository url, if any
show_cursor_position = false,               -- Display line and column number of cursor's position
swap_fields = false,                        -- If enabled, workspace is displayed first
swap_icons = false,                         -- If enabled, editor is displayed on the main image
workspace_blacklist = {},                   -- List of workspace names to hide
},
lsp = {
show_problem_count = false,                 -- Display number of diagnostics problems
severity = 1,                               -- 1 = Error, 2 = Warning, 3 = Info, 4 = Hint
scope = 'workspace',                        -- buffer or workspace
},
idle = {
enable = true,                              -- Enable idle status
show_status = true,                         -- Display idle status, disable to hide the rich presence on idle
timeout = 300000,                           -- Timeout in milliseconds after which the idle status is set, 0 to display immediately
disable_on_focus = true,                    -- Do not display idle status when neovim is focused
text = 'Idle',                              -- Text to display when idle
tooltip = '💤',                             -- Text to display when hovering over the idle image
},
text = {
viewing = 'Viewing {}',                     -- Text to display when viewing a readonly file
editing = 'Editing {}',                     -- Text to display when editing a file
file_browser = 'Browsing files in {}',      -- Text to display when browsing files (Empty string to disable)
plugin_manager = 'Managing plugins in {}',  -- Text to display when managing plugins (Empty string to disable)
lsp_manager = 'Configuring LSP in {}',      -- Text to display when managing LSP servers (Empty string to disable)
vcs = 'Committing changes in {}',           -- Text to display when using Git or Git-related plugin (Empty string to disable)
workspace = 'In {}',                        -- Text to display when in a workspace (Empty string to disable)
},
buttons = {
{
label = 'View Repository',                -- Text displayed on the button
url = 'git',                              -- URL where the button leads to ('git' = automatically fetch Git repository URL)
},
-- {
--   label = 'View Plugin',
--   url = 'https://github.com/vyfor/cord.nvim',
-- }
},
assets = nil,                                 -- Custom file icons, see the wiki*
-- assets = {
--   lazy = {                                 -- Vim filetype or file name or file extension = table or string
--     name = 'Lazy',                         -- Optional override for the icon name, redundant for language types
--     icon = 'https://example.com/lazy.png', -- Rich Presence asset name or URL
--     tooltip = 'lazy.nvim',                 -- Text to display when hovering over the icon
--     type = 2,                              -- 0 = language, 1 = file browser, 2 = plugin manager, 3 = lsp manager, 4 = vcs; defaults to language
--   },
--   ['Cargo.toml'] = 'crates',
-- },
}
hide comments ```lua { usercmds = true, log_level = 'error', timer = { interval = 1500, reset_on_idle = false, reset_on_change = false, }, editor = { image = nil, client = 'neovim', tooltip = 'The Superior Text Editor', }, display = { show_time = true, show_repository = true, show_cursor_position = false, swap_fields = false, swap_icons = false, workspace_blacklist = {}, }, lsp = { show_problem_count = false, severity = 1, scope = 'workspace', }, idle = { enable = true, show_status = true, timeout = 300000, disable_on_focus = true, text = 'Idle', tooltip = '💤', }, text = { viewing = 'Viewing {}', editing = 'Editing {}', file_browser = 'Browsing files in {}', plugin_manager = 'Managing plugins in {}', lsp_manager = 'Configuring LSP in {}', vcs = 'Committing changes in {}', workspace = 'In {}', }, buttons = { { label = 'View Repository', url = 'git', }, }, assets = nil, } ```

* Wiki: Add or change file icons

⌨️ User commands

🌱 Contributing

This project is in beta. Contributions of any kind are welcome, just make sure you read the Contribution Guidelines first. You can also contact me directly on Discord (vyfor) if you have any questions.

❓ FAQ

🔧 Troubleshooting