
    gT                   :   d dl mZ d dlmZmZmZ d dlmZmZm	Z	 ddl
mZ erd dlmZ er1d dlZej                  dk\  rd d	lmZ nd d	lmZ d d
lmZ d dlmZ ddl  G d de      Z G d de      Z G d de      Z G d de      Z G d d      Z G d d      Zy)    )annotations)TYPE_CHECKINGAnyLiteral)
SchemaBase	Undefineduse_signature   )core)SequenceN)      )Self)	Parameter)Optional)*c            V      0    e Zd ZdZddiZeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeefV	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d fdZ xZS )_MarkDefu={  
    MarkDef schema wrapper.

    Parameters
    ----------
    align : dict, :class:`Align`, :class:`ExprRef`, Literal['left', 'center', 'right']
        The horizontal alignment of the text or ranged marks (area, bar, image, rect, rule).
        One of ``"left"``, ``"right"``, ``"center"``.

        **Note:** Expression reference is *not* supported for range marks.
    angle : dict, float, :class:`ExprRef`
        The rotation angle of the text, in degrees.
    aria : bool, dict, :class:`ExprRef`
        A boolean flag indicating if `ARIA attributes
        <https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA>`__ should be
        included (SVG output only). If ``false``, the "aria-hidden" attribute will be set on
        the output SVG element, removing the mark item from the ARIA accessibility tree.
    ariaRole : str, dict, :class:`ExprRef`
        Sets the type of user interface element of the mark item for `ARIA accessibility
        <https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA>`__ (SVG output
        only). If specified, this property determines the "role" attribute. Warning: this
        property is experimental and may be changed in the future.
    ariaRoleDescription : str, dict, :class:`ExprRef`
        A human-readable, author-localized description for the role of the mark item for
        `ARIA accessibility
        <https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA>`__ (SVG output
        only). If specified, this property determines the "aria-roledescription" attribute.
        Warning: this property is experimental and may be changed in the future.
    aspect : bool, dict, :class:`ExprRef`
        Whether to keep aspect ratio of image marks.
    bandSize : float
        The width of the ticks.

        **Default value:**  3/4 of step (width step for horizontal ticks and height step for
        vertical ticks).
    baseline : dict, :class:`ExprRef`, :class:`Baseline`, :class:`TextBaseline`, Literal['alphabetic', 'line-bottom', 'line-top', 'top', 'middle', 'bottom']
        For text marks, the vertical text baseline. One of ``"alphabetic"`` (default),
        ``"top"``, ``"middle"``, ``"bottom"``, ``"line-top"``, ``"line-bottom"``, or an
        expression reference that provides one of the valid values. The ``"line-top"`` and
        ``"line-bottom"`` values operate similarly to ``"top"`` and ``"bottom"``, but are
        calculated relative to the ``lineHeight`` rather than ``fontSize`` alone.

        For range marks, the vertical alignment of the marks. One of ``"top"``,
        ``"middle"``, ``"bottom"``.

        **Note:** Expression reference is *not* supported for range marks.
    binSpacing : float
        Offset between bars for binned field. The ideal value for this is either 0
        (preferred by statisticians) or 1 (Vega-Lite default, D3 example style).

        **Default value:** ``1``
    blend : dict, :class:`Blend`, :class:`ExprRef`, Literal[None, 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity']
        The color blend mode for drawing an item on its current background. Any valid `CSS
        mix-blend-mode <https://developer.mozilla.org/en-US/docs/Web/CSS/mix-blend-mode>`__
        value can be used.

        __Default value:__ ``"source-over"``
    clip : bool, dict, :class:`ExprRef`
        Whether a mark be clipped to the enclosing group's width and height.
    color : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple']
        Default color.

        **Default value:**  :raw-html:`<span style="color: #4682b4;">` ■ :raw-html:`</span>`
        ``"#4682b4"``

        **Note:**

        * This property cannot be used in a `style config
          <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__.
        * The ``fill`` and ``stroke`` properties have higher precedence than ``color`` and
          will override ``color``.
    continuousBandSize : float
        The default size of the bars on continuous scales.

        **Default value:** ``5``
    cornerRadius : dict, float, :class:`ExprRef`
        The radius in pixels of rounded rectangles or arcs' corners.

        **Default value:** ``0``
    cornerRadiusBottomLeft : dict, float, :class:`ExprRef`
        The radius in pixels of rounded rectangles' bottom left corner.

        **Default value:** ``0``
    cornerRadiusBottomRight : dict, float, :class:`ExprRef`
        The radius in pixels of rounded rectangles' bottom right corner.

        **Default value:** ``0``
    cornerRadiusEnd : dict, float, :class:`ExprRef`
        * For vertical bars, top-left and top-right corner radius.

        * For horizontal bars, top-right and bottom-right corner radius.
    cornerRadiusTopLeft : dict, float, :class:`ExprRef`
        The radius in pixels of rounded rectangles' top right corner.

        **Default value:** ``0``
    cornerRadiusTopRight : dict, float, :class:`ExprRef`
        The radius in pixels of rounded rectangles' top left corner.

        **Default value:** ``0``
    cursor : dict, :class:`Cursor`, :class:`ExprRef`, Literal['auto', 'default', 'none', 'context-menu', 'help', 'pointer', 'progress', 'wait', 'cell', 'crosshair', 'text', 'vertical-text', 'alias', 'copy', 'move', 'no-drop', 'not-allowed', 'e-resize', 'n-resize', 'ne-resize', 'nw-resize', 's-resize', 'se-resize', 'sw-resize', 'w-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'col-resize', 'row-resize', 'all-scroll', 'zoom-in', 'zoom-out', 'grab', 'grabbing']
        The mouse cursor used over the mark. Any valid `CSS cursor type
        <https://developer.mozilla.org/en-US/docs/Web/CSS/cursor#Values>`__ can be used.
    description : str, dict, :class:`ExprRef`
        A text description of the mark item for `ARIA accessibility
        <https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA>`__ (SVG output
        only). If specified, this property determines the `"aria-label" attribute
        <https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-label_attribute>`__.
    dir : dict, :class:`ExprRef`, :class:`TextDirection`, Literal['ltr', 'rtl']
        The direction of the text. One of ``"ltr"`` (left-to-right) or ``"rtl"``
        (right-to-left). This property determines on which side is truncated in response to
        the limit parameter.

        **Default value:** ``"ltr"``
    discreteBandSize : dict, float, :class:`RelativeBandSize`
        The default size of the bars with discrete dimensions. If unspecified, the default
        size is  ``step-2``, which provides 2 pixel offset between bars.
    dx : dict, float, :class:`ExprRef`
        The horizontal offset, in pixels, between the text label and its anchor point. The
        offset is applied after rotation by the *angle* property.
    dy : dict, float, :class:`ExprRef`
        The vertical offset, in pixels, between the text label and its anchor point. The
        offset is applied after rotation by the *angle* property.
    ellipsis : str, dict, :class:`ExprRef`
        The ellipsis string for text truncated in response to the limit parameter.

        **Default value:** ``"…"``
    fill : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple'], None
        Default fill color. This property has higher precedence than ``config.color``. Set
        to ``null`` to remove fill.

        **Default value:** (None)
    fillOpacity : dict, float, :class:`ExprRef`
        The fill opacity (value between [0,1]).

        **Default value:** ``1``
    filled : bool
        Whether the mark's color should be used as fill color instead of stroke color.

        **Default value:** ``false`` for all ``point``, ``line``, and ``rule`` marks as well
        as ``geoshape`` marks for `graticule
        <https://vega.github.io/vega-lite/docs/data.html#graticule>`__ data sources;
        otherwise, ``true``.

        **Note:** This property cannot be used in a `style config
        <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__.
    font : str, dict, :class:`ExprRef`
        The typeface to set the text in (e.g., ``"Helvetica Neue"``).
    fontSize : dict, float, :class:`ExprRef`
        The font size, in pixels.

        **Default value:** ``11``
    fontStyle : str, dict, :class:`ExprRef`, :class:`FontStyle`
        The font style (e.g., ``"italic"``).
    fontWeight : dict, :class:`ExprRef`, :class:`FontWeight`, Literal['normal', 'bold', 'lighter', 'bolder', 100, 200, 300, 400, 500, 600, 700, 800, 900]
        The font weight. This can be either a string (e.g ``"bold"``, ``"normal"``) or a
        number (``100``, ``200``, ``300``, ..., ``900`` where ``"normal"`` = ``400`` and
        ``"bold"`` = ``700``).
    height : dict, float, :class:`ExprRef`, :class:`RelativeBandSize`
        Height of the marks.  One of:

        * A number representing a fixed pixel height.

        * A relative band size definition.  For example, ``{band: 0.5}`` represents half of
          the band
    href : str, dict, :class:`URI`, :class:`ExprRef`
        A URL to load upon mouse click. If defined, the mark acts as a hyperlink.
    innerRadius : dict, float, :class:`ExprRef`
        The inner radius in pixels of arc marks. ``innerRadius`` is an alias for
        ``radius2``.

        **Default value:** ``0``
    interpolate : dict, :class:`ExprRef`, :class:`Interpolate`, Literal['basis', 'basis-open', 'basis-closed', 'bundle', 'cardinal', 'cardinal-open', 'cardinal-closed', 'catmull-rom', 'linear', 'linear-closed', 'monotone', 'natural', 'step', 'step-before', 'step-after']
        The line interpolation method to use for line and area marks. One of the following:

        * ``"linear"``: piecewise linear segments, as in a polyline.
        * ``"linear-closed"``: close the linear segments to form a polygon.
        * ``"step"``: alternate between horizontal and vertical segments, as in a step
          function.
        * ``"step-before"``: alternate between vertical and horizontal segments, as in a
          step function.
        * ``"step-after"``: alternate between horizontal and vertical segments, as in a step
          function.
        * ``"basis"``: a B-spline, with control point duplication on the ends.
        * ``"basis-open"``: an open B-spline; may not intersect the start or end.
        * ``"basis-closed"``: a closed B-spline, as in a loop.
        * ``"cardinal"``: a Cardinal spline, with control point duplication on the ends.
        * ``"cardinal-open"``: an open Cardinal spline; may not intersect the start or end,
          but will intersect other control points.
        * ``"cardinal-closed"``: a closed Cardinal spline, as in a loop.
        * ``"bundle"``: equivalent to basis, except the tension parameter is used to
          straighten the spline.
        * ``"monotone"``: cubic interpolation that preserves monotonicity in y.
    invalid : :class:`MarkInvalidDataMode`, Literal['filter', 'break-paths-filter-domains', 'break-paths-show-domains', 'break-paths-show-path-domains', 'show'], None
        Invalid data mode, which defines how the marks and corresponding scales should
        represent invalid values (``null`` and ``NaN`` in continuous scales *without*
        defined output for invalid values).

        * ``"filter"`` — *Exclude* all invalid values from the visualization's *marks* and
          *scales*. For path marks (for line, area, trail), this option will create paths
          that connect valid points, as if the data rows with invalid values do not exist.

        * ``"break-paths-filter-domains"`` — Break path marks (for line, area, trail) at
          invalid values.  For non-path marks, this is equivalent to ``"filter"``. All
          *scale* domains will *exclude* these filtered data points.

        * ``"break-paths-show-domains"`` — Break paths (for line, area, trail) at invalid
          values.  Hide invalid values for non-path marks. All *scale* domains will
          *include* these filtered data points (for both path and non-path marks).

        * ``"show"`` or ``null`` — Show all data points in the marks and scale domains. Each
          scale will use the output for invalid values defined in ``config.scale.invalid``
          or, if unspecified, by default invalid values will produce the same visual values
          as zero (if the scale includes zero) or the minimum value (if the scale does not
          include zero).

        * ``"break-paths-show-path-domains"`` (default) — This is equivalent to
          ``"break-paths-show-domains"`` for path-based marks (line/area/trail) and
          ``"filter"`` for non-path marks.

        **Note**: If any channel's scale has an output for invalid values defined in
        ``config.scale.invalid``, all values for the scales will be considered "valid" since
        they can produce a reasonable output for the scales. Thus, fields for such channels
        will not be filtered and will not cause path breaks.
    limit : dict, float, :class:`ExprRef`
        The maximum length of the text mark in pixels. The text value will be automatically
        truncated if the rendered size exceeds the limit.

        **Default value:** ``0`` -- indicating no limit
    line : bool, dict, :class:`OverlayMarkDef`
        A flag for overlaying line on top of area marks, or an object defining the
        properties of the overlayed lines.

        * If this value is an empty object (``{}``) or ``true``, lines with default
          properties will be used.

        * If this value is ``false``, no lines would be automatically added to area marks.

        **Default value:** ``false``.
    lineBreak : str, dict, :class:`ExprRef`
        A delimiter, such as a newline character, upon which to break text strings into
        multiple lines. This property is ignored if the text is array-valued.
    lineHeight : dict, float, :class:`ExprRef`
        The line height in pixels (the spacing between subsequent lines of text) for
        multi-line text marks.
    minBandSize : dict, float, :class:`ExprRef`
        The minimum band size for bar and rectangle marks. **Default value:** ``0.25``
    opacity : dict, float, :class:`ExprRef`
        The overall opacity (value between [0,1]).

        **Default value:** ``0.7`` for non-aggregate plots with ``point``, ``tick``,
        ``circle``, or ``square`` marks or layered ``bar`` charts and ``1`` otherwise.
    order : bool, None
        For line and trail marks, this ``order`` property can be set to ``null`` or
        ``false`` to make the lines use the original order in the data sources.
    orient : :class:`Orientation`, Literal['horizontal', 'vertical']
        The orientation of a non-stacked bar, tick, area, and line charts. The value is
        either horizontal (default) or vertical.

        * For bar, rule and tick, this determines whether the size of the bar and tick
          should be applied to x or y dimension.
        * For area, this property determines the orient property of the Vega output.
        * For line and trail marks, this property determines the sort order of the points in
          the line if ``config.sortLineBy`` is not specified. For stacked charts, this is
          always determined by the orientation of the stack; therefore explicitly specified
          value will be ignored.
    outerRadius : dict, float, :class:`ExprRef`
        The outer radius in pixels of arc marks. ``outerRadius`` is an alias for ``radius``.

        **Default value:** ``0``
    padAngle : dict, float, :class:`ExprRef`
        The angular padding applied to sides of the arc, in radians.
    point : bool, dict, Literal['transparent'], :class:`OverlayMarkDef`
        A flag for overlaying points on top of line or area marks, or an object defining the
        properties of the overlayed points.

        * If this property is ``"transparent"``, transparent points will be used (for
          enhancing tooltips and selections).

        * If this property is an empty object (``{}``) or ``true``, filled points with
          default properties will be used.

        * If this property is ``false``, no points would be automatically added to line or
          area marks.

        **Default value:** ``false``.
    radius : dict, float, :class:`ExprRef`
        For arc mark, the primary (outer) radius in pixels.

        For text marks, polar coordinate radial offset, in pixels, of the text from the
        origin determined by the ``x`` and ``y`` properties.

        **Default value:** ``min(plot_width, plot_height)/2``
    radius2 : dict, float, :class:`ExprRef`
        The secondary (inner) radius in pixels of arc marks.

        **Default value:** ``0``
    radius2Offset : dict, float, :class:`ExprRef`
        Offset for radius2.
    radiusOffset : dict, float, :class:`ExprRef`
        Offset for radius.
    shape : str, dict, :class:`ExprRef`, :class:`SymbolShape`
        Shape of the point marks. Supported values include:

        * plotting shapes: ``"circle"``, ``"square"``, ``"cross"``, ``"diamond"``,
          ``"triangle-up"``, ``"triangle-down"``, ``"triangle-right"``, or
          ``"triangle-left"``.
        * the line symbol ``"stroke"``
        * centered directional shapes ``"arrow"``, ``"wedge"``, or ``"triangle"``
        * a custom `SVG path string
          <https://developer.mozilla.org/en-US/docs/Web/SVG/Tutorial/Paths>`__ (For correct
          sizing, custom shape paths should be defined within a square bounding box with
          coordinates ranging from -1 to 1 along both the x and y dimensions.)

        **Default value:** ``"circle"``
    size : dict, float, :class:`ExprRef`
        Default size for marks.

        * For ``point``/``circle``/``square``, this represents the pixel area of the marks.
          Note that this value sets the area of the symbol; the side lengths will increase
          with the square root of this value.
        * For ``bar``, this represents the band size of the bar, in pixels.
        * For ``text``, this represents the font size, in pixels.

        **Default value:**

        * ``30`` for point, circle, square marks; width/height's ``step``
        * ``2`` for bar marks with discrete dimensions;
        * ``5`` for bar marks with continuous dimensions;
        * ``11`` for text marks.
    smooth : bool, dict, :class:`ExprRef`
        A boolean flag (default true) indicating if the image should be smoothed when
        resized. If false, individual pixels should be scaled directly rather than
        interpolated with smoothing. For SVG rendering, this option may not work in some
        browsers due to lack of standardization.
    stroke : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple'], None
        Default stroke color. This property has higher precedence than ``config.color``. Set
        to ``null`` to remove stroke.

        **Default value:** (None)
    strokeCap : dict, :class:`ExprRef`, :class:`StrokeCap`, Literal['butt', 'round', 'square']
        The stroke cap for line ending style. One of ``"butt"``, ``"round"``, or
        ``"square"``.

        **Default value:** ``"butt"``
    strokeDash : dict, Sequence[float], :class:`ExprRef`
        An array of alternating stroke, space lengths for creating dashed or dotted lines.
    strokeDashOffset : dict, float, :class:`ExprRef`
        The offset (in pixels) into which to begin drawing with the stroke dash array.
    strokeJoin : dict, :class:`ExprRef`, :class:`StrokeJoin`, Literal['miter', 'round', 'bevel']
        The stroke line join method. One of ``"miter"``, ``"round"`` or ``"bevel"``.

        **Default value:** ``"miter"``
    strokeMiterLimit : dict, float, :class:`ExprRef`
        The miter limit at which to bevel a line join.
    strokeOffset : dict, float, :class:`ExprRef`
        The offset in pixels at which to draw the group stroke and fill. If unspecified, the
        default behavior is to dynamically offset stroked groups such that 1 pixel stroke
        widths align with the pixel grid.
    strokeOpacity : dict, float, :class:`ExprRef`
        The stroke opacity (value between [0,1]).

        **Default value:** ``1``
    strokeWidth : dict, float, :class:`ExprRef`
        The stroke width, in pixels.
    style : str, Sequence[str]
        A string or array of strings indicating the name of custom styles to apply to the
        mark. A style is a named collection of mark property defaults defined within the
        `style configuration
        <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__. If style is an
        array, later styles will override earlier styles. Any `mark properties
        <https://vega.github.io/vega-lite/docs/encoding.html#mark-prop>`__ explicitly
        defined within the ``encoding`` will override a style default.

        **Default value:** The mark's name. For example, a bar mark will have style
        ``"bar"`` by default. **Note:** Any specified style will augment the default style.
        For example, a bar mark with ``"style": "foo"`` will receive from
        ``config.style.bar`` and ``config.style.foo`` (the specified style ``"foo"`` has
        higher precedence).
    tension : dict, float, :class:`ExprRef`
        Depending on the interpolation type, sets the tension parameter (for line and area
        marks).
    text : str, dict, :class:`Text`, Sequence[str], :class:`ExprRef`
        Placeholder text if the ``text`` channel is not specified
    theta : dict, float, :class:`ExprRef`
        * For arc marks, the arc length in radians if theta2 is not specified, otherwise the
          start arc angle. (A value of 0 indicates up or “north”, increasing values proceed
          clockwise.)

        * For text marks, polar coordinate angle in radians.
    theta2 : dict, float, :class:`ExprRef`
        The end angle of arc marks in radians. A value of 0 indicates up or “north”,
        increasing values proceed clockwise.
    theta2Offset : dict, float, :class:`ExprRef`
        Offset for theta2.
    thetaOffset : dict, float, :class:`ExprRef`
        Offset for theta.
    thickness : float
        Thickness of the tick mark.

        **Default value:**  ``1``
    timeUnitBandPosition : float
        Default relative band position for a time unit. If set to ``0``, the marks will be
        positioned at the beginning of the time unit band step. If set to ``0.5``, the marks
        will be positioned in the middle of the time unit band step.
    timeUnitBandSize : float
        Default relative band size for a time unit. If set to ``1``, the bandwidth of the
        marks will be equal to the time unit band step. If set to ``0.5``, bandwidth of the
        marks will be half of the time unit band step.
    tooltip : str, bool, dict, float, :class:`ExprRef`, :class:`TooltipContent`, None
        The tooltip text string to show upon mouse hover or an object defining which fields
        should the tooltip be derived from.

        * If ``tooltip`` is ``true`` or ``{"content": "encoding"}``, then all fields from
          ``encoding`` will be used.
        * If ``tooltip`` is ``{"content": "data"}``, then all fields that appear in the
          highlighted data point will be used.
        * If set to ``null`` or ``false``, then no tooltip will be used.

        See the `tooltip <https://vega.github.io/vega-lite/docs/tooltip.html>`__
        documentation for a detailed discussion about tooltip  in Vega-Lite.

        **Default value:** ``null``
    url : str, dict, :class:`URI`, :class:`ExprRef`
        The URL of the image file for image marks.
    width : dict, float, :class:`ExprRef`, :class:`RelativeBandSize`
        Width of the marks.  One of:

        * A number representing a fixed pixel width.

        * A relative band size definition.  For example, ``{band: 0.5}`` represents half of
          the band.
    x : dict, float, :class:`ExprRef`, Literal['width']
        X coordinates of the marks, or width of horizontal ``"bar"`` and ``"area"`` without
        specified ``x2`` or ``width``.

        The ``value`` of this channel can be a number or a string ``"width"`` for the width
        of the plot.
    x2 : dict, float, :class:`ExprRef`, Literal['width']
        X2 coordinates for ranged ``"area"``, ``"bar"``, ``"rect"``, and  ``"rule"``.

        The ``value`` of this channel can be a number or a string ``"width"`` for the width
        of the plot.
    x2Offset : dict, float, :class:`ExprRef`
        Offset for x2-position.
    xOffset : dict, float, :class:`ExprRef`
        Offset for x-position.
    y : dict, float, :class:`ExprRef`, Literal['height']
        Y coordinates of the marks, or height of vertical ``"bar"`` and ``"area"`` without
        specified ``y2`` or ``height``.

        The ``value`` of this channel can be a number or a string ``"height"`` for the
        height of the plot.
    y2 : dict, float, :class:`ExprRef`, Literal['height']
        Y2 coordinates for ranged ``"area"``, ``"bar"``, ``"rect"``, and  ``"rule"``.

        The ``value`` of this channel can be a number or a string ``"height"`` for the
        height of the plot.
    y2Offset : dict, float, :class:`ExprRef`
        Offset for y2-position.
    yOffset : dict, float, :class:`ExprRef`
        Offset for y-position.
    $refz#/definitions/MarkDefcW                (   t        X|   dWi d|d|d|d|d|d|d|d|d	|	d
|
d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d|d | d!|!d"|"d#|#d$|$d%|%d&|&d'|'d(|(d)|)d*|*d+|+d,|,d-|-d.|.d/|/d0|0d1|1d2|2d3|3d4|4d5|5d6|6d7|7d8|8d9|9d:|:d;|;d<|<d=|=d>|>d?|?d@@dAAdBBdCCdDDdEEdFFdGGdHHdIIdJJdKKdLLdMMdNNdOOdPPdQQdRRdSSdTTdUUdVVW y )XNalignangleariaariaRoleariaRoleDescriptionaspectbandSizebaseline
binSpacingblendclipcolorcontinuousBandSizecornerRadiuscornerRadiusBottomLeftcornerRadiusBottomRightcornerRadiusEndcornerRadiusTopLeftcornerRadiusTopRightcursordescriptiondirdiscreteBandSizedxdyellipsisfillfillOpacityfilledfontfontSize	fontStyle
fontWeightheighthrefinnerRadiusinterpolateinvalidlimitline	lineBreak
lineHeightminBandSizeopacityorderorientouterRadiuspadAnglepointradiusradius2radius2OffsetradiusOffsetshapesizesmoothstroke	strokeCap
strokeDashstrokeDashOffset
strokeJoinstrokeMiterLimitstrokeOffsetstrokeOpacitystrokeWidthstyletensiontextthetatheta2theta2OffsetthetaOffset	thicknesstimeUnitBandPositiontimeUnitBandSizetooltipurlwidthxx2x2OffsetxOffsetyy2y2OffsetyOffset super__init__)Yselfr   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r0   r1   r2   r3   r4   r5   r6   r7   r8   r9   r:   r;   r<   r=   r>   r?   r@   rA   rB   rC   rD   rE   rF   rG   rH   rI   rJ   rK   rL   rM   rN   rO   rP   rQ   rR   rS   rT   rU   rV   rW   rX   rY   rZ   r[   r\   r]   r^   r_   r`   ra   rb   rc   rd   re   rf   rg   rh   ri   rj   rk   rl   kwds	__class__sY                                                                                           U/var/www/openai/venv/lib/python3.12/site-packages/altair/vegalite/v5/schema/mixins.pyrp   z_MarkDef.__init__  s3   ` 	 X	
X	
X	
 X	
 	X	

 !4X	
 X	
 X	
 X	
 "X	
 X	
 X	
 X	
  2X	
 &X	
 $:X	
  %<!X	
