
    ȯeiR                       U d dl mZ d dlmZ d dlmZ d dlmZmZ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mZmZ d d	lmZmZ d d
lmZmZ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) d dl*m+Z+m,Z, d dl-m.Z.m/Z/m0Z0m1Z1 d dl2m3Z3m4Z4 erd dl5m6Z6 d dl7m8Z8 e4e3z  e9e4e3z     z  dz  Z:de;d<   e<ed   z  Z=de;d<   	 	 	 	 ddZ>e G d d             Z? G d d      Z@y)    )annotations)	dataclass)dedent)TYPE_CHECKINGLiteral	TypeAliascastoverload)config)enforce_filename_restrictionnormalize_upload_file_type)current_form_id)LayoutConfigWidthWithoutContentvalidate_width)check_widget_policiesmaybe_raise_label_warnings)KeyLabelVisibilitycompute_and_register_element_id get_label_visibility_proto_valueto_key)FileUploaderState)UploadedFileInfo)FileUploader)gather_metrics)ScriptRunContextget_script_run_ctx)
WidgetArgsWidgetCallbackWidgetKwargsregister_widget)DeletedFileUploadedFile)Sequence)DeltaGeneratorNr   SomeUploadedFiles	directoryAcceptMultipleFilesc                   | g S t               }|g S | j                  }t        |      dk(  rg S |j                  j	                  |j
                  |D cg c]  }|j                   c}      }|D ci c]  }|j                  | }}g }|D ]k  }|j                  |j                        }|(t        ||j                        }|j                  |       H|j                  t        |j                               m |S c c}w c c}w )Nr   )
session_idfile_ids)r   uploaded_file_infolenuploaded_file_mgr	get_filesr+   file_idgetr$   	file_urlsappendr#   )	widget_valuectxr-   ffile_recs_list	file_recscollected_filesmaybe_file_recuploaded_files	            j/var/www/html/glpi_dashboard/venv/lib/python3.12/site-packages/streamlit/elements/widgets/file_uploader.py_get_upload_filesr>   H   s    	

C
{	%88
!#	**44>>%78!))8 5 N
 (66!A6I68:O ;"qyy1%(EM""=1"";qyy#9:;  9 7s   C<
2Dc                  6    e Zd ZU ded<   dZded<   ddZd	dZy)
FileUploaderSerder)   accept_multiple_filesNzSequence[str] | Noneallowed_typesc                &   t        |      }|D ]@  }t        |t              r| j                  s!t	        |j
                  | j                         B | j                  du xs | j                  dk(  }t        |      dk(  r
|rg }|S d }|S |r|n|d   }|S )NTr(   r   )r>   
isinstancer#   rB   r   namerA   r.   )selfui_valueupload_filesfileis_multiple_or_directoryreturn_values         r=   deserializezFileUploaderSerde.deserializeo   s    (2  	LD$,!!,TYY8J8JK	L &&$. 9))[8 	!
 |!4LbL  SWL  ,D<VWL    c                \   t               }|s|S t        |t              s|g}|D ]  }t        |t              r|j                  j                         }|j                  |_        |j                  |_        |j                  |_        |j                  j                  |j                          |S N)FileUploaderStateProtorD   listr#   r-   addr1   rE   sizer3   CopyFrom
