Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unjs/consola
๐จ Elegant Console Logger for Node.js and Browser
https://github.com/unjs/consola
cli console fancy log node terminal
Last synced: 5 days ago
JSON representation
๐จ Elegant Console Logger for Node.js and Browser
- Host: GitHub
- URL: https://github.com/unjs/consola
- Owner: unjs
- License: other
- Created: 2018-03-31T15:47:47.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2024-12-28T21:45:50.000Z (14 days ago)
- Last Synced: 2025-01-04T08:38:52.767Z (8 days ago)
- Topics: cli, console, fancy, log, node, terminal
- Language: TypeScript
- Homepage:
- Size: 2.67 MB
- Stars: 6,259
- Watchers: 31
- Forks: 182
- Open Issues: 44
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome - unjs/consola - ๐จ Elegant Console Logger for Node.js and Browser (TypeScript)
- awesome-nodejs-cn - consola - **star:6261** ๆงๅถๅฐ่ฎฐๅฝๅจใ ![star > 2000][Awesome] (ๅ / ๆฅๅฟ)
- awesome-repositories - unjs/consola - ๐จ Elegant Console Logger for Node.js and Browser (TypeScript)
- awesome-github-star - consola
- awesome-list - consola
- awesome-nodejs - consola - Console logger. (Packages / Logging)
- awesome-javascript - consola
- project-awesome - unjs/consola - ๐จ Elegant Console Logger for Node.js and Browser (TypeScript)
- awesome - unjs/consola - ๐จ Elegant Console Logger for Node.js and Browser (TypeScript)
README
# ๐จ Consola
> Elegant Console Wrapper
[![npm version][npm-version-src]][npm-version-href]
[![npm downloads][npm-downloads-src]][npm-downloads-href]
[![bundle][bundle-src]][bundle-href]## Why Consola?
๐ย Easy to use
๐ ย Fancy output with fallback for minimal environments
๐ย Pluggable reporters
๐ปย Consistent command line interface (CLI) experience
๐ทย Tag support
๐ย Redirect `console` and `stdout/stderr` to consola and easily restore redirect.
๐ย Browser support
โฏย Pause/Resume support
๐ปย Mocking support
๐ฎโโ๏ธย Spam prevention by throttling logs
โฏย Interactive prompt support powered by [`clack`](https://github.com/natemoo-re/clack)## Installation
Using npm:
```bash
npm i consola
```Using yarn:
```bash
yarn add consola
```Using pnpm:
```bash
pnpm i consola
```## Getting Started
```js
// ESM
import { consola, createConsola } from "consola";// CommonJS
const { consola, createConsola } = require("consola");consola.info("Using consola 3.0.0");
consola.start("Building project...");
consola.warn("A new version of consola is available: 3.0.1");
consola.success("Project built!");
consola.error(new Error("This is an example error. Everything is fine!"));
consola.box("I am a simple box");
await consola.prompt("Deploy to the production?", {
type: "confirm",
});
```Will display in the terminal:
![consola-screenshot](https://github.com/unjs/consola/assets/904724/0e511ee6-2543-43ab-9eda-152f07134d94)
You can use smaller core builds without fancy reporter to save 80% of the bundle size:
```ts
import { consola, createConsola } from "consola/basic";
import { consola, createConsola } from "consola/browser";
import { createConsola } from "consola/core";
```## Consola Methods
#### `(logObject)` `(args...)`
Log to all reporters.
Example: `consola.info('Message')`
#### `await prompt(message, { type, cancel })`
Show an input prompt. Type can either of `text`, `confirm`, `select` or `multiselect`.
If prompt is canceled by user (with Ctrol+C), default value will be resolved by default. This strategy can be configured by setting `{ cancel: "..." }` option:
- `"default"` - Resolve the promise with the `default` value or `initial` value.
- `"undefined`" - Resolve the promise with `undefined`.
- `"null"` - Resolve the promise with `null`.
- `"symbol"` - Resolve the promise with a symbol `Symbol.for("cancel")`.
- `"reject"` - Reject the promise with an error.See [examples/prompt.ts](./examples/prompt.ts) for usage examples.
#### `addReporter(reporter)`
- Aliases: `add`
Register a custom reporter instance.
#### `removeReporter(reporter?)`
- Aliases: `remove`, `clear`
Remove a registered reporter.
If no arguments are passed all reporters will be removed.
#### `setReporters(reporter|reporter[])`
Replace all reporters.
#### `create(options)`
Create a new `Consola` instance and inherit all parent options for defaults.
#### `withDefaults(defaults)`
Create a new `Consola` instance with provided defaults
#### `withTag(tag)`
- Aliases: `withScope`
Create a new `Consola` instance with that tag.
#### `wrapConsole()` `restoreConsole()`
Globally redirect all `console.log`, etc calls to consola handlers.
#### `wrapStd()` `restoreStd()`
Globally redirect all stdout/stderr outputs to consola.
#### `wrapAll()` `restoreAll()`
Wrap both, std and console.
console uses std in the underlying so calling `wrapStd` redirects console too.
Benefit of this function is that things like `console.info` will be correctly redirected to the corresponding type.#### `pauseLogs()` `resumeLogs()`
- Aliases: `pause`/`resume`
**Globally** pause and resume logs.
Consola will enqueue all logs when paused and then sends them to the reported when resumed.
#### `mockTypes`
- Aliases: `mock`
Mock all types. Useful for using with tests.
The first argument passed to `mockTypes` should be a callback function accepting `(typeName, type)` and returning the mocked value:
```js
// Jest
consola.mockTypes((typeName, type) => jest.fn());
// Vitest
consola.mockTypes((typeName, type) => vi.fn());
```Please note that with the example above, everything is mocked independently for each type. If you need one mocked fn create it outside:
```js
// Jest
const fn = jest.fn();
// Vitest
const fn = vi.fn();
consola.mockTypes(() => fn);
```If callback function returns a _falsy_ value, that type won't be mocked.
For example if you just need to mock `consola.fatal`:
```js
// Jest
consola.mockTypes((typeName) => typeName === "fatal" && jest.fn());
// Vitest
consola.mockTypes((typeName) => typeName === "fatal" && vi.fn());
```**NOTE:** Any instance of consola that inherits the mocked instance, will apply provided callback again.
This way, mocking works for `withTag` scoped loggers without need to extra efforts.## Custom Reporters
Consola ships with 3 built-in reporters out of the box. A fancy colored reporter by default and fallsback to a basic reporter if running in a testing or CI environment detected using [unjs/std-env](https://github.com/unjs/std-env) and a basic browser reporter.
You can create a new reporter object that implements `{ log(logObject): () => { } }` interface.
**Example:** Simple JSON reporter
```ts
import { createConsola } from "consola";const consola = createConsola({
reporters: [
{
log: (logObj) => {
console.log(JSON.stringify(logObj));
},
},
],
});// Prints {"date":"2023-04-18T12:43:38.693Z","args":["foo bar"],"type":"log","level":2,"tag":""}
consola.log("foo bar");
```## Log Level
Consola only shows logs with configured log level or below. (Default is `3`)
Available log levels:
- `0`: Fatal and Error
- `1`: Warnings
- `2`: Normal logs
- `3`: Informational logs, success, fail, ready, start, ...
- `4`: Debug logs
- `5`: Trace logs
- `-999`: Silent
- `+999`: Verbose logsYou can set the log level by either:
- Passing `level` option to `createConsola`
- Setting `consola.level` on instance
- Using the `CONSOLA_LEVEL` environment variable (not supported for browser and core builds).## Log Types
Log types are exposed as `consola.[type](...)` and each is a preset of styles and log level.
A list of all available built-in types is [available here](./src/constants.ts).
## Creating a new instance
Consola has a global instance and is recommended to use everywhere.
In case more control is needed, create a new instance.```js
import { createConsola } from "consola";const logger = createConsola({
// level: 4,
// fancy: true | false
// formatOptions: {
// columns: 80,
// colors: false,
// compact: false,
// date: false,
// },
});
```## Integrations
### With jest or vitest
```js
describe("your-consola-mock-test", () => {
beforeAll(() => {
// Redirect std and console to consola too
// Calling this once is sufficient
consola.wrapAll();
});beforeEach(() => {
// Re-mock consola before each test call to remove
// calls from before
// Jest
consola.mockTypes(() => jest.fn());
// Vitest
consola.mockTypes(() => vi.fn());
});test("your test", async () => {
// Some code here// Let's retrieve all messages of `consola.log`
// Get the mock and map all calls to their first argument
const consolaMessages = consola.log.mock.calls.map((c) => c[0]);
expect(consolaMessages).toContain("your message");
});
});
```### With jsdom
```js
{
new jsdom.VirtualConsole().sendTo(consola);
}
```## Console Utils
```ts
// ESM
import {
stripAnsi,
centerAlign,
rightAlign,
leftAlign,
align,
box,
colors,
getColor,
colorize,
} from "consola/utils";// CommonJS
const { stripAnsi } = require("consola/utils");
```## Raw logging methods
Objects sent to the reporter could lead to unexpected output when object is close to internal object structure containing either `message` or `args` props. To enforce the object to be interpreted as pure object, you can use the `raw` method chained to any log type.
**Example:**
```js
// Prints "hello"
consola.log({ message: "hello" });// Prints "{ message: 'hello' }"
consola.log.raw({ message: "hello" });
```## License
MIT
[npm-version-src]: https://img.shields.io/npm/v/consola?style=flat&colorA=18181B&colorB=F0DB4F
[npm-version-href]: https://npmjs.com/package/consola
[npm-downloads-src]: https://img.shields.io/npm/dm/consola?style=flat&colorA=18181B&colorB=F0DB4F
[npm-downloads-href]: https://npmjs.com/package/consola
[codecov-src]: https://img.shields.io/codecov/c/gh/unjs/consola/main?style=flat&colorA=18181B&colorB=F0DB4F
[codecov-href]: https://codecov.io/gh/unjs/consola
[bundle-src]: https://img.shields.io/bundlephobia/min/consola?style=flat&colorA=18181B&colorB=F0DB4F
[bundle-href]: https://bundlephobia.com/result?p=consola