o
    NhY.                  
   @   s(  d Z ddlZddlZddlZddlZddlZddl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	 Zd
d ZeddddddZdd ZejdejdejdejdejdiZd2ddZd3ddZdd Zd d! Zd"d# Zd$d% Z d&d' Z!d(d) Z"d*d+ Z#d4d,d-Z$d.d/ Z%d0d1 Z&dS )5zk
Utility Routines for Working with Matplotlib Objects
====================================================
    N)colorConverter)Path)MarkerStyle)Affine2D)tickerc                 C   s   | du st | d dkrdS t | d dkr't | }djdd |D  S t | }d	d
dd |dd D  d
 t|d  d S )z8Convert matplotlib color code to hex color or RGBA colorN   r   none   z#{0:02X}{1:02X}{2:02X}c                 s   s    | ]	}t d | V  qdS    N)int).0c r   f/var/www/html/Persson_Maskin/env/lib/python3.10/site-packages/plotly/matplotlylib/mplexporter/utils.py	<genexpr>   s    zexport_color.<locals>.<genexpr>zrgba(z, c                 s   s&    | ]}t tt|d  V  qdS r
   )strr   npround)r   valr   r   r   r   !      $ ))r   to_rgbato_rgbformatjoinr   )colorrgbr   r   r   r   export_color   s    


r   c                 C   s   t dd |  D S )z5Convert a many-to-one mapping to a one-to-one mappingc                 s   s&    | ]\}}|D ]}||fV  qqd S Nr   )r   keysr   keyr   r   r   r   *   r   z_many_to_one.<locals>.<genexpr>)dictitems)
input_dictr   r   r   _many_to_one(   s   r%   r   z6,6z2,2z4,4,2,4))solid-)NN)dashedz--)dotted:)dashdotz-.)  Noner   c                 C   s\   | j dddurdtt| jS |  }t|d}|dkr,t	d
| td }|S )ap  Get an SVG dash array for the given matplotlib linestyle

    Parameters
    ----------
    obj : matplotlib object
        The matplotlib line or path object, which must have a get_linestyle()
        method which returns a valid matplotlib line code

    Returns
    -------
    dasharray : string
        The HTML/SVG dasharray code associated with the object.
    _dashSeqN,z	not foundz:line style '{0}' not understood: defaulting to solid line.r&   )__dict__getr   mapr   r/   get_linestyle
LINESTYLESwarningswarnr   )objls	dasharrayr   r   r   get_dasharray8   s   r;   LMSCZFc                 C   sn   |dur	|  |} dd | j|dD }|stdg fS t| \}}tttj| 	dd}|t|fS )a  Construct the vertices and SVG codes for the path

    Parameters
    ----------
    path : matplotlib.Path object

    transform : matplotlib transform (optional)
        if specified, the path will be transformed before computing the output.

    Returns
    -------
    vertices : array
        The shape (M, 2) array of vertices of the Path. Note that some Path
        codes require multiple vertices, so the length of these vertices may
        be longer than the list of path codes.
    path_codes : list
        A length N list of single-character path codes, N <= M. Each code is
        a single character, in ['L','M','S','C','Z']. See the standard SVG
        path specification for a description of these.
    Nc                 S   s*   g | ]\}}|t jkr|ng t| fqS r   )r   	CLOSEPOLY	PATH_DICT)r   vertices	path_coder   r   r   
<listcomp>t   s    zSVG_path.<locals>.<listcomp>)simplify)r      rG   )
transformediter_segmentsr   zerosziparraylist	itertoolschainreshape)path	transformrF   	vc_tuplesrC   codesr   r   r   SVG_path\   s   

