
    di=                         d Z ddlmZ ddlmZmZ ddlmZ ddlm	Z	 ddl
mZ ddlmZ ddlmZ dd	lmZ dd
lmZmZmZ ddlmZ erddlmZ  G d de	          Z G d de          Z G d de          ZdS )z5This module contains objects that represent stickers.    )Sequence)TYPE_CHECKINGFinal)	constants)_BaseThumbedMedium)File)	PhotoSize)TelegramObject)enum)de_json_optionalde_list_optionalparse_sequence_arg)JSONDict)Botc            #       f    e Zd ZU dZdZ	 	 	 	 	 	 	 	 d dddedededed	ed
edededz  dedz  dedz  dddddedz  dedz  dedz  de	dz  f  fdZ
ej        j        Zee         ed<   	 ej        j        Zee         ed<   	 ej        j        Zee         ed<   	 ed!de	dddd f fd            Z xZS )"Stickeraj  This object represents a sticker.

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

    Note:
        As of v13.11 :paramref:`is_video` is a required argument and therefore the order of the
        arguments had to be changed. Use keyword arguments to make sure that the arguments are
        passed correctly.

    .. versionchanged:: 20.5
      |removed_thumb_note|

    Args:
        file_id (:obj:`str`): Identifier for this file, which can be used to download
            or reuse the file.
        file_unique_id (:obj:`str`): Unique identifier for this file, which
            is supposed to be the same over time and for different bots.
            Can't be used to download or reuse the file.
        width (:obj:`int`): Sticker width.
        height (:obj:`int`): Sticker height.
        is_animated (:obj:`bool`): :obj:`True`, if the sticker is animated.
        is_video (:obj:`bool`): :obj:`True`, if the sticker is a video sticker.

            .. versionadded:: 13.11
        type (:obj:`str`): Type of the sticker. Currently one of :attr:`REGULAR`,
            :attr:`MASK`, :attr:`CUSTOM_EMOJI`. The type of the sticker is independent from its
            format, which is determined by the fields :attr:`is_animated` and :attr:`is_video`.

            .. versionadded:: 20.0
        emoji (:obj:`str`, optional): Emoji associated with the sticker
        set_name (:obj:`str`, optional): Name of the sticker set to which the sticker belongs.
        mask_position (:class:`telegram.MaskPosition`, optional): For mask stickers, the position
            where the mask should be placed.
        file_size (:obj:`int`, optional): File size in bytes.

        premium_animation (:class:`telegram.File`, optional): For premium regular stickers,
            premium animation for the sticker.

            .. versionadded:: 20.0
        custom_emoji_id (:obj:`str`, optional): For custom emoji stickers, unique identifier of the
            custom emoji.

            .. versionadded:: 20.0
        thumbnail (:class:`telegram.PhotoSize`, optional): Sticker thumbnail in the ``.WEBP`` or
            ``.JPG`` format.

            .. versionadded:: 20.2
        needs_repainting (:obj:`bool`, optional): :obj:`True`, if the sticker must be repainted to
            a text color in messages, the color of the Telegram Premium badge in emoji status,
            white color on chat photos, or another appropriate color in other places.

            .. versionadded:: 20.2

    Attributes:
        file_id (:obj:`str`): Identifier for this file, which can be used to download
            or reuse the file.
        file_unique_id (:obj:`str`): Unique identifier for this file, which
            is supposed to be the same over time and for different bots.
            Can't be used to download or reuse the file.
        width (:obj:`int`): Sticker width.
        height (:obj:`int`): Sticker height.
        is_animated (:obj:`bool`): :obj:`True`, if the sticker is animated.
        is_video (:obj:`bool`): :obj:`True`, if the sticker is a video sticker.

            .. versionadded:: 13.11
        type (:obj:`str`): Type of the sticker. Currently one of :attr:`REGULAR`,
            :attr:`MASK`, :attr:`CUSTOM_EMOJI`. The type of the sticker is independent from its
            format, which is determined by the fields :attr:`is_animated` and :attr:`is_video`.

            .. versionadded:: 20.0
        emoji (:obj:`str`): Optional. Emoji associated with the sticker.
        set_name (:obj:`str`): Optional. Name of the sticker set to which the sticker belongs.
        mask_position (:class:`telegram.MaskPosition`): Optional. For mask stickers, the position
            where the mask should be placed.
        file_size (:obj:`int`): Optional. File size in bytes.

        premium_animation (:class:`telegram.File`): Optional. For premium regular stickers,
            premium animation for the sticker.

            .. versionadded:: 20.0
        custom_emoji_id (:obj:`str`): Optional. For custom emoji stickers, unique identifier of the
            custom emoji.

            .. versionadded:: 20.0
        thumbnail (:class:`telegram.PhotoSize`): Optional. Sticker thumbnail in the ``.WEBP`` or
            ``.JPG`` format.

            .. versionadded:: 20.2
        needs_repainting (:obj:`bool`): Optional. :obj:`True`, if the sticker must be repainted to
            a text color in messages, the color of the Telegram Premium badge in emoji status,
            white color on chat photos, or another appropriate color in other places.

            .. versionadded:: 20.2
    )custom_emoji_idemojiheightis_animatedis_videomask_positionneeds_repaintingpremium_animationset_nametypewidthN