" ,#X	
$ !4%X	
& "6'X	
( )X	
* $+X	
, -X	
. ./X	
0 1X	
2 3X	
4 5X	
6 7X	
8 $9X	
: ;X	
< =X	
> ?X	
@  AX	
B "CX	
D EX	
F GX	
H $IX	
J $KX	
L MX	
N OX	
P QX	
R  SX	
T "UX	
V $WX	
X YX	
Z [X	
\ ]X	
^ $_X	
` aX	
b cX	
d eX	
f gX	
h (iX	
j &kX	
l mX	
n oX	
p qX	
r sX	
t  uX	
v "wX	
x .yX	
z "{X	
| .}X	
~ &X	
@ (AX	
B $CX	
D EX	
F GX	
H IX	
J KX	
L MX	
N &OX	
P $QX	
R  SX	
T "6UX	
V .WX	
X YX	
Z [X	
\ ]X	
^ _X	
` aX	
b cX	
d eX	
f gX	
h iX	
j kX	
l oX	
    )r   z0Optional[Parameter | SchemaBase | Map | Align_T]r   .Optional[float | Parameter | SchemaBase | Map]r   -Optional[bool | Parameter | SchemaBase | Map]r   ,Optional[str | Parameter | SchemaBase | Map]r   rx   r   rw   r   Optional[float]r   z7Optional[Parameter | SchemaBase | Map | TextBaseline_T]r   ry   r    z0Optional[Parameter | SchemaBase | Map | Blend_T]r!   rw   r"   :Optional[str | Parameter | SchemaBase | Map | ColorName_T]r#   ry   r$   rv   r%   rv   r&   rv   r'   rv   r(   rv   r)   rv   r*   z1Optional[Parameter | SchemaBase | Map | Cursor_T]r+   rx   r,   z8Optional[Parameter | SchemaBase | Map | TextDirection_T]r-   z"Optional[float | SchemaBase | Map]r.   rv   r/   rv   r0   rx   r1   AOptional[str | Parameter | SchemaBase | Map | ColorName_T | None]r2   rv   r3   Optional[bool]r4   rx   r5   rv   r6   rx   r7   z5Optional[Parameter | SchemaBase | Map | FontWeight_T]r8   rv   r9   rx   r:   rv   r;   z6Optional[Parameter | SchemaBase | Map | Interpolate_T]r<   3Optional[SchemaBase | MarkInvalidDataMode_T | None]r=   rv   r>   !Optional[bool | SchemaBase | Map]r?   rx   r@   rv   rA   rv   rB   rv   rC   zOptional[bool | None]rD   $Optional[SchemaBase | Orientation_T]rE   rv   rF   rv   rG   z:Optional[bool | SchemaBase | Literal['transparent'] | Map]rH   rv   rI   rv   rJ   rv   rK   rv   rL   rx   rM   rv   rN   rw   rO   r{   rP   z4Optional[Parameter | SchemaBase | Map | StrokeCap_T]rQ   z8Optional[Parameter | SchemaBase | Sequence[float] | Map]rR   rv   rS   z5Optional[Parameter | SchemaBase | Map | StrokeJoin_T]rT   rv   rU   rv   rV   rv   rW   rv   rX   zOptional[str | Sequence[str]]rY   rv   rZ   z<Optional[str | Parameter | SchemaBase | Sequence[str] | Map]r[   rv   r\   rv   r]   rv   r^   rv   r_   ry   r`   ry   ra   ry   rb   zBOptional[str | bool | float | Parameter | SchemaBase | Map | None]rc   rx   rd   rv   re   AOptional[float | Parameter | SchemaBase | Literal['width'] | Map]rf   r   rg   rv   rh   rv   ri   BOptional[float | Parameter | SchemaBase | Literal['height'] | Map]rj   r   rk   rv   rl   rv   __name__
__module____qualname____doc___schemar   rp   __classcell__rs   s   @rt   r   r      s   M^ ./G CL@I>GAJLU@I$-LU&/BK>GLU.7GP  JSNW DMDMHQ?H=F=FAJ FO!*=FCLBKLUAJ=FFONWGP@I2;BKENFOBK'07@FOCLLUAJBKHQGP>G?H@I JS KTLUKTGPHQFO/8BKMV@IAJGPFO%.09,5 <E@I  CLBK  CLBK[H
?H
 >H
 <	H

 ?H
 JH
 >H
 "H
 JH
 $H
 @H
 <H
 JH
 ,H
 EH
 !
!H
&"
'H
, H-H
. L/H
0
1H
6 B7H
8 B9H
: F;H
< ==H
> ;?H
@ ;AH
B ?CH
D
EH
J DKH
L MH
N ;OH
P AQH
R @SH
T JUH
V ?WH
X ;YH
Z D[H
\ L]H
^ E_H
` >aH
b 0cH
d @eH
f CgH
h DiH
j @kH
l %mH
n 5oH
p DqH
r AsH
t JuH
v ?wH
x @yH
z F{H
| E}H
~ <H
@ =AH
B >CH
D
EH
J HKH
L
MH
R ISH
T JUH
V IWH
X EYH
Z F[H
\ D]H
^ -_H
` @aH
b KcH
d >eH
f ?gH
h EiH
j DkH
l #mH
n .oH
p *qH
r
sH
x :yH
z >{H
|
}H
B
CH
H AIH
J @KH
L
MH
R
SH
X AYH
Z @[H
 H
ru   r   c                  t     e Zd ZdZddiZeeeeeeeeeeeef	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d fdZ xZS )_BoxPlotDefuV  
    BoxPlotDef schema wrapper.

    Parameters
    ----------
    box : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    clip : bool
        Whether a composite mark be clipped to the enclosing group's width and height.
    color : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple']
        Default color.

        **Default value:**  :raw-html:`<span style="color: #4682b4;">` ■ :raw-html:`</span>`
        ``"#4682b4"``

        **Note:**

        * This property cannot be used in a `style config
          <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__.
        * The ``fill`` and ``stroke`` properties have higher precedence than ``color`` and
          will override ``color``.
    extent : float, Literal['min-max']
        The extent of the whiskers. Available options include:

        * ``"min-max"``: min and max are the lower and upper whiskers respectively.
        * A number representing multiple of the interquartile range. This number will be
          multiplied by the IQR to determine whisker boundary, which spans from the smallest
          data to the largest data within the range *[Q1 - k * IQR, Q3 + k * IQR]* where
          *Q1* and *Q3* are the first and third quartiles while *IQR* is the interquartile
          range (*Q3-Q1*).

        **Default value:** ``1.5``.
    invalid : :class:`MarkInvalidDataMode`, Literal['filter', 'break-paths-filter-domains', 'break-paths-show-domains', 'break-paths-show-path-domains', 'show'], None
        Invalid data mode, which defines how the marks and corresponding scales should
        represent invalid values (``null`` and ``NaN`` in continuous scales *without*
        defined output for invalid values).

        * ``"filter"`` — *Exclude* all invalid values from the visualization's *marks* and
          *scales*. For path marks (for line, area, trail), this option will create paths
          that connect valid points, as if the data rows with invalid values do not exist.

        * ``"break-paths-filter-domains"`` — Break path marks (for line, area, trail) at
          invalid values.  For non-path marks, this is equivalent to ``"filter"``. All
          *scale* domains will *exclude* these filtered data points.

        * ``"break-paths-show-domains"`` — Break paths (for line, area, trail) at invalid
          values.  Hide invalid values for non-path marks. All *scale* domains will
          *include* these filtered data points (for both path and non-path marks).

        * ``"show"`` or ``null`` — Show all data points in the marks and scale domains. Each
          scale will use the output for invalid values defined in ``config.scale.invalid``
          or, if unspecified, by default invalid values will produce the same visual values
          as zero (if the scale includes zero) or the minimum value (if the scale does not
          include zero).

        * ``"break-paths-show-path-domains"`` (default) — This is equivalent to
          ``"break-paths-show-domains"`` for path-based marks (line/area/trail) and
          ``"filter"`` for non-path marks.

        **Note**: If any channel's scale has an output for invalid values defined in
        ``config.scale.invalid``, all values for the scales will be considered "valid" since
        they can produce a reasonable output for the scales. Thus, fields for such channels
        will not be filtered and will not cause path breaks.
    median : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    opacity : float
        The opacity (value between [0,1]) of the mark.
    orient : :class:`Orientation`, Literal['horizontal', 'vertical']
        Orientation of the box plot. This is normally automatically determined based on
        types of fields on x and y channels. However, an explicit ``orient`` be specified
        when the orientation is ambiguous.

        **Default value:** ``"vertical"``.
    outliers : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    rule : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    size : float
        Size of the box and median tick of a box plot
    ticks : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    r   z#/definitions/BoxPlotDefc                >    t        |   d|||||||||	|
||d| y )N)boxr!   r"   extentr<   medianrB   rD   outliersrulerM   ticksrm   rn   )rq   r   r!   r"   r   r<   r   rB   rD   r   r   rM   r   rr   rs   s                 rt   rp   z_BoxPlotDef.__init__  sE      	 	
	
 	
ru   )r   r~   r!   r|   r"   rz   r   z$Optional[float | Literal['min-max']]r<   r}   r   r~   rB   ry   rD   r   r   r~   r   r~   rM   ry   r   r~   r   r   s   @rt   r   r     s    Qf 12G 2;(LU7@GP4=#,7@6?2; )3<
.
 
 J	

 5
 E
 2
 !
 5
 4
 0
 
 1
 
