
    6DhY                     .    S SK Jr  S SKr " S S\5      rg)    )BaseLayoutHierarchyTypeNc                     ^  \ rS rSrSrSr1 Skr\S 5       r\R                  S 5       r\S 5       r
\
R                  S 5       r
\S	 5       r\R                  S
 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S 5       r\S 5       r\R                  S  5       r\S! 5       r\R                  S" 5       r\S# 5       r\R                  S$ 5       r\S% 5       r\R                  S& 5       r\S' 5       r\R                  S( 5       r\S) 5       r\R                  S* 5       r\S+ 5       r\R                  S, 5       r\S- 5       r\R                  S. 5       r\S/ 5       r\R                  S0 5       r\S1 5       r\R                  S2 5       r\S3 5       r \ R                  S4 5       r \S5 5       r!\!R                  S6 5       r!\S7 5       r"\"R                  S8 5       r"\S9 5       r#\#R                  S: 5       r#\S; 5       r$\$R                  S< 5       r$\S= 5       r%\%R                  S> 5       r%\S? 5       r&\&R                  S@ 5       r&\SA 5       r'\'R                  SB 5       r'\SC 5       r(\(R                  SD 5       r(\SE 5       r)                                 SHU 4SF jjr*SGr+U =r,$ )IShape   layoutzlayout.shape>    x0x1y0y1linenamepathtypexrefyreflabellayerlegendopacityvisiblex0shiftx1shiftxanchory0shifty1shiftyanchoreditablefillrule	fillcolor	xsizemode	ysizemode
legendrank
showlegendlegendgrouplegendwidthlegendgrouptitletemplateitemnamec                     U S   $ )a  
Determines whether the shape could be activated for edit or
not. Has no effect when the older editable shapes mode is
enabled via `config.editable` or `config.edits.shapePosition`.

The 'editable' property must be specified as a bool
(either True, or False)

Returns
-------
bool
r    selfs    Q/var/www/html/env/lib/python3.13/site-packages/plotly/graph_objs/layout/_shape.pyr   Shape.editable/   s     J    c                     XS'   g )Nr   r)   r+   vals     r,   r   r-   ?   
    Zr.   c                     U S   $ )a  
Sets the color filling the shape's interior. Only applies to
closed shapes.

The 'fillcolor' property is a color and may be specified as:
  - A hex string (e.g. '#ff0000')
  - An rgb/rgba string (e.g. 'rgb(255,0,0)')
  - An hsl/hsla string (e.g. 'hsl(0,100%,50%)')
  - An hsv/hsva string (e.g. 'hsv(0,100%,100%)')
  - A named CSS color: see https://plotly.com/python/css-colors/ for a list

Returns
-------
str
r   r)   r*   s    r,   r   Shape.fillcolorC   s    " K  r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r4   V   
    [r.   c                     U S   $ )aK  
Determines which regions of complex paths constitute the
interior. For more info please visit
https://developer.mozilla.org/en-
US/docs/Web/SVG/Attribute/fill-rule

The 'fillrule' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['evenodd', 'nonzero']

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.fillruleZ   s      Jr.   c                     XS'   g )Nr   r)   r0   s     r,   r   r8   l   r2   r.   c                     U S   $ )a  
The 'label' property is an instance of Label
that may be specified as:
  - An instance of :class:`plotly.graph_objs.layout.shape.Label`
  - A dict of string/value properties that will be passed
    to the Label constructor

Returns
-------
plotly.graph_objs.layout.shape.Label
r   r)   r*   s    r,   r   Shape.labelp   s     G}r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r;      	    Wr.   c                     U S   $ )a-  
Specifies whether shapes are drawn below gridlines ("below"),
between gridlines and traces ("between") or above traces
("above").

The 'layer' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['below', 'above', 'between']

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.layer   s     G}r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r?      r=   r.   c                     U S   $ )a  
Sets the reference to a legend to show this shape in.
References to these legends are "legend", "legend2", "legend3",
etc. Settings for these legends are set in the layout, under
`layout.legend`, `layout.legend2`, etc.

The 'legend' property is an identifier of a particular
subplot, of type 'legend', that may be specified as the string 'legend'
optionally followed by an integer >= 1
(e.g. 'legend', 'legend1', 'legend2', 'legend3', etc.)

Returns
-------
str
r   r)   r*   s    r,   r   Shape.legend   s    " H~r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rB      s	    Xr.   c                     U S   $ )a"  
Sets the legend group for this shape. Traces and shapes part of
the same legend group hide/show at the same time when toggling
legend items.

The 'legendgroup' property is a string and must be specified as:
  - A string
  - A number that will be converted to a string

Returns
-------
str
r$   r)   r*   s    r,   r$   Shape.legendgroup   s     M""r.   c                     XS'   g )Nr$   r)   r0   s     r,   r$   rE      
    !]r.   c                     U S   $ )aM  