api_kwargsfile_idfile_unique_idr   r   r   r   r   r   	file_sizer   r   zMaskPosition | Noner   zFile | Noner   	thumbnailr   r   c                   t                                          |||	||           |                                 5  || _        || _        || _        || _        t          j        t          j
        ||          | _        || _        |
| _        || _        || _        || _        || _        d d d            d S # 1 swxY w Y   d S )N)r    r!   r"   r#   r   )super__init__	_unfrozenr   r   r   r   r   
get_memberr   StickerTyper   r   r   r   r   r   r   )selfr    r!   r   r   r   r   r   r   r"   r   r   r   r   r#   r   r   	__class__s                    T/root/projects/qq-shell/venv/lib/python3.11/site-packages/telegram/_files/sticker.pyr&   zSticker.__init__   s"   ( 	)! 	 	
 	
 	
 ^^ 	B 	B#DJ%DK%0D"*DM!_Y-BD$OODI%*DJ(0DM6CD2CD"/>D 1AD!	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	B 	Bs   A,B55B9<B9REGULARMASKCUSTOM_EMOJIdatabot
Bot | Nonereturnc                    |                      |          }t          |                    d          t          |          |d<   t          |                    d          t          |          |d<   t          |                    d          t
          |          |d<   i }|                    d          |                    d          |d<   t                                          |||          S ),See :meth:`telegram.TelegramObject.de_json`.r#   r   r   thumbNr0   r1   r   )	_parse_datar   getr	   MaskPositionr   popr%   _de_json)clsr0   r1   r   r+   s       r,   de_jsonzSticker.de_json   s     t$$,TXXk-B-BIsSS[ 0/1J1JLZ] ^ ^_$4TXX>Q5R5RTXZ]$^$^ !
 88G("&((7"3"3JwwwTszJJJ    )NNNNNNNNN)__name__
__module____qualname____doc__	__slots__strintboolr	   r   r&   r   r)   r-   r   __annotations__r.   r/   classmethodr>   __classcell__r+   s   @r,   r   r   %   s        ^ ^@I. ! $#/3+/&*&*(,!(B$ '+%(B (B (B(B (B 	(B
 (B (B (B (B Tz(B :(B *(B -(B )(B t(B t#(B  +!(B$ tO%(B (B (B (B (B (BT $/7GU3Z7779 ,1D%*1116(4AL%*AAA>K K8 K, K) K K K K K [K K K K Kr?   r   c                        e Zd ZdZdZ	 ddddededee         ded	edz  d
e	dz  f fdZ
edde	dddd f fd            Z xZS )
StickerSeta  This object represents a sticker set.

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

    Note:
        As of v13.11 :paramref:`is_video` is a required argument and therefore the order of the
        arguments had to be changed. Use keyword arguments to make sure that the arguments are
        passed correctly.

    .. versionchanged:: 20.0
        The parameter ``contains_masks`` has been removed. Use :paramref:`sticker_type` instead.


    .. versionchanged:: 21.1
        The parameters ``is_video`` and ``is_animated`` are deprecated and now made optional. Thus,
        the order of the arguments had to be changed.

    .. versionchanged:: 20.5
       |removed_thumb_note|

    .. versionremoved:: 21.2
       Removed the deprecated arguments and attributes ``is_animated`` and ``is_video``.

    Args:
        name (:obj:`str`): Sticker set name.
        title (:obj:`str`): Sticker set title.
        stickers (Sequence[:class:`telegram.Sticker`]): List of all set stickers.

            .. versionchanged:: 20.0
                |sequenceclassargs|

        sticker_type (:obj:`str`): Type of stickers in the set, currently one of
            :attr:`telegram.Sticker.REGULAR`, :attr:`telegram.Sticker.MASK`,
            :attr:`telegram.Sticker.CUSTOM_EMOJI`.

            .. versionadded:: 20.0
        thumbnail (:class:`telegram.PhotoSize`, optional): Sticker set thumbnail in the ``.WEBP``,
            ``.TGS``, or ``.WEBM`` format.

            .. versionadded:: 20.2

    Attributes:
        name (:obj:`str`): Sticker set name.
        title (:obj:`str`): Sticker set title.
        stickers (tuple[:class:`telegram.Sticker`]): List of all set stickers.

            .. versionchanged:: 20.0
                |tupleclassattrs|

        sticker_type (:obj:`str`): Type of stickers in the set, currently one of
            :attr:`telegram.Sticker.REGULAR`, :attr:`telegram.Sticker.MASK`,
            :attr:`telegram.Sticker.CUSTOM_EMOJI`.

            .. versionadded:: 20.0
        thumbnail (:class:`telegram.PhotoSize`): Optional. Sticker set thumbnail in the ``.WEBP``,
            ``.TGS``, or ``.WEBM`` format.

            .. versionadded:: 20.2
    )namesticker_typestickersr#   titleNr   rO   rR   rQ   rP   r#   r   c                    t                                          |           || _        || _        t	          |          | _        || _        || _        | j        f| _        | 	                                 d S Nr   )
r%   r&   rO   rR   r   rQ   rP   r#   	_id_attrs_freeze)r*   rO   rR   rQ   rP   r#   r   r+   s          r,   r&   zStickerSet.__init__  sh     	J///	
-?-I-I!-+4)r?   r0   r1   r2   r3   c                 l   |                      |          }t          |                    d          t          |          |d<   t	          |                    d          t
          |          |d<   i }dD ]}||v r|                    |          ||<   t                                          |||          S )r5   r#   rQ   )contains_masksr6   r   r   r7   )	r8   r   r9   r	   r   r   r;   r%   r<   )r=   r0   r1   r   deprecated_fieldr+   s        r,   r>   zStickerSet.de_json2  s     t$$,TXXk-B-BIsSS[+DHHZ,@,@'3OOZ
 !W 	J 	J4''/3xx8H/I/I
+,wwTszJJJr?   r@   )rA   rB   rC   rD   rE   rF   r   r   r	   r   r&   rJ   r>   rK   rL   s   @r,   rN   rN      s       ; ;zI '+ '+    7#	
  t# tO     * K K8 K, K, K K K K K [K K K K Kr?   rN   c                   
    e Zd ZU dZdZej        j        Zee	         e