ru   r   c            	      b     e Zd ZdZddiZeeeeeeeeef		 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d fdZ xZS )_ErrorBarDefu  
    ErrorBarDef schema wrapper.

    Parameters
    ----------
    clip : bool
        Whether a composite mark be clipped to the enclosing group's width and height.
    color : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple']
        Default color.

        **Default value:**  :raw-html:`<span style="color: #4682b4;">` ■ :raw-html:`</span>`
        ``"#4682b4"``

        **Note:**

        * This property cannot be used in a `style config
          <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__.
        * The ``fill`` and ``stroke`` properties have higher precedence than ``color`` and
          will override ``color``.
    extent : :class:`ErrorBarExtent`, Literal['ci', 'iqr', 'stderr', 'stdev']
        The extent of the rule. Available options include:

        * ``"ci"``: Extend the rule to the confidence interval of the mean.
        * ``"stderr"``: The size of rule are set to the value of standard error, extending
          from the mean.
        * ``"stdev"``: The size of rule are set to the value of standard deviation,
          extending from the mean.
        * ``"iqr"``: Extend the rule to the q1 and q3.

        **Default value:** ``"stderr"``.
    opacity : float
        The opacity (value between [0,1]) of the mark.
    orient : :class:`Orientation`, Literal['horizontal', 'vertical']
        Orientation of the error bar. This is normally automatically determined, but can be
        specified when the orientation is ambiguous and cannot be automatically determined.
    rule : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    size : float
        Size of the ticks of an error bar
    thickness : float
        Thickness of the ticks and the bar of an error bar
    ticks : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    r   z#/definitions/ErrorBarDefc
                8    t        |   d|||||||||	d	|
 y )N)	r!   r"   r   rB   rD   r   rM   r_   r   rm   rn   )rq   r!   r"   r   rB   rD   r   rM   r_   r   rr   rs   s              rt   rp   z_ErrorBarDef.__init__a  s<     	 	
	
 	
ru   )r!   r|   r"   rz   r   'Optional[SchemaBase | ErrorBarExtent_T]rB   ry   rD   r   r   r~   rM   ry   r_   ry   r   r~   r   r   s   @rt   r   r   1  s    +Z 23G  )LU:C#,7@2; )%.3<

 J
 8	

 !
 5
 0
 
 #
 1
 
ru   r   c            	      b     e Zd ZdZddiZeeeeeeeeef		 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d fdZ xZS )_ErrorBandDefu  
    ErrorBandDef schema wrapper.

    Parameters
    ----------
    band : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    borders : bool, dict, :class:`BarConfig`, :class:`AreaConfig`, :class:`LineConfig`, :class:`MarkConfig`, :class:`RectConfig`, :class:`TickConfig`, :class:`AnyMarkConfig`

    clip : bool
        Whether a composite mark be clipped to the enclosing group's width and height.
    color : str, dict, :class:`Color`, :class:`ExprRef`, :class:`Gradient`, :class:`HexColor`, :class:`ColorName`, :class:`LinearGradient`, :class:`RadialGradient`, Literal['black', 'silver', 'gray', 'white', 'maroon', 'red', 'purple', 'fuchsia', 'green', 'lime', 'olive', 'yellow', 'navy', 'blue', 'teal', 'aqua', 'orange', 'aliceblue', 'antiquewhite', 'aquamarine', 'azure', 'beige', 'bisque', 'blanchedalmond', 'blueviolet', 'brown', 'burlywood', 'cadetblue', 'chartreuse', 'chocolate', 'coral', 'cornflowerblue', 'cornsilk', 'crimson', 'cyan', 'darkblue', 'darkcyan', 'darkgoldenrod', 'darkgray', 'darkgreen', 'darkgrey', 'darkkhaki', 'darkmagenta', 'darkolivegreen', 'darkorange', 'darkorchid', 'darkred', 'darksalmon', 'darkseagreen', 'darkslateblue', 'darkslategray', 'darkslategrey', 'darkturquoise', 'darkviolet', 'deeppink', 'deepskyblue', 'dimgray', 'dimgrey', 'dodgerblue', 'firebrick', 'floralwhite', 'forestgreen', 'gainsboro', 'ghostwhite', 'gold', 'goldenrod', 'greenyellow', 'grey', 'honeydew', 'hotpink', 'indianred', 'indigo', 'ivory', 'khaki', 'lavender', 'lavenderblush', 'lawngreen', 'lemonchiffon', 'lightblue', 'lightcoral', 'lightcyan', 'lightgoldenrodyellow', 'lightgray', 'lightgreen', 'lightgrey', 'lightpink', 'lightsalmon', 'lightseagreen', 'lightskyblue', 'lightslategray', 'lightslategrey', 'lightsteelblue', 'lightyellow', 'limegreen', 'linen', 'magenta', 'mediumaquamarine', 'mediumblue', 'mediumorchid', 'mediumpurple', 'mediumseagreen', 'mediumslateblue', 'mediumspringgreen', 'mediumturquoise', 'mediumvioletred', 'midnightblue', 'mintcream', 'mistyrose', 'moccasin', 'navajowhite', 'oldlace', 'olivedrab', 'orangered', 'orchid', 'palegoldenrod', 'palegreen', 'paleturquoise', 'palevioletred', 'papayawhip', 'peachpuff', 'peru', 'pink', 'plum', 'powderblue', 'rosybrown', 'royalblue', 'saddlebrown', 'salmon', 'sandybrown', 'seagreen', 'seashell', 'sienna', 'skyblue', 'slateblue', 'slategray', 'slategrey', 'snow', 'springgreen', 'steelblue', 'tan', 'thistle', 'tomato', 'turquoise', 'violet', 'wheat', 'whitesmoke', 'yellowgreen', 'rebeccapurple']
        Default color.

        **Default value:**  :raw-html:`<span style="color: #4682b4;">` ■ :raw-html:`</span>`
        ``"#4682b4"``

        **Note:**

        * This property cannot be used in a `style config
          <https://vega.github.io/vega-lite/docs/mark.html#style-config>`__.
        * The ``fill`` and ``stroke`` properties have higher precedence than ``color`` and
          will override ``color``.
    extent : :class:`ErrorBarExtent`, Literal['ci', 'iqr', 'stderr', 'stdev']
        The extent of the band. Available options include:

        * ``"ci"``: Extend the band to the confidence interval of the mean.
        * ``"stderr"``: The size of band are set to the value of standard error, extending
          from the mean.
        * ``"stdev"``: The size of band are set to the value of standard deviation,
          extending from the mean.
        * ``"iqr"``: Extend the band to the q1 and q3.

        **Default value:** ``"stderr"``.
    interpolate : :class:`Interpolate`, Literal['basis', 'basis-open', 'basis-closed', 'bundle', 'cardinal', 'cardinal-open', 'cardinal-closed', 'catmull-rom', 'linear', 'linear-closed', 'monotone', 'natural', 'step', 'step-before', 'step-after']
        The line interpolation method for the error band. One of the following:

        * ``"linear"``: piecewise linear segments, as in a polyline.
        * ``"linear-closed"``: close the linear segments to form a polygon.
        * ``"step"``: a piecewise constant function (a step function) consisting of
          alternating horizontal and vertical lines. The y-value changes at the midpoint of
          each pair of adjacent x-values.
        * ``"step-before"``: a piecewise constant function (a step function) consisting of
          alternating horizontal and vertical lines. The y-value changes before the x-value.
        * ``"step-after"``: a piecewise constant function (a step function) consisting of
          alternating horizontal and vertical lines. The y-value changes after the x-value.
        * ``"basis"``: a B-spline, with control point duplication on the ends.
        * ``"basis-open"``: an open B-spline; may not intersect the start or end.
        * ``"basis-closed"``: a closed B-spline, as in a loop.
        * ``"cardinal"``: a Cardinal spline, with control point duplication on the ends.
        * ``"cardinal-open"``: an open Cardinal spline; may not intersect the start or end,
          but will intersect other control points.
        * ``"cardinal-closed"``: a closed Cardinal spline, as in a loop.
        * ``"bundle"``: equivalent to basis, except the tension parameter is used to
          straighten the spline.
        * ``"monotone"``: cubic interpolation that preserves monotonicity in y.
    opacity : float
        The opacity (value between [0,1]) of the mark.
    orient : :class:`Orientation`, Literal['horizontal', 'vertical']
        Orientation of the error band. This is normally automatically determined, but can be
        specified when the orientation is ambiguous and cannot be automatically determined.
    tension : float
        The tension parameter for the interpolation type of the error band.
    r   z#/definitions/ErrorBandDefc
                8    t        |   d|||||||||	d	|
 y )N)	bandbordersr!   r"   r   r;   rB   rD   rY   rm   rn   )rq   r   r   r!   r"   r   r;   rB   rD   rY   rr   rs   s              rt   rp   z_ErrorBandDef.__init__  s<     	 	
