U
    g                     @   s   d Z ddlmZmZmZmZ ddlmZ ddlm	Z	 ddl
mZmZ ddlmZ ddlmZmZ erpddlmZ G d	d
 d
eZdS )zQThis module contains the classes that represent Telegram InputTextMessageContent.    )TYPE_CHECKINGOptionalSequenceTuple)InputMessageContent)MessageEntity)parse_lpo_and_dwppparse_sequence_arg)DEFAULT_NONE)JSONDictODVInput)LinkPreviewOptionsc                	       s\   e Zd ZdZdZedefdddeee ee	e
  ed ee ee d fddZ  ZS )	InputTextMessageContenta_	  
    Represents the content of a text message to be sent as the result of an inline query.

    Objects of this class are comparable in terms of equality. Two objects of this class are
    considered equal, if their :attr:`message_text` is equal.

    Examples:
        :any:`Inline Bot <examples.inlinebot>`

    Args:
        message_text (:obj:`str`): Text of the message to be sent,
            :tg-const:`telegram.constants.MessageLimit.MIN_TEXT_LENGTH`-
            :tg-const:`telegram.constants.MessageLimit.MAX_TEXT_LENGTH` characters after entities
            parsing.
        parse_mode (:obj:`str`, optional): |parse_mode|
        entities (Sequence[:class:`telegram.MessageEntity`], optional): |caption_entities|

            .. versionchanged:: 20.0
                |sequenceclassargs|

        link_preview_options (:obj:`LinkPreviewOptions`, optional): Link preview generation
            options for the message. Mutually exclusive with
            :paramref:`disable_web_page_preview`.

            .. versionadded:: 20.8

    Keyword Args:
        disable_web_page_preview (:obj:`bool`, optional): Disables link previews for links in the
            sent message. Convenience parameter for setting :paramref:`link_preview_options`.
            Mutually exclusive with :paramref:`link_preview_options`.

            .. versionchanged:: 20.8
                Bot API 7.0 introduced :paramref:`link_preview_options` replacing this
                argument. PTB will automatically convert this argument to that one, but
                for advanced options, please use :paramref:`link_preview_options` directly.

            .. versionchanged:: 21.0
                |keyword_only_arg|

    Attributes:
        message_text (:obj:`str`): Text of the message to be sent,
            :tg-const:`telegram.constants.MessageLimit.MIN_TEXT_LENGTH`-
            :tg-const:`telegram.constants.MessageLimit.MAX_TEXT_LENGTH` characters after entities
            parsing.
        parse_mode (:obj:`str`): Optional. |parse_mode|
        entities (Tuple[:class:`telegram.MessageEntity`]): Optional. |captionentitiesattr|

            .. versionchanged:: 20.0

                * |tupleclassattrs|
                * |alwaystuple|
        link_preview_options (:obj:`LinkPreviewOptions`): Optional. Link preview generation
            options for the message.

            .. versionadded:: 20.8

    )entitieslink_preview_optionsmessage_text
parse_modeN)disable_web_page_preview
api_kwargsr   )r   r   r   r   r   r   c             	      sR   t  j|d |  2 || _|| _t|| _t||| _| jf| _	W 5 Q R X d S )N)r   )
super__init__Z	_unfrozenr   r   r	   r   r   r   Z	_id_attrs)selfr   r   r   r   r   r   	__class__ L/tmp/pip-unpacked-wheel-swnnwir2/telegram/_inline/inputtextmessagecontent.pyr   ]   s    


 z InputTextMessageContent.__init__)__name__
__module____qualname____doc__	__slots__r
   strr   r   r   r   boolr   r   __classcell__r   r   r   r   r       s    :
r   N)r   typingr   r   r   r   Z$telegram._inline.inputmessagecontentr   Ztelegram._messageentityr   Ztelegram._utils.argumentparsingr   r	   Ztelegram._utils.defaultvaluer
   Ztelegram._utils.typesr   r   Ztelegram._linkpreviewoptionsr   r   r   r   r   r   <module>   s   