2021-04-25 16:51:58 -07:00
< img src = "https://gist.githubusercontent.com/andweeb/df3216345530234289b87cf5080c2c60/raw/8de399cfed82c137f793e9f580027b5246bc4379/presence.nvim.png" alt = "presence.nvim" > ​
2021-03-01 09:34:30 -08:00
2021-05-13 19:57:38 -07:00
**[Features](#features)** | ** [Installation ](#installation )** | ** [Configuration ](#configuration )** | ** [Troubleshooting ](#troubleshooting )** | ** [Development ](#development )** | ** [Contributing ](#contributing )**
2021-05-05 23:18:04 -07:00
2021-05-13 19:57:38 -07:00
> Discord [Rich Presence](https://discord.com/rich-presence) plugin for [Neovim](https://neovim.io)
2021-03-01 09:34:30 -08:00
2021-08-10 19:51:57 -07:00
< img src = "https://gist.githubusercontent.com/andweeb/df3216345530234289b87cf5080c2c60/raw/ad916fec8de921d0021801a0af877a5349621e7e/presence-demo-a.gif" width = "100%" alt = "demo.gif" >
2021-03-01 09:34:30 -08:00
## Features
2021-07-09 13:14:38 -07:00
* Light and unobtrusive
2021-03-01 09:34:30 -08:00
* No Python/Node providers (or CoC) required
2021-07-09 13:14:38 -07:00
* Cross-platform support: macOS, nixOS, Linux, Windows[\*](https://github.com/andweeb/presence.nvim/projects/1#card-60537963), WSL[\*](https://github.com/andweeb/presence.nvim/wiki/Rich-Presence-in-WSL)
2021-03-01 09:34:30 -08:00
* Startup time is fast(er than other Rich Presence plugins, by [kind of a lot ](https://github.com/andweeb/presence.nvim/wiki/Plugin-Comparisons ))
2021-07-09 13:14:38 -07:00
* Written in Lua and [highly configurable ](#configuration ) in Lua (but also configurable in VimL if you want)
* Manages Rich Presence across multiple Neovim instances in various environments (tmux panes/windows, ssh sessions, terminal tabs/windows, etc.)
2021-03-01 09:34:30 -08:00
## Installation
Use your favorite plugin manager
* [vim-plug ](https://github.com/junegunn/vim-plug ): `Plug 'andweeb/presence.nvim'`
2021-05-13 19:57:38 -07:00
* [packer.nvim ](https://github.com/wbthomason/packer.nvim ): `use 'andweeb/presence.nvim'`
2021-03-01 09:34:30 -08:00
#### Notes
2021-07-09 13:14:38 -07:00
* Requires [Neovim 0.5 ](https://github.com/neovim/neovim/releases/tag/v0.5.0 ) or higher
* Rich Presence should work automatically after installation (unless you're using WSL, in which case [see here ](https://github.com/andweeb/presence.nvim/wiki/Rich-Presence-in-WSL ))
2021-03-01 09:34:30 -08:00
## Configuration
2021-07-09 13:14:38 -07:00
Configuration is not necessary for Rich Presence to work. But for those that want to override the default configs, the following options are available to configure in either Lua or VimL.
2021-03-01 09:34:30 -08:00
### Lua
2021-07-09 13:14:38 -07:00
Require the plugin and call `setup` with a config table with one or more of the following keys:
2021-03-01 09:34:30 -08:00
```lua
2021-05-19 22:38:26 -07:00
-- The setup config table shows all available config options with their default values:
require("presence"):setup({
-- General options
auto_update = true, -- Update activity based on autocmd events (if `false` , map or manually execute `:lua package.loaded.presence:update()` )
neovim_image_text = "The One True Text Editor", -- Text displayed when hovered over the Neovim image
main_image = "neovim", -- Main image display (either "neovim" or "file")
client_id = "793271441293967371", -- Use your own Discord application client id (not recommended)
log_level = nil, -- Log messages at or above this level (one of the following: "debug", "info", "warn", "error")
2021-05-22 19:46:41 +00:00
debounce_timeout = 10, -- Number of seconds to debounce events (or calls to `:lua package.loaded.presence:update(<filename>, true)` )
enable_line_number = false, -- Displays the current line number instead of the current project
2021-08-10 19:51:57 -07:00
blacklist = {}, -- A list of strings or Lua patterns that disable Rich Presence if the current file name, path, or workspace matches
2021-08-09 23:17:37 -07:00
buttons = true, -- Configure Rich Presence button(s), either a boolean to enable/disable, a static table (`{{ label = "< label > ", url = "< url > " }, ...}`, or a function(buffer: string, repo_url: string|nil): table)
2021-05-19 22:38:26 -07:00
-- Rich Presence text options
editing_text = "Editing %s", -- Format string rendered when an editable file is loaded in the buffer
2021-05-24 11:45:09 -07:00
file_explorer_text = "Browsing %s", -- Format string rendered when browsing a file explorer
git_commit_text = "Committing changes", -- Format string rendered when commiting changes in git
plugin_manager_text = "Managing plugins", -- Format string rendered when managing plugins
reading_text = "Reading %s", -- Format string rendered when a read-only or unmodifiable file is loaded in the buffer
2021-05-19 22:38:26 -07:00
workspace_text = "Working on %s", -- Workspace format string (either string or function(git_project_name: string|nil, buffer: string): string)
2021-05-22 19:46:41 +00:00
line_number_text = "Line %s out of %s", -- Line number format string (for when enable_line_number is set to true)
2021-03-01 09:34:30 -08:00
})
```
### VimL
Or if global variables are more your thing, you can use any of the following instead:
```viml
2021-05-19 22:38:26 -07:00
" General options
let g:presence_auto_update = 1
let g:presence_neovim_image_text = "The One True Text Editor"
let g:presence_main_image = "neovim"
let g:presence_client_id = "793271441293967371"
2021-03-01 09:34:30 -08:00
let g:presence_log_level
2021-05-22 19:46:41 +00:00
let g:presence_debounce_timeout = 10
let g:presence_enable_line_number = 0
2021-08-07 23:28:03 -07:00
let g:presence_blacklist = []
2021-08-10 19:51:57 -07:00
let g:presence_buttons = 1
2021-05-19 22:38:26 -07:00
" Rich Presence text options
let g:presence_editing_text = "Editing %s"
2021-05-19 23:23:15 -07:00
let g:presence_file_explorer_text = "Browsing %s"
2021-05-19 22:38:26 -07:00
let g:presence_git_commit_text = "Committing changes"
let g:presence_plugin_manager_text = "Managing plugins"
let g:presence_reading_text = "Reading %s"
let g:presence_workspace_text = "Working on %s"
2021-05-22 19:46:41 +00:00
let g:presence_line_number_text = "Line %s out of %s"
2021-03-01 09:34:30 -08:00
```
2021-05-05 23:18:04 -07:00
## Troubleshooting
* Ensure that Discord is running
2021-07-09 13:14:38 -07:00
* Ensure that your Neovim version is 0.5 or higher
2021-05-05 23:18:04 -07:00
* Ensure Game Activity is enabled in your Discord settings
* Enable logging and inspect the logs after opening a buffer
2021-05-13 19:57:38 -07:00
* Set the [`log_level` ](#lua ) setup option or [`g:presence_log_level` ](#viml ) to `"debug"`
* Load a file and inspect the logs with `:messages`
2021-07-09 13:14:38 -07:00
* If there is a `Failed to determine Discord IPC socket` error, your particular OS may not yet be supported
2021-05-13 19:57:38 -07:00
* If you don't see an existing [issue ](https://github.com/andweeb/presence.nvim/issues ) or [card ](https://github.com/andweeb/presence.nvim/projects/1#column-14183588 ) for your OS, create a prefixed [issue ](https://github.com/andweeb/presence.nvim/issues/new ) (e.g. `[Void Linux]` )
2021-07-09 13:14:38 -07:00
* Still not working and need help? Create a new [issue ](https://github.com/andweeb/presence.nvim/issues )!
2021-05-13 19:57:38 -07:00
## Development
* Clone the repo: `git clone https://github.com/andweeb/presence.nvim.git`
* Enable [logging ](#configuration ) and ensure that `presence.nvim` is **_not_** in the list of vim plugins in your config
* Run `nvim` with your local changes: `nvim --cmd 'set rtp+=path/to/your/local/presence.nvim' file.txt`
* Ensure that there are no [luacheck ](https://github.com/mpeterv/luacheck/ ) errors: `luacheck lua`
2021-05-05 23:18:04 -07:00
2021-03-01 09:34:30 -08:00
## Contributing
2021-07-09 13:14:38 -07:00
Pull requests are very welcome, feel free to open an issue to work on any of the open [todo items ](https://github.com/andweeb/presence.nvim/projects/1?add_cards_query=is%3Aopen ) or message [droob#1322 ](https://discordapp.com/users/241953146232897550 ) on Discord!
2021-03-01 09:34:30 -08:00
2021-05-05 23:18:04 -07:00
Asset additions and changes are also welcome! Supported file types can be found in [`file_assets.lua` ](lua/presence/file_assets.lua ) and their referenced asset files can be found [in this folder ](https://www.dropbox.com/sh/j8913f0gav3toeh/AADxjn0NuTprGFtv3Il1Pqz-a?dl=0 ).