U
    g                     @   sl   d Z ddlmZmZmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZ erXddlmZ G dd	 d	eZd
S )zRThis module contains the class that represent a Telegram InlineQueryResultsButton.    )TYPE_CHECKINGFinalOptional)	constants)TelegramObject)JSONDict)
WebAppInfo)Botc                       s   e Zd ZU dZdZdddeee ee ee d fddZ	e
dee ed ed  d	 fd
dZejjZee ed< ejjZee ed<   ZS )InlineQueryResultsButtona
  This object represents a button to be shown above inline query results. You **must** use
    exactly one of the optional fields.

    Objects of this class are comparable in terms of equality. Two objects of this class are
    considered equal, if their :attr:`text`, :attr:`web_app` and :attr:`start_parameter` are equal.

    Args:
        text (:obj:`str`): Label text on the button.
        web_app (:class:`telegram.WebAppInfo`, optional): Description of the
            `Web App <https://core.telegram.org/bots/webapps>`_ that will be launched when the
            user presses the button. The Web App will be able to switch back to the inline mode
            using the method
            `switchInlineQuery <https://core.telegram.org/bots/webapps#initializing-mini-apps>`_
            inside the Web App.
        start_parameter (:obj:`str`, optional):  Deep-linking parameter for the
            :guilabel:`/start` message sent to the bot when user presses the switch button.
            :tg-const:`telegram.InlineQuery.MIN_SWITCH_PM_TEXT_LENGTH`-
            :tg-const:`telegram.InlineQuery.MAX_SWITCH_PM_TEXT_LENGTH` characters,
            only ``A-Z``, ``a-z``, ``0-9``, ``_`` and ``-`` are allowed.

            Example:
                An inline bot that sends YouTube videos can ask the user to connect the bot to
                their YouTube account to adapt search results accordingly. To do this, it displays
                a 'Connect your YouTube account' button above the results, or even before showing
                any. The user presses the button, switches to a private chat with the bot and, in
                doing so, passes a start parameter that instructs the bot to return an OAuth link.
                Once done, the bot can offer a switch_inline button so that the user can easily
                return to the chat where they wanted to use the bot's inline capabilities.

    Attributes:
        text (:obj:`str`): Label text on the button.
        web_app (:class:`telegram.WebAppInfo`): Optional. Description of the
            `Web App <https://core.telegram.org/bots/webapps>`_ that will be launched when the
            user presses the button. The Web App will be able to switch back to the inline mode
            using the method ``web_app_switch_inline_query`` inside the Web App.
        start_parameter (:obj:`str`): Optional. Deep-linking parameter for the
            :guilabel:`/start` message sent to the bot when user presses the switch button.
            :tg-const:`telegram.InlineQuery.MIN_SWITCH_PM_TEXT_LENGTH`-
            :tg-const:`telegram.InlineQuery.MAX_SWITCH_PM_TEXT_LENGTH` characters,
            only ``A-Z``, ``a-z``, ``0-9``, ``_`` and ``-`` are allowed.

    )start_parametertextweb_appN
api_kwargs)r   r   r   r   c                   s>   t  j|d || _|| _|| _| j| j| jf| _|   d S )Nr   )super__init__r   r   r   Z	_id_attrsZ_freeze)selfr   r   r   r   	__class__ M/tmp/pip-unpacked-wheel-swnnwir2/telegram/_inline/inlinequeryresultsbutton.pyr   N   s    z!InlineQueryResultsButton.__init__r	   )databotreturnc                    s.   |sdS t |d||d< t j||dS )z,See :meth:`telegram.TelegramObject.de_json`.Nr   )r   r   )r   de_jsongetr   )clsr   r   r   r   r   r   c   s    z InlineQueryResultsButton.de_jsonMIN_START_PARAMETER_LENGTHMAX_START_PARAMETER_LENGTH)NN)N)__name__
__module____qualname____doc__	__slots__strr   r   r   r   classmethodr   r   ZInlineQueryResultsButtonLimitr   r   int__annotations__r   __classcell__r   r   r   r   r
       s0   
+    r
   N)r"   typingr   r   r   Ztelegramr   Ztelegram._telegramobjectr   Ztelegram._utils.typesr   Ztelegram._webappinfor   r	   r
   r   r   r   r   <module>   s   