npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

cliedit

v0.1.3

Published

A lightweight, raw-mode terminal editor utility for Node.js CLI applications, with line wrapping and undo/redo support.

Readme

cliedit

A lightweight, zero-dependency, raw-mode terminal editor component for Node.js.

cliedit is designed to be imported into your own CLI application to provide a full-featured, TTY-based text editing experience. It's perfect for applications that need to ask the user for multi-line input, edit configuration files, or write commit messages.

It includes line wrapping, visual navigation, smart auto-indentation, undo/redo, text selection, Find/Replace, and cross-platform clipboard support.

Features

  • Raw Mode TTY: Takes over the terminal for a full "app-like" feel.
  • Visual Line Wrapping: Text wraps to fit the terminal width.
  • Visual Navigation: Up/Down arrows move by visual rows, not logical lines.
  • Undo/Redo: Ctrl+Z / Ctrl+Y for persistent history.
  • Text Selection: Ctrl+Arrow keys to select text.
  • Clipboard Support: Ctrl+C (Copy), Ctrl+X (Cut), Ctrl+V (Paste) for system clipboard (macOS, Windows, and Linux via xclip).
  • File I/O: Loads from and saves to the filesystem.
  • Search & Replace: Ctrl+W to find text, Ctrl+R to find and replace interactively.
  • Go to Line: Ctrl+L to quickly jump to a specific line number.
  • Smart Auto-Indentation: Automatically preserves indentation level when pressing Enter.

Installation

npm install cliedit

Usage

The package exports an async function openEditor that returns a Promise. The promise resolves when the user quits the editor.

import { openEditor } from 'cliedit';
import path from 'path';

async function getCommitMessage() {
  const tempFile = path.resolve(process.cwd(), 'COMMIT_MSG.txt');
  console.log('Opening editor for commit message...');

  try {
    const result = await openEditor(tempFile);

    // Give the terminal a moment to restore
    await new Promise(res => setTimeout(res, 50));

    if (result.saved) {
      console.log('Message saved!');
      console.log('---------------------');
      console.log(result.content);
      console.log('---------------------');
    } else {
      console.log('Editor quit without saving.');
    }
  } catch (err) {
    console.error('Editor failed to start:', err);
  }
}

getCommitMessage();

Public API

openEditor(filepath: string)

Opens the editor for the specified file. If the file doesn't exist, it will be created upon saving.

  • Returns: Promise<{ saved: boolean; content: string }>
    • saved: true if the user saved (Ctrl+S), false otherwise (Ctrl+Q).
    • content: The final content of the file as a string.

CliEditor

The main editor class. You can import this directly if you need to extend or instantiate the editor with custom logic.

import { CliEditor } from 'cliedit';

Types

Key types are also exported for convenience:

import type {
  DocumentState,
  VisualRow,
  EditorMode,
  NormalizedRange,
} from 'cliedit';

Acknowledgements

Please see the ACKNOWLEDGEMENTS.md file for important copyright information regarding the vendored keypress component.

License

MIT