o
    Yh                     @  s   U d dl mZ d dlZd dlmZmZm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 erCd d	lmZ d d
l	mZ eeef Zded< d d!ddZd"ddZd#ddZG dd dZdS )$    )annotationsN)TYPE_CHECKINGUnioncast)	TypeAlias)LayoutConfigvalidate_width)StreamlitAPIException)Progress)
clean_text)DeltaGenerator)WidthWithoutContentr   
FloatOrInt              ?valuefloatlowhighreturnboolc                 C  s<   ||   ko	|kn  pt j| |dddpt j| |dddS )a+  
    Checks given value is 'between' the bounds of [low, high],
    considering close values around bounds are acceptable input.

    Notes
    -----
    This check is required for handling values that are slightly above or below the
    acceptable range, for example -0.0000000000021, 1.0000000000000013.
    These values are little off the conventional 0.0 <= x <= 1.0 condition
    due to floating point operations, but should still be considered acceptable input.

    Parameters
    ----------
    value : float
    low : float
    high : float

    g&.>)rel_tolabs_tol)mathisclose)r   r   r    r   \/var/www/html/Persson_Maskin/env/lib/python3.10/site-packages/streamlit/elements/progress.py_check_float_between%   s
   r   intc                 C  sv   t | trd|   krdkr| S  td|  t | tr1t| dddr*t| d S td|  tdt| j )	Nr   d   z+Progress Value has invalid value [0, 100]: r   r   )r   r   z-Progress Value has invalid value [0.0, 1.0]: z!Progress Value has invalid type: )
isinstancer   r	   r   r   type__name__)r   r   r   r   
_get_value?   s    

r#   text
str | Nonec                 C  s2   | d u rd S t | trt| S tdt|  d)NzProgress Text is of type zd, which is not an accepted type.Text only accepts: str. Please convert the text to an accepted type.)r    strr   r	   r!   )r$   r   r   r   	_get_textR   s   
r'   c                   @  s*   e Zd Z		ddddZedddZdS )ProgressMixinNstretchr   r   r$   r%   widthr   r   r   c                 C  sJ   t  }t||_t|}|dur||_t| t|d}| jjd||dS )a  Display a progress bar.

        Parameters
        ----------
        value : int or float
            0 <= value <= 100 for int

            0.0 <= value <= 1.0 for float

        text : str or None
            A message to display above the progress bar. The text can optionally
            contain GitHub-flavored Markdown of the following types: Bold, Italics,
            Strikethroughs, Inline Code, Links, and Images. Images display like
            icons, with a max height equal to the font height.

            Unsupported Markdown elements are unwrapped so only their children
            (text contents) render. Display unsupported elements as literal
            characters by backslash-escaping them. E.g.,
            ``"1\. Not an ordered list"``.

            See the ``body`` parameter of |st.markdown|_ for additional,
            supported Markdown directives.

            .. |st.markdown| replace:: ``st.markdown``
            .. _st.markdown: https://docs.streamlit.io/develop/api-reference/text/st.markdown

        width : "stretch" or int
            The width of the progress element. This can be one of the following:

            - ``"stretch"`` (default): The width of the element matches the
              width of the parent container.
            - An integer specifying the width in pixels: The element has a
              fixed width. If the specified width is greater than the width of
              the parent container, the width of the element matches the width
              of the parent container.

        Example
        -------
        Here is an example of a progress bar increasing over time and disappearing when it reaches completion:

        >>> import streamlit as st
        >>> import time
        >>>
        >>> progress_text = "Operation in progress. Please wait."
        >>> my_bar = st.progress(0, text=progress_text)
        >>>
        >>> for percent_complete in range(100):
        ...     time.sleep(0.01)
        ...     my_bar.progress(percent_complete + 1, text=progress_text)
        >>> time.sleep(1)
        >>> my_bar.empty()
        >>>
        >>> st.button("Rerun")

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

        N)r*   progress)layout_config)	ProgressProtor#   r   r'   r$   r   r   dg_enqueue)selfr   r$   r*   progress_protor,   r   r   r   r+   ^   s   B

zProgressMixin.progressc                 C  s
   t d| S )zGet our DeltaGenerator.r   )r   )r0   r   r   r   r.      s   
zProgressMixin.dg)Nr)   )r   r   r$   r%   r*   r   r   r   )r   r   )r"   
__module____qualname__r+   propertyr.   r   r   r   r   r(   ]   s    Mr(   )r   r   )r   r   r   r   r   r   r   r   )r   r   r   r   )r$   r%   r   r%   )
__future__r   r   typingr   r   r   typing_extensionsr   #streamlit.elements.lib.layout_utilsr   r   streamlit.errorsr	   streamlit.proto.Progress_pb2r
   r-   streamlit.string_utilr   streamlit.delta_generatorr   r   r   r   r   __annotations__r   r#   r'   r(   r   r   r   r   <module>   s    