_file_urls)rF   filesstate_protor7   	file_infos        r=   	serializezFileUploaderSerde.serialize   s    ,.%&GE 	7A![)/:/M/M/Q/Q/SI !		IVVINVVIN((6	7 rM   )rG   FileUploaderStateProto | Nonereturnr'   )rV   r'   r[   rP   )__name__
__module____qualname____annotations__rB   rL   rY    rM   r=   r@   r@   j   s    ..*.M'.,rM   r@   c                  6   e Zd Ze	 	 	 	 	 ddddd	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd       Ze	 	 	 	 	 	 ddddd	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd       Zedddddddddd		 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd	       Zeddddddddddd

	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd       Z ed      	 	 	 	 	 	 	 ddddd	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 dd       Z	 	 	 	 	 	 	 dddddd	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 ddZedd       Zy)FileUploaderMixinNFvisiblestretch)disabledlabel_visibilitywidthc	                    y rO   r`   rF   labeltyperA   keyhelp	on_changeargskwargsre   rf   rg   s               r=   file_uploaderzFileUploaderMixin.file_uploader        !rM   c	                    y rO   r`   ri   s               r=   rq   zFileUploaderMixin.file_uploader        "rM   )	rk   rl   rm   rn   ro   rp   re   rf   rg   c       
             y rO   r`   rF   rj   rA   rk   rl   rm   rn   ro   rp   re   rf   rg   s               r=   rq   zFileUploaderMixin.file_uploader   rr   rM   )
rA   rk   rl   rm   rn   ro   rp   re   rf   rg   c       
             y rO   r`   rv   s               r=   rq   zFileUploaderMixin.file_uploader   rt   rM   rq   c	               P    t               }| j                  |||||||||	|
