2.1.0
core framework for tgsnake for parsing message.
Repository
Current version released
a year ago
Versions
@tgsnake/parser
core framework for tgsnake for parsing message.
example :
'**bold**';it will be
[
  'bold',
  [
    {
      offset: 0,
      length: 4,
      type: 'bold',
    },
  ],
];Quick Start
Breaking Changes in v2!
In this v2 is not supported gramjs framework by default! Unlike v1 which supports it, in v2 we fully use@tgsnake/core.
// index.ts
import { Parser } from '@tgsnake/parser'
import { Client } from '@tgsnake/core'
const client = new Client(...)
const entities = Parser.parse('**Hello World**,'markdown')converting tgsnake entities to raw api
Parser.toRaw(client, entities);converting raw entities to tgsnake entities
Parser.fromRaw(TypeMessageEntities);available parseMode
markdown
'**bold**';
'__italic__';
'~~strike~~';
'`code`';
'```pre```';
'[text](link)';
'--underline--';
'||spoiler||';
'>blockquote';
'**>expandable blockquote';Escaping
for escaping just add backslash (\) before markdown syntax.
'\\**bold\\**';
'\\__italic\\__';
'\\~~strike\\~~';
'\\`code\\`';
'\\```pre\\```';
'[text]\\(link)';
'\\--underline\\--';
'\\||spoiler\\||';
'\\>blockquote';
'\\**>expandable blockquote';html
"<b>bold</b>" || "<strong>bold</strong>"
"<i>italic</i>" || "<em>italic</em>"
"<s>strike</s>" || "<del>strike</del>"
"<code>code</code>"
"<pre><code>pre</code></pre>"  || "<pre><code language-javascript >pre</code></pre>"
"<a href="link">text</a>"
"<u>underline</u>"
"<spoiler>spoiler</spoiler>" || "<sp>spoiler</sp>" || "<tg-spoiler>spoiler</tg-spoiler>" || '<span class="tg-spoiler">spoiler</span>'
"<tg-emoji id="1">text<tg-emoji>" || "<span id="1" class="tg-emoji">text<span>"
"<blockquote>blockquote</blockquote>"
"<blockquote expandable>expandable blockquote</blockquote>"Escaping
for escaping replace < with < , > with &rt; , & with &
"<b&rt;bold</b&rt;" || "<strong&rt;bold</strong&rt;"
"<i&rt;italic</i&rt;" || "<em&rt;italic</em&rt;"
"<s&rt;strike</s&rt;" || "<del&rt;strike</del&rt;"
"<code&rt;code</code&rt;"
"<pre&rt;<code&rt;pre</code&rt;</pre&rt;"  || "<pre&rt;<code language-javascript &rt;pre</code&rt;</pre&rt;"
"<a href="link"&rt;text</a&rt;"
"<u&rt;underline</u&rt;"
"<spoiler&rt;spoiler</spoiler&rt;" || "<sp&rt;spoiler</sp&rt;" || "<tg-spoiler&rt;spoiler</tg-spoiler&rt;" || '<span class="tg-spoiler"&rt;spoiler</span&rt;'
"<blockquote&rt;blockquote</blockquote&rt;"Available Formating Style
| Entity Type | Markdown style | HTML style | Description | 
|---|---|---|---|
| Bold | *text* | 
<b>text</b> or <strong>text</strong> | 
|
| Italic | __text__ | 
<i>text</i> or <em>text</em> | 
|
~~text~~ | 
<s>text</s> or <del>text</del> | 
||
Code | 
`text` | 
<code>text</code> | 
|
Pre | 
```text``` | 
<pre><code>text</code></pre> or <pre language-javascript><code>text</code></pre> | 
|
| Link | [text](link) | 
<a href="link">text</a> | 
You can fill the link params with tg://user?id=123456 for mentioning user and tg://emoji?id=123456 for custom emoji. | 
| Underline | --text-- | 
<u>text</u> | 
|
| Spoiler | ||text|| | 
<spoiler>text</spoiler> or <sp>text</sp> or <tg-spoiler>text</tg-spoiler> or <span class="tg-spoiler">text</span> | 
|
| Custom Emoji | [text](tg://emoji?id=123456) | 
<tg-emoji id="123456">text</tg-emoji> or <emoji id="123456">text</emoji> or <span class="tg-emoji" id="123456">text</span> | 
HTML tag has 2 way to define the emojiId. First using id attribute and seconds use emojiId attribute. | 
| Blockquote | >text | 
<blockquote>text</blockquote> | 
Build with ♥️ by tgsnake dev.