An open API service indexing awesome lists of open source software.

https://github.com/gramiojs/format

Library for formatting text for Telegram Bot API
https://github.com/gramiojs/format

bot formatting gramio html markdown markdownv2 parse-mode telegram telegram-bot telegram-bot-api

Last synced: 3 months ago
JSON representation

Library for formatting text for Telegram Bot API

Awesome Lists containing this project

README

          

# @gramio/format

Library for [formatting](https://core.telegram.org/bots/api#messageentity) text for Telegram Bot API. Used under the hood by [GramIO](https://gramio.dev/) framework but it is framework-agnostic.

[![npm](https://img.shields.io/npm/v/@gramio/format?logo=npm&style=flat&labelColor=000&color=3b82f6)](https://www.npmjs.org/package/@gramio/format)
[![JSR](https://jsr.io/badges/@gramio/format)](https://jsr.io/@gramio/format)
[![JSR Score](https://jsr.io/badges/@gramio/format/score)](https://jsr.io/@gramio/format)

## Installation

```sh
npm install @gramio/format
# or
bun add @gramio/format
```

## Overview

`@gramio/format` builds [`MessageEntity`](https://core.telegram.org/bots/api#messageentity) objects alongside the text so you never have to track character offsets manually. All formatters compose freely — nest them as deeply as you like.

```ts
import { format, bold, italic, link, spoiler } from "@gramio/format";

const msg = format`${bold`Hi!`}

Can ${italic("you")} help ${spoiler`me`}?

Can you give me a ${link("star", "https://github.com/gramiojs/gramio")}?`;

// msg.text → the plain string
// msg.entities → ready-to-send MessageEntity[]
```

---

## Template literals

### `format`

Strips leading indentation from every line (safe to indent inside your source).

```ts
import { format, bold, italic } from "@gramio/format";

format`Hello ${bold("world")}!`
// text: "Hello world!"
// entities: [{ type: "bold", offset: 6, length: 5 }]
```

### `formatSaveIndents`

Same as `format` but preserves all whitespace exactly as written.

```ts
import { formatSaveIndents, code } from "@gramio/format";

formatSaveIndents`Run:\n ${code("bun install")}`
```

---

## Formatters

Every formatter accepts either a plain string, a `FormattableString`, or a tagged template literal.

```ts
bold("text")
bold`text`
bold(italic("text")) // nested: bold wraps italic
```

| Formatter | Telegram entity | Notes |
|---|---|---|
| `bold` | `bold` | Cannot be combined with `code` / `pre` |
| `italic` | `italic` | Cannot be combined with `code` / `pre` |
| `underline` | `underline` | Cannot be combined with `code` / `pre` |
| `strikethrough` | `strikethrough` | Cannot be combined with `code` / `pre` |
| `spoiler` | `spoiler` | Cannot be combined with `code` / `pre` |
| `blockquote` | `blockquote` | Cannot be nested |
| `expandableBlockquote` | `expandable_blockquote` | Cannot be nested |
| `code` | `code` | Inline monospace; cannot be combined with others |
| `pre(text, lang?)` | `pre` | Code block; optional language for syntax highlight |
| `link(text, url)` | `text_link` | Cannot be combined with `code` / `pre` |
| `mention(text, user)` | `text_mention` | |
| `customEmoji(emoji, id)` | `custom_emoji` | Requires purchased username on Fragment |

### Examples

```ts
import {
bold, italic, underline, strikethrough, spoiler,
blockquote, expandableBlockquote,
code, pre, link, mention, customEmoji,
format,
} from "@gramio/format";

bold`Important`
italic`Subtle`
underline`Marked`
strikethrough`Removed`
spoiler`Secret`

blockquote`A quote from someone wise.`
expandableBlockquote`A very long quote that can be collapsed.`

code`npm install`
pre("console.log('hi')", "js")

link("GramIO", "https://gramio.dev")
mention("John", { id: 1, is_bot: false, first_name: "John" })
customEmoji("⚔️", "5222106016283378623")

// Compose freely
format`${bold("Price")}: ${italic("$42")}\nSee ${link("docs", "https://gramio.dev")}`
```

---

## `join` — formatting arrays

Array `.join()` discards entities. Use `join` instead:

```ts
import { join, bold, format } from "@gramio/format";

const items = ["apple", "banana", "cherry"];

format`Shopping list:\n${join(items, (item) => bold(item), "\n")}`;
// text: "Shopping list:\napple\nbanana\ncherry"
// entities: bold on each item at the correct offsets
```

The third argument is the separator (default `", "`). Return `null`, `undefined`, or `false` from the iterator to skip an item.

---

## `markdownToFormattable` — Markdown → FormattableString

Converts a Markdown string to a `FormattableString` with proper entities. Useful when your content comes from a Markdown source (e.g., API docs, user input).

**Requires [`marked`](https://marked.js.org/) as a peer dependency:**

```sh
npm install marked
```

```ts
import { markdownToFormattable } from "@gramio/format/markdown";

const result = markdownToFormattable(
"# Title\n\n**bold** and *italic*\n\n> Blockquote\n\n[link](https://gramio.dev)"
);

// result.text → "Title\n\nbold and italic\n\nBlockquote\n\nlink"
// result.entities → bold, italic, blockquote, text_link at correct offsets
```

### Supported Markdown elements

| Markdown | Result |
|---|---|
| `**text**` / `__text__` | bold |
| `*text*` / `_text_` | italic |
| `~~text~~` | strikethrough |
| `` `code` `` | inline code |
| ```` ```lang\n...\n``` ```` | pre block (with optional language) |
| `> text` | blockquote |
| `[text](url)` | link |
| `![alt](url)` | link (image → text link) |
| `# Heading` … `###### Heading` | bold |
| `- item` / `1. item` | list with bullet/number prefix |

---

## `htmlToFormattable` — HTML → FormattableString

Converts an HTML string to a `FormattableString`. Designed for HTML produced by rich-text editors such as **TipTap**, **ProseMirror**, or **Quill**.

**Requires [`node-html-parser`](https://github.com/taoqf/node-html-parser) as a peer dependency:**

```sh
npm install node-html-parser
```

```ts
import { htmlToFormattable } from "@gramio/format/html";

const result = htmlToFormattable(
"

Hello world

"
);

// result.text → "Hello world"
// result.entities → [bold offset=0 len=5, italic offset=6 len=5]
```

### Supported HTML elements

| Element | Result | Notes |
|---|---|---|
| ``, `` | bold | |
| ``, `` | italic | |
| `` | underline | |
| ``, ``, `` | strikethrough | |
| `` | inline code | When not inside `

` |

| `
` | pre block | Language extracted from `language-*` class |

| `
` | blockquote | Children processed recursively |
| `` | link | |
| `

` … `

` | bold | |
| `


`, `


` | transparent wrapper | Children joined with `""` |
| `
` | `\n` | |
| `