Need help with vim-github-dashboard?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.


:octocat: Browse GitHub events in Vim

432 Stars 19 Forks 117 Commits 4 Opened issues

Services available

Need anything else?


Browse GitHub events (user dashboard, user/repo activity) in Vim.

User dashboard:
:GHD! matz

User activity:
:GHA! matz

Repository activity:
:GHA! mruby/mruby

(Color scheme used: seoul256-light)


Using vim-plug:

Plug 'junegunn/vim-github-dashboard'


  1. Your Vim must have Ruby support enabled. Check if
    :echo has('ruby')
    prints 1.
  2. If you see LoadError on
    :ruby require 'json/pure'
    , you need to install

Mac OS X

The current version of Mac OS X is shipped with a Ruby-enabled Vim. However, by default it comes with an old Ruby (1.8.7), so you still need to install

) gem.
sudo gem install json_pure

If your Vim crashes, try installing a newer version of Vim with Homebrew.


sudo apt-get install ruby rubygems vim-nox && sudo /usr/bin/gem install json_pure

(Reference: Installing vim with ruby support (+ruby))


  1. Download and install the official GVim
  2. Download a newer build of GVim executable from here and replace the existing one
  3. Download and install Ruby 1.9.3 using RubyInstaller. You must check
    Add Ruby executable to your PATH


With authentication

  • :GHDashboard
  • :GHDashboard USER
  • :GHActivity
  • :GHActivity USER
  • :GHActivity USER/REPO

Without authentication (60 calls/hour limit, only public activities)

  • :GHDashboard! USER
  • :GHActivity! USER
  • :GHActivity! USER/REPO



to navigate back and forth through the links.


key or
on a link to open it in the browser.


to refresh the window.


to close the window.


When you first run

command, you will be asked to enter your GitHub username and the password. Once it is successfully authenticated, the Vim process will remember the credentials and will no more ask for them.

If you don't want to be asked for username and password, you can set up

variable as follows.
let g:github_dashboard = { 'username': 'you', 'password': 'secret' }

Since having plain-text password in your .vimrc is not the most secure thing you can do, it is strongly recommended that you don't put password in your Vim configuration file.

As a more secure alternative, create a Personal Access Token, export it as an environment variable and use it as a password.

# in some secure file sourced in your .bashrc, .bash_profile, .zshrc, etc.
export GITHUB_TOKEN=""
let g:github_dashboard = { 'username': 'you', 'password': $GITHUB_TOKEN }

Without authentication

In fact, GitHub API allows you to browse dashboard or activity stream without authentication, though the hourly rate is limited to 60. Well, that's good enough as long as you don't check GitHub page every minute. Use bang commands then:


Caveat about GitHub Two-factor authentication

If you have enabled GitHub Two-factor authentication, you cannot login with your username and password. In that case, you can generate a Personal Access Token and use it as the password.

Optional configuration

let g:github_dashboard = {}

" Dashboard window position " - Options: tab, top, bottom, above, below, left, right " - Default: tab let g:github_dashboard['position'] = 'top'

" Disable Emoji output " - Default: only enable on terminal Vim on Mac let g:github_dashboard['emoji'] = 0

" Customize emoji (see let g:github_dashboard['emoji_map'] = { \ 'user_dashboard': 'blush', \ 'user_activity': 'smile', \ 'repo_activity': 'laughing', \ 'ForkEvent': 'fork_and_knife' \ }

" Command to open link URLs " - Default: auto-detect let g:github_dashboard['open_command'] = 'open'

" API timeout in seconds " - Default: 10, 20 let g:github_dashboard['api_open_timeout'] = 10 let g:github_dashboard['api_read_timeout'] = 20

" Do not set statusline " - Then you can customize your own statusline with github_dashboard#status() let g:github_dashboard['statusline'] = 0

" GitHub Enterprise let g:github_dashboard['api_endpoint'] = '' let g:github_dashboard['web_endpoint'] = ''


In case you need access to GitHub Enterprise as well as the public GitHub, you might want to define multiple sets of configuration as profiles.

" Default configuration for public GitHub
let g:github_dashboard = {
\ 'username': 'kent'
\ }

" Profile named ck let g:github_dashboard#ck = { \ 'username': 'kent.clark', \ 'api_endpoint': '', \ 'web_endpoint': '' \ }

" Profile named super let g:github_dashboard#super = { \ 'username': 'superman', \ 'api_endpoint': '', \ 'web_endpoint': '' \ }

Then you can access each GitHub instance like so:


" GitHub Enterprise requires authentication, so use non-bang versions GHD -ck GHA -ck lois

GHD -super GHA -super batman/bmobile


Junegunn Choi



"Why Ruby?"

  1. This is a personal fun project, and I like Ruby, so why not?
  2. Ruby allows me to access GitHub API without another Vim plugin or an external executable
  3. Mac OS X (which I use the most) is shipped with a Ruby-enabled Vim, so it's pretty easy to set up

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.