
- Complete NestJS TypeScript implementation with WebSocket support - Direct messaging (DM) and group chat functionality - End-to-end encryption with AES encryption and key pairs - Media file support (images, videos, audio, documents) up to 100MB - Push notifications with Firebase Cloud Messaging integration - Mention alerts and real-time typing indicators - User authentication with JWT and Passport - SQLite database with TypeORM entities and relationships - Comprehensive API documentation with Swagger/OpenAPI - File upload handling with secure access control - Online/offline status tracking and presence management - Message editing, deletion, and reply functionality - Notification management with automatic cleanup - Health check endpoint for monitoring - CORS configuration for cross-origin requests - Environment-based configuration management - Structured for Flutter SDK integration Features implemented: ✅ Real-time messaging with Socket.IO ✅ User registration and authentication ✅ Direct messages and group chats ✅ Media file uploads and management ✅ End-to-end encryption ✅ Push notifications ✅ Mention alerts ✅ Typing indicators ✅ Message read receipts ✅ Online status tracking ✅ File access control ✅ Comprehensive API documentation Ready for Flutter SDK development and production deployment.
153 lines
4.2 KiB
Markdown
153 lines
4.2 KiB
Markdown
# ansi-styles [](https://travis-ci.org/chalk/ansi-styles)
|
|
|
|
> [ANSI escape codes](https://en.wikipedia.org/wiki/ANSI_escape_code#Colors_and_Styles) for styling strings in the terminal
|
|
|
|
You probably want the higher-level [chalk](https://github.com/chalk/chalk) module for styling your strings.
|
|
|
|
<img src="screenshot.svg" width="900">
|
|
|
|
## Install
|
|
|
|
```
|
|
$ npm install ansi-styles
|
|
```
|
|
|
|
## Usage
|
|
|
|
```js
|
|
const style = require('ansi-styles');
|
|
|
|
console.log(`${style.green.open}Hello world!${style.green.close}`);
|
|
|
|
|
|
// Color conversion between 16/256/truecolor
|
|
// NOTE: If conversion goes to 16 colors or 256 colors, the original color
|
|
// may be degraded to fit that color palette. This means terminals
|
|
// that do not support 16 million colors will best-match the
|
|
// original color.
|
|
console.log(style.bgColor.ansi.hsl(120, 80, 72) + 'Hello world!' + style.bgColor.close);
|
|
console.log(style.color.ansi256.rgb(199, 20, 250) + 'Hello world!' + style.color.close);
|
|
console.log(style.color.ansi16m.hex('#abcdef') + 'Hello world!' + style.color.close);
|
|
```
|
|
|
|
## API
|
|
|
|
Each style has an `open` and `close` property.
|
|
|
|
## Styles
|
|
|
|
### Modifiers
|
|
|
|
- `reset`
|
|
- `bold`
|
|
- `dim`
|
|
- `italic` *(Not widely supported)*
|
|
- `underline`
|
|
- `inverse`
|
|
- `hidden`
|
|
- `strikethrough` *(Not widely supported)*
|
|
|
|
### Colors
|
|
|
|
- `black`
|
|
- `red`
|
|
- `green`
|
|
- `yellow`
|
|
- `blue`
|
|
- `magenta`
|
|
- `cyan`
|
|
- `white`
|
|
- `blackBright` (alias: `gray`, `grey`)
|
|
- `redBright`
|
|
- `greenBright`
|
|
- `yellowBright`
|
|
- `blueBright`
|
|
- `magentaBright`
|
|
- `cyanBright`
|
|
- `whiteBright`
|
|
|
|
### Background colors
|
|
|
|
- `bgBlack`
|
|
- `bgRed`
|
|
- `bgGreen`
|
|
- `bgYellow`
|
|
- `bgBlue`
|
|
- `bgMagenta`
|
|
- `bgCyan`
|
|
- `bgWhite`
|
|
- `bgBlackBright` (alias: `bgGray`, `bgGrey`)
|
|
- `bgRedBright`
|
|
- `bgGreenBright`
|
|
- `bgYellowBright`
|
|
- `bgBlueBright`
|
|
- `bgMagentaBright`
|
|
- `bgCyanBright`
|
|
- `bgWhiteBright`
|
|
|
|
## Advanced usage
|
|
|
|
By 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.
|
|
|
|
- `style.modifier`
|
|
- `style.color`
|
|
- `style.bgColor`
|
|
|
|
###### Example
|
|
|
|
```js
|
|
console.log(style.color.green.open);
|
|
```
|
|
|
|
Raw 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.
|
|
|
|
###### Example
|
|
|
|
```js
|
|
console.log(style.codes.get(36));
|
|
//=> 39
|
|
```
|
|
|
|
## [256 / 16 million (TrueColor) support](https://gist.github.com/XVilka/8346728)
|
|
|
|
`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.
|
|
|
|
The following color spaces from `color-convert` are supported:
|
|
|
|
- `rgb`
|
|
- `hex`
|
|
- `keyword`
|
|
- `hsl`
|
|
- `hsv`
|
|
- `hwb`
|
|
- `ansi`
|
|
- `ansi256`
|
|
|
|
To use these, call the associated conversion function with the intended output, for example:
|
|
|
|
```js
|
|
style.color.ansi.rgb(100, 200, 15); // RGB to 16 color ansi foreground code
|
|
style.bgColor.ansi.rgb(100, 200, 15); // RGB to 16 color ansi background code
|
|
|
|
style.color.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code
|
|
style.bgColor.ansi256.hsl(120, 100, 60); // HSL to 256 color ansi foreground code
|
|
|
|
style.color.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color foreground code
|
|
style.bgColor.ansi16m.hex('#C0FFEE'); // Hex (RGB) to 16 million color background code
|
|
```
|
|
|
|
## Related
|
|
|
|
- [ansi-escapes](https://github.com/sindresorhus/ansi-escapes) - ANSI escape codes for manipulating the terminal
|
|
|
|
## Maintainers
|
|
|
|
- [Sindre Sorhus](https://github.com/sindresorhus)
|
|
- [Josh Junon](https://github.com/qix-)
|
|
|
|
## For enterprise
|
|
|
|
Available as part of the Tidelift Subscription.
|
|
|
|
The maintainers of `ansi-styles` and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. [Learn more.](https://tidelift.com/subscription/pkg/npm-ansi-styles?utm_source=npm-ansi-styles&utm_medium=referral&utm_campaign=enterprise&utm_term=repo)
|