#	
 	
ru   )r   r~   r   r~   r!   r|   r"   rz   r   r   r;   z$Optional[SchemaBase | Interpolate_T]rB   ry   rD   r   rY   ry   r   r   s   @rt   r   r   |  s    ?B 34G 3<5>(LU:C<E#,7@#,
/
 3
 	

 J
 8
 :
 !
 5
 !
 
ru   r   c                     e Zd ZdZ ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Z	 ee      dd       Z
 ee      dd       Z ee      dd       Z ee      dd	       Z ee      dd
       Z ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Z ee      dd       Zy)MarkMethodMixinz(A mixin class that defines mark methods.c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z5Set the chart's mark to 'arc' (see :class:`MarkDef`).Fdeepc              3  ,   K   | ]  }|t         u  y wNr   .0vals     rt   	<genexpr>z+MarkMethodMixin.mark_arc.<locals>.<genexpr>       =}s)#}   typearcrm   copyanyvaluesr   MarkDefmarkrq   rr   r   s      rt   mark_arczMarkMethodMixin.mark_arc  U     yyey$=t{{}==8%848DI  DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'area' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_area.<locals>.<genexpr>  r   r   r   arearm   r   r   s      rt   	mark_areazMarkMethodMixin.mark_area  U     yyey$=t{{}==9&9D9DI  DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z5Set the chart's mark to 'bar' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z+MarkMethodMixin.mark_bar.<locals>.<genexpr>  r   r   r   barrm   r   r   s      rt   mark_barzMarkMethodMixin.mark_bar  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z7Set the chart's mark to 'image' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z-MarkMethodMixin.mark_image.<locals>.<genexpr>   r   r   r   imagerm   r   r   s      rt   
mark_imagezMarkMethodMixin.mark_image  U     yyey$=t{{}==:':T:DI   DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'line' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_line.<locals>.<genexpr>
  r   r   r   r>   rm   r   r   s      rt   	mark_linezMarkMethodMixin.mark_line  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z7Set the chart's mark to 'point' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z-MarkMethodMixin.mark_point.<locals>.<genexpr>  r   r   r   rG   rm   r   r   s      rt   
mark_pointzMarkMethodMixin.mark_point  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'rect' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_rect.<locals>.<genexpr>  r   r   r   rectrm   r   r   s      rt   	mark_rectzMarkMethodMixin.mark_rect  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'rule' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_rule.<locals>.<genexpr>(  r   r   r   r   rm   r   r   s      rt   	mark_rulezMarkMethodMixin.mark_rule$  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'text' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_text.<locals>.<genexpr>2  r   r   r   rZ   rm   r   r   s      rt   	mark_textzMarkMethodMixin.mark_text.  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z6Set the chart's mark to 'tick' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z,MarkMethodMixin.mark_tick.<locals>.<genexpr><  r   r   r   tickrm   r   r   s      rt   	mark_tickzMarkMethodMixin.mark_tick8  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z7Set the chart's mark to 'trail' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z-MarkMethodMixin.mark_trail.<locals>.<genexpr>F  r   r   r   trailrm   r   r   s      rt   
mark_trailzMarkMethodMixin.mark_trailB  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z8Set the chart's mark to 'circle' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z.MarkMethodMixin.mark_circle.<locals>.<genexpr>P  r   r   r   circlerm   r   r   s      rt   mark_circlezMarkMethodMixin.mark_circleL  U     yyey$=t{{}==;(;d;DI  !DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z8Set the chart's mark to 'square' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z.MarkMethodMixin.mark_square.<locals>.<genexpr>Z  r   r   r   squarerm   r   r   s      rt   mark_squarezMarkMethodMixin.mark_squareV  r   ru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z:Set the chart's mark to 'geoshape' (see :class:`MarkDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z0MarkMethodMixin.mark_geoshape.<locals>.<genexpr>d  r   r   r   geoshaperm   r   r   s      rt   mark_geoshapezMarkMethodMixin.mark_geoshape`  sU     yyey$=t{{}===*==DI  #DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z<Set the chart's mark to 'boxplot' (see :class:`BoxPlotDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z/MarkMethodMixin.mark_boxplot.<locals>.<genexpr>n  r   r   r   boxplotrm   )r   r   r   r   
BoxPlotDefr   r   s      rt   mark_boxplotzMarkMethodMixin.mark_boxplotj  sU     yyey$=t{{}==?Y?$?DI  "DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z>Set the chart's mark to 'errorbar' (see :class:`ErrorBarDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z0MarkMethodMixin.mark_errorbar.<locals>.<genexpr>x  r   r   r   errorbarrm   )r   r   r   r   ErrorBarDefr   r   s      rt   mark_errorbarzMarkMethodMixin.mark_errorbart  sW     yyey$=t{{}==((AjADADI  #DIru   c                    | j                  d      }t        d |j                         D              rt        j                  dddi||_        |S d|_        |S )z@Set the chart's mark to 'errorband' (see :class:`ErrorBandDef`).Fr   c              3  ,   K   | ]  }|t         u  y wr   r   r   s     rt   r   z1MarkMethodMixin.mark_errorband.<locals>.<genexpr>  r   r   r   	errorbandrm   )r   r   r   r   ErrorBandDefr   r   s      rt   mark_errorbandzMarkMethodMixin.mark_errorband~  sW     yyey$=t{{}==))C{CdCDI  $DIru   N)rr   r   returnr   )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   rm   ru   rt   r   r     s   28  8  8  8  8  8  8  8  8  8  8  8  8  8  ;   <  ! =! "ru   r   c                  
   e Zd ZdZ eej                        d:d       Z eej                        d:d       Z	 eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d	       Z eej                        d:d
       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z eej                        d:d       Z  eej                        d:d       Z! eej                        d:d       Z" eejF                        d:d       Z$ eejJ                        d:d       Z& eejN                        d:d       Z( eejR                        d:d       Z* eejV                        d:d       Z, eejZ                        d:d        Z. eejR                        d:d!       Z/ eejN                        d:d"       Z0 eejb                        d:d#       Z2 eejb                        d:d$       Z3 eejb                        d:d%       Z4 eejb                        d:d&       Z5 eej                        d:d'       Z6 eejn                        d:d(       Z8 eejr                        d:d)       Z: eejN                        d:d*       Z; eejN                        d:d+       Z< eejz                        d:d,       Z> eej~                        d:d-       Z@ eej                        d:d.       ZA eejN                        d:d/       ZB eej                        d:d0       ZD eej                        d:d1       ZF eejN                        d:d2       ZG eejN                        d:d3       ZH eej                        d:d4       ZJ eej                        d:d5       ZL eej                        d:d6       ZN eejr                        d:d7       ZO eej                        d:d8       ZQy9);ConfigMethodMixinz*A mixin class that defines config methods.c                ^    | j                  d      }t        j                  |i ||_        |S )NFr   )r   r   Configconfigrq   argskwargsr   s       rt   	configurezConfigMethodMixin.configure  s,    yyey$kk4262ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r   r   r   r   r   
RectConfigr   s       rt   configure_arczConfigMethodMixin.configure_arc  sN    yyxjy);;)#++-DK!__d=f=Eru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   
AreaConfigr   s       rt   configure_areaz ConfigMethodMixin.configure_area  N    yyxjy);;)#++-DK"oot>v>Fru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisr   r   r   r   r   
AxisConfigr   s       rt   configure_axisz ConfigMethodMixin.configure_axis  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisBandr  r   s       rt   configure_axisBandz$ConfigMethodMixin.configure_axisBand  N    yyxjy);;)#++-DK"&//4"B6"BJru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   
axisBottomr  r   s       rt   configure_axisBottomz&ConfigMethodMixin.configure_axisBottom  N    yyxjy);;)#++-DK$(OOT$DV$DL!ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisDiscreter  r   s       rt   configure_axisDiscretez(ConfigMethodMixin.configure_axisDiscrete  N    yyxjy);;)#++-DK&*oot&Fv&FN#ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisLeftr  r   s       rt   configure_axisLeftz$ConfigMethodMixin.configure_axisLeft  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	axisPointr  r   s       rt   configure_axisPointz%ConfigMethodMixin.configure_axisPoint  N    yyxjy);;)#++-DK#'??D#CF#CK ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisQuantitativer  r   s       rt   configure_axisQuantitativez,ConfigMethodMixin.configure_axisQuantitative  sO    yyxjy);;)#++-DK*.//4*J6*J&'ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	axisRightr  r   s       rt   configure_axisRightz%ConfigMethodMixin.configure_axisRight  r   ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisTemporalr  r   s       rt   configure_axisTemporalz(ConfigMethodMixin.configure_axisTemporal  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisTopr  r   s       rt   configure_axisTopz#ConfigMethodMixin.configure_axisTop  sN    yyxjy);;)#++-DK!%$!A&!AIru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisXr  r   s       rt   configure_axisXz!ConfigMethodMixin.configure_axisX  N    yyxjy);;)#++-DK#??Gru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	axisXBandr  r   s       rt   configure_axisXBandz%ConfigMethodMixin.configure_axisXBand  r   ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisXDiscreter  r   s       rt   configure_axisXDiscretez)ConfigMethodMixin.configure_axisXDiscrete  N    yyxjy);;)#++-DK'+'G'GO$ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   
axisXPointr  r   s       rt   configure_axisXPointz&ConfigMethodMixin.configure_axisXPoint
  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisXQuantitativer  r   s       rt   configure_axisXQuantitativez-ConfigMethodMixin.configure_axisXQuantitative  O    yyxjy);;)#++-DK+/??D+KF+K'(ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisXTemporalr  r   s       rt   configure_axisXTemporalz)ConfigMethodMixin.configure_axisXTemporal  r7  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisYr  r   s       rt   configure_axisYz!ConfigMethodMixin.configure_axisY"  r0  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	axisYBandr  r   s       rt   configure_axisYBandz%ConfigMethodMixin.configure_axisYBand*  r   ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisYDiscreter  r   s       rt   configure_axisYDiscretez)ConfigMethodMixin.configure_axisYDiscrete2  r7  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   