d<   	 ej        j        Zee	         e
d<   	 ej        j        Zee	         e
d<   	 ej        j        Zee	         e
d<   	 ddd	e	d
ededededz  f
 fdZ xZS )r:   a  This object describes the position on faces where a mask should be placed by default.

    Objects of this class are comparable in terms of equality. Two objects of this class are
    considered equal, if their :attr:`point`, :attr:`x_shift`, :attr:`y_shift` and, :attr:`scale`
    are equal.

    Args:
        point (:obj:`str`): The part of the face relative to which the mask should be placed.
            One of :attr:`FOREHEAD`, :attr:`EYES`, :attr:`MOUTH`, or :attr:`CHIN`.
        x_shift (:obj:`float`): Shift by X-axis measured in widths of the mask scaled to the face
            size, from left to right. For example, choosing ``-1.0`` will place mask just to the
            left of the default mask position.
        y_shift (:obj:`float`): Shift by Y-axis measured in heights of the mask scaled to the face
            size, from top to bottom. For example, ``1.0`` will place the mask just below the
            default mask position.
        scale (:obj:`float`): Mask scaling coefficient. For example, ``2.0`` means double size.

    Attributes:
        point (:obj:`str`): The part of the face relative to which the mask should be placed.
            One of :attr:`FOREHEAD`, :attr:`EYES`, :attr:`MOUTH`, or :attr:`CHIN`.
        x_shift (:obj:`float`): Shift by X-axis measured in widths of the mask scaled to the face
            size, from left to right. For example, choosing ``-1.0`` will place mask just to the
            left of the default mask position.
        y_shift (:obj:`float`): Shift by Y-axis measured in heights of the mask scaled to the face
            size, from top to bottom. For example, ``1.0`` will place the mask just below the
            default mask position.
        scale (:obj:`float`): Mask scaling coefficient. For example, ``2.0`` means double size.

    )pointscalex_shifty_shiftFOREHEADEYESMOUTHCHINNr   r[   r]   r^   r\   r   c                    t                                          |           || _        || _        || _        || _        | j        | j        | j        | j        f| _        |                                  d S rT   )r%   r&   r[   r]   r^   r\   rU   rV   )r*   r[   r]   r^   r\   r   r+   s         r,   r&   zMaskPosition.__init__n  se     	J///
%%!
*dlDL$*Mr?   )rA   rB   rC   rD   rE   r   r:   r_   r   rF   rI   r`   ra   rb   floatr   r&   rK   rL   s   @r,   r:   r:   D  s         < 9I$1:HeCj:::; -2D%*2227!.4E5:4448 -2D%*2227 '+    	
  tO         r?   r:   N)rD   collections.abcr   typingr   r   telegramr   "telegram._files._basethumbedmediumr   telegram._files.filer   telegram._files.photosizer	   telegram._telegramobjectr
   telegram._utilsr   telegram._utils.argumentparsingr   r   r   telegram._utils.typesr   r   r   rN   r:    r?   r,   <module>rp      s  & < ; $ $ $ $ $ $ ' ' ' ' ' ' ' '       A A A A A A % % % % % % / / / / / / 3 3 3 3 3 3             b b b b b b b b b b * * * * * * oK oK oK oK oK  oK oK oKdjK jK jK jK jK jK jK jKZ; ; ; ; ;> ; ; ; ; ;r?   