The 'legendgrouptitle' property is an instance of Legendgrouptitle
that may be specified as:
  - An instance of :class:`plotly.graph_objs.layout.shape.Legendgrouptitle`
  - A dict of string/value properties that will be passed
    to the Legendgrouptitle constructor

Returns
-------
plotly.graph_objs.layout.shape.Legendgrouptitle
r&   r)   r*   s    r,   r&   Shape.legendgrouptitle   s     &''r.   c                     XS'   g )Nr&   r)   r0   s     r,   r&   rI          #& r.   c                     U S   $ )aZ  
Sets the legend rank for this shape. Items and groups with
smaller ranks are presented on top/left side while with
"reversed" `legend.traceorder` they are on bottom/right side.
The default legendrank is 1000, so that you can use ranks less
than 1000 to place certain items before all unranked items, and
ranks greater than 1000 to go after all unranked items. When
having unranked or equal rank items shapes would be displayed
after traces i.e. according to their order in data and layout.

The 'legendrank' property is a number and may be specified as:
  - An int or float

Returns
-------
int|float
r"   r)   r*   s    r,   r"   Shape.legendrank   s    & L!!r.   c                     XS'   g )Nr"   r)   r0   s     r,   r"   rM      
     \r.   c                     U S   $ )z
Sets the width (in px or fraction) of the legend for this
shape.

The 'legendwidth' property is a number and may be specified as:
  - An int or float in the interval [0, inf]

Returns
-------
int|float
r%   r)   r*   s    r,   r%   Shape.legendwidth   s     M""r.   c                     XS'   g )Nr%   r)   r0   s     r,   r%   rQ      rG   r.   c                     U S   $ )a  
The 'line' property is an instance of Line
that may be specified as:
  - An instance of :class:`plotly.graph_objs.layout.shape.Line`
  - A dict of string/value properties that will be passed
    to the Line constructor

Returns
-------
plotly.graph_objs.layout.shape.Line
r   r)   r*   s    r,   r   
Shape.line  s     F|r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rT     	    Vr.   c                     U S   $ )a  
When used in a template, named items are created in the output
figure in addition to any items the figure already has in this
array. You can modify these items in the output figure by
making your own item with `templateitemname` matching this
`name` alongside your modifications (including `visible: false`
or `enabled: false` to hide it). Has no effect outside of a
template.

The 'name' property is a string and must be specified as:
  - A string
  - A number that will be converted to a string

Returns
-------
str
r   r)   r*   s    r,   r   
Shape.name  s    & F|r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rX   +  rV   r.   c                     U S   $ )z
Sets the opacity of the shape.

The 'opacity' property is a number and may be specified as:
  - An int or float in the interval [0, 1]

Returns
-------
int|float
r   r)   r*   s    r,   r   Shape.opacity/  s     Ir.   c                     XS'   g )Nr   r)   r0   s     r,   r   r[   =  	    Yr.   c                     U S   $ )a  
For `type` "path" - a valid SVG path with the pixel values
replaced by data values in `xsizemode`/`ysizemode` being
"scaled" and taken unmodified as pixels relative to `xanchor`
and `yanchor` in case of "pixel" size mode. There are a few
restrictions / quirks only absolute instructions, not relative.
So the allowed segments are: M, L, H, V, Q, C, T, S, and Z arcs
(A) are not allowed because radius rx and ry are relative. In
the future we could consider supporting relative commands, but
we would have to decide on how to handle date and log axes.
Note that even as is, Q and C Bezier paths that are smooth on
linear axes may not be smooth on log, and vice versa. no
chained "polybezier" commands - specify the segment type for
each one. On category axes, values are numbers scaled to the
serial numbers of categories because using the categories
themselves there would be no way to describe fractional
positions On data axes: because space and T are both normal
components of path strings, we can't use either to separate
date from time parts. Therefore we'll use underscore for this
purpose: 2015-02-21_13:45:56.789

The 'path' property is a string and must be specified as:
  - A string
  - A number that will be converted to a string

Returns
-------
str
r   r)   r*   s    r,   r   
Shape.pathA  s    > F|r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r_   b  rV   r.   c                     U S   $ )z
Determines whether or not this shape is shown in the legend.

The 'showlegend' property must be specified as a bool
(either True, or False)

Returns
-------
bool
r#   r)   r*   s    r,   r#   Shape.showlegendf  s     L!!r.   c                     XS'   g )Nr#   r)   r0   s     r,   r#   rb   t  rO   r.   c                     U S   $ )aa  
Used to refer to a named item in this array in the template.
Named items from the template will be created even without a
matching item in the input figure, but you can modify one by
making an item with `templateitemname` matching its `name`,
alongside your modifications (including `visible: false` or
`enabled: false` to hide it). If there is no template or no
matching item, this item will be hidden unless you explicitly
show it with `visible: true`.