axisYPointr  r   s       rt   configure_axisYPointz&ConfigMethodMixin.configure_axisYPoint:  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisYQuantitativer  r   s       rt   configure_axisYQuantitativez-ConfigMethodMixin.configure_axisYQuantitativeB  r>  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   axisYTemporalr  r   s       rt   configure_axisYTemporalz)ConfigMethodMixin.configure_axisYTemporalJ  r7  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   	BarConfigr   s       rt   configure_barzConfigMethodMixin.configure_barR  sN    yyxjy);;)#++-DK!^^T<V<Eru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   BoxPlotConfigr   s       rt   configure_boxplotz#ConfigMethodMixin.configure_boxplotZ  sP    yyxjy);;)#++-DK!%!3!3T!DV!DIru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r   r   r   r   r   
MarkConfigr   s       rt   configure_circlez"ConfigMethodMixin.configure_circleb  N    yyxjy);;)#++-DK $ @ @Hru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   concatr   r   r   r   r   CompositionConfigr   s       rt   configure_concatz"ConfigMethodMixin.configure_concatj  sP    yyxjy);;)#++-DK $ 6 6 G GHru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   ErrorBandConfigr   s       rt   configure_errorbandz%ConfigMethodMixin.configure_errorbandr  P    yyxjy);;)#++-DK#'#7#7#H#HK ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   ErrorBarConfigr   s       rt   configure_errorbarz$ConfigMethodMixin.configure_errorbarz  sP    yyxjy);;)#++-DK"&"5"5t"Fv"FJru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   facetra  r   s       rt   configure_facetz!ConfigMethodMixin.configure_facet  sP    yyxjy);;)#++-DK#55tFvFGru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r[  r   s       rt   configure_geoshapez$ConfigMethodMixin.configure_geoshape  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   headerr   r   r   r   r   HeaderConfigr   s       rt   configure_headerz"ConfigMethodMixin.configure_header  P    yyxjy);;)#++-DK $ 1 14 B6 BHru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   headerColumnrr  r   s       rt   configure_headerColumnz(ConfigMethodMixin.configure_headerColumn  sP    yyxjy);;)#++-DK&*&7&7&H&HN#ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   headerFacetrr  r   s       rt   configure_headerFacetz'ConfigMethodMixin.configure_headerFacet  sP    yyxjy);;)#++-DK%)%6%6%G%GM"ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	headerRowrr  r   s       rt   configure_headerRowz%ConfigMethodMixin.configure_headerRow  sP    yyxjy);;)#++-DK#'#4#4d#Ef#EK ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r  r   s       rt   configure_imagez!ConfigMethodMixin.configure_image  r0  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   legend)r   r   r   r   r   LegendConfigr   s       rt   configure_legendz"ConfigMethodMixin.configure_legend  ru  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r>   r   r   r   r   r   
LineConfigr   s       rt   configure_linez ConfigMethodMixin.configure_line  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r[  r   s       rt   configure_markz ConfigMethodMixin.configure_mark  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   rG   r[  r   s       rt   configure_pointz!ConfigMethodMixin.configure_point  r0  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   
projection)r   r   r   r   r   ProjectionConfigr   s       rt   configure_projectionz&ConfigMethodMixin.configure_projection  sP    yyxjy);;)#++-DK$($9$94$J6$JL!ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   range)r   r   r   r   r   RangeConfigr   s       rt   configure_rangez!ConfigMethodMixin.configure_range  P    yyxjy);;)#++-DK#//@@Gru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r  r   s       rt   configure_rectz ConfigMethodMixin.configure_rect  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r[  r   s       rt   configure_rulez ConfigMethodMixin.configure_rule  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   scale)r   r   r   r   r   ScaleConfigr   s       rt   configure_scalez!ConfigMethodMixin.configure_scale  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   	selection)r   r   r   r   r   SelectionConfigr   s       rt   configure_selectionz%ConfigMethodMixin.configure_selection  rg  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r[  r   s       rt   configure_squarez"ConfigMethodMixin.configure_square
  r^  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   rZ   r[  r   s       rt   configure_textz ConfigMethodMixin.configure_text  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   )r   r   r   r   r   
TickConfigr   s       rt   configure_tickz ConfigMethodMixin.configure_tick  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   title)r   r   r   r   r   TitleConfigr   s       rt   configure_titlez!ConfigMethodMixin.configure_title"  r  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   tooltipFormat)r   r   r   r   r   FormatConfigr   s       rt   configure_tooltipFormatz)ConfigMethodMixin.configure_tooltipFormat*  sP    yyxjy);;)#++-DK'+'8'8$'I&'IO$ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   r   r  r   s       rt   configure_trailz!ConfigMethodMixin.configure_trail2  r0  ru   c                    | j                  dg      }|j                  t        u rt        j                         |_        t        j
                  |i ||j                  d<   |S )Nr   r   view)r   r   r   r   r   
ViewConfigr   s       rt   configure_viewz ConfigMethodMixin.configure_view:  r  ru   N)r   r   )Rr   r   r   r   r	   r   r   r   r  r  r  r  r  r  r  r  r  r  r  r#  r&  r)  r,  r/  r3  r6  r:  r=  rA  rD  rG  rJ  rM  rP  rS  rU  rV  rX  rY  r\  r]  rb  rc  re  rf  ri  rj  rm  ro  rs  rt  rx  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  rm   ru   rt   r   r     s^   44;;  
 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4??# $ 4>>" # 4%%& ' 4??# $ 4))* + 4''( ) 4&&' ( 4))* + 4??# $ 4$$% & 4$$% & 4$$% & 4$$% & 4??# $ 4$$% & 4??# $ 4??# $ 4??# $ 4(() * 4##$ % 4??# $ 4??# $ 4##$ % 4''( ) 4??# $ 4??# $ 4??# $ 4##$ % 4$$% & 4??# $ 4??# $ru   r   )
__future__r   typingr   r   r   altair.utilsr   r   r	    r   collections.abcr   sysversion_infor   typing_extensionsaltairr   altair.typingr   _typingr   r   r   r   r   r   rm   ru   rt   <module>r     s    # . . = = (
7"* &Z

z Z

zt
* t
nH
: H
V\
J \
~k k\w wru   