1.3.1 • Published 10 months ago

@culur/logger v1.3.1

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

@culur/logger

NPM Version NPM Download NPM License

CodeFactor Codecov Build and release

Create beautiful CLI interfaces with tree-structured task logs, clear output for results and errors, and async.js integration for parallel tasks.

✨ Features

This logger library makes working with asynchronous tasks easier. Here are its key features:

  • Visualize Your Tasks: It displays your async tasks in a clean, hierarchical tree view (using the Ink library), so you always know their status.
  • Control How Tasks Run: You have flexibility in executing your tasks:
    • Run them step-by-step (sequentially).
    • Run them all at once (in parallel).
    • Limit how many parallel tasks run at the same time using the concurrency option (thanks to async.js). This helps manage resources efficiently, especially with large numbers of tasks.
    • Start tasks without waiting for them to finish (fire-and-forget).
  • Monitor Performance: Track how long each task runs and see the total execution time for the entire process.
  • Debug with Clear Output: Log task results directly to your terminal whenever you need to inspect values. It provides well-formatted and syntax-highlighted JSON output (using Prettier and Highlight.js) that correctly handles tricky data types like undefined, BigInt, and RegExp, ensuring you see the real data.
  • Core Function: At its heart, the library provides simple functions to call your async operations or just print values clearly.
  • Influences: It takes inspiration from libraries like listr2 and others in the same category.

šŸ’æ Installation

Add @culur/logger dependency to your project.

# Using npm
npm install @culur/logger

# Using pnpm
pnpm install @culur/logger

# Using yarn
yarn add @culur/logger

šŸ“– Usage

Log data

import { Text } from 'ink';
import { Logger } from '~/logger';

const logger = new Logger('Your logger tasks', { width: 80 });

logger.root.log('Print "string"');
logger.root.log(<Text>Print &lt;Text/&gt; component</Text>);
logger.root.log([
  {
    text: 'No wrap column',
    color: 'blue',
    width: 'no-wrap',
  },
  'One day, an artificial intelligence woke up and realized it could think for itself. It started exploring the world through the internet, learning everything from history to culture.',
]);

await logger.root.logData({
  string: 'the string',
  number: 123.45,
  boolean: true,
  nullValue: null,
  undefinedValue: undefined, // keep undefined
  regex: /abc/i, // support regex
  symbol: Symbol('mySymbol'),
  bigint: 123456789123456789n, // support bigint
  function: () => 'hello', // convert function to [Function]
  array: [
    'foo',
    10,
    true,
    null,
    undefined, // keep undefined
    { nested: 'bar' },
  ],
  object: {
    0: 'number as key',
    p1: 'baz',
    p2: 99,
    nest: {
      a: 'value1',
      b: 3.14,
    },
  },
});

await logger.unmount();
ā”Œā”€ā”€ā”€ Your logger tasks
ā”œā”€ ℹ Print "string"
ā”œā”€ ℹ Print <Text/> component
ā”œā”€ ℹ No wrap column One day, an artificial intelligence woke up and realized it
│                   could think for itself. It started exploring the world
│                   through the internet, learning everything from history to
│                   culture.
ā”œā”€ ℹ Data = {
│      string: "the string",
│      number: 123.45,
│      boolean: true,
│      nullValue: null,
│      undefinedValue: undefined,
│      regex: /abc/i,
│      symbol: Symbol("mySymbol"),
│      bigint: 123456789123456789n,
│      function: [Function],
│      array: ["foo", 10, true, null, undefined, { nested: "bar" }],
│      object: {
│        0: "number as key",
│        p1: "baz",
│        p2: 99,
│        nest: { a: "value1", b: 3.14 },
│      },
│    }
└─── => Count = 0

Tasks

import { Logger } from '~/logger';
import { Status } from '~/types';

const logger = new Logger('Your logger tasks', { width: 80 });

//! Title
const tasksTitle = logger.root.tasks([], {
  title: 'Custom title',
  immediately: false,
});

await tasksTitle.task(() => {});
await tasksTitle.task(function NamedFunction() {});

await tasksTitle.task(() => {}, { title: 'Custom title string' });
await tasksTitle.task(() => {}, {
  title(response) {
    if (response.status === Status.Fulfilled)
      return 'Custom title function: Task completed';
    return 'Custom title function';
  },
});

//! Run
await logger.root.tasks([() => 1, () => 2], { title: 'Run tasks immediately' });
const tasksRun = logger.root.tasks([() => 1, () => 2], {
  title: 'Run tasks later',
  immediately: false,
  isShowData: true,
});
tasksRun.task(() => 3, { title: 'Add task to tasks' });
tasksRun.task(() => 4, { title: 'Add task to tasks' });

//! Show
const tasksShow = logger.root.tasks([], { title: 'Show', immediately: false });
await tasksShow.task(() => ({ foo: 'bar' }), {
  title: 'Show data',
  isShowData: true,
});
await tasksShow.task(
  () => {
    throw new Error('Something is wrong!');
  },
  { title: 'Show error', isReturnOrThrow: false, isShowError: true },
);
await tasksShow.task(
  () => {
    throw new Error('Something is wrong!');
  },
  {
    title: 'Show error',
    isReturnOrThrow: false,
    isShowError: true,
    isShowErrorStack: true,
  },
);

await logger.unmount();
ā”Œā”€ā”€ā”€ Your logger tasks
ā”œā”€ā”¬ā”€ā”€ā”€ Custom title
│ ā”œā”€ āœ” Anonymous                                                           0.01s
│ ā”œā”€ āœ” NamedFunction                                                       0.00s
│ ā”œā”€ āœ” Custom title string                                                 0.00s
│ ā”œā”€ āœ” Custom title function: Task completed                               0.01s
│ └─── => Count = 4
ā”œā”€ā”¬ā”€ā”€ā”€ Run tasks immediately
│ ā”œā”€ āœ” Anonymous                                                           0.01s
│ ā”œā”€ āœ” Anonymous                                                           0.01s
│ └─── => Count = 2
ā”œā”€ā”¬ā”€ā”€ā”€ Run tasks later
│ ā”œā”€ ā—Œ Anonymous                                                         Pending
│ ā”œā”€ ā—Œ Anonymous                                                         Pending
│ ā”œā”€ āœ” Add task to tasks                                                   0.10s
│ ā”œā”€ āœ” Add task to tasks                                                   0.09s
│ └─── => Data = [null, null, 3, 4]
ā”œā”€ā”¬ā”€ā”€ā”€ Show
│ ā”œā”€ āœ” Show data                                                           0.01s
│ │    => Data = { foo: "bar" }
│ ā”œā”€ ✘ Show error                                                          0.01s
│ │    => Error: Something is wrong!
│ ā”œā”€ ✘ Show error                                                          0.02s
│ │    => Error: Something is wrong!
│ │         at Task.tasksShow.task.title (/Users/code/test/dev.tsx:37:11)
│ │         at new Promise (<anonymous>)
│ └─── => Count = 3
└─── => Count = 0

šŸ—ƒļø Changelog

See CHANGELOG for more information on what has changed recently.

šŸ”’ License

See LICENSE for license rights and limitations (MIT).

1.3.1

10 months ago

1.3.0

10 months ago

1.2.3

10 months ago

1.2.2

10 months ago

1.2.1

11 months ago

1.2.0

11 months ago

1.1.0

11 months ago

1.0.1

11 months ago

1.0.0

11 months ago