rV   Tc                 C   sz   i }|   |d< |d du rd|d< t|  |d< |r%t|  |d< nd|d< |  |d< t| |d< |  |d	< |S )
z4Get the style dictionary for matplotlib path objectsalphaNr	   	edgecolor	facecolorr   	edgewidthr:   zorder)	get_alphar   get_edgecolorget_facecolorget_linewidthr;   
get_zorder)rR   fillstyler   r   r   get_path_style   s   rc   c                 C   sh   i }|   |d< |d du rd|d< t|  |d< |  |d< t| |d< |  |d< |  |d< |S )	z4Get the style dictionary for matplotlib line objectsrW   Nr	   r   	linewidthr:   r[   	drawstyle)r\   r   	get_colorr_   r;   r`   get_drawstyle)linerb   r   r   r   get_line_style   s   ri   c                 C   s   i }|   |d< |d du rd|d< t|  |d< t|  |d< |  |d< |  |d< t|  }|  }| t	 
||  }t| ||d< ||d	< |  |d
< |S )z6Get the style dictionary for matplotlib marker objectsrW   Nr	   rY   rX   rZ   marker
markerpath
markersizer[   )r\   r   get_markerfacecolorget_markeredgecolorget_markeredgewidth
get_markerr   get_markersizeget_transformr   scalerV   get_pathr`   )rh   rb   markerstylerl   markertransformr   r   r   get_marker_style   s"   rw   c                 C   s~   i }|   |d< |d du rd|d< |  |d< t|  |d< |  |d< |  |d< | j|d< |  |d	< |  |d
< |S )z.Return the text style dict for a text instancerW   Nr	   fontsizer   halignvalignmalignrotationr[   )	r\   get_sizer   rf   get_horizontalalignmentget_verticalalignment_multialignmentget_rotationr`   )textrb   r   r   r   get_text_style   s   
r   c                 C   s|  i }| j dd}t| tjjr|rd|d< nd|d< nt| tjjr/|r*d|d< nd|d< ntd| | 	 }t
| |d	< t|tjrOt| |d
< nd|d
< |  }t|tjrbd|d< n5t|tjrpt|j|d< n't|tjrt|jjd  |d< ntdd |  D sd|d< nd|d< |  |d< |  }|r|d  |d< nd|d< t| |d< |  |d< |S )z=Return the property dictionary for a matplotlib.Axis instancelabel1OnTbottompositiontopleftrightz{0} should be an Axis instancenticks
tickvaluesNr,   
tickformatr   c                 s   s    | ]}|  V  qd S r   )get_visible)r   labelr   r   r   r      s    z&get_axis_properties.<locals>.<genexpr>rs   rx   gridvisible)_major_tick_kwr2   
isinstance
matplotlibaxisXAxisYAxis
ValueErrorr   get_major_locatorlenr   FixedLocatorrN   get_major_formatterNullFormatterFixedFormatterseqFuncFormatterfuncargsvaluesanyget_ticklabels	get_scaleget_fontsizeget_grid_styler   )r   propsr   locator	formatterlabelsr   r   r   get_axis_properties   sD   





r   c                 C   s^   |   }| jd r+t|dkr+t|d  }|d  }t|d }td|||dS ddiS )NgridOnr   T)r   r   r:   rW   F)get_gridlinesr   r   r   rf   r\   r;   r"   )r   	gridlinesr   rW   r:   r   r   r   r     s   r   c                 C   s   |   |  | jdS )N)figwidth	figheightdpi)get_figwidthget_figheightr   )figr   r   r   get_figure_properties  s   r   c              
      sX  t | j | j |  j|  | j|  | j	 t
| jt
| jgd}dD ]}t| |d  t| d| }|}t jtjjrd}zdd lddlm} W n ty]   d Y nw d urzt j|rz fdd	|D }d
d	 |D }ndd	 tj|D }n  }|dvrtd  |||d < |||d < |||d < q(|S )N)axesbgaxesbgalphaboundsdynamicaxisonframe_onpatch_visibleaxes)xyr   z
get_{0}limdater   )PeriodConverterc                    s    g | ]}j t| jd qS ))ordinalfreq)Periodr   r   r   dr   pdr   r   rE   .  s     z'get_axes_properties.<locals>.<listcomp>c              	   S   s.   g | ]}|j |jd  |j|j|j|jdfqS )r	   r   )yearmonthdayhourminutesecondr   r   r   r   rE   /  s     c              
   S   s4   g | ]}|j |jd  |j|j|j|j|jd fqS )r	   gMbP?)r   r   r   r   r   r   microsecondr   r   r   r   rE   4  s    
)r   linearlogzUnknown axis scale: {0}rs   limdomain)r   patchr^   r\   get_positionr   get_navigater   get_frame_onr   r   xaxisyaxisgetattrr   r   	converterr   datesDateConverterpandaspandas.tseries.converterr   ImportErrornum2dater   r   )axr   axnamer   r   rs   r   _datesr   r   r   get_axes_properties  sH   

r   c                 c   sX    t | dr't|  dkr'|  D ]}|s|V  t||D ]}|V  qqdS | V  dS )z
    Returns an iterator over all childen and nested children using
    obj's get_children() method

    if skipContainers is true, only childless objects are returned.
    get_childrenr   N)hasattrr   r   iter_all_children)r8   skipContainerschild
grandchildr   r   r   r   M  s   
r   c                 C   s    |   \}}| }|||dS )N)handlesr   r   )get_legend_handles_labelsr   )r   legendr   r   r   r   r   r   get_legend_properties_  s   r   c                 C   sV   | j }t }| }||   | | || |d t|	 
dS )a$  
    Convert a matplotlib image to a base64 png representation

    Parameters
    ----------
    image : matplotlib image object
        The image to be converted.

    Returns
    -------
    image_base64 : string
        The UTF8-encoded base64 string representation of the png image.
    r   zutf-8)r   ioBytesIOr   
get_extent	write_pngseekbase64	b64encodereaddecode)imager   binary_bufferr   r   r   r   image_to_base64e  s   


r   )NF)T)F)'__doc__rO   r   r   numpyr   r6   r   matplotlib.colorsr   matplotlib.pathr   matplotlib.markersr   matplotlib.transformsr   r   r   r%   r5   r;   LINETOMOVETOCURVE3CURVE4rA   rB   rV   rc   ri   rw   r   r   r   r   r   r   r   r   r   r   r   r   <module>   sR    
	
&:
8