# Colors contribution layer for Spacemacs
![logo](img/rainbow_dash.png)
**Table of Contents**
- [Colors contribution layer for Spacemacs](#colors-contribution-layer-for-spacemacs)
- [Description](#description)
- [Install](#install)
- [Enable rainbow-identifiers](#enable-rainbow-identifiers)
- [Enable Nyan cat](#enable-nyan-cat)
- [Key bindings](#key-bindings)
- [Rainbow Identifiers](#rainbow-identifiers)
- [Rainbow Mode](#rainbow-mode)
## Description
This layer colors your life with:
- [rainbow identifiers][]
- [rainbow mode][]
- [nyan mode][]
[rainbow identifiers][] mode will colorize each variables and functions with an
almost unique color. The keywords and the declaration of function colors are
disabled in order to make the colorized variables and functions stand out.
[rainbow mode][] displays strings representing colors with the color they
represent as background.
[nyan mode][] display a Nyan cat progress bar in the mode-line.
## Install
To use this contribution add it to your `~/.spacemacs`
```elisp
(setq-default dotspacemacs-configuration-layers '(colors))
```
### Enable rainbow-identifiers
To enable the package `rainbow-identifiers` set the variable
`colors-enable-rainbow-identifiers` to `t`:
```elisp
(setq-default dotspacemacs-configuration-layers '(
(colors :variables colors-enable-rainbow-identifiers t)))
```
### Enable Nyan cat
To enable the package `nyan-mode` set the variable
`colors-enable-nyan-cat-progress-bar` to `t`:
```elisp
(setq-default dotspacemacs-configuration-layers '(
(colors :variables colors-enable-nyan-cat-progress-bar t)))
```
It may be handy to enable it only in a GUI, you can do it by using
a quasi-quoted list:
```elisp
(setq-default dotspacemacs-configuration-layers
`((colors :variables
colors-enable-nyan-cat-progress-bar ,(display-graphic-p))))
```
## Key bindings
The prefix associated with colors is C.
### Rainbow Identifiers
![theme_tweaks_python](img/theme-tweaks-python.png)
`rainbow-identifiers` mode can be toggled on and off with:
t C i
Note that the toggle is local to the current buffer.
The `saturation` and `lightness` of identifier colors can be adjusted live
with the micro-state:
Key Binding | Description
--------------|------------------------------------------------------------
` C i s` | initiate change `saturation` mini-mode
` C i l` | initiate change `lightness` mini-mode
`+` | increase the `saturation` or `lightness`
`-` | decrease the `saturation` or `lightness`
`=` | reset the `saturation` or `lightness`
Any other key | leave the change mini-mode
### Rainbow Mode
![rainbow_mode](img/rainbow-mode.png)
`rainbow-mode` mode can be toggled on and off with:
t C c
### Nyan Mode
`nyan-mode` mode can be toggled on and off with:
t m n
Note that the toggle is local to the current buffer.
[rainbow identifiers]: https://github.com/Fanael/rainbow-identifiers
[rainbow mode]: https://julien.danjou.info/projects/emacs-packages
[nyan mode]: https://github.com/syl20bnr/nyan-mode