readme.md
1# ansi-styles [![Build Status](https://travis-ci.org/chalk/ansi-styles.svg?branch=master)](https://travis-ci.org/chalk/ansi-styles)
2
3> [ANSI escape codes](http://en.wikipedia.org/wiki/ANSI_escape_code#Colors_and_Styles) for styling strings in the terminal
4
5You probably want the higher-level [chalk](https://github.com/chalk/chalk) module for styling your strings.
6
7<img src="https://cdn.rawgit.com/chalk/ansi-styles/8261697c95bf34b6c7767e2cbe9941a851d59385/screenshot.svg" width="900">
8
9
10## Install
11
12```
13$ npm install ansi-styles
14```
15
16
17## Usage
18
19```js
20const style = require('ansi-styles');
21
22console.log(`${style.green.open}Hello world!${style.green.close}`);
23
24
25// Color conversion between 16/256/truecolor
26// NOTE: If conversion goes to 16 colors or 256 colors, the original color
27// may be degraded to fit that color palette. This means terminals
28// that do not support 16 million colors will best-match the
29// original color.
30console.log(style.bgColor.ansi.hsl(120, 80, 72) + 'Hello world!' + style.bgColor.close);
31console.log(style.color.ansi256.rgb(199, 20, 250) + 'Hello world!' + style.color.close);
32console.log(style.color.ansi16m.hex('#ABCDEF') + 'Hello world!' + style.color.close);
33```
34
35## API
36
37Each style has an `open` and `close` property.
38
39
40## Styles
41
42### Modifiers
43
44- `reset`
45- `bold`
46- `dim`
47- `italic` *(Not widely supported)*
48- `underline`
49- `inverse`
50- `hidden`
51- `strikethrough` *(Not widely supported)*
52
53### Colors
54
55- `black`
56- `red`
57- `green`
58- `yellow`
59- `blue`
60- `magenta`
61- `cyan`
62- `white`
63- `gray` ("bright black")
64- `redBright`
65- `greenBright`
66- `yellowBright`
67- `blueBright`
68- `magentaBright`
69- `cyanBright`
70- `whiteBright`
71
72### Background colors
73
74- `bgBlack`
75- `bgRed`
76- `bgGreen`
77- `bgYellow`
78- `bgBlue`
79- `bgMagenta`
80- `bgCyan`
81- `bgWhite`
82- `bgBlackBright`
83- `bgRedBright`
84- `bgGreenBright`
85- `bgYellowBright`
86- `bgBlueBright`
87- `bgMagentaBright`
88- `bgCyanBright`
89- `bgWhiteBright`
90
91
92## Advanced usage
93
94By default, you get a map of styles, but the styles are also available as groups. They are non-enumerable so they don't show up unless you access them explicitly. This makes it easier to expose only a subset in a higher-level module.
95
96- `style.modifier`
97- `style.color`
98- `style.bgColor`
99
100###### Example
101
102```js
103console.log(style.color.green.open);
104```
105
106Raw escape codes (i.e. without the CSI escape prefix `\u001B[` and render mode postfix `m`) are available under `style.codes`, which returns a `Map` with the open codes as keys and close codes as values.
107
108###### Example
109
110```js
111console.log(style.codes.get(36));
112//=> 39
113```
114
115
116## [256 / 16 million (TrueColor) support](https://gist.github.com/XVilka/8346728)
117
118`ansi-styles` uses the [`color-convert`](https://github.com/Qix-/color-convert) package to allow for converting between various colors and ANSI escapes, with support for 256 and 16 million colors.
119
120To use these, call the associated conversion function with the intended output, for example:
121
122```js
123style.color.ansi.rgb(100, 200, 15); // RGB to 16 color ansi foreground code
124style.bgColor.ansi.rgb(100, 200, 15); // RGB to 16 color ansi background code
125
126style.color.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code
127style.bgColor.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code
128
129style.color.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color foreground code
130style.bgColor.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color background code
131```
132
133
134## Related
135
136- [ansi-escapes](https://github.com/sindresorhus/ansi-escapes) - ANSI escape codes for manipulating the terminal
137
138
139## Maintainers
140
141- [Sindre Sorhus](https://github.com/sindresorhus)
142- [Josh Junon](https://github.com/qix-)
143
144
145## License
146
147MIT
148