/vim-colors-stylus

Light (& dark) color scheme inspired by vim-colors-pencil

Primary LanguageVim ScriptOtherNOASSERTION

vim-colors-stylus

A light (and dark) color scheme for Vim, originaly based on vim-colors-pencil

code-example

Features

NOTE: this color scheme is still a major work in progress

The stylus color scheme is a color rework of the excellent pencil color scheme.

The original pencil color scheme took its inspiration from iA Writer, an "elegant word processor available on the iOS and OSX platforms."

This Vim color scheme (and the original pencil) features:

  • Subtle indicators of changes in the gutter for Signify, git-gutter, etc.
  • Use for both code and prose, though it’s definitely geared towards the latter
  • Light and dark background variants
  • iTerm color scheme (coming soon?) for using this color scheme with terminal-based Vim
  • Support for tpope/vim-markdown, plasticboy/vim-markdown, and gabrielelana/vim-markdown
  • Support for the bling/vim-airline status bar plugin
  • Support for Vim’s Conceal feature to hide _ and * markup for _italic_, **bold** and ***bold italic*** styled text in Markdown

Requirements

Currently requires vim >= 7.0

Installation

For a basic install simply copy the color scheme file to your ~/.vim/colors directory.

For full support in which the airline theme is available, install using Pathogen, Vundle, Neobundle, or your favorite Vim package manager.

Configuration

Contrast

If you’re looking for greater contrast, set the following in your .vimrc:

let g:stylus_higher_contrast_ui = 0   " 0=low (def), 1=high

It currently only affects the blacks and grays.

Headings color

When using a filetype of markdown, the ‘#’ heading text is shaded dark blue by default. This compensates for the lack of a visual cue found in iA Writer where the heading indicators are inside the left margin.

If you’re looking for neutral heading colors:

let g:stylus_neutral_headings = 1   " 0=blue (def), 1=normal

Code background color

Similar to the rendered markdown found on GitHub, inline and fenced code blocks will have a subtle gray background.

If you’re looking for neutral code background:

let g:stylus_neutral_code_bg = 1   " 0=gray (def), 1=normal

See g:stylus_higher_contrast_ui above for adjusting the code background contrast.

Curled Underline for Spelling Highlights

You can choose between undercurl and underline in highlighting misspelled words.

let g:stylus_spell_undercurl = 1       " 0=underline, 1=undercurl (def)

Non-spell underlines remain non-curled.

Terminal Italics

If you're using Vim in the terminal and your terminal supports italics, you can opt-in to italic support for some syntax highlighting, such as comments, by setting the following in your .vimrc:

let g:stylus_terminal_italics = 1

Airline Theme

airline-example

A matching theme for the Airline status bar plugin is available. Enable by adding to your .vimrc:

let g:airline_theme = 'stylus'

Concealing __styling markup__ in Markdown

The stylus color scheme supports the highlighting groups in the tpope/vim-markdown syntax plugin, to take advantage of Vim’s Conceal feature to hide _ and * markup for _italic_, **bold** and ***bold italic*** styled text in Markdown

See the vim-pencil plugin for details on automatically enabling this feature.

For more details on Vim’s Conceal feature, see:

:help conceallevel
:help concealcursor

Usage

Just like any other color scheme:

:colorscheme stylus

You can toggle between the light and dark variants:

:set background=dark
:set background=light

Like any other color scheme, you can add these commands to your .vimrc.

Font choices

I generally use Source Code Pro, a free monospace font family from Adobe.

@reedes recommeded the following for the stylus theme:

See also

If you find this colorscheme useful, you may want to check out these plugins by the original author of pencil, @reedes:

  • vim-lexical - building on Vim’s spell-check and thesaurus/dictionary completion
  • vim-litecorrect - lightweight auto-correction for Vim
  • vim-one - make use of Vim’s +clientserver capabilities
  • vim-pencil - rethinking Vim as a tool for writers
  • vim-textobj-quote - extends Vim to support typographic (‘curly’) quotes
  • vim-textobj-sentence - improving on Vim's native sentence motion command
  • vim-thematic - modify Vim’s appearance to suit your task and environment
  • vim-wheel - screen-anchored cursor movement for Vim
  • vim-wordy - uncovering usage problems in writing

The README in thematic has more details on setting up emulation of iA Writer.

Contributors

The original pencil color scheme was written by @reedes.

Thanks to those who have helped improve the original pencil color scheme:

Future development

If you’ve spotted a problem or have an idea on improving this color scheme, please post it to the github project issue page.