||      S )a%  Display a file uploader widget.
        By default, uploaded files are limited to 200 MB each. You can
        configure this using the ``server.maxUploadSize`` config option. For
        more information on how to set config options, see |config.toml|_.

        .. |config.toml| replace:: ``config.toml``
        .. _config.toml: https://docs.streamlit.io/develop/api-reference/configuration/config.toml

        Parameters
        ----------
        label : str
            A short label explaining to the user what this file uploader is for.
            The label 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.

            For accessibility reasons, you should never set an empty label, but
            you can hide it with ``label_visibility`` if needed. In the future,
            we may disallow empty labels by raising an exception.

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

        type : str, list of str, or None
            The allowed file extension(s) for uploaded files. This can be one
            of the following types:

            - ``None`` (default): All file extensions are allowed.
            - A string: A single file extension is allowed. For example, to
              only accept CSV files, use ``"csv"``.
            - A sequence of strings: Multiple file extensions are allowed. For
              example, to only accept JPG/JPEG and PNG files, use
              ``["jpg", "jpeg", "png"]``.

            .. note::
                This is a best-effort check, but doesn't provide a
                security guarantee against users uploading files of other types
                or type extensions. The correct handling of uploaded files is
                part of the app developer's responsibility.

        accept_multiple_files : bool or "directory"
            Whether to accept more than one file in a submission. This can be one
            of the following values:

            - ``False`` (default): The user can only submit one file at a time.
            - ``True``: The user can upload multiple files at the same time.
            - ``"directory"``: The user can select a directory to upload all
              files in the directory and its subdirectories. If ``type`` is
              set, only files matching those type(s) will be uploaded.

            When this is ``True`` or ``"directory"``, the return value will be
            a list and a user can additively select files if they click the
            browse button on the widget multiple times.

        key : str or int
            An optional string or integer to use as the unique key for the widget.
            If this is omitted, a key will be generated for the widget
            based on its content. No two widgets may have the same key.

        help : str or None
            A tooltip that gets displayed next to the widget label. Streamlit
            only displays the tooltip when ``label_visibility="visible"``. If
            this is ``None`` (default), no tooltip is displayed.

            The tooltip can optionally contain GitHub-flavored Markdown,
            including the Markdown directives described in the ``body``
            parameter of ``st.markdown``.

        on_change : callable
            An optional callback invoked when this file_uploader's value
            changes.

        args : list or tuple
            An optional list or tuple of args to pass to the callback.

        kwargs : dict
            An optional dict of kwargs to pass to the callback.

        disabled : bool
            An optional boolean that disables the file uploader if set to
            ``True``. The default is ``False``.

        label_visibility : "visible", "hidden", or "collapsed"
            The visibility of the label. The default is ``"visible"``. If this
            is ``"hidden"``, Streamlit displays an empty spacer instead of the
            label, which can help keep the widget aligned with other widgets.
            If this is ``"collapsed"``, Streamlit displays no label or spacer.

        width : "stretch" or int
            The width of the file uploader widget. This can be one of the
            following:

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

        Returns
        -------
        None, UploadedFile, or list of UploadedFile
            - If accept_multiple_files is ``False``, returns either ``None`` or
              an ``UploadedFile`` object.
            - If accept_multiple_files is ``True`` or ``"directory"``, returns
              a list with the uploaded files as ``UploadedFile`` objects. If no
              files were uploaded, returns an empty list.

            The ``UploadedFile`` class is a subclass of ``BytesIO``, and
            therefore is "file-like". This means you can pass an instance of it
            anywhere a file is expected.

        Examples
        --------
        **Example 1: Accept a single file at a time**

        >>> import streamlit as st
        >>> import pandas as pd
        >>> from io import StringIO
        >>>
        >>> uploaded_file = st.file_uploader("Choose a file")
        >>> if uploaded_file is not None:
        ...     # To read file as bytes:
        ...     bytes_data = uploaded_file.getvalue()
        ...     st.write(bytes_data)
        >>>
        ...     # To convert to a string based IO:
        ...     stringio = StringIO(uploaded_file.getvalue().decode("utf-8"))
        ...     st.write(stringio)
        >>>
        ...     # To read file as string:
        ...     string_data = stringio.read()
        ...     st.write(string_data)
        >>>
        ...     # Can be used wherever a "file-like" object is accepted:
        ...     dataframe = pd.read_csv(uploaded_file)
        ...     st.write(dataframe)

        **Example 2: Accept multiple files at a time**

        >>> import pandas as pd
        >>> import streamlit as st
        >>>
        >>> uploaded_files = st.file_uploader(
        ...     "Upload data", accept_multiple_files=True, type="csv"
        ... )
        >>> for uploaded_file in uploaded_files:
        ...     df = pd.read_csv(uploaded_file)
        ...     st.write(df)

        .. output::
           https://doc-file-uploader.streamlit.app/
           height: 375px

        **Example 3: Accept an entire directory**

        >>> import streamlit as st
        >>>
        >>> uploaded_files = st.file_uploader(
        ...     "Upload images", accept_multiple_files="directory", type=["jpg", "png"]
        ... )
        >>> for uploaded_file in uploaded_files:
        ...     st.image(uploaded_file)

        .. output::
           https://doc-file-uploader-directory.streamlit.app/
           height: 375px

        )rj   rk   rA   rl   rm   rn   ro   rp   re   rf   rg   r6   )r   _file_uploader)rF   rj   rk   rA   rl   rm   rn   ro   rp   re   rf   rg   r6   s                r=   rq   zFileUploaderMixin.file_uploader   sI    D !""""7- # 
 	
rM   )rf   re   r6   rg   c	                  t        |      }t        | j                  ||d d       t        ||	       t	        d|ddh| j                  |||||	      }|rt        |      nd }t               }||_        ||_        ||ng |j                  d d  t        j                  d      |_        |dk(  }|d	u xs ||_        ||_        t        | j                        |_        |
|_        t%        |	      |j&                  _        |t+        |      |_        t/        ||
      }t1        |j                  ||||j2                  |j4                  |d      }t7        |       t9        |      }| j                  j;                  d||       t=        |j(                  t>              ry t=        |j(                  t@              r+|j(                  D cg c]  }t=        |t>              r| c}S |j(                  S c c}w )NF)default_valuewrites_allowedrq   rk   rA   )user_keykey_as_main_identitydgrj   rk   rA   rm   rg   zserver.maxUploadSizer(   T)rB   file_uploader_state_value)on_change_handlerro   rp   deserializer
serializerr6   
value_type)rg   )layout_config)!r   r   r   r   r   r   FileUploaderProtoidrj   rk   r   
get_optionmax_upload_size_mbmultiple_filesaccept_directoryr   form_idre   r   rf   valuer   rm   r@   r"   rL   rY   r   r   _enqueuerD   r#   rQ   )rF   rj   rk   rA   rl   rm   rn   ro   rp   rf   re   r6   rg   
element_idnormalized_typefile_uploader_protois_directory_uploadserdewidget_stater   r7   s                        r=   ry   z FileUploaderMixin._file_uploader  s     SkGG 	
 	#5*:;4 #)*A!Bww"7

 ?C4T:/1!+$)!.:O 	  # 281B1B"2
. 4{B!T)@-@ 	* 0C,&5dgg&>#'/$5U6
,,2 '-d|$!"7W
 '""'**2	
 	u$510 	 	
 l((+6l(($/+11T!A{9SATT!!! Us   G+G+c                    t        d|       S )zGet our DeltaGenerator.r&   )r	   )rF   s    r=   r   zFileUploaderMixin.dg*  s     $d++rM   )NNNNN)rj   strrk   str | Sequence[str] | NonerA   Literal[True, 'directory']rl   
Key | Nonerm   
str | Nonern   WidgetCallback | Nonero   WidgetArgs | Nonerp   WidgetKwargs | Nonere   boolrf   r   rg   r   r[   list[UploadedFile])FNNNNN)rj   r   rk   r   rA   Literal[False]rl   r   rm   r   rn   r   ro   r   rp   r   re   r   rf   r   rg   r   r[   UploadedFile | None)rj   r   rA   r   rk   r   rl   r   rm   r   rn   r   ro   r   rp   r   re   r   rf   r   rg   r   r[   r   )rj   r   rA   r   rk   r   rl   r   rm   r   rn   r   ro   r   rp   r   re   r   rf   r   rg   r   r[   r   )NFNNNNN)rj   r   rk   r   rA   r)   rl   r   rm   r   rn   r   ro   r   rp   r   re   r   rf   r   rg   r   r[   (UploadedFile | list[UploadedFile] | None)rj   r   rk   r   rA   r)   rl   r   rm   r   rn   r   ro   r   rp   r   rf   r   re   r   r6   zScriptRunContext | Nonerg   r   r[   r   )r[   r&   )	r\   r]   r^   r
   rq   r   ry   propertyr   r`   rM   r=   rb   rb      sE     +/"&&*! ,5%.!! )!  :	!
 ! ! )!  ! $! ! *! #! 
! !$ 
 16+/"&&*" ,5%."" )"  .	"
 " " )"  " $" " *" #" 
" ".  ,0+/"&&*,5%.!!  :	!
 )! ! ! )!  ! $! ! *! #! 
! !$ 
 16+/+/"&&*,5%.""  .	"
 )" " " )"  " $" " *" #" 
" "  O$ ,05:+/"&&*O
 ,5%.O
O
 )O
  3	O

 O
 O
 )O
  O
 $O
 O
 *O
 #O
 
2O
 %O
h ,05:+/"&&*`" -6'+%.`"`" )`"  3	`"
 `" `" )`"  `" $`" *`" `" %`" #`" 
2`"D , ,rM   rb   )r5   rZ   r[   z list[UploadedFile | DeletedFile])A
__future__r   dataclassesr   textwrapr   typingr   r   r   r	   r
   	streamlitr   *streamlit.elements.lib.file_uploader_utilsr   r   !streamlit.elements.lib.form_utilsr   #streamlit.elements.lib.layout_utilsr   r   r   streamlit.elements.lib.policiesr   r   streamlit.elements.lib.utilsr   r   r   r   r   streamlit.proto.Common_pb2r   rP   r   UploadedFileInfoProto streamlit.proto.FileUploader_pb2r   r   streamlit.runtime.metrics_utilr   streamlit.runtime.scriptrunnerr   r   streamlit.runtime.stater   r    r!   r"   'streamlit.runtime.uploaded_file_managerr#   r$   collections.abcr%   streamlit.delta_generatorr&   rQ   r'   r_   r   r)   r>   r@   rb   r`   rM   r=   <module>r      s    # !  D D  > 
  S P N 9 O  N(8 ;l[&@!AADH 9  "&(<!< Y </%D + + +\T, T,rM   