o
    h                     @  sb   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 er(d dlmZ G dd dZd	S )
    )annotations)TYPE_CHECKINGcast)Empty)Skeleton)gather_metrics)DeltaGeneratorc                   @  sD   e Zd ZeddddZeddddddZedddZdS )
EmptyMixinemptyreturnr   c                 C  s   t  }| jd|S )u  Insert a single-element container.

        Inserts a container into your app that can be used to hold a single element.
        This allows you to, for example, remove elements at any point, or replace
        several elements at once (using a child multi-element container).

        To insert/replace/clear an element on the returned container, you can
        use ``with`` notation or just call methods directly on the returned object.
        See examples below.

        Examples
        --------
        Inside a ``with st.empty():`` block, each displayed element will
        replace the previous one.

        >>> import streamlit as st
        >>> import time
        >>>
        >>> with st.empty():
        ...     for seconds in range(10):
        ...         st.write(f"⏳ {seconds} seconds have passed")
        ...         time.sleep(1)
        ...     st.write(":material/check: 10 seconds over!")
        ... st.button("Rerun")

        .. output::
           https://doc-empty.streamlit.app/
           height: 220px

        You can use an ``st.empty`` to replace multiple elements in
        succession. Use ``st.container`` inside ``st.empty`` to display (and
        later replace) a group of elements.

        >>> import streamlit as st
        >>> import time
        >>>
        >>> st.button("Start over")
        >>>
        >>> placeholder = st.empty()
        >>> placeholder.markdown("Hello")
        >>> time.sleep(1)
        >>>
        >>> placeholder.progress(0, "Wait for it...")
        >>> time.sleep(1)
        >>> placeholder.progress(50, "Wait for it...")
        >>> time.sleep(1)
        >>> placeholder.progress(100, "Wait for it...")
        >>> time.sleep(1)
        >>>
        >>> with placeholder.container():
        ...     st.line_chart({"data": [1, 5, 2, 6]})
        ...     time.sleep(1)
        ...     st.markdown("3...")
        ...     time.sleep(1)
        ...     st.markdown("2...")
        ...     time.sleep(1)
        ...     st.markdown("1...")
        ...     time.sleep(1)
        >>>
        >>> placeholder.markdown("Poof!")
        >>> time.sleep(1)
        >>>
        >>> placeholder.empty()

        .. output::
           https://doc-empty-placeholder.streamlit.app/
           height: 600px

        r
   )
EmptyProtodg_enqueue)selfempty_proto r   L/var/www/vscode/kcb/lib/python3.10/site-packages/streamlit/elements/empty.pyr
      s   GzEmptyMixin.empty	_skeletonN)heightr   
int | Nonec                C  s   t  }|r||_| jd|S )a  Insert a single-element container which displays a "skeleton" placeholder.

        Inserts a container into your app that can be used to hold a single element.
        This allows you to, for example, remove elements at any point, or replace
        several elements at once (using a child multi-element container).

        To insert/replace/clear an element on the returned container, you can
        use ``with`` notation or just call methods directly on the returned object.
        See some of the examples below.

        This is an internal method and should not be used directly.

        Parameters
        ----------
        height: int or None
            Desired height of the skeleton expressed in pixels. If None, a
            default height is used.
        skeleton)SkeletonProtor   r   r   )r   r   skeleton_protor   r   r   r   f   s   zEmptyMixin._skeletonc                 C  s
   t d| S )zGet our DeltaGenerator.r   )r   )r   r   r   r   r      s   
zEmptyMixin.dg)r   r   )r   r   r   r   )__name__
__module____qualname__r   r
   r   propertyr   r   r   r   r   r	      s    Ir	   N)
__future__r   typingr   r   streamlit.proto.Empty_pb2r   r   streamlit.proto.Skeleton_pb2r   r   streamlit.runtime.metrics_utilr   streamlit.delta_generatorr   r	   r   r   r   r   <module>   s   