The 'templateitemname' property is a string and must be specified as:
  - A string
  - A number that will be converted to a string

Returns
-------
str
r'   r)   r*   s    r,   r'   Shape.templateitemnamex  s    ( &''r.   c                     XS'   g )Nr'   r)   r0   s     r,   r'   re     rK   r.   c                     U S   $ )a  
Specifies the shape type to be drawn. If "line", a line is
drawn from (`x0`,`y0`) to (`x1`,`y1`) with respect to the axes'
sizing mode. If "circle", a circle is drawn from
((`x0`+`x1`)/2, (`y0`+`y1`)/2)) with radius (|(`x0`+`x1`)/2 -
`x0`|, |(`y0`+`y1`)/2 -`y0`)|) with respect to the axes' sizing
mode. If "rect", a rectangle is drawn linking (`x0`,`y0`),
(`x1`,`y0`), (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`) with respect
to the axes' sizing mode. If "path", draw a custom SVG path
using `path`. with respect to the axes' sizing mode.

The 'type' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['circle', 'rect', 'path', 'line']

Returns
-------
Any
r   r)   r*   s    r,   r   
Shape.type  s    * F|r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rh     rV   r.   c                     U S   $ )aS  
Determines whether or not this shape is visible. If
"legendonly", the shape is not drawn, but can appear as a
legend item (provided that the legend itself is visible).

The 'visible' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        [True, False, 'legendonly']

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.visible       Ir.   c                     XS'   g )Nr   r)   r0   s     r,   r   rk     r]   r.   c                     U S   $ )z
Sets the shape's starting x position. See `type` and
`xsizemode` for more info.

The 'x0' property accepts values of any type

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.x0       Dzr.   c                     XS'   g )Nr   r)   r0   s     r,   r   ro     	    T
r.   c                     U S   $ )aI  
Shifts `x0` away from the center of the category when `xref` is
a "category" or "multicategory" axis. -0.5 corresponds to the
start of the category and 0.5 corresponds to the end of the
category.

The 'x0shift' property is a number and may be specified as:
  - An int or float in the interval [-1, 1]

Returns
-------
int|float
r   r)   r*   s    r,   r   Shape.x0shift  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rt     r]   r.   c                     U S   $ )z
Sets the shape's end x position. See `type` and `xsizemode` for
more info.

The 'x1' property accepts values of any type

Returns
-------
Any
r	   r)   r*   s    r,   r	   Shape.x1  rp   r.   c                     XS'   g )Nr	   r)   r0   s     r,   r	   rw     rr   r.   c                     U S   $ )aI  
Shifts `x1` away from the center of the category when `xref` is
a "category" or "multicategory" axis. -0.5 corresponds to the
start of the category and 0.5 corresponds to the end of the
category.

The 'x1shift' property is a number and may be specified as:
  - An int or float in the interval [-1, 1]

Returns
-------
int|float
r   r)   r*   s    r,   r   Shape.x1shift  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   rz     r]   r.   c                     U S   $ )ag  
Only relevant in conjunction with `xsizemode` set to "pixel".
Specifies the anchor point on the x axis to which `x0`, `x1`
and x coordinates within `path` are relative to. E.g. useful to
attach a pixel sized shape to a certain data value. No effect
when `xsizemode` not set to "pixel".

The 'xanchor' property accepts values of any type

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.xanchor  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r}   !  r]   r.   c                     U S   $ )a  
Sets the shape's x coordinate axis. If set to a x axis id (e.g.
"x" or "x2"), the `x` position refers to a x coordinate. If set
to "paper", the `x` position refers to the distance from the
left of the plotting area in normalized coordinates where 0 (1)
corresponds to the left (right). If set to a x axis ID followed
by "domain" (separated by a space), the position behaves like
for "paper", but refers to the distance in fractions of the
domain length from the left of the domain of that axis: e.g.,
*x2 domain* refers to the domain of the second x  axis and a x
position of 0.5 refers to the point between the left and the
right of the domain of the second x axis.

The 'xref' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['paper']
  - A string that matches one of the following regular expressions:
        ['^x([2-9]|[1-9][0-9]+)?( domain)?$']

Returns
-------
Any
r   r)   r*   s    r,   r   
Shape.xref%      2 F|r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r   @  rV   r.   c                     U S   $ )a  
Sets the shapes's sizing mode along the x axis. If set to
"scaled", `x0`, `x1` and x coordinates within `path` refer to
data values on the x axis or a fraction of the plot area's
width (`xref` set to "paper"). If set to "pixel", `xanchor`
specifies the x position in terms of data or plot fraction but
`x0`, `x1` and x coordinates within `path` are pixels relative
to `xanchor`. This way, the shape can have a fixed width while
maintaining a position relative to data or plot fraction.

The 'xsizemode' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['scaled', 'pixel']

Returns
-------
Any
r    r)   r*   s    r,   r    Shape.xsizemodeD      ( K  r.   c                     XS'   g )Nr    r)   r0   s     r,   r    r   Z  r6   r.   c                     U S   $ )z
Sets the shape's starting y position. See `type` and
`ysizemode` for more info.

The 'y0' property accepts values of any type

Returns
-------
Any
r
   r)   r*   s    r,   r
   Shape.y0^  rp   r.   c                     XS'   g )Nr
   r)   r0   s     r,   r
   r   l  rr   r.   c                     U S   $ )aI  
Shifts `y0` away from the center of the category when `yref` is
a "category" or "multicategory" axis. -0.5 corresponds to the
start of the category and 0.5 corresponds to the end of the
category.

The 'y0shift' property is a number and may be specified as:
  - An int or float in the interval [-1, 1]

Returns
-------
int|float
r   r)   r*   s    r,   r   Shape.y0shiftp  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r     r]   r.   c                     U S   $ )z
Sets the shape's end y position. See `type` and `ysizemode` for
more info.

The 'y1' property accepts values of any type

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.y1  rp   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r     rr   r.   c                     U S   $ )aI  
Shifts `y1` away from the center of the category when `yref` is
a "category" or "multicategory" axis. -0.5 corresponds to the
start of the category and 0.5 corresponds to the end of the
category.

The 'y1shift' property is a number and may be specified as:
  - An int or float in the interval [-1, 1]

Returns
-------
int|float
r   r)   r*   s    r,   r   Shape.y1shift  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r     r]   r.   c                     U S   $ )ag  
Only relevant in conjunction with `ysizemode` set to "pixel".
Specifies the anchor point on the y axis to which `y0`, `y1`
and y coordinates within `path` are relative to. E.g. useful to
attach a pixel sized shape to a certain data value. No effect
when `ysizemode` not set to "pixel".

The 'yanchor' property accepts values of any type

Returns
-------
Any
r   r)   r*   s    r,   r   Shape.yanchor  rl   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r     r]   r.   c                     U S   $ )a  
Sets the shape's y coordinate axis. If set to a y axis id (e.g.
"y" or "y2"), the `y` position refers to a y coordinate. If set
to "paper", the `y` position refers to the distance from the
bottom of the plotting area in normalized coordinates where 0
(1) corresponds to the bottom (top). If set to a y axis ID
followed by "domain" (separated by a space), the position
behaves like for "paper", but refers to the distance in
fractions of the domain length from the bottom of the domain of
that axis: e.g., *y2 domain* refers to the domain of the second
y  axis and a y position of 0.5 refers to the point between the
bottom and the top of the domain of the second y axis.

The 'yref' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['paper']
  - A string that matches one of the following regular expressions:
        ['^y([2-9]|[1-9][0-9]+)?( domain)?$']

Returns
-------
Any
r   r)   r*   s    r,   r   
Shape.yref  r   r.   c                     XS'   g )Nr   r)   r0   s     r,   r   r     rV   r.   c                     U S   $ )a  
Sets the shapes's sizing mode along the y axis. If set to
"scaled", `y0`, `y1` and y coordinates within `path` refer to
data values on the y axis or a fraction of the plot area's
height (`yref` set to "paper"). If set to "pixel", `yanchor`
specifies the y position in terms of data or plot fraction but
`y0`, `y1` and y coordinates within `path` are pixels relative
to `yanchor`. This way, the shape can have a fixed height while
maintaining a position relative to data or plot fraction.

The 'ysizemode' property is an enumeration that may be specified as:
  - One of the following enumeration values:
        ['scaled', 'pixel']

Returns
-------
Any
r!   r)   r*   s    r,   r!   Shape.ysizemode  r   r.   c                     XS'   g )Nr!   r)   r0   s     r,   r!   r     r6   r.   c                     g)Nar+          editable
            Determines whether the shape could be activated for
            edit or not. Has no effect when the older editable
            shapes mode is enabled via `config.editable` or
            `config.edits.shapePosition`.
        fillcolor
            Sets the color filling the shape's interior. Only
            applies to closed shapes.
        fillrule
            Determines which regions of complex paths constitute
            the interior. For more info please visit
            https://developer.mozilla.org/en-
            US/docs/Web/SVG/Attribute/fill-rule
        label
            :class:`plotly.graph_objects.layout.shape.Label`
            instance or dict with compatible properties
        layer
            Specifies whether shapes are drawn below gridlines
            ("below"), between gridlines and traces ("between") or
            above traces ("above").
        legend
            Sets the reference to a legend to show this shape in.
            References to these legends are "legend", "legend2",
            "legend3", etc. Settings for these legends are set in
            the layout, under `layout.legend`, `layout.legend2`,
            etc.
        legendgroup
            Sets the legend group for this shape. Traces and shapes
            part of the same legend group hide/show at the same
            time when toggling legend items.
        legendgrouptitle
            :class:`plotly.graph_objects.layout.shape.Legendgroupti
            tle` instance or dict with compatible properties
        legendrank
            Sets the legend rank for this shape. Items and groups
            with smaller ranks are presented on top/left side while
            with "reversed" `legend.traceorder` they are on
            bottom/right side. The default legendrank is 1000, so
            that you can use ranks less than 1000 to place certain
            items before all unranked items, and ranks greater than
            1000 to go after all unranked items. When having
            unranked or equal rank items shapes would be displayed
            after traces i.e. according to their order in data and
            layout.
        legendwidth
            Sets the width (in px or fraction) of the legend for
            this shape.
        line
            :class:`plotly.graph_objects.layout.shape.Line`
            instance or dict with compatible properties
        name
            When used in a template, named items are created in the
            output figure in addition to any items the figure
            already has in this array. You can modify these items
            in the output figure by making your own item with
            `templateitemname` matching this `name` alongside your
            modifications (including `visible: false` or `enabled:
            false` to hide it). Has no effect outside of a
            template.
        opacity
            Sets the opacity of the shape.
        path
            For `type` "path" - a valid SVG path with the pixel
            values replaced by data values in
            `xsizemode`/`ysizemode` being "scaled" and taken
            unmodified as pixels relative to `xanchor` and
            `yanchor` in case of "pixel" size mode. There are a few
            restrictions / quirks only absolute instructions, not
            relative. So the allowed segments are: M, L, H, V, Q,
            C, T, S, and Z arcs (A) are not allowed because radius
            rx and ry are relative. In the future we could consider
            supporting relative commands, but we would have to
            decide on how to handle date and log axes. Note that
            even as is, Q and C Bezier paths that are smooth on
            linear axes may not be smooth on log, and vice versa.
            no chained "polybezier" commands - specify the segment
            type for each one. On category axes, values are numbers
            scaled to the serial numbers of categories because
            using the categories themselves there would be no way
            to describe fractional positions On data axes: because
            space and T are both normal components of path strings,
            we can't use either to separate date from time parts.
            Therefore we'll use underscore for this purpose:
            2015-02-21_13:45:56.789
        showlegend
            Determines whether or not this shape is shown in the
            legend.
        templateitemname
            Used to refer to a named item in this array in the
            template. Named items from the template will be created
            even without a matching item in the input figure, but
            you can modify one by making an item with
            `templateitemname` matching its `name`, alongside your
            modifications (including `visible: false` or `enabled:
            false` to hide it). If there is no template or no
            matching item, this item will be hidden unless you
            explicitly show it with `visible: true`.
        type
            Specifies the shape type to be drawn. If "line", a line
            is drawn from (`x0`,`y0`) to (`x1`,`y1`) with respect
            to the axes' sizing mode. If "circle", a circle is
            drawn from ((`x0`+`x1`)/2, (`y0`+`y1`)/2)) with radius
            (|(`x0`+`x1`)/2 - `x0`|, |(`y0`+`y1`)/2 -`y0`)|) with
            respect to the axes' sizing mode. If "rect", a
            rectangle is drawn linking (`x0`,`y0`), (`x1`,`y0`),
            (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`) with respect to
            the axes' sizing mode. If "path", draw a custom SVG
            path using `path`. with respect to the axes' sizing
            mode.
        visible
            Determines whether or not this shape is visible. If
            "legendonly", the shape is not drawn, but can appear as
            a legend item (provided that the legend itself is
            visible).
        x0
            Sets the shape's starting x position. See `type` and
            `xsizemode` for more info.
        x0shift
            Shifts `x0` away from the center of the category when
            `xref` is a "category" or "multicategory" axis. -0.5
            corresponds to the start of the category and 0.5
            corresponds to the end of the category.
        x1
            Sets the shape's end x position. See `type` and
            `xsizemode` for more info.
        x1shift
            Shifts `x1` away from the center of the category when
            `xref` is a "category" or "multicategory" axis. -0.5
            corresponds to the start of the category and 0.5
            corresponds to the end of the category.
        xanchor
            Only relevant in conjunction with `xsizemode` set to
            "pixel". Specifies the anchor point on the x axis to
            which `x0`, `x1` and x coordinates within `path` are
            relative to. E.g. useful to attach a pixel sized shape
            to a certain data value. No effect when `xsizemode` not
            set to "pixel".
        xref
            Sets the shape's x coordinate axis. If set to a x axis
            id (e.g. "x" or "x2"), the `x` position refers to a x
            coordinate. If set to "paper", the `x` position refers
            to the distance from the left of the plotting area in
            normalized coordinates where 0 (1) corresponds to the
            left (right). If set to a x axis ID followed by
            "domain" (separated by a space), the position behaves
            like for "paper", but refers to the distance in
            fractions of the domain length from the left of the
            domain of that axis: e.g., *x2 domain* refers to the
            domain of the second x  axis and a x position of 0.5
            refers to the point between the left and the right of
            the domain of the second x axis.
        xsizemode
            Sets the shapes's sizing mode along the x axis. If set
            to "scaled", `x0`, `x1` and x coordinates within `path`
            refer to data values on the x axis or a fraction of the
            plot area's width (`xref` set to "paper"). If set to
            "pixel", `xanchor` specifies the x position in terms of
            data or plot fraction but `x0`, `x1` and x coordinates
            within `path` are pixels relative to `xanchor`. This
            way, the shape can have a fixed width while maintaining
            a position relative to data or plot fraction.
        y0
            Sets the shape's starting y position. See `type` and
            `ysizemode` for more info.
        y0shift
            Shifts `y0` away from the center of the category when
            `yref` is a "category" or "multicategory" axis. -0.5
            corresponds to the start of the category and 0.5
            corresponds to the end of the category.
        y1
            Sets the shape's end y position. See `type` and
            `ysizemode` for more info.
        y1shift
            Shifts `y1` away from the center of the category when
            `yref` is a "category" or "multicategory" axis. -0.5
            corresponds to the start of the category and 0.5
            corresponds to the end of the category.
        yanchor
            Only relevant in conjunction with `ysizemode` set to
            "pixel". Specifies the anchor point on the y axis to
            which `y0`, `y1` and y coordinates within `path` are
            relative to. E.g. useful to attach a pixel sized shape
            to a certain data value. No effect when `ysizemode` not
            set to "pixel".
        yref
            Sets the shape's y coordinate axis. If set to a y axis
            id (e.g. "y" or "y2"), the `y` position refers to a y
            coordinate. If set to "paper", the `y` position refers
            to the distance from the bottom of the plotting area in
            normalized coordinates where 0 (1) corresponds to the
            bottom (top). If set to a y axis ID followed by
            "domain" (separated by a space), the position behaves
            like for "paper", but refers to the distance in
            fractions of the domain length from the bottom of the
            domain of that axis: e.g., *y2 domain* refers to the
            domain of the second y  axis and a y position of 0.5
            refers to the point between the bottom and the top of
            the domain of the second y axis.
        ysizemode
            Sets the shapes's sizing mode along the y axis. If set
            to "scaled", `y0`, `y1` and y coordinates within `path`
            refer to data values on the y axis or a fraction of the
            plot area's height (`yref` set to "paper"). If set to
            "pixel", `yanchor` specifies the y position in terms of
            data or plot fraction but `y0`, `y1` and y coordinates
            within `path` are pixels relative to `yanchor`. This
            way, the shape can have a fixed height while
            maintaining a position relative to data or plot
            fraction.
        r)   r*   s    r,   _prop_descriptionsShape._prop_descriptions  s    Rr.   c"           	      \  > [         T#U ]  S5        SU";   a  U"S   U l        gUc  0 nOb[        XR                  5      (       a  UR                  5       nO7[        U[        5      (       a  [        R                  " U5      nO[        S5      eU"R                  SS5      U l        U"R                  SS5      U l        U R                  S	X5        U R                  S
X5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SX5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  SUU5        U R                  S UU5        U R                  S!UU5        U R                  S"UU5        U R                  S#UU5        U R                  S$UU5        U R                  S%UU5        U R                  S&UU5        U R                  S'UU 5        U R                  S(UU!5        U R                  " S)0 [        U40 U"D6D6  SU l        g)*a%  
Construct a new Shape object

Parameters
----------
arg
    dict of properties compatible with this constructor or
    an instance of :class:`plotly.graph_objs.layout.Shape`
editable
    Determines whether the shape could be activated for
    edit or not. Has no effect when the older editable
    shapes mode is enabled via `config.editable` or
    `config.edits.shapePosition`.
fillcolor
    Sets the color filling the shape's interior. Only
    applies to closed shapes.
fillrule
    Determines which regions of complex paths constitute
    the interior. For more info please visit
    https://developer.mozilla.org/en-
    US/docs/Web/SVG/Attribute/fill-rule
label
    :class:`plotly.graph_objects.layout.shape.Label`
    instance or dict with compatible properties
layer
    Specifies whether shapes are drawn below gridlines
    ("below"), between gridlines and traces ("between") or
    above traces ("above").
legend
    Sets the reference to a legend to show this shape in.
    References to these legends are "legend", "legend2",
    "legend3", etc. Settings for these legends are set in
    the layout, under `layout.legend`, `layout.legend2`,
    etc.
legendgroup
    Sets the legend group for this shape. Traces and shapes
    part of the same legend group hide/show at the same
    time when toggling legend items.
legendgrouptitle
    :class:`plotly.graph_objects.layout.shape.Legendgroupti
    tle` instance or dict with compatible properties
legendrank
    Sets the legend rank for this shape. Items and groups
    with smaller ranks are presented on top/left side while
    with "reversed" `legend.traceorder` they are on
    bottom/right side. The default legendrank is 1000, so
    that you can use ranks less than 1000 to place certain
    items before all unranked items, and ranks greater than
    1000 to go after all unranked items. When having
    unranked or equal rank items shapes would be displayed
    after traces i.e. according to their order in data and
    layout.
legendwidth
    Sets the width (in px or fraction) of the legend for
    this shape.
line
    :class:`plotly.graph_objects.layout.shape.Line`
    instance or dict with compatible properties
name
    When used in a template, named items are created in the
    output figure in addition to any items the figure
    already has in this array. You can modify these items
    in the output figure by making your own item with
    `templateitemname` matching this `name` alongside your
    modifications (including `visible: false` or `enabled:
    false` to hide it). Has no effect outside of a
    template.
opacity
    Sets the opacity of the shape.
path
    For `type` "path" - a valid SVG path with the pixel
    values replaced by data values in
    `xsizemode`/`ysizemode` being "scaled" and taken
    unmodified as pixels relative to `xanchor` and
    `yanchor` in case of "pixel" size mode. There are a few
    restrictions / quirks only absolute instructions, not
    relative. So the allowed segments are: M, L, H, V, Q,
    C, T, S, and Z arcs (A) are not allowed because radius
    rx and ry are relative. In the future we could consider
    supporting relative commands, but we would have to
    decide on how to handle date and log axes. Note that
    even as is, Q and C Bezier paths that are smooth on
    linear axes may not be smooth on log, and vice versa.
    no chained "polybezier" commands - specify the segment
    type for each one. On category axes, values are numbers
    scaled to the serial numbers of categories because
    using the categories themselves there would be no way
    to describe fractional positions On data axes: because
    space and T are both normal components of path strings,
    we can't use either to separate date from time parts.
    Therefore we'll use underscore for this purpose:
    2015-02-21_13:45:56.789
showlegend
    Determines whether or not this shape is shown in the
    legend.
templateitemname
    Used to refer to a named item in this array in the
    template. Named items from the template will be created
    even without a matching item in the input figure, but
    you can modify one by making an item with
    `templateitemname` matching its `name`, alongside your
    modifications (including `visible: false` or `enabled:
    false` to hide it). If there is no template or no
    matching item, this item will be hidden unless you
    explicitly show it with `visible: true`.
type
    Specifies the shape type to be drawn. If "line", a line
    is drawn from (`x0`,`y0`) to (`x1`,`y1`) with respect
    to the axes' sizing mode. If "circle", a circle is
    drawn from ((`x0`+`x1`)/2, (`y0`+`y1`)/2)) with radius
    (|(`x0`+`x1`)/2 - `x0`|, |(`y0`+`y1`)/2 -`y0`)|) with
    respect to the axes' sizing mode. If "rect", a
    rectangle is drawn linking (`x0`,`y0`), (`x1`,`y0`),
    (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`) with respect to
    the axes' sizing mode. If "path", draw a custom SVG
    path using `path`. with respect to the axes' sizing
    mode.
visible
    Determines whether or not this shape is visible. If
    "legendonly", the shape is not drawn, but can appear as
    a legend item (provided that the legend itself is
    visible).
x0
    Sets the shape's starting x position. See `type` and
    `xsizemode` for more info.
x0shift
    Shifts `x0` away from the center of the category when
    `xref` is a "category" or "multicategory" axis. -0.5
    corresponds to the start of the category and 0.5
    corresponds to the end of the category.
x1
    Sets the shape's end x position. See `type` and
    `xsizemode` for more info.
x1shift
    Shifts `x1` away from the center of the category when
    `xref` is a "category" or "multicategory" axis. -0.5
    corresponds to the start of the category and 0.5
    corresponds to the end of the category.
xanchor
    Only relevant in conjunction with `xsizemode` set to
    "pixel". Specifies the anchor point on the x axis to
    which `x0`, `x1` and x coordinates within `path` are
    relative to. E.g. useful to attach a pixel sized shape
    to a certain data value. No effect when `xsizemode` not
    set to "pixel".
xref
    Sets the shape's x coordinate axis. If set to a x axis
    id (e.g. "x" or "x2"), the `x` position refers to a x
    coordinate. If set to "paper", the `x` position refers
    to the distance from the left of the plotting area in
    normalized coordinates where 0 (1) corresponds to the
    left (right). If set to a x axis ID followed by
    "domain" (separated by a space), the position behaves
    like for "paper", but refers to the distance in
    fractions of the domain length from the left of the
    domain of that axis: e.g., *x2 domain* refers to the
    domain of the second x  axis and a x position of 0.5
    refers to the point between the left and the right of
    the domain of the second x axis.
xsizemode
    Sets the shapes's sizing mode along the x axis. If set
    to "scaled", `x0`, `x1` and x coordinates within `path`
    refer to data values on the x axis or a fraction of the
    plot area's width (`xref` set to "paper"). If set to
    "pixel", `xanchor` specifies the x position in terms of
    data or plot fraction but `x0`, `x1` and x coordinates
    within `path` are pixels relative to `xanchor`. This
    way, the shape can have a fixed width while maintaining
    a position relative to data or plot fraction.
y0
    Sets the shape's starting y position. See `type` and
    `ysizemode` for more info.
y0shift
    Shifts `y0` away from the center of the category when
    `yref` is a "category" or "multicategory" axis. -0.5
    corresponds to the start of the category and 0.5
    corresponds to the end of the category.
y1
    Sets the shape's end y position. See `type` and
    `ysizemode` for more info.
y1shift
    Shifts `y1` away from the center of the category when
    `yref` is a "category" or "multicategory" axis. -0.5
    corresponds to the start of the category and 0.5
    corresponds to the end of the category.
yanchor
    Only relevant in conjunction with `ysizemode` set to
    "pixel". Specifies the anchor point on the y axis to
    which `y0`, `y1` and y coordinates within `path` are
    relative to. E.g. useful to attach a pixel sized shape
    to a certain data value. No effect when `ysizemode` not
    set to "pixel".
yref
    Sets the shape's y coordinate axis. If set to a y axis
    id (e.g. "y" or "y2"), the `y` position refers to a y
    coordinate. If set to "paper", the `y` position refers
    to the distance from the bottom of the plotting area in
    normalized coordinates where 0 (1) corresponds to the
    bottom (top). If set to a y axis ID followed by
    "domain" (separated by a space), the position behaves
    like for "paper", but refers to the distance in
    fractions of the domain length from the bottom of the
    domain of that axis: e.g., *y2 domain* refers to the
    domain of the second y  axis and a y position of 0.5
    refers to the point between the bottom and the top of
    the domain of the second y axis.
ysizemode
    Sets the shapes's sizing mode along the y axis. If set
    to "scaled", `y0`, `y1` and y coordinates within `path`
    refer to data values on the y axis or a fraction of the
    plot area's height (`yref` set to "paper"). If set to
    "pixel", `yanchor` specifies the y position in terms of
    data or plot fraction but `y0`, `y1` and y coordinates
    within `path` are pixels relative to `yanchor`. This
    way, the shape can have a fixed height while
    maintaining a position relative to data or plot
    fraction.

Returns
-------
Shape
shapes_parentNzThe first argument to the plotly.graph_objs.layout.Shape
constructor must be a dict or
an instance of :class:`plotly.graph_objs.layout.Shape`skip_invalidF	_validateTr   r   r   r   r   r   r$   r&   r"   r%   r   r   r   r   r#   r'   r   r   r   r   r	   r   r   r   r    r
   r   r   r   r   r   r!   r)   )super__init__r   
isinstance	__class__to_plotly_jsondict_copycopy
ValueErrorpop_skip_invalidr   _set_property_process_kwargs)$r+   argr   r   r   r   r   r   r$   r&   r"   r%   r   r   r   r   r#   r'   r   r   r   r   r	   r   r   r   r    r
   r   r   r   r   r   r!   kwargsr   s$                                      r,   r   Shape.__init__  s   F 	"!),DL;C^^,,$$&CT""**S/C:  $ZZ>K6:s5;7:s57C/7C/8S1=#;-sE<9=#;63-63-9c363-<j9-s4DE63-9c734b)9c734b)9c739c7363-;Y74b)9c734b)9c739c7363-;Y73tC2623"r.   )r   r   r   )!NNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN)-__name__
__module____qualname____firstlineno___parent_path_str	_path_str_valid_propspropertyr   setterr   r   r   r   r   r$   r&   r"   r%   r   r   r   r   r#   r'   r   r   r   r   r	   r   r   r   r    r
   r   r   r   r   r   r!   r   r   __static_attributes____classcell__)r   s   @r,   r   r      s2   I!LF     __  ! !$        " __    \\     \\   $ ]]  # #  " " ( ( ' ' " "( ! ! # # " "   
[[   ( 
[[    ^^   @ 
[[  " " ! ! ( (* ' '  , 
[[     ^^    YY     ^^    YY     ^^     ^^   4 
[[  ! !*       YY     ^^    YY     ^^     ^^   4 
[[  ! !*     S Sn Ez# z#r.   r   )plotly.basedatatypesr   _BaseLayoutHierarchyTyper   r   r   r)   r.   r,   <module>r      s    U B#$ B#r.   