Skip to main content

A small package handling telegram message copying preserving text entities

Project description

Telegram Message Copy (TeMeCo)

EO principles respected here Build Status codecov PyPI version

temeco is a simple Telegram message entities to html translator. Telegram Bot API makes it cumbersome fro bots to copy a user's message preserving its entities, since it is currently impossible for a bot to send entities directly along with a message, so it needs to translate a message with entities into HTML or Markdown.

This little package solves this problem and provides a convenient way to translate a message with entities to HTML.

TelegramUTF16Text class is also aware of the fact that Telegram calculates offsets for entities using UTF-16 encoding. This comes into play when text being copied contains symbols which have different lengths in UTF-8 and UTF-16 code units, like emojis.

Installation

pip install temeco

Usage:

from temeco.temeco import BasicEntity, TelegramUTF16Text, HtmlFromMsg

text = (
   "dolorem ipsum, quia dolor sit, 🔥🚒 amet, consectetur, adipisci velit, sed quia 🙃 non numquam eius modi"
   " tempora incidunt, 🙊\nut labore et dolore magnam aliquam quaerat voluptatem."
)
HtmlFromMsg(
   msg_txt=TelegramUTF16Text(text),
   entities=[
       BasicEntity(
           type="bold", offset=8, length=5, msg_text=TelegramUTF16Text(text)
       ),
       BasicEntity(
           type="code", offset=55, length=8, msg_text=TelegramUTF16Text(text)
       ),
       BasicEntity(
           type="text_link",
           offset=64,
           length=5,
           data={"url": "http://google.com/"},
           msg_text=TelegramUTF16Text(text),
       ),
       BasicEntity(
           type="italic",
           offset=153,
           length=7,
           msg_text=TelegramUTF16Text(text),
       ),
   ],
).as_str()

Note:

BasicEntity class supports the following types of entities:

  • bold
  • italic
  • text_link
  • code (monospace text)
  • pre (preformatted text)

Entities like hashtags and usernames are copied as is, since Telegram recognizes them without extra code.

You may create your own class implementing Entity interface and use it instead of BasicEntity.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

temeco-0.1.3.tar.gz (4.3 kB view details)

Uploaded Source

Built Distribution

temeco-0.1.3-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file temeco-0.1.3.tar.gz.

File metadata

  • Download URL: temeco-0.1.3.tar.gz
  • Upload date:
  • Size: 4.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.2 Linux/5.4.0-42-generic

File hashes

Hashes for temeco-0.1.3.tar.gz
Algorithm Hash digest
SHA256 658914a0f5a98662ec35c06bf026edc5ee36fb341945c1dfd7ac7fc1f41e2c47
MD5 aa6aa18ce3285c8a599a7cb160afb33c
BLAKE2b-256 281855a4a85d7f1b95661b204f7f06eb3e0a3816131b8f8ee7014574e7d881f0

See more details on using hashes here.

File details

Details for the file temeco-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: temeco-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 4.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.2 Linux/5.4.0-42-generic

File hashes

Hashes for temeco-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 290e5bbf02a514cf072535836c47b0bd6090bc4afa495f8e424c5ed6baabea52
MD5 28df71b133367694ff804614f551c5d3
BLAKE2b-256 947f2a3ec7f258bb2432af7e3401af99b9e01f10dba9ff800b0dbebcab8fdb0c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page