All Downloads are FREE. Search and download functionalities are using the official Maven repository.

telegramium.bots.high.messageentities.MessageEntities.scala Maven / Gradle / Ivy

package telegramium.bots.high.messageentities

import telegramium.bots.MessageEntity
import telegramium.bots.User
import telegramium.bots.high.messageentities.MessageEntityFormat.*

/** Utility class to work with styled messages using message entities (see
  * https://core.telegram.org/bots/api#messageentity).
  *
  * Compose your message's text using different formatting options like plain text, bold, italics, links, mentions,
  * hashtags and more. This class automatically takes care of calculating text offsets and lengths required by the
  * Telegram API.
  *
  * @example
  *   {{{
  *   val msgEntities = MessageEntities()
  *     .bold("Hello, ")
  *     .mention("@user")
  *     .plain("! Welcome to our ")
  *     .textLink("website", "https://example.com")
  *     .lineBreak()
  *     .plain("Enjoy your stay.")
  *
  *   Methods.sendMessage(
  *     chatId,
  *     // Hello, @user! Welcome to our website\nEnjoy your stay.
  *     text = msgEntities.toPlainText(),
  *     // List(BoldMessageEntity(0, 7), MentionMessageEntity(7, 5), TextLinkMessageEntity(29, 7, "https://example.com"))
  *     entities = msgEntities.toTelegramEntities()
  *   )
  *   }}}
  *
  * @param underlying
  *   This class is basically a thin wrapper over the `Vector` collection. It supports some of the `Vector` operations
  *   directly, such as `++`, `:+`, and `+:`. For additional collection methods not directly available through this
  *   class, you can access the underlying `Vector` instance.
  */
class MessageEntities(val underlying: Vector[MessageEntityFormat] = Vector.empty) extends AnyVal {
  def add(entity: MessageEntityFormat): MessageEntities = :+(entity)

  /** Converts the underlying message entity formats to a list of Telegram message entities.
    *
    * Note: There is no `Plain` message entity in Telegram, so you won't see it in the final list.
    */
  def toTelegramEntities(): List[MessageEntity] = MessageEntityFormat.toMessageEntities(underlying)

  /** Converts the underlying message entity formats to a plain text string. You can pass it as the `text` parameter of
    * the `sendMessage` Telegram Bot API method.
    */
  def toPlainText(): String = underlying.map(_.text).mkString

  def plain(text: String): MessageEntities                         = add(Plain(text))
  def bold(text: String): MessageEntities                          = add(Bold(text))
  def mention(text: String): MessageEntities                       = add(Mention(text))
  def cashtag(text: String): MessageEntities                       = add(Cashtag(text))
  def code(text: String): MessageEntities                          = add(Code(text))
  def botCommand(text: String): MessageEntities                    = add(BotCommand(text))
  def customEmoji(text: String, customEmojiId: String)             = add(CustomEmoji(text, customEmojiId))
  def spoiler(text: String)                                        = add(Spoiler(text))
  def email(text: String): MessageEntities                         = add(Email(text))
  def blockquote(text: String): MessageEntities                    = add(Blockquote(text))
  def expandableBlockquote(text: String): MessageEntities          = add(ExpandableBlockquote(text))
  def pre(text: String, language: Option[String]): MessageEntities = add(Pre(text, language))
  def italic(text: String): MessageEntities                        = add(Italic(text))
  def strikethrough(text: String): MessageEntities                 = add(Strikethrough(text))
  def underline(text: String): MessageEntities                     = add(Underline(text))
  def hashtag(text: String): MessageEntities                       = add(Hashtag(text))
  def textMention(text: String, user: User): MessageEntities       = add(TextMention(text, user))
  def textLink(text: String, url: String): MessageEntities         = add(TextLink(text, url))
  def url(text: String): MessageEntities                           = add(Url(text))
  def phoneNumber(text: String): MessageEntities                   = add(PhoneNumber(text))
  def lineBreak()                                                  = add(MessageEntityFormat.Plain.lineBreak)

  /** Alias for `lineBreak` */
  def br() = lineBreak()

  def ++(other: MessageEntities): MessageEntities      = new MessageEntities(underlying ++ other.underlying)
  def :+(entity: MessageEntityFormat): MessageEntities = new MessageEntities(underlying :+ entity)
  def +:(entity: MessageEntityFormat): MessageEntities = new MessageEntities(entity +: underlying)
}

object MessageEntities {
  def apply(): MessageEntities = new MessageEntities()

  def apply(entities: Seq[MessageEntityFormat]): MessageEntities = new MessageEntities(entities.toVector)

  def apply(first: MessageEntityFormat, rest: MessageEntityFormat*): MessageEntities =
    apply(first +: rest.toVector)

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy