All Downloads are FREE. Search and download functionalities are using the official Maven repository.

web-interface.assets.0c1a66a2-34.1ec71fc30880f2142b45.js.map Maven / Gradle / Ivy

There is a newer version: 6.0.5
Show newest version
{"version":3,"sources":["webpack:///./node_modules/plotly.js/src/components/errorbars/style.js","webpack:///./node_modules/plotly.js/src/components/drawing/index.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/layout_defaults.js","webpack:///./node_modules/plotly.js/src/lib/nested_property.js","webpack:///./node_modules/plotly.js/src/traces/pie/base_plot.js","webpack:///./node_modules/plotly.js/src/snapshot/helpers.js","webpack:///./node_modules/plotly.js/src/traces/scatter/text_defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/tick_value_defaults.js","webpack:///./node_modules/plotly.js/src/lib/clear_responsive.js","webpack:///./node_modules/plotly.js/src/components/color/index.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/defaults.js","webpack:///./node_modules/plotly.js/src/plot_api/container_array_match.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/draw.js","webpack:///./node_modules/plotly.js/src/lib/index.js","webpack:///./node_modules/plotly.js/src/lib/mod.js","webpack:///./node_modules/plotly.js/src/traces/scatter/xy_defaults.js","webpack:///./node_modules/plotly.js/src/fonts/mathjax_config.js","webpack:///./node_modules/plotly.js/src/lib/stats.js","webpack:///./node_modules/plotly.js/src/snapshot/filesaver.js","webpack:///./node_modules/plotly.js/src/components/annotations/draw.js","webpack:///./node_modules/plotly.js/src/components/legend/draw.js","webpack:///./node_modules/plotly.js/src/traces/histogram/bin_label_vals.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/category_order_defaults.js","webpack:///./node_modules/plotly.js/src/traces/scatter/line_shape_defaults.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/attributes.js","webpack:///./node_modules/plotly.js/src/plots/pad_attributes.js","webpack:///./node_modules/plotly.js/build/plotcss.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/attributes.js","webpack:///./node_modules/plotly.js/src/components/legend/style.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/index.js","webpack:///./node_modules/plotly.js/src/constants/numerical.js","webpack:///./node_modules/plotly.js/src/components/fx/hovermode_defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/axes.js","webpack:///./node_modules/plotly.js/src/components/sliders/index.js","webpack:///./node_modules/plotly.js/src/traces/pie/style_one.js","webpack:///./node_modules/plotly.js/src/components/annotations3d/index.js","webpack:///./node_modules/plotly.js/src/lib/anchor_utils.js","webpack:///./node_modules/plotly.js/src/traces/bar/uniform_text.js","webpack:///./node_modules/plotly.js/src/components/colorbar/defaults.js","webpack:///./node_modules/plotly.js/src/lib/dom.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/find_empties.js","webpack:///./node_modules/plotly.js/src/lib/events.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/index.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/constraints.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/micropolar_manager.js","webpack:///./node_modules/plotly.js/src/components/images/defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/dragbox.js","webpack:///./node_modules/plotly.js/src/lib/svg_text_utils.js","webpack:///./node_modules/has-hover/index.js","webpack:///./node_modules/plotly.js/src/plots/plots.js","webpack:///./node_modules/plotly.js/src/traces/histogram/average.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/index.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/style_defaults.js","webpack:///./node_modules/plotly.js/src/lib/throttle.js","webpack:///./node_modules/plotly.js/src/components/fx/index.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/index.js","webpack:///./node_modules/plotly.js/src/components/sliders/defaults.js","webpack:///./node_modules/plotly.js/src/components/modebar/manage.js","webpack:///./node_modules/plotly.js/src/plot_api/plot_template.js","webpack:///./node_modules/plotly.js/src/components/fx/defaults.js","webpack:///./node_modules/plotly.js/src/traces/scatter/calc_selection.js","webpack:///./node_modules/plotly.js/src/components/errorbars/calc.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/style.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/attributes.js","webpack:///./node_modules/plotly.js/src/components/annotations/calc_autorange.js","webpack:///./node_modules/plotly.js/src/components/fx/attributes.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/micropolar.js","webpack:///./node_modules/events/events.js","webpack:///./node_modules/plotly.js/src/components/colorscale/scales.js","webpack:///./node_modules/plotly.js/src/lib/relink_private.js","webpack:///./node_modules/polybooljs/lib/segment-selector.js","webpack:///./node_modules/plotly.js/src/components/grid/index.js","webpack:///./node_modules/is-string-blank/index.js","webpack:///./node_modules/plotly.js/src/traces/scatter/hover.js","webpack:///./node_modules/plotly.js/src/traces/scatter/style.js","webpack:///./node_modules/plotly.js/src/traces/bar/plot.js","webpack:///./node_modules/plotly.js/src/components/fx/hover.js","webpack:///./node_modules/plotly.js/src/traces/histogram/norm_functions.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/constants.js","webpack:///./node_modules/plotly.js/src/components/shapes/helpers.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/clean_ticks.js","webpack:///./node_modules/plotly.js/src/components/modebar/index.js","webpack:///./node_modules/plotly.js/src/components/fx/helpers.js","webpack:///./node_modules/plotly.js/src/traces/scatter/stack_defaults.js","webpack:///./node_modules/plotly.js/src/traces/scatter/subtypes.js","webpack:///./node_modules/plotly.js/src/plots/attributes.js","webpack:///./node_modules/plotly.js/src/lib/override_cursor.js","webpack:///./node_modules/plotly.js/src/snapshot/download.js","webpack:///./node_modules/plotly.js/src/components/fx/hoverlabel_defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/graph_interact.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/plot.js","webpack:///./node_modules/plotly.js/src/traces/pie/attributes.js","webpack:///./node_modules/plotly.js/src/components/sliders/constants.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/defaults.js","webpack:///./node_modules/plotly.js/src/plots/animation_attributes.js","webpack:///./node_modules/plotly.js/src/components/fx/constants.js","webpack:///./node_modules/plotly.js/src/locale-en-us.js","webpack:///./node_modules/plotly.js/src/plot_api/helpers.js","webpack:///./node_modules/plotly.js/src/components/annotations3d/convert.js","webpack:///./node_modules/plotly.js/src/traces/bar/layout_attributes.js","webpack:///./node_modules/plotly.js/src/components/annotations/common_defaults.js","webpack:///./node_modules/plotly.js/src/lib/filter_unique.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/autorange.js","webpack:///./node_modules/plotly.js/src/traces/histogram/calc.js","webpack:///./node_modules/plotly.js/src/plots/frame_attributes.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/calc.js","webpack:///./node_modules/plotly.js/src/traces/scatter/constants.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/defaults.js","webpack:///./node_modules/plotly.js/src/lib/make_trace_groups.js","webpack:///./node_modules/plotly.js/src/plots/layout_attributes.js","webpack:///./node_modules/plotly.js/src/traces/pie/event_data.js","webpack:///./node_modules/plotly.js/src/components/annotations/arrow_paths.js","webpack:///./node_modules/plotly.js/src/plots/array_container_defaults.js","webpack:///./node_modules/plotly.js/src/plots/get_data.js","webpack:///./node_modules/plotly.js/src/traces/pie/layout_attributes.js","webpack:///./node_modules/plotly.js/src/components/colorscale/layout_defaults.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/xyz_defaults.js","webpack:///./node_modules/plotly.js/lib/pie.js","webpack:///./node_modules/plotly.js/src/components/color/attributes.js","webpack:///./node_modules/plotly.js/src/lib/dates.js","webpack:///./node_modules/plotly.js/src/components/colorscale/layout_attributes.js","webpack:///./node_modules/plotly.js/src/components/colorscale/cross_trace_defaults.js","webpack:///./node_modules/plotly.js/src/components/annotations/attributes.js","webpack:///./node_modules/plotly.js/src/components/drawing/attributes.js","webpack:///./node_modules/plotly.js/src/traces/pie/layout_defaults.js","webpack:///./node_modules/plotly.js/src/components/images/convert_coords.js","webpack:///./node_modules/plotly.js/node_modules/es6-promise/dist/es6-promise.js","webpack:///./node_modules/plotly.js/src/lib/setcursor.js","webpack:///./node_modules/plotly.js/src/traces/bar/helpers.js","webpack:///./node_modules/plotly.js/src/lib/filter_visible.js","webpack:///./node_modules/plotly.js/src/components/legend/constants.js","webpack:///./node_modules/plotly.js/src/traces/bar/constants.js","webpack:///./node_modules/plotly.js/src/lib/localize.js","webpack:///./node_modules/plotly.js/src/lib/clear_gl_canvases.js","webpack:///./node_modules/plotly.js/src/components/colorbar/has_colorbar.js","webpack:///./node_modules/plotly.js/src/components/colorscale/defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/tick_mark_defaults.js","webpack:///./node_modules/plotly.js/src/snapshot/toimage.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/axis_attributes.js","webpack:///./node_modules/plotly.js/src/lib/array.js","webpack:///./node_modules/plotly.js/src/components/errorbars/compute_error.js","webpack:///./node_modules/plotly.js/src/plot_api/edit_types.js","webpack:///./node_modules/plotly.js/src/components/drawing/symbol_defs.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/attributes.js","webpack:///./node_modules/plotly.js/src/plot_api/plot_config.js","webpack:///./node_modules/plotly.js/src/plots/template_attributes.js","webpack:///./node_modules/plotly.js/src/snapshot/svgtoimg.js","webpack:///./node_modules/plotly.js/src/components/fx/click.js","webpack:///./node_modules/plotly.js/src/plot_api/subroutines.js","webpack:///./node_modules/plotly.js/src/components/legend/handle_click.js","webpack:///./node_modules/plotly.js/src/components/colorbar/constants.js","webpack:///./node_modules/plotly.js/src/traces/pie/style.js","webpack:///./node_modules/plotly.js/src/traces/scatter/format_labels.js","webpack:///./node_modules/plotly.js/src/traces/pie/calc.js","webpack:///./node_modules/plotly.js/src/lib/relative_attr.js","webpack:///./node_modules/plotly.js/src/traces/bar/arrays_to_calcdata.js","webpack:///./node_modules/plotly.js/src/traces/scatter/marker_defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/set_convert.js","webpack:///./node_modules/plotly.js/src/registry.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/convert_column_xyz.js","webpack:///./node_modules/plotly.js/src/core.js","webpack:///./node_modules/plotly.js/src/constants/docs.js","webpack:///./node_modules/plotly.js/src/components/dragelement/cursor.js","webpack:///./node_modules/plotly.js/src/components/legend/index.js","webpack:///./node_modules/plotly.js/src/components/shapes/draw.js","webpack:///./node_modules/plotly.js/src/components/modebar/buttons.js","webpack:///./node_modules/plotly.js/src/traces/scatter/colorscale_calc.js","webpack:///./node_modules/plotly.js/src/traces/scatter/attributes.js","webpack:///./node_modules/is-browser/client.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/select.js","webpack:///./node_modules/plotly.js/src/lib/push_unique.js","webpack:///./node_modules/plotly.js/src/plot_api/validate.js","webpack:///./node_modules/plotly.js/src/constants/interactions.js","webpack:///./node_modules/gl-mat4/fromQuat.js","webpack:///./node_modules/plotly.js/src/components/errorbars/index.js","webpack:///./node_modules/plotly.js/src/plots/command.js","webpack:///./node_modules/plotly.js/src/traces/scatter/select.js","webpack:///./node_modules/plotly.js/src/traces/bar/hover.js","webpack:///./node_modules/plotly.js/src/lib/geometry2d.js","webpack:///./node_modules/plotly.js/src/components/errorbars/defaults.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/hover.js","webpack:///./node_modules/plotly.js/src/components/shapes/defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/constants.js","webpack:///./node_modules/plotly.js/src/traces/bar/style.js","webpack:///./node_modules/plotly.js/src/components/colorbar/draw.js","webpack:///./node_modules/plotly.js/src/components/dragelement/index.js","webpack:///./node_modules/plotly.js/src/traces/scatter/marker_colorbar.js","webpack:///./node_modules/plotly.js/src/lib/search.js","webpack:///./node_modules/plotly.js/src/plots/gl3d/project.js","webpack:///./node_modules/plotly.js/src/snapshot/cloneplot.js","webpack:///./node_modules/plotly.js/lib/core.js","webpack:///./node_modules/plotly.js/src/plot_api/template_api.js","webpack:///./node_modules/polybooljs/lib/intersecter.js","webpack:///./node_modules/polybooljs/lib/build-log.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/scrollbox.js","webpack:///./node_modules/plotly.js/src/components/images/draw.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/draw.js","webpack:///./node_modules/plotly.js/src/components/legend/helpers.js","webpack:///./node_modules/plotly.js/src/traces/scatter/line_points.js","webpack:///./node_modules/plotly.js/src/traces/pie/defaults.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/make_bound_array.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/constants.js","webpack:///./node_modules/plotly.js/src/traces/scatter/defaults.js","webpack:///./node_modules/plotly.js/src/components/images/attributes.js","webpack:///./node_modules/plotly.js/src/components/annotations/convert_coords.js","webpack:///./node_modules/plotly.js/src/traces/scatter/line_defaults.js","webpack:///./node_modules/plotly.js/src/components/annotations/click.js","webpack:///./node_modules/plotly.js/src/components/annotations/index.js","webpack:///./node_modules/plotly.js/src/traces/bar/layout_defaults.js","webpack:///./node_modules/plotly.js/src/lib/is_plain_object.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/interp2d.js","webpack:///./node_modules/plotly.js/src/components/sliders/attributes.js","webpack:///./node_modules/plotly.js/lib/scatter.js","webpack:///./node_modules/plotly.js/src/components/annotations/defaults.js","webpack:///./node_modules/plotly.js/src/traces/pie/helpers.js","webpack:///./node_modules/plotly.js/src/traces/scatter/index.js","webpack:///./node_modules/plotly.js/src/components/annotations3d/defaults.js","webpack:///./node_modules/plotly.js/src/version.js","webpack:///./node_modules/plotly.js/src/lib/clean_number.js","webpack:///./node_modules/plotly.js/src/plot_api/plot_schema.js","webpack:///./node_modules/plotly.js/src/lib/coerce.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/draw.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/constants.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/line_grid_defaults.js","webpack:///./node_modules/plotly.js/src/components/dragelement/align.js","webpack:///./node_modules/plotly.js/src/traces/bar/index.js","webpack:///./node_modules/plotly.js/src/lib/polygon.js","webpack:///./node_modules/plotly.js/src/traces/bar/event_data.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/index.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/scale_zoom.js","webpack:///./node_modules/plotly.js/src/components/rangeselector/get_update_object.js","webpack:///./node_modules/plotly.js/src/traces/pie/index.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/calc_autorange.js","webpack:///./node_modules/plotly.js/src/traces/pie/plot.js","webpack:///./node_modules/plotly.js/src/components/fx/layout_global_defaults.js","webpack:///./node_modules/plotly.js/src/traces/scatter/calc.js","webpack:///./node_modules/plotly.js/src/traces/bar/cross_trace_calc.js","webpack:///./node_modules/plotly.js/src/components/fx/calc.js","webpack:///./node_modules/plotly.js/lib/bar.js","webpack:///./node_modules/polybooljs/lib/segment-chainer.js","webpack:///./node_modules/plotly.js/src/traces/histogram2d/calc.js","webpack:///./node_modules/plotly.js/src/components/dragelement/unhover.js","webpack:///./node_modules/plotly.js/src/lib/loggers.js","webpack:///./node_modules/plotly.js/src/lib/identity.js","webpack:///./node_modules/plotly.js/src/traces/bar/defaults.js","webpack:///./node_modules/plotly.js/src/components/fx/layout_defaults.js","webpack:///./node_modules/mouse-event-offset/index.js","webpack:///./node_modules/plotly.js/src/components/colorbar/attributes.js","webpack:///./node_modules/plotly.js/src/components/sliders/draw.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/transition_axes.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/position_defaults.js","webpack:///./node_modules/plotly.js/src/constants/alignment.js","webpack:///./node_modules/plotly.js/src/plot_api/manage_arrays.js","webpack:///./node_modules/plotly.js/src/traces/scatter/arrays_to_calcdata.js","webpack:///./node_modules/plotly.js/src/components/colorscale/attributes.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/include_components.js","webpack:///./node_modules/plotly.js/src/lib/noop.js","webpack:///./node_modules/plotly.js/src/traces/bar/style_defaults.js","webpack:///./node_modules/plotly.js/src/traces/bar/calc.js","webpack:///./node_modules/plotly.js/src/components/colorscale/calc.js","webpack:///./node_modules/plotly.js/src/components/legend/get_legend_data.js","webpack:///./node_modules/plotly.js/src/plots/font_attributes.js","webpack:///./node_modules/plotly.js/src/fonts/ploticon.js","webpack:///./node_modules/plotly.js/src/components/updatemenus/index.js","webpack:///./node_modules/plotly.js/src/lib/matrix.js","webpack:///./node_modules/plotly.js/src/traces/bar/attributes.js","webpack:///./node_modules/plotly.js/src/components/colorscale/index.js","webpack:///./node_modules/plotly.js/src/lib/keyed_container.js","webpack:///./node_modules/plotly.js/src/lib/queue.js","webpack:///./node_modules/plotly.js/src/components/shapes/constants.js","webpack:///./node_modules/plotly.js/src/traces/scatter/fillcolor_defaults.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/axis_ids.js","webpack:///./node_modules/plotly.js/src/components/errorbars/plot.js","webpack:///./node_modules/plotly.js/src/constants/xmlns_namespaces.js","webpack:///./node_modules/polybooljs/index.js","webpack:///./node_modules/plotly.js/src/lib/angles.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/undo_manager.js","webpack:///./node_modules/plotly.js/src/lib/regex.js","webpack:///./node_modules/plotly.js/src/lib/notifier.js","webpack:///./node_modules/plotly.js/src/traces/scatter/get_trace_color.js","webpack:///./node_modules/polybooljs/lib/epsilon.js","webpack:///./node_modules/plotly.js/src/traces/scatter/cross_trace_calc.js","webpack:///./node_modules/plotly.js/src/components/annotations/draw_arrow_head.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/tick_label_defaults.js","webpack:///./node_modules/plotly.js/src/snapshot/tosvg.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/axis_autotype.js","webpack:///./node_modules/plotly.js/src/plots/domain.js","webpack:///./node_modules/plotly.js/src/components/legend/attributes.js","webpack:///./node_modules/plotly.js/src/plot_api/index.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/oppaxis_attributes.js","webpack:///./node_modules/plotly.js/src/components/shapes/calc_autorange.js","webpack:///./node_modules/plotly.js/src/plot_api/plot_api.js","webpack:///./node_modules/plotly.js/src/components/annotations3d/draw.js","webpack:///./node_modules/plotly.js/src/components/colorscale/helpers.js","webpack:///./node_modules/plotly.js/src/components/legend/defaults.js","webpack:///./node_modules/plotly.js/src/components/images/index.js","webpack:///./node_modules/plotly.js/src/components/colorbar/index.js","webpack:///./node_modules/plotly.js/src/traces/scatter/make_bubble_size_func.js","webpack:///./node_modules/plotly.js/src/traces/scatter/plot.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/clean_2d_array.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/helpers.js","webpack:///./node_modules/plotly.js/src/components/shapes/index.js","webpack:///./node_modules/plotly.js/src/locale-en.js","webpack:///./node_modules/react-plotly.js/factory.js","webpack:///./node_modules/plotly.js/src/components/rangeslider/defaults.js","webpack:///./node_modules/polybooljs/lib/linked-list.js","webpack:///./node_modules/plotly.js/src/components/errorbars/attributes.js","webpack:///./node_modules/has-passive-events/index.js","webpack:///./node_modules/plotly.js/src/traces/scatter/cross_trace_defaults.js","webpack:///./node_modules/plotly.js/lib/heatmap.js","webpack:///./node_modules/plotly.js/src/components/fx/layout_attributes.js","webpack:///./node_modules/plotly.js/src/plots/polar/legacy/area_attributes.js","webpack:///./node_modules/plotly.js/src/traces/scatter/link_traces.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/axis_defaults.js","webpack:///./node_modules/plotly.js/src/traces/heatmap/colorbar.js","webpack:///./node_modules/plotly.js/src/plot_api/to_image.js","webpack:///./node_modules/plotly.js/src/lib/to_log_range.js","webpack:///./node_modules/plotly.js/src/components/shapes/attributes.js","webpack:///./node_modules/plotly.js/src/lib/extend.js","webpack:///./node_modules/plotly.js/src/components/titles/index.js","webpack:///./node_modules/plotly.js/src/components/modebar/modebar.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/type_defaults.js","webpack:///./node_modules/plotly.js/src/traces/bar/select.js","webpack:///./node_modules/fast-isnumeric/index.js","webpack:///./node_modules/plotly.js/src/snapshot/index.js","webpack:///./node_modules/plotly.js/src/traces/histogram/bin_functions.js","webpack:///./node_modules/polybooljs/lib/geojson.js","webpack:///./node_modules/plotly.js/src/traces/bar/sieve.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/layout_attributes.js","webpack:///./node_modules/plotly.js/src/plots/cartesian/attributes.js","webpack:///./node_modules/plotly.js/src/components/annotations3d/attributes.js"],"names":["d3","Color","module","exports","traces","each","d","trace","yObj","error_y","xObj","error_x","s","select","this","selectAll","style","thickness","call","stroke","color","copy_ystyle","isNumeric","tinycolor","Registry","Colorscale","Lib","svgTextUtils","xmlnsNamespaces","LINE_SPACING","DESELECTDIM","subTypes","makeBubbleSizeFn","appendArrayPointValue","drawing","font","family","size","isPlainObject","fill","setPosition","x","y","attr","setSize","w","h","setRect","translatePoint","sel","xa","ya","c2p","node","nodeName","translatePoints","hideOutsideRangePoint","xcalendar","ycalendar","isPtWithinRange","hideOutsideRangePoints","traceGroups","subplot","_hasClipOnAxisFalse","xaxis","yaxis","selector","traceIs","crispRound","gd","lineWidth","dflt","_context","staticPlot","Math","round","singleLineStyle","lw","lc","ld","line","lw1","width","dash","dashLine","lineGroupStyle","dashStyle","dlw","max","singleFillStyle","fillcolor","data","fillGroupStyle","shape","SYMBOLDEFS","symbolNames","symbolFuncs","symbolNeedLines","symbolNoDot","symbolNoFill","symbolList","Object","keys","forEach","k","symDef","n","push","f","needLine","noDot","noFill","MAXSYMBOL","length","makePointPath","symbolNumber","r","base","v","vbase","indexOf","replace","floor","HORZGRADIENT","x1","x2","y1","y2","VERTGRADIENT","stopFormatter","format","gradientInfo","radial","radialreversed","reversed","horizontal","attrs","horizontalreversed","vertical","verticalreversed","gradient","gradientID","type","colorscale","prop","len","info","colorStops","Array","i","fullLayout","_fullLayout","fullID","_uid","_defs","join","identity","exit","remove","enter","append","el","stops","tc","offset","tinyRGB","getAlpha","getFullUrl","className2query","parentNode","_gradientUrlQueryParts","initGradients","ensureSingle","pointStyle","fns","makePointStyleFns","singlePointStyle","marker","markerLine","selectedOpacityFn","undefined","mo","opacity","ms2mrc","ms","mrc","selectedSizeFn","mx","symbol","om","fillColor","lineColor","perPointGradient","so","outlierwidth","outliercolor","markerLineWidth","mlw","mlcc","lineScale","mlc","isArrayOrTypedArray","defaultLine","mcc","markerScale","mc","selectedColorFn","isBlank","markerGradient","gradientType","mgt","isArray","gradientColor","mgc","uid","out","tryColorscale","isBubble","selectedpoints","extendFlat","makeSelectedPointStyleFns","selectedAttrs","selected","unselectedAttrs","unselected","selectedMarker","unselectedMarker","smo","usmo","smoIsDefined","usmoIsDefined","smc","usmc","sms","usms","smsIsDefined","usmsIsDefined","makeSelectedTextStyleFns","textFont","textfont","selectedTextFont","unselectedTextFont","stc","utc","selectedTextColorFn","addOpacity","selectedPointStyle","seq","pt","mrc2","prefix","cont","nestedProperty","get","colorArray","_colorAx","makeColorScaleFuncFromTrace","TEXTOFFSETSIGN","start","end","middle","bottom","top","textPointPosition","textPosition","fontSize","markerRadius","group","numLines","lineCount","dx","dy","extracTextFontSize","ts","textPointStyle","texttemplate","p","text","extractOption","labels","_module","formatLabels","pointValues","meta","_meta","texttemplateString","_d3locale","pos","tp","textposition","fontColor","tf","convertToTspans","selectedTextStyle","tx","makeTangent","prevpt","thispt","nextpt","smoothness","d1x","d1y","d2x","d2y","d1a","pow","CatmullRomExp","d2a","numx","numy","denom1","denom2","smoothopen","pts","path","tangents","smoothclosed","pLast","STEPPATH","hv","p0","p1","vh","hvh","vhv","STEPLINEAR","steps","onestep","makeTester","tester","ensureSingleById","svgAttrs","position","left","height","testref","savedBBoxes","savedBBoxesCount","nodeHash","inputText","getAttribute","localId","context","_exportedPlot","_baseUrl","bBox","inTester","hash","testNode","childNodes","innerNode","transform","innerBB","right","cloneNode","appendChild","positionText","testRect","getBoundingClientRect","refRect","removeChild","bb","setClipUrl","getTranslate","element","translate","match","p2","split","setTranslate","getter","setter","trim","getScale","setScale","SCALE_RE","setPointGroupScale","selection","xScale","yScale","scale","t","setAttribute","TEXT_POINT_LAST_TRANSLATION_RE","setTextPointsScale","transforms","parseFloat","existingTransform","isUnifiedHover","handleHoverModeDefaults","Template","basePlotLayoutAttributes","layoutAttributes","handleTypeDefaults","handleAxisDefaults","handleConstraintDefaults","handlePositionDefaults","axisIds","id2name","name2id","AX_ID_PATTERN","getComponentMethod","appendList","item","layoutIn","layoutOut","fullData","j","ax2traces","xaMayHide","yaMayHide","xaMustDisplay","yaMustDisplay","yaMustNotReverse","yaMayReverse","axHasImage","outerTicks","noGrids","xaName","yaName","xaxes","yaxes","orientation","_cheater","subplots","_subplots","xIds","yIds","xNames","simpleMap","yNames","axNames","concat","plotBgColor","background","coerce","axName","axId","axLetter","axLayoutIn","axLayoutOut","bgColor","combine","paper_bgcolor","newAxLayoutOut","_traceIndices","map","_expandedIndex","_annIndices","_shapeIndices","_imgIndices","_subplotsWith","_counterAxes","_name","_attr","_id","coerce2","getCounterAxes","getOverlayableAxes","list","axName2","overlaying","counterAxes","allAxisIds","missingMatchedAxisIdsLookup","missingMatchedAxisIds","addMissingMatchedAxis","matchesIn","matches","test","hovermode","unifiedHover","charAt","newContainer","visibleDflt","reverseDflt","defaultOptions","letter","showGrid","calendar","automargin","splomStash","_splomAxes","uirevision","unifiedSpike","spikecolor","spikethickness","spikedash","spikemode","spikesnap","overlayableAxes","grid","_input","defaultOptions2","rangeSliderDefaults","rangeSelectorDefaults","anchoredAxis","anchor","constraintGroups","_axisConstraintGroups","matchGroups","_axisMatchGroups","allAxisIdsIncludingMissing","axNamesIncludingMissing","scaleanchorDflt","constrainDflt","hasOwnProperty","rng","autorange","range","slice","_matchGroup","group2","axId2","warn","splice","npGet","parts","curPart","allSame","curCont","container","propStr","String","substr","indexed","indices","propParts","Number","set","astr","obj","badContainer","npSet","ARGS_PATTERN","isDeletable","val","propPart","containerLevels","toDelete","setArrayAll","checkNewContainer","joinPropStr","pop","newPart","toAdd","containerArray","innerParts","arrayVal","allSet","thisVal","thisPropStr","deleteThis","firstPart","part","nextPart","plots","name","plot","transitionOpts","makeOnCompleteCallback","plotBasePlot","clean","newFullData","newFullLayout","oldFullData","oldFullLayout","cleanBasePlot","getDelay","_has","getRedrawFunc","encodeSVG","svg","encodeURIComponent","encodeJSON","json","DOM_URL","window","URL","webkitURL","createObjectURL","blob","revokeObjectURL","url","createBlob","Blob","binary","b","buf","ArrayBuffer","arr","Uint8Array","charCodeAt","fixBinary","atob","octetStream","document","location","href","IMAGE_URL_PREFIX","MSG_IE_BAD_FORMAT","traceIn","traceOut","layout","opts","coerceFont","noSelect","cleanTicks","containerIn","containerOut","axType","readInput","_template","tickmode","_tick0","_dtick","_tickvals","dtick","tick0","_responsiveChartHandler","removeEventListener","colorAttrs","defaults","lightLine","cleanOne","valTrim","rgba","rgbStr","c","toRgb","g","rgb","cstr","op","front","back","fc","a","toRgbString","bc","bcflat","fcflat","contrast","lightAmount","darkAmount","isDark","lighten","darken","toString","key","el0","handleXYZDefaults","handleStyleDefaults","colorscaleDefaults","attributes","defaultColor","isArray1D","z","zsmooth","cLetter","visible","arrayStr","rootContainers","layoutArrayContainers","regexpContainers","layoutArrayRegexes","rootPart","index","tail","array","property","Plots","Drawing","arrayEditor","constants","ScrollBox","keyFunction","menuOpts","_index","isActive","gButton","menuIndexAttrName","setActive","buttonOpts","gHeader","scrollBox","buttonIndex","isSilentUpdate","active","applyUpdate","drawButtons","drawHeader","header","headerClassName","dims","_dims","headerOpts","buttons","blankHeaderOpts","posOpts","pad","yPad","l","xPad","positionOverrides","headerWidth","headerHeight","drawItem","setItemPosition","headerArrowClassName","classed","arrowSymbol","direction","arrowOffsetX","textOffsetY","on","removeAllButtons","styleOnMouseOver","styleOnMouseOut","lx","ly","buttonData","isFolded","klass","dropdownButtonClassName","buttonClassName","filterVisible","transition","x0","y0","isVertical","gapButtonHeader","gapButton","openHeight","openWidth","scrollBoxPosition","borderwidth","button","event","defaultPrevented","execute","args2","executeAPICommand","method","args","emit","menu","styleButtons","translateX","translateY","heights","widths","enable","hbar","vbar","drawScrollBox","hasHBar","hasVBar","disable","hideScrollBox","itemOpts","drawItemRect","drawItemText","itemRectClassName","rx","ry","bordercolor","bgcolor","itemTextClassName","label","templateString","showactive","activeColor","hoverColor","findDimensions","width1","height1","totalWidth","totalHeight","fakeButtons","tWidth","wEff","textPadX","minWidth","tHeight","tLines","hEff","minHeight","ceil","arrowPadX","paddedWidth","paddedHeight","graphSize","_size","xanchor","isRightAnchor","isCenterAnchor","yanchor","isBottomAnchor","isMiddleAnchor","autoMargin","autoMarginId","center","autoMarginIdRoot","overrideOpts","rect","borderWidth","finalHeight","spanOffset","textOffsetX","newMenuIndexAttr","menuData","clearAutoMargin","menus","_menulayer","containerClassName","headerGroupClassName","headerGroups","dropdownButtonGroupClassName","scrollBoxId","_gButton","manageCommandObserver","numConstants","FP_SAFE","BADNUM","lib","keyedContainer","relativeAttr","toLogRange","relinkPrivateKeys","arrayModule","isTypedArray","ensureArray","maxRowLength","minRowLength","modModule","mod","modHalf","coerceModule","valObjectMeta","coerceHoverinfo","coerceSelectionMarkerOpacity","validate","datesModule","dateTime2ms","isDateTime","ms2DateTime","ms2DateTimeLocal","cleanDate","isJSDate","formatDate","incrementMonth","dateTick0","dfltRange","findExactDates","MIN_MS","MAX_MS","searchModule","findBin","sorterAsc","sorterDes","distinctVals","roundUp","sort","findIndexOfMin","statsModule","aggNums","mean","median","midRange","variance","stdev","interp","matrixModule","init2dArray","transposeRagged","dot","translationMatrix","rotationMatrix","rotationXYMatrix","apply2DTransform","apply2DTransform2","anglesModule","deg2rad","rad2deg","angleDelta","angleDist","isFullCircle","isAngleInsideSector","isPtInsideSector","pathArc","pathSector","pathAnnulus","anchorUtils","isLeftAnchor","isTopAnchor","geom2dModule","segmentsIntersect","segmentDistance","getTextLocation","clearLocationCache","getVisibleSegment","findPointOnPath","extendModule","extendDeep","extendDeepAll","extendDeepNoArrays","loggersModule","log","error","regexModule","counterRegex","counter","throttleModule","throttle","throttleDone","done","clearThrottle","clear","domModule","makePtIndex2PtNumber","indexToPoints","ptIndex2ptNumber","getGraphDiv","isPlotDiv","removeElement","addStyleRule","addRelatedStyleRule","deleteRelatedStyleRule","clearResponsive","makeTraceGroups","_","notifier","filterUnique","pushUnique","cleanNumber","ensureNumber","isIndex","noop","repeat","cnt","swapAttrs","attrList","part1","part2","xp","yp","temp","raiseToTop","elem","cancelTransition","duration","constrain","v0","v1","min","bBoxIntersect","func","randstr","existing","bits","_recursion","digits","res","Infinity","rem","random","parsed","parseInt","OptionControl","opt","optname","self","optObj","optionList","smooth","arrayIn","FWHM","alen","alen2","wlen","arrayOut","cos","PI","syncOrAsync","sequence","arg","finalStep","ret","continueAsync","fni","then","promiseError","stripTrailingSlash","str","noneOrAll","hasAny","hasAll","mergeArray","traceAttr","cd","cdAttr","fn","hasFn","imax","mergeArrayCastPositive","isFinite","fillArray","castOption","ptNumber","calcPt","calcKey","traceKey","traceVal","tagSelected","calcTrace","ptNumber2cdIndex","_indexToPoints","ptIndex","cdIndex","selIndices2selPoints","getTargetArray","transformOpts","target","minExtend","obj1","obj2","objOut","subarray","titleCase","toUpperCase","containsAny","fragments","isIE","navigator","msSaveBlob","IS_IE9_OR_BELOW_REGEX","isIE9orBelow","userAgent","IS_SAFARI_REGEX","isSafari","isD3Selection","parent","nodeType","className","enterFn","layer","id","objectFromPath","value","tmpObj","dottedPropertyRegex","indexedPropertyRegex","expandObjectPaths","datum","idx","dest","trailingPath","numSeparate","separators","separatethousands","Error","thousandsRe","decimalSep","thouSep","TEMPLATE_STRING_REGEX","SIMPLE_PROPERTY_REGEX","string","getterCache","dummy","isValidTextValue","hovertemplateWarnings","count","hovertemplateString","templateFormatString","apply","arguments","texttemplateWarnings","TEMPLATE_STRING_FORMAT_SEPARATOR","d3locale","fmt","numberFormat","timeFormat","time","subplotSort","numA","numB","charA","charB","isNumA","isNumB","randSeed","seedPseudoRandom","pseudoRandom","lastVal","abs","fillText","contOut","htx","formatPercent","ratio","toFixed","isHidden","display","getComputedStyle","getTextTransform","noCenter","textX","textY","targetX","targetY","anchorX","anchorY","rotate","ensureUniformFontSize","baseFont","uniformtext","minsize","handleCalendarDefaults","xlen","_length","MathJax","PlotlyConfig","MathJaxConfig","Hub","Config","messageStyle","skipStartupTypeset","displayAlign","tex2jax","inlineMath","Configured","numArr","sqrt","frac","helpers","saveLink","createElement","canUseSaveLink","Promise","resolve","reject","objectUrl","download","body","click","Axes","Fx","setCursor","dragElement","drawArrowHead","drawOne","options","annotations","getFromId","xref","yref","drawRaw","subplotId","containerStr","gs","edits","editHelpers","modifyBase","modifyItem","getUpdateObj","_infolayer","annClipID","annPosPx","textangle","annGroup","annTextGroup","editTextPosition","showarrow","textEvents","captureevents","annotationText","annTextGroupInner","_dragging","makeEventData","hovertext","hoverOptions","hoverlabel","hoverFont","bBoxRef","loneHover","borderColor","fontFamily","_hoverlayer","outerContainer","_paper","loneUnhover","borderpad","borderfull","annTextBG","isSizeConstrained","annTextClip","_topclips","annText","makeEditable","delegate","textLayout","_text","initialEvent","eventData","annotation","fullAnnotation","align","drawGraphicalElements","anchor3","insert","cursor","mathjaxGroup","hasMathjax","empty","anntextBB","textWidth","textHeight","annWidth","annHeight","outerWidth","outerHeight","shiftFraction","annotationIsOffscreen","letters","basePx","textPadShift","alignPosition","autoAlignFraction","textShift","axRef","tailRef","ax","dimAngle","annSizeFromWidth","annSizeFromHeight","sin","annSize","overallShift","posPx","posFraction","r2fraction","_offset","r2p","head","arrowLength","maxPx","shiftPlus","shiftMinus","xShift","yShift","valign","texty","textx","baseTextTransform","drawArrow","headX","headY","tailX","tailY","applyTransform","applyTransform2","xLeft","xRight","yTop","yBottom","edges","reduce","strokewidth","arrowwidth","arrowColor","arrowcolor","arrowSide","arrowside","arrowGroup","arrow","annotationPosition","arrowDragHeadX","arrowDragHeadY","standoff","annx0","anny0","arrowDrag","init","prepFn","moveFn","annxy0","xcenter","ycenter","p2r","axref","ayref","ay","doneFn","notesBox","querySelector","redraw","selectedObj","csr","xUpdate","yUpdate","widthFraction","_xsize","_xshift","xshift","heightFraction","_ysize","_yshift","yshift","getCursor","clickFn","draw","previousPromises","Events","handleClick","alignmentConstants","FROM_TL","FROM_BR","getLegendData","clickOrDoubleClick","legend","legendItem","numClicks","evt","evtData","curveNumber","expandedIndex","frames","_transitionData","_frames","config","_fullData","_group","triggerHandler","_clickTimeout","setTimeout","doubleClickDelay","clearTimeout","_legendMouseDownTime","drawTexts","isPieLike","traceIndex","isEditable","_main","legendText","maxNameLength","_maxNameLength","entries","textEl","ensureLength","textGap","newName","fullInput","_fullInput","update","hasTransform","groupbyIndices","getTransformIndices","kcont","constructUpdate","maxLength","targetLength","setupTraceToggle","newMouseDownTime","traceToggle","Date","getTime","_dragged","_editing","showlegend","mathjaxNode","bw","lineHeight","title","mathjaxBB","textLines","textNode","titlePad","_titleWidth","_titleHeight","computeTextDimensions","getXanchor","getYanchor","clipId","legendData","calcdata","hiddenSlices","hiddenlabels","_topdefs","clipPath","bg","titleEl","scrollBar","scrollBarEnterAttrs","scrollBarColor","groups","isGrouped","bw2","itemGap","endPad","isBelowPlotArea","isAbovePlotArea","_maxHeight","toggleRectWidth","_width","_height","titleSize","side","getTitleSize","tracegroupgap","_lgroupsLength","isLeftOfPlotArea","isRightOfPlotArea","isBeyondPlotAreaY","hw","_maxWidth","maxItemWidth","combinedItemWidth","maxRowWidth","maxGroupHeightInRow","groupOffsetX","groupOffsetY","maxWidthInGroup","offsetY","next","nTraces","oneRowLegend","maxItemHeightInRow","offsetX","rowWidth","_effHeight","legendPosition","computeLegendDimensions","expandMargin","xf","yf","margin","autoexpand","lx0","ly0","_scrollY","eventY0","eventY1","scrollBoxY0","scrollBarHeight","scrollBarMinHeight","scrollBarYMax","scrollBarMargin","scrollBoxYMax","scrollRatio","scrollBoxY","scrollBarWidth","scrollHandler","deltaY","preventDefault","scrollBarDrag","behavior","drag","e","sourceEvent","changedTouches","clientY","ctrlKey","getScrollBarDragY","scrollBoxTouchDrag","getNaturalDragY","newX","newY","clickedTrace","filter","bbox","clientX","oneYear","ONEAVGYEAR","oneMonth","ONEAVGMONTH","oneDay","ONEDAY","oneHour","ONEHOUR","oneMin","ONEMIN","oneSec","ONESEC","tickIncrement","biggestDigitChanged","v2","pa","dv","isDate","digit","biggestGuaranteedDigitChanged","nextDigit","didDigitChange","LN10","dateParts1","dateParts","dateParts2","parti","c2d","unshift","leftGap","rightGap","binEdges","disambiguateEdges","dv0","dv1","dv2","edge0","edge1","leftDigit","rightDigit","dashExclude","increment","isRightEdge","dateStr","dashPos","roundedV","d2c","nextV","orderDefault","categoryarray","isValidArray","order","categoryorder","_initialCategories","axData","dataAttr","lookup","vals","findCategories","reverse","fontAttrs","overrideAll","padAttrs","templatedArray","buttonsAttrs","valType","role","description","values","freeLength","items","_arrayAttrRegexps","editType","borderLine","rules","Y","fullSelector","buttonAttrs","step","stepmode","activecolor","extractOpts","stylePie","pieCastOption","getGradientDirection","reversescale","isRadial","constantItemSizing","itemsizing","boundLineWidth","cst","styleBarLike","lThis","desiredType","isVisible","barpath","d0","stylePieLike","tMod","d0Mod","traceGroup","layers","markerOffsetY","useGradient","ptsData","dd","cOpts","vertexcolor","facecolor","isWaterfall","_distinct","dir","hasTotals","boxpoints","points","sizeref","sizemin","sizemode","dMod","showFill","showLine","hasLines","contours","showGradientLine","showGradientFill","coloring","showlines","_operation","markersOrText","hasMarkers","hasText","anyFill","anyLine","pathStart","this3","showMarkers","showText","showLines","boundVal","attrIn","arrayToValFn","bounds","valIn","valToBound","pickFirst","dEdit","tEdit","ptgroup","txt","getModuleCalcData","ensureSingleAndAddDatum","plotOne","plotinfo","cdSubplot","cdModuleAndOthers","cdModule","traceLayerClasses","modules","_modules","layerData","zoomScaleQueryParts","categories","layerName","plotMethod","zoomScale","isRangePlot","clipOnAxisFalseQuery","layerClipId","getModule","clipOnAxisFalseTraces","zoomScalePts","zoomScaleTxt","makeSubplotLayer","plotgroup","xLayer","layerValue2layerClass","yLayer","hasOnlyLargeSploms","_hasOnlyLargeSploms","mainplot","mainplotinfo","mainplotgroup","xId","yId","gridlayer","zerolinelayer","overlinesBelow","overaxesBelow","overplot","overlinesAbove","overaxesAbove","xlines","ylines","xaxislayer","yaxislayer","backLayer","shapelayer","imagelayer","idSort","purgeSubplotLayers","overlayIdsToRemove","removeSubplotExtras","_plots","overlays","overlayInfo","_draggers","idRoot","idRegex","attrRegex","supplyLayoutDefaults","transitionAxes","finalizeSubplots","xi","yi","xList","yList","spSVG","cartesian","spAll","gl2d","allX","allY","ki","pcd","subplotInfo","carpet","oldPlots","newPlots","oldSubplotList","hadGl","hasGl","_scene","destroy","oldAxIDs","listIds","oldAxId","hadCartesian","hasCartesian","_cartesianlayer","oldSubplotId","drawFramework","subplotData","ids","regulars","xa2","_mainAxis","ya2","mainPlotinfo","subplotIds","makeSubplotData","subplotLayers","draglayer","rangePlot","toSVG","imageRoot","_glimages","root","imageData","toDataURL","xmlns","preserveAspectRatio","updateFx","MAX_VALUE","EPOCHJD","ALMOST_EQUAL","LOG_CLIP","MINUS_SIGN","hovermodeDflt","clickmode","_isHoriz","stackOpts","_scatterStackOpts","groupOpts","stackgroup","isHoriz","Titles","axAttrs","MID_SHIFT","CAP_SHIFT","OPPOSITE_SIDE","axes","setConvert","autoType","cleanId","getFromTrace","getAutoRange","findExtremes","coerceRef","extraOption","axlist","refAttr","attrDef","coercePosition","cleanPos","fraction2r","cleanPosition","redrawComponents","axIds","_redrawOneComp","moduleName","methodName","stashName","shortCircuit","stash","ind","getDataConversions","targetArray","d2cTarget","_categories","toNum","getDataToCoordFunc","counterLetter","minDtick","newDiff","newFirst","allow","_minDtick","_forceTick0","saveRangeInitial","overwrite","axList","hasOneAxisChanged","isNew","_rangeInitial","hasChanged","saveShowSpikeInitial","allSpikesEnabled","_showSpikeInitial","showspikes","_showspikes","_cartesianSpikesEnabled","autoBin","nbins","is2d","dummyAx","dataMin","dataMax","_dataSpan","c2r","size0","distinctData","msexp","minDiff","minSize","autoTicks","binEnd","finalSize","binStart","tickFirst","edgecount","midcount","intcount","blankCount","nearEdge","dataCount","binshift","autoShiftNumericBins","stats","exactDays","numMonths","exactYears","exactMonths","nextBinStart","autoShiftMonthBins","prepTicks","r2l","minPx","nt","nticks","tickfont","_roughDTick","_lBreaks","l2r","autoTickRound","calcTicks","tickvals","ticktext","ticksOut","r0expanded","r1expanded","tickMin","tickMax","tickVal2l","d2l_noadd","d2l","vali","tickText","tickTextObj","rangebreaks","maskBreaks","arrayTicks","_tmin","startTick","endTick","axrev","tickVals","isDLog","xPrevious","maxTicks","minor","generateTicks","_rangebreaks","brk","prevPos","tf2","newTickVals","last","q","isAngular","_tmax","_prevDateHead","_inCalcTicks","_minor","_value","roundBase10","roundBase24","roundBase60","roundDays","roundLog1","roundLog2","roundAngles","roundDTick","roughDTick","roundingSet","_tickexponent","_tickround","tick0ms","tick0str","tick0len","tick1len","r2d","maxend","rangeexp","isSIFormat","exponentformat","beyondSI","getBase","roughX2","_hasDayOfWeekBreaks","olddtick","axSign","tType","dtSigned","tickset","sRound","r0","tmin","dtNum","t1","mult","newDTick","t0","hover","noSuffixPrefix","arrayMode","extraPrecision","showAttr","firstOrLast","first","hideexp","showexponent","tr","hoverformat","getTickFormat","m","M","S","headStr","_dateFormat","_extraFormat","splitIndex","tickformat","dtChar0","numFormat","absP","exponentFormat","firstChar","formatLog","tt","formatCategory","cats","tt2","text2","formatMultiCategory","thetaunit","num","almostEq","precision","findPrecision","number","gcd","findGCD","num2frac","isNeg","formatAngle","formatLinear","tickprefix","showtickprefix","ticksuffix","showticksuffix","tickson","showdividers","inbounds","l2p","xbnd","hoverLabelText","val2","logOffScale","c2l","SIPREFIXES","exponent","fmtoverride","tickRound","ah","_numFormat","signedExponent","dp","_separators","getSecondaryLabelVals","tickDataFn","axInfo","approxTitleDepth","extraLines","BR_TAG_ALL","clipEnds","selectTickLabel","gTick","mj","axAutoMarginID","axMirrorAutoMarginID","rangeSliderAutoMarginID","mergeAxisGroups","intoSet","fromSet","swapAxisGroup","xFullAxes","yFullAxes","allAxKeys","noSwapAttrs","numericTypes","keyi","xVal","yVal","allEqual","coerceLinearX","coerceLinearY","xVali","yVali","swapAxisAttrs","_dfltTitle","ann","dfltTitle","np","tickstop","stopi","convertFn","leftDtick","rightDtick","convertToMs","compareLogTicks","priority","leftPriority","rightPriority","isProperLogStop","isLeftDtickNull","isRightDtickNull","isDtickInRangeLeft","isDtickInRangeRight","tickformatstops","enabled","dtickrange","getSubplots","subplotObj","allSubplots","findSubplotsWithAxis","aParts","bParts","axMatch","RegExp","subplotsWithAx","sp","makeClipPaths","fullWidth","fullHeight","xaList","yaList","clipList","axClips","_clips","axDone","_r","_rl","_mainSubplot","mainAxLayer","mainLinePosition","_mainLinePosition","mainMirrorPosition","_mainMirrorPosition","_vals","mirror","_selections","_tickAngles","_prevTickAngles","_depth","llbboxes","valsClipped","transFn","makeTransFn","boundaryVals","_push","bndIndex","xb","getBoundaryVals","ticks","gridVals","_gridVals","dividerVals","current","getDividerVals","finishedGrids","counterAxis","mainCounterID","gridPath","drawGrid","drawZeroLine","tickSigns","getTickSigns","tickSubplots","mirrorTickPath","fullTickPath","tickPath","mainTickPath","makeTickPath","_anchorAxis","dividerLookup","drawTicks","_linepositions","linepositions","spTickPath","drawLabels","labelFns","makeLabelFns","bboxKey","getLabelLevelBbox","cls","repositionOnUpdate","secondary","dividers","dividercolor","dividerwidth","drawDividers","hasRangeSlider","llbbox","mirrorPush","rangeSliderPush","sMirror","getPxPosition","outsideTickLen","ticklen","domainIndices","rExtra","xr","lExtra","xl","bExtra","yb","tExtra","yt","domain","linewidth","_counterDomainMin","_counterDomainMax","skipTitle","titleStandoff","showticklabels","avoid","tickLabels","translation","offsetLeft","offsetTop","propContainer","propName","placeholder","drawTitle","suffix","thisLabel","calcLabelLevelBbox","sideOpposite","main","shift","sgn","angle","ticksOnOutsideLabels","labelStandoff","labelShift","rad","showline","ff","flipIt","xFn","yFn","anchorFn","heightFn","tickangle","crisp","tickcolor","tickwidth","counterAx","showgrid","shouldShowZeroLine","isArrayMode","_gw","gridwidth","gridcolor","show","zl","da","db","zerolinecolor","zerolinewidth","tickAngle","prevAngle","labelsReady","positionLabels","nLines","anchorHeight","mjShift","newPromise","_promises","autoangle","all","_redrawFromAutoMarginCount","maxFontSize","lbbArray","vLen","rotate90","_m","gap","lbb","anchorAxis","zeroline","mainCounterAxis","zeroPosition","lineNearZero","ax2","tolerance","closeEnough","pos2","linePositions","counterLetterAxes","counterAxis2","anyCounterAxLineAtZero","hasBarsOrFill","allowAutoMargin","swap","axGroups","groupsi","groupj","group0","makeAxisGroups","moduleType","schema","scene","handleDefaults","includeBasePlot","GL3D","subplotsRegistry","gl3d","_basePlotModules","convert","getMinKey","traceType","recordMinTextSize","mode","minKey","hide","clearMinTextSize","resizeText","gTrace","shouldHide","handleTickValueDefaults","handleTickMarkDefaults","handleTickLabelDefaults","colorbarOut","colorbarIn","colorbar","thicknessmode","lenmode","loggers","elParent","styleString","getElementById","createTextNode","styleSheet","sheet","insertRule","addRule","gdElement","el3","HTMLElement","prevRow","thisPt","neighborCount","newNeighborHash","foundNewNeighbors","empties","neighborHash","noNeighborList","nextRow","row","blank","rowLength","EventEmitter","plotObj","_ev","ev","internalEv","_internalEv","bind","once","removeListener","removeAllListeners","_internalOn","_internalOnce","_removeInternalListener","_removeAllInternalListeners","jQuery","trigger","jQueryHandlerValue","nodeEventHandlerValue","handlers","_events","handler","listener","fired","purge","oppAxisAttrs","rangeslider","calcAutorange","makeData","autoMarginOpts","scaleZoom","makePadFn","concatExtremes","FROM_BL","getConstraintOpts","thisID","idj","axj","doesNotConstrainRange","thisType","linkableAxes","fixedrange","thisGroup","linkableAxesNoLoops","updateConstraintGroups","scaleanchor","scaleratio","groupi","keyj","thisGroupIndex","thisGroupKeys","baseScale","updateDomain","factor","inputDomain","_inputDomain","centerFraction","constraintoward","matchOpts","scaleOpts","enforce","axisID","normScale","axisIDs","minScale","maxScale","matchScale","normScales","hasAnyDomainConstraint","_inputRange","_constraintShrinkable","domainShrunk","rangeShrunk","rl0","rl1","rangeCenter","rangeMin","rangeMax","halfRange","outerMin","outerMax","getPad","newVal","extremes","minArray","maxArray","isConstrained","micropolar","UndoManager","manager","framework","_gd","previousConfigClone","convertedInput","undoManager","_inputConfig","_container","Axis","adapter","plotly","render","fillLayout","isPolar","getConfig","getLiveConfig","getLiveScales","angularScale","radialScale","setUndoPoint","_configClone","_previousConfigClone","that","configClone","util","cloneJson","add","undo","redo","paperDiv","paper","dflts","_paperdiv","handleArrayContainerDefaults","imageDefaults","imageIn","imageOut","source","gdMock","axLetters","handleItemDefaults","supportsPassive","clearGlCanvases","redrawReglTraces","prepSelect","clearSelect","selectOnClick","MINDRAG","MINZOOM","SHOWZOOMOUTTIP","makeDragger","dragClass","dragger3","makeRectDragger","dragger","isDirectionActive","activeVal","zoomAxRanges","r0Fraction","r1Fraction","updates","linkedAxes","axi","isY","r0F","r1F","p2l","axRangeLinear0","axRangeLinearSpan","linkedR0Fraction","dragAxList","pix","delta","dZoom","makeZoombox","zoomlayer","lum","xs","ys","path0","makeCorners","updateZoombox","zb","corners","box","dimmed","transitionZoombox","removeZoombox","showDoubleClickNotifier","showTips","isSelectOrLasso","dragmode","xyCorners","clen","calcLinks","xaHash","yaHash","xID","yID","xLinkID","yLinkID","isSubplotConstrained","xLinks","yLinks","xaHashLinked","xaxesLinked","yaHashLinked","yaxesLinked","attachWheelEventHandler","wheelEventName","onwheel","_onwheel","addEventListener","passive","onmousewheel","hashValues","makeDragBox","ns","ew","xa0","ya0","pw","ph","links","xActive","yActive","allFixedRanges","editX","editY","hasScatterGl","hasSplom","hasSVG","_zoomlayer","isMainDrag","singleEnd","recomputeAxisLists","nsew","toLowerCase","getDragCursor","onmousedown","pointerEvents","zoomMode","zoomDragged","dragOptions","clearAndResetSelect","_transitioningWithDuration","doubleClickConfig","doubleClick","rangeInitial","attrStr","initialText","dig","initialVal","diff","getEndText","hAlign","vAlign","showAxisRangeEntryBoxes","immediate","horizontalAlign","verticalAlign","d2r","zoomMove","dx0","dy0","noZoom","r1","xCorners","yCorners","computeZoomUpdates","updateMatchedAxRange","zoomDone","dragTail","startX","startY","dragModePrev","dragModeNow","shiftKey","minDrag","dragBBox","_hmpixcount","_hmlumcount","plot_bgcolor","getLuminance","zoomPrep","plotDrag","_redrag","dragDataNow","_dragdata","updateSubplots","scrollViewBox","redrawTimer","REDRAWDELAY","_replotting","ticksAndAnnotations","dxySign","dxyFraction","dz","xStart","yStart","axArray","movedAx","newLinearizedEnd","otherEnd","newEnd","matchedAxes","constrainedAxes","activeAxIds","pushActiveAxIds","viewBox","plotinfos","splom","xrng","yrng","xScaleFactor","yScaleFactor","xScaleFactor2","yScaleFactor2","clipDx","clipDy","editX2","editY2","getShift","scaleAndGetShift","getLinkedScaleFactor","plotDx","plotDy","clipRect","scaleFactor","from","_scrollZoom","_enablescrollzoom","stopPropagation","wheelDelta","zoom","exp","gbb","xfrac","yfrac","zoomWheelOneAxis","axRange","getSize","_selection","_dimension","FIND_TEX","_callback","tex","svgClass","_texString","_config","originalRenderer","originalConfig","originalProcessSectionDelay","tmpDiv","Queue","processSectionDelay","menuSettings","renderer","setRenderer","randomID","visibility","LT_MATCH","GT_MATCH","Typeset","glyphDefs","svgBBox","texToSVG","_svgEl","_glyphDefs","_svgBBox","newSvg","insertBefore","firstChild","overflow","newSvgW","newSvgH","containerNode","NEWLINES","currentNode","hasLink","nodeStack","currentLine","newLine","lineNode","createElementNS","class","oldNodeStack","enterNode","nodeSpec","nodeAttrs","popup","onclick","newNode","addTextNode","resetter","RESET_DY","SHIFT_DY","exitNode","BR_TAG","SPLIT_TAGS","ONE_TAG","tagType","tagStyle","TAG_STYLES","convertEntities","extra","css","getQuotedMatch","STYLEMATCH","COLORMATCH","HREFMATCH","dummyAnchor","PROTOCOLS","protocol","encodeURI","decodeURI","TARGETMATCH","POPUPMATCH","buildSVGText","sup","sub","span","em","_str","re","result","plainText","allowedTags","eLen","oldParts","newParts","prevTag","pLen","pLen2","entityToUnicode","mu","amp","lt","gt","nbsp","times","plusmn","deg","ENTITY_MATCH","fullMatch","innerMatch","code","stringFromCodePoint","fromCodePoint","stringFromCharCode","fromCharCode","alignHTMLWith","_base","thisRect","getTop","getLeft","alignH","alignV","bRect","cRect","setOrGet","thisX","thisY","_delegate","dispatch","handlerElement","div","cStyle","outline","padding","contenteditable","textContent","mathjaxClass","edit","editDiv","activeElement","blur","which","cancel","input","selectElementContents","appendEditable","_el","createRange","selectNodeContents","getSelection","removeAllRanges","addRange","focus","rebind","hasHover","isBrowser","global","matchMedia","PlotSchema","animationAttrs","frameAttrs","allTypes","fontWeight","transformsRegistry","commandModule","computeAPICommandBindings","hasSimpleAPICommandBindings","redrawText","resize","resolveLastResize","_redrawTimer","_resolveResize","oldchanged","changed","autoplay","autosize","addLinks","showLink","showSources","linkContainer","contains","getComputedTextLength","toolspan","spacespan","sourcespan","link","linkText","sendData","sendDataToCloud","pathname","query","search","positionPlayWithData","baseUrl","PLOTLYENV","BASE_URL","plotlyServerURL","hiddenformDiv","hiddenform","action","graphJson","submit","d3FormatKeys","extraFormatKeys","getFormatObj","formatKeys","locale","formatDone","formatObj","includeFormat","newFormat","formatFinished","formatKey","locales","formatj","localeRegistry","baseLocale","en","findMainSubplot","mockGd","isX","anchorAx","mainSubplotID","nextBestMainSubplotID","anchorID","counterIDs","counterPart","hasMakesDataTransform","ti","makesData","applyTransforms","fullTrace","dataOut","transformIndex","initMargins","_pushmargin","_pushmarginIds","supplyDefaults","skipUpdateCalc","_skipDefaults","newLayout","newData","oldCalcdata","createTransitionData","_traceWord","_mapboxAccessToken","mapboxAccessToken","_initialAutoSizeIsDone","oldWidth","oldHeight","supplyLayoutGlobalDefaults","sanitizeMargins","missingWidthOrHeight","autosizable","plotAutoSize","decimal","thousands","getFormatter","_dataLength","_visibleModules","collectableSubplotTypes","subplotType","subplotAttr","emptySubplotLists","splomAxes","splomSubplots","_splomSubplots","_splomGridDflt","_firstScatter","_alignmentOpts","_colorAxes","_requestRangeslider","_traceUids","prevFullInput","oldFullInput","thisFullInput","oldLen","seenUids","setUid","tryUid","newUid","getTraceUids","_globalTransforms","globalTransforms","supplyDataDefaults","splomXa","splomYa","_hasPlotType","supplyLayoutModuleDefaults","crossTraceDefaultsFuncs","funci","crossTraceDefaults","shapes","images","_hasCartesian","_hasGeo","_hasGL3D","_hasGL2D","_hasTernary","_hasPie","linkSubplots","cleanPlot","meta4data","fillMetaTextHelpers","_preGUI","_tracePreGUI","tracePreGUI","uids","supplyDefaultsUpdateCalc","newTrace","cd0","oldTrace","_hasCalcTransform","oldArrayVal","arrayAttrs","_arrayAttrs","_frameHash","_counter","_interruptCallbacks","category","basePlotModules","_glcontainer","_glcanvas","hasInfoLayer","oldLoop","oldUid","oldSubplots","newSubplots","newSubplotList","oldSubplot","cliponaxis","mainAx","clearExpandedTraceDefaultColors","_colorAttrs","crawl","attrName","level","dataIn","visibleModules","colorCnt","pushModule","basePlotModule","_transformModules","carpetIndex","carpetDependents","dataTemplate","template","templater","traceTemplater","supplyTraceDefaults","sdInvisible","expandedTraces","expandedTrace","fullExpandedTrace","_expandedInput","carpetAxis","_carpet","supplyAnimationDefaults","optsOut","frame","supplyAnimationFrameDefaults","supplyAnimationTransitionDefaults","supplyFrameDefaults","frameIn","frameOut","colorIndex","traceInIndex","colorway","subplotAttrs","attri","_dfltShowLegend","hovertemplate","selectPoints","supplyTransformDefaults","transformModules","transformList","transformOut","transformIn","isFirstStage","doLaterStages","_dataTemplate","globalFont","modebarDefaultColor","modebar","newWidth","newHeight","frameMargins","fillFrame","innerWidth","innerHeight","computedStyle","maxWidth","maxHeight","widthHasChanged","heightHasChanged","_initialAutoSize","transitionData","component","componentsRegistry","Cartesian","_modeBar","_animationRaf","cancelAnimationFrame","fid","undoqueue","undonum","_transitioning","_hoverdata","_snapshotInProgress","_mouseDownTime","styleModules","correction","plotWidth","plotHeight","clearAutoMarginIds","o","pushMargin","pushMarginIds","doAutoMargin","oldMargins","ml","mr","mt","mb","k1","pushleft","pushbottom","fl","pl","fb","pb","k2","fr","pr","newL","newR","ft","newB","newT","didMarginChange","maxNumberOfRedraws","marginKeys","_transition","aborted","executeCallbacks","prepareFn","rehover","numCallbacks","numCompleted","makeCallback","callback","flushCallbacks","completeTransition","runFn","transitionStarting","margin0","margin1","m0","m1","dataonly","output","useDefaults","includeConfig","stripObj","keepFunction","src","stream","fit","JSON","stringify","modifyFrames","operations","oldName","computeFrame","frameName","traceIndices","destIndex","frameLookup","framePtr","frameStack","frameNameStack","baseframe","extendLayout","extendTrace","recomputeFrameHash","extendObjectWithContainers","containerPaths","containerProp","containerVal","destProp","srcContainer","destContainer","copy","expandedObj","containerObj","srcObj","dataArrayContainers","destTrace","srcTrace","destLayout","srcLayout","frameOpts","transitionedTraces","axEdits","dataLength","traceIdx","animatable","layoutUpdate","axisAttrRe","doCalcdata","xr0","yr0","xr1","yr1","traceTransitionOpts","hasAxisTransition","transitionFromReact","restyleFlags","relayoutFlags","anim","axisTransitionOpts","allTraceIndices","transitionTraces","ordering","_numBoxes","_numViolins","_violinScaleGroupStats","_piecolormap","_sunburstcolormap","_treemapcolormap","_funnelareacolormap","findArrayAttributes","_extremes","polarIds","polar","radialaxis","angularaxis","cauto","cmin","cmax","hasCalcTransform","transformCalci","calc","cdi","dirty","calcTransform","calci","isContainer","setupAxisCategories","doCrossTraceCalc","sorted","affectedTraces","zMapCategory","counterAxLetter","xCategorical","yCategorical","aggFn","sortAxisCategoriesByValueRegex","aggregator","categoriesValue","_xautoBinFinished","_yautoBinFinished","cat","catIndex","currentDimensionIndex","_axesDim","associatedXAxisID","_diag","dimensions","_categoriesMap","dimension","mapping","_categoriesValue","categoriesAggregatedValue","_categoriesAggregatedValue","sortByInitialCategories","sortAxisCategoriesByValue","axLookup","clearCalc","setupMultiCategory","crossTraceCalc","spType","methods","spInfo","_rehover","redrag","generalUpdatePerTraceModule","subplotCalcData","subplotLayout","traceHashOld","traceHash","calcTraces","moduleNameOld","fakeCalcTrace","moduleCalcData","cdmodule","had","has","counts","nMax","total","hoverPoints","timerCache","_clearTimeout","cache","timer","minInterval","now","idi","exec","onDone","previousOnDone","hoverModule","getDistanceFunction","getClosest","inbox","quadrature","castHoverOption","castHoverinfo","hoverinfo","unhover","containerOrSelection","stepAttrs","sliderDefaults","sliderIn","sliderOut","stepDefaults","stepCount","_stepCount","visSteps","_visibleSteps","valueIn","valueOut","scatterSubTypes","createModeBar","modeBarButtons","modeBar","displayModeBar","watermark","modeBarButtonsToRemove","modeBarButtonsToAdd","buttonGroups","customButtons","buttonGroup","fillCustomButton","buttonsToRemove","buttonsToAdd","hasGL3D","hasGeo","hasPie","hasFunnelarea","hasGL2D","hasTernary","hasMapbox","hasPolar","hasSankey","allAxesFixed","areAllAxesFixed","hasUnifiedHoverLabel","addGroup","newGroup","commonGroup","showEditInChartStudio","showSendToCloud","zoomGroup","hoverGroup","resetGroup","dragModeGroup","hasNoHover","selectable","isSelectable","appendButtonsToGroups","getButtonGroups","plotAttributes","templateAttrs","validItemName","arrayDefaultKey","lastChar","_isLinkedToArray","typeTemplates","traceCounts","typei","baseName","arrayTemplater","inclusionAttr","defaultsTemplate","templateItems","usedNames","newItem","itemIn","templateItemName","templateItem","defaultItems","outi","_templateitemname","parentIn","itemOut","lengthIn","itemStr","resetUpdate","updateOut","updateToApply","handleHoverLabelDefaults","namelength","makeComputeError","calcOneAxis","axis","coord","computeError","iIn","calcCoord","errors","shoe","hat","baseExtremes","tozero","padded","colorAttributes","impliedEdits","annAutorange","calcAxisExpansion","apos","ref","aref","padplus","padminus","headSize","arrowsize","headPlus","headMinus","startHeadSize","startarrowsize","startHeadPlus","startHeadMinus","extremeArrowHead","r2c","ppadplus","ppadminus","extremeText","hoverLabelAttrs","arrayOk","µ","version","inputConfig","liveConfig","axisConfig","_data","dataOriginal","defaultColorRange","strokeColor","geometry","darker","strokeDash","strokeSize","isStacked","dataWithGroupId","groupId","grouped","nest","dataYStack","stacked","prevArray","yStack","sumArrays","merge","radius","extent","chartCenter","arrayLast","flattenArray","radialAxis","DATAEXTENT","linear","angularDataMerged","isOrdinal","deduplicate","hasOnlyLineOrDotPlot","needsEndSpacing","angularDomain","angularAxis","angularDomainStep","angularDomainWithPadding","tickCount","ticksCount","ticksStep","angularTicksStep","minorTicks","angularAxisRange","toPrecision","endPadding","doc","DOMParser","parseFromString","ownerDocument","importNode","documentElement","legendContainer","chartGroup","lineStyle","tickColor","fontStyle","outlineColor","showLegend","elements","datumClone","dotType","visibleInLegend","Legend","legendConfig","defaultConfig","reverseOrder","legendBBox","getBBox","centeringOffset","titleBBox","gridLinesVisible","gridCircles","backgroundCircle","backgroundColor","currentAngle","tickSize","ticksSuffix","tickOrientation","angularAxisEnter","minorTickColor","tickLength","ticksText","labelOffset","orient","labelsVisible","rewriteTicks","rightmostTickEndX","getCTM","hasGeometry","geometryContainer","geometryConfigs","geometryConfig","dB","iB","geometryConfigsGrouped","geometryConfigsGrouped2","finalGeometryConfig","angularValue","radialValue","guides","tooltipContainer","angularTooltip","tooltipPanel","radialTooltip","geometryTooltip","hasTick","angularGuideLine","mouseAngle","getMousePos","angleWithOriginOffset","invert","convertToCartesian","move","angularGuideCircle","newColor","hsl","textData","_x","xClone","getinputConfig","category10","AREA","LINE","DOT","BAR","_override","_objA","_objB","_extend","_rndSnd","dataFromEquation2","_equation","_step","theta","dataFromEquation","_val","_count","fillArrays","_obj","_valueNames","parse","validateKeys","objHasKeys","zip","sum","arrayEqual","thetaRadians","_digits","_referenceElement","mousePos","mouse","mouseX","mouseY","atan2","duplicatesCount","uniques","dups","duplicates","translator","sourceBranch","targetBranch","targetBranchCopy","previousValue","currentValue","PolyChart","dashArray","solid","isStack","domainMin","generator","pI","dataConfig","stackTop","barWidth","stackedData","dotSize","polarCoordinates","getPolarCoordinates","interpolate","lineInterpolation","lineData","dotVisible","markStyle","lineSelection","angularRange","triangleAngle","arc","startAngle","endAngle","innerRadius","outerRadius","geometryLayer","geometryType","getColorScale","colorScale","category20","BarChart","AreaChart","DotPlot","LinePlot","flattenData","colors","isContinuous","svgEnter","dataNumbered","dataScale","colorBandWidth","legendElement","_type","squareSize","symbolType","symbolTypes","legendAxis","textColor","tooltipEl","tooltipTextEl","backgroundEl","tooltipEnter","boxStyle","backGroundW","backGroundH","_pos","outputConfig","barmode","traceorder","ReflectOwnKeys","R","Reflect","ReflectApply","receiver","Function","prototype","ownKeys","getOwnPropertySymbols","getOwnPropertyNames","NumberIsNaN","isNaN","_eventsCount","_maxListeners","defaultMaxListeners","checkListener","TypeError","_getMaxListeners","_addListener","prepend","events","warning","create","newListener","warned","emitter","console","onceWrapper","wrapFn","_onceWrap","state","wrapped","_listeners","unwrap","evlistener","unwrapListeners","arrayClone","listenerCount","defineProperty","enumerable","RangeError","getPrototypeOf","setMaxListeners","getMaxListeners","doError","er","err","message","listeners","addListener","prependListener","prependOnceListener","originalListener","spliceOne","off","rawListeners","eventNames","scales","defaultScale","RdBu","isValidScaleArray","scl","highestVal","si","isValid","parseScale","toContainer","fromContainer","fromVal","toVal","minLen","segments","buildLog","seg","myFill","above","below","otherFill","segmentId","SegmentSelector","union","intersect","difference","differenceRev","xor","domainAttrs","cartesianIdRegex","gridAttrs","rows","roworder","columns","pattern","xgap","ygap","noGridCell","xside","yside","getAxes","gridVal","splomVal","fillGridPositions","dfltGap","dfltSide","dirGap","cellDomain","cellStart","fillGridAxes","axesIn","axesAllowed","axisMap","fillOneAxis","axisId","sizeDefaults","gridIn","xAxes","yAxes","dfltRows","dfltColumns","hasSubplotGrid","hasXaxes","hasYaxes","isSplomGenerated","gridOut","_hasSubplotGrid","dfltSideX","dfltSideY","dfltGapX","dfltGapY","_domains","contentDefaults","subplotsOut","yPos","useDefaultSubplots","_axisMap","subplotsIn","rowOut","rowIn","anchors","_anchors","i0","inc","iFinal","column","getTraceColor","pointData","xval","yval","xpx","ypx","hoveron","minRad","dxy","di","distfn","kink","dxRaw","dyRaw","xc","yc","sizeVal","sNorm","xLabelVal","yLabelVal","spikeDistance","_polygons","polygon","xCross","polygons","polygonsIn","inside","xmin","xmax","ymin","ymax","yAvg","distance","maxHoverDistance","stylePoints","styleText","styleOnSelect","uniformText","attributeText","attributeTextPosition","TEXTPAD","keyFunc","getKeyFunc","dirSign","onComplete","hasTransition","ease","easing","getRotateFromAngle","getRotatedTextSize","textBB","absSin","absCos","toMoveInsideBar","isHorizontal","constrained","isEnd","isStart","toRight","leftToRight","toLeft","textpad","extrapad","traceLayer","norm","bargap","groupgap","bargroupgap","bartraces","plotGroup","isFunnel","shouldDisplayZeros","adjustPixel","connector","withTransition","pointGroup","bars","bar","xy","sAxis","pAxis","s0","s1","getXY","getLineWidth","roundWithLine","fixpx","vc","hideZeroSpan","styleFns","appendTextNode","pLetter","vLetter","vAxis","formatNumber","labelLabel","u","valueLabel","rawS","deltaLabel","final","finalLabel","initial","initialLabel","percentInitial","begR","percentInitialLabel","percentPrevious","difR","percentPreviousLabel","percentTotal","sumR","percenTotalLabel","customdata","calcTexttemplate","textinfo","hasFlag","flag","nPercent","hasMultiplePercents","calcTextinfo","getValue","coerceString","getText","coerceEnumerated","getTextPosition","inStackOrRelativeMode","calcBar","isOutmostBar","_outmost","layoutFont","barColor","getBarColor","insideTextFont","getInsideTextFont","outsideTextFont","getOutsideTextFont","textSelection","barHeight","hasB","fitsInside","fitsInsideIfRotated","fitsInsideIfShrunk","currentTransform","constraintext","toMoveOutsideBar","insidetextanchor","appendBarText","hasClipOnAxisFalse","overrideCursor","legendSupplyDefaults","legendDraw","YANGLE","YA_RADIANS","YFACTOR","YSHIFTX","YSHIFTY","HOVERARROWSIZE","HOVERTEXTPAD","hoverDataKey","noHoverEvent","HOVERID","HOVERMINTIME","overlayedSubplots","pi","xaArray","yaArray","supportsCompare","spId","_subplot","unhoverRaw","xvalArray","yvalArray","itemnum","curvenum","subploti","closedataPreviousLength","hoverdistance","spikedistance","hoverData","searchData","spikePoints","hLinePoint","vLinePoint","hasOneHorizontalTrace","isTraceInSubplots","dbb","pointerX","pointerY","flat","p2c","findHoverPoints","customXVal","customYVal","getSubplot","maxSpikeDistance","xSpike","ySpike","zLabelVal","_splomScenes","pointNumber","newPoints","newPoint","newPointNum","cleanPoint","closestPoints","point","tmpPoint","closestVPoints","closestVPt","fillSpikePoint","closestHPoints","closestHPt","selectClosestPoint","pointsData","thisSpikeDistance","resultPoint","minDistance","spikelineOpts","oldspikepoints","_spikepoints","newspikepoints","tmpHPoint","tmpVPoint","spikesChanged","createSpikelines","d1","d2","isXYhover","hd","boxmode","violinmode","posLetter","dPos","repeated","oldhoverdata","newhoverdata","ht","rotateLabels","labelOpts","commonLabelOpts","hoverLabels","createHoverText","axKey","donepositioning","topOverlap","bottomOverlap","pti","sumdp","nummoves","nLabels","pointgroups","constrainGroup","grp","minPt","maxPt","pmin","pmax","deleteCount","del","axIsX","posref","by","g0","g1","hoverPt","hoverAvoidOverlaps","alignHoverText","tagName","hasClickToShow","oldPt","newPt","pointNumbers","hoverChanged","xvals","yvals","_hover","hoverItems","multiHover","hoverItem","xLabel","yLabel","zLabel","idealAlign","nameLength","textAlign","hovertemplateLabels","container3","outerContainer3","fullOpts","hoverLabel","lastBottomY","topY","anchorIndex","EXTRA_STRING_REGEX","HOVERFONT","HOVERFONTSIZE","c0","commonAttr","t00","outerContainerBB","outerTop","showCommonLabel","traceHoverinfo","allHaveZ","commonLabel","filterClosePoints","lpath","ltext","commonBgColor","commonStroke","contrastColor","commonLabelFont","tbb","topsign","halfWidth","leftsign","halfHeight","lty","ltx","dummyBB","textClip","mockLayoutIn","mockLayoutOut","legendOpts","texts","getHoverLabelText","txWidth","txHeight","overflowBottom","color0","numsColor","nameColor","tx2","tx2width","tx2height","t2bb","anchorStartOK","anchorEndOK","hty","txTotalWidth","ty0","bx","txwidth","txHalfWidth","overflowR","overflowL","nameOverride","extraText","horzSign","alignShift","txx","tx2x","posX","posY","pass","getVal","xerr","xeText","xerrneg","yerr","yeText","yerrneg","infomode","showY","showX","hLinePointX","hLinePointY","xBase","xEndSpike","dfltHLineColor","readability","yMode","yThickness","yColor","xEdge","xAcross0","xAcross1","cx","cy","vLinePointX","vLinePointY","yBase","yEndSpike","dfltVLineColor","xMode","xThickness","xColor","yEdge","yAcross0","yAcross1","percent","probability","density","yinc","minButtonWidth","rangeToShapePosition","shapePositionToRange","decodeDate","convertToPx","encodeDate","convertToDate","extractPathCoords","paramsToUse","extractedCoordinates","segmentRE","segment","relevantParamIdx","drawn","params","paramRE","getDataToPixel","dataToPixel","getPixelToData","pixelToData","roundPositionForSharpStrokeRendering","strokeWidth","strokeWidthIsOdd","posValAsInt","isLog","isCat","dtickDflt","dtickNum","manage","geo","newDistance","passVal","pointIndices","pointIndex","getPointKey","pointVal","getPointData","appendArrayMultiPointValues","keyVal","pointKeyMap","locations","parents","xyHoverMode","unifiedHoverMode","perStackAttrs","stackGroup","subplotStackOpts","firstTrace","attrFound","traceHasAttr","isOrientation","fillDflt","trace2","fxAttrs","_noTemplating","legendgroup","flags","extras","token","noBlank","strict","maxpoints","STASHATTR","savedCursor","classes","toImage","fileSaver","imageDataOnly","promise","filename","catch","contIn","inheritFontAttr","DRAGGERSIZE","initInteractions","maindrag","onmousemove","_hoversubplot","_lasthover","onmouseout","showAxisDragHandles","hoverLayer","findInterp","pixel","pixArray","maxBin","bin","pix0","pix1","bin0","bin1","findInterpFromCenters","centerPixArray","putColor","pixels","pxIndex","cdheatmaps","heatmapLayer","xCenter","yCenter","isContour","xrev","yrev","xfill","yfill","imageWidth","imageHeight","canvasW","canvasH","canvas","getContext","sclFunc","noNumericCheck","returnArray","xbi","ybi","pixcount","rcount","gcount","bcount","yinterp","xForPx","yForPx","xPixArray","yPixArray","xinterpArray","findInterpX","findInterpY","interpColor","setColor","createImageData","pxArray","dlen","putImageData","xGap","yGap","xGapLeft","yGapTop","fillStyle","fillRect","avgColor","image3","pixsize","xinterp","z00","z01","z10","z11","baseAttrs","hovertemplateAttrs","texttemplateAttrs","textFontAttrs","colorEditType","label0","dlabel","scalegroup","insidetextorientation","insidetextfont","outsidetextfont","hole","rotation","pull","_deprecated","titlefont","titleposition","groupClassName","inputAreaClass","railRectClass","railTouchRectClass","gripRectClass","tickRectClass","inputProxyClass","labelsClass","labelGroupClass","labelClass","currentValueClass","railHeight","railRadius","railWidth","railBorder","railBorderWidth","railBorderColor","railBgColor","railInset","stepInset","gripRadius","gripWidth","gripHeight","gripBorder","gripBorderWidth","gripBorderColor","gripBgColor","gripBgActiveColor","labelPadding","tickWidth","tickOffset","minorTickOffset","minorTickLength","currentValuePadding","currentValueInset","buttonDefaults","buttonIn","buttonOut","selectorOut","selectorIn","rangeselector","posDflt","anchoredList","getPosDflt","fromcurrent","dictionary","date","m4FromQuat","AxisIds","cleanAxRef","cleanTitle","titleContainer","rewireAttr","oldAttrName","newAttrName","oldAttrSet","newAttrSet","cleanFinanceDir","dirContainer","dirName","commonPrefix","name1","name2","show1","show2","cleanTextPosition","emptyContainer","outer","innerStr","clearPromiseQueue","cleanLayout","xaxis1","yaxis1","scene1","axisAttrRegex","polarAttrRegex","ternaryAttrRegex","ternary","sceneAttrRegex","isdate","islog","rangemode","autotick","aaxis","baxis","caxis","cameraposition","mat","eye","camera","up","zaxis","annotationsLen","shapesLen","cleanData","tracei","ybins","xbins","dc","yeColor","bardir","swapXYData","reversescl","containerName","highlightColor","highlightcolor","highlightWidth","highlightwidth","increasingShowlegend","increasing","decreasingShowlegend","decreasing","increasingName","decreasingName","filtersrc","valuecalendar","styles","prevStyles","styleKeys","autobinx","autobiny","transpose","errorY","copyYstyle","hoverInfoParts","coerceTraceIndices","traceIndicesOut","manageArrayContainers","undoit","pLength","pLastIsNumber","contPath","ATTR_TAIL_RE","getParent","hasParent","aobj","attrParent","clearAxisTypes","axAttr","sceneName","typeAttr","mockAnnAxes","fullSceneLayout","pdata","_xa","_pdata","_ya","anns","barnorm","annIn","annOut","borderOpacity","showArrow","arrowhead","hoverText","globalHoverLabel","hoverBG","hoverBorder","seen","newRange","minmin","maxmax","axReverse","minpt","maxpt","minbest","maxbest","rangeMode","toZero","nonNegative","axLen","minSpan","calcBreaksLength","lBreaks","rangebreaksOut","locateBreaks","mbest","lower","upper","maxPad","prev","rangeEnd","extrappad","_concat","collapseMinArray","collapseMaxArray","newPad","collapseArray","lessOrEqual","greaterOrEqual","atLeastAsExtreme","includeThis","clipAtZero","goodNumber","doAutoRange","axIn","axeRangeOpts","dmin","dmax","ppadiplus","ppadiminus","vmin","vmax","hasArrayOption","vpadLinearized","makePadAccessor","ppad","vpadplus","vpad","vpadminus","collapseOpts","addItem","iMax","arraysToCalcdata","binFunctions","normFunctions","doAvg","getBinSpanLabelRound","calcAllAutoBins","mainData","_overlayEdgeCase","pos0","autoVals","cumulativeSpec","binAttr","groupName","binOpts","_histogramBinOpts","isOverlay","cleanBound","setBound","bins","newBins","allPos","isFirstVisible","has2dMap","hasHist2dContour","mainDatai","dirs","makeCalcdata","_autoBin","newBinSpec","sizeFound","overlaidTraceGroup","xid","yid","getConnectedHistograms","pastThisTrace","singleValuedTraces","resulti","binSpeci","isSingleValued","dataVals","handleSingleValueOverlays","cumulative","currentbin","traceInputBins","traceBinOptsCalc","mainStart","startIn","hasStart","startFound","traceStart","newStart","mainEnd","endIn","hasEnd","endFound","traceEnd","autoBinAttr","i2","counterData","binsAndPos","binSpec","nonuniformBins","inputPoints","histnorm","histfunc","densityNorm","rawCounterData","sizeInit","binFunc","normFunc","isAvg","pr2c","_roundFnOpts","roundFnOpts","roundFn","uniqueValsPerBin","posi","currentBin","vi","prevSum","firstHalfPoint","nextHalfPoint","cdf","seriesLen","firstNonzero","lastNonzero","ph0","ph1","_computePh","histogram2dCalc","colorscaleCalc","convertColumnData","clean2dArray","interp2d","findEmpties","makeBoundArray","binned","isHist","isGL2D","zIn","_y","_z","connectgaps","_emptypoints","noZsmooth","msg","avgdx","maxErrX","avgdy","maxErrY","xIn","xtype","xArray","yIn","ytype","yArray","_hovertext","xRanges","yRanges","dummyTrace","PTS_LINESONLY","minTolerance","toleranceGrowth","maxScreensAway","eventDataKeys","menuDefaults","menuIn","menuOut","hidesources","datarevision","editrevision","selectionrevision","backoff","noRotate","parentObjIn","parentObjOut","previousContOut","SUBPLOT_PATTERN","getSubplotCalcData","calcData","arg1","remainingCalcData","getSubplotData","subplotX","subplotY","spmatch","piecolorway","extendpiecolors","colorScaleAttrs","colorScaleDefaults","colorAxIn","colorAxOut","colorAxes","coerceAx","coloraxis","coordDefaults","coordStr","xName","yName","ylen","zi","allRowsAreArrays","oneRowIsFilled","hasOneNumber","isValidZ","lightFraction","Loggers","utcFormat","DATETIME_REGEXP","DATETIME_REGEXP_CN","YFIRST","getFullYear","isWorldCalendar","calendars","lpad","sunday","tzOffset","getTimezoneOffset","offsetTweak","getUTCMinutes","getMinutes","getUTCSeconds","getSeconds","getUTCMilliseconds","getMilliseconds","comb","isWorld","isChinese","H","cDate","calInstance","isIntercalary","newDate","toMonthIndex","toJD","UTC","setUTCFullYear","getUTCMonth","getUTCDate","NINETYDAYS","THREEHOURS","FIVEMIN","includeTime","msec10","msecTenths","msRounded","dateJD","timeMs","fromJD","getUTCHours","getHours","fracMatch","modDateFormat","formatter","MAXSECONDS","extraFormat","year","month","timePart","timeStr","secStr","formatTime","dayMonthYear","dayMonth","THREEDAYS","dMonth","setUTCMonth","day","sequential","Reds","sequentialminus","Blues","diverging","_isSubplotObj","colorAttr","noColorAxis","showScaleDflt","hasColorscale","relinkColorAttrs","outerCont","cbOpt","isAuto","auto","autocolorscale","cbOpts","ARROWPATHS","cartesianConstants","startarrowhead","startstandoff","clicktoshow","xclick","yclick","newType","doExtra","toLog","fromLog","image","attrPrefix","currentPos","currentSize","newPos","newSize","factory","isFunction","vertxNext","customSchedulerFn","asap","queue","flush","scheduleFlush","browserWindow","browserGlobal","BrowserMutationObserver","MutationObserver","WebKitMutationObserver","isNode","process","isWorker","Uint8ClampedArray","importScripts","MessageChannel","useSetTimeout","globalSetTimeout","channel","iterations","observer","onFulfillment","onRejection","_arguments","child","constructor","PROMISE_ID","makePromise","_state","invokeCallback","_result","subscribe","object","_resolve","nextTick","observe","characterData","port1","onmessage","port2","postMessage","vertx","runOnLoop","runOnContext","attemptVertx","substring","GET_THEN_ERROR","ErrorObject","getThen","handleMaybeThenable","maybeThenable","then$$","thenable","fulfill","_reject","reason","handleOwnThenable","sealed","fulfillmentHandler","rejectionHandler","tryThen","_label","handleForeignThenable","publishRejection","_onerror","publish","_subscribers","subscribers","settled","detail","TRY_CATCH_ERROR","hasCallback","succeeded","failed","tryCatch","Enumerator","Constructor","_instanceConstructor","_remaining","_enumerate","resolver","needsResolver","initializePromise","needsNew","polyfill","local","P","promiseToString","cast","_eachEntry","entry","resolve$$","_then","_settledAt","_willSettleAt","enumerator","race","_setScheduler","scheduleFn","_setAsap","asapFn","_asap","attributeDefinition","defaultValue","coerceNumber","coerceColor","arrayOrScalar","baseFilter","calcDataFilter","filterFn","dict","regl","depth","hasColorbar","colorbarDefaults","isValidScale","npMaybe","parentCont","parentContIn","parentContOut","inTrace","thisFn","colorAx","colorbarVisuals","minIn","maxIn","validMinMax","autoColorscaleDflt","sclIn","sclTemplate","tickLen","clonePlot","svgToImg","clone","clonedGd","redrawFunc","delay","axesAttrs","deprecationWarning","domainAttr","mergeAttrs","axisName","nonCommonAttrs","commonAttrs","tickorientation","endpadding","ab","isView","DataView","_rowLength","len0","_constructor","arg0","argi","leni","allArray","totalLen","makeComputeErrorValue","dataPt","symmetric","arrayminus","valMinus","NaN","computeErrorValue","computeErrorValueMinus","valueminus","traceOpts","layoutOpts","traceEditTypeFlags","layoutEditTypeFlags","falseObj","editTypeOverride","overrideContainers","overrideOne","traceFlags","layoutFlags","editTypeParts","circle","rs","square","diamond","rd","cross","rc","rc2","ne","se","sw","nw","rt","r2","pentagon","hexagon","hexagon2","octagon","star","x3","x4","y3","y4","hexagram","aPart","rp","hourglass","bowtie","asterisk","scatterAttrs","FORMAT_LINK","hoverongaps","zhoverformat","autoColorDflt","configAttributes","editable","annotationTail","axisTitleText","colorbarPosition","colorbarTitleText","shapePosition","titleText","responsive","scrollZoom","toImageButtonOptions","displaylogo","plotGlPixelRatio","setBackground","topojsonURL","logging","notifyOnLogging","queueLength","dfltConfig","templateFormatStringDescription","DATE_FORMAT_LINK","describeVariables","descPart","quotedKeys","Image","ieSvgError","svgBlob","w0","h0","w1","h1","ctx","img","onload","imgData","drawImage","errorMsg","onerror","annotationsDone","emitClick","stopImmediatePropagation","ModeBar","axisConstraints","enforceAxisConstraints","cleanAxisConstraints","overlappingDomain","xDomain","yDomain","domains","existingX","existingY","lsInner","_hasZeroWidth","_hasZeroHeight","drawMainTitle","getLinePosition","lwHalf","_lw","lowerBackgroundIDs","backgroundIds","lowerDomains","noNeedForBg","pgNode","plotgroupBg","xLinesXLeft","xLinesXRight","xLinesYBottom","xLinesYTop","leftYLineWidth","rightYLineWidth","yLinesYBottom","yLinesYTop","yLinesXLeft","yLinesXRight","connectYBottom","connectYTop","extraSubplot","lowerBackgrounds","_bgLayer","plotClipId","plotClip","xLinePath","xLinePathFree","yLinePath","yLinePathFree","mainPath","pathFn","pathFnFree","xPath","shouldShowLinesOrTicks","findCounterAxisLineWidth","linecolor","yPath","shouldShowLineThisSide","sideIndex","getMainTitleX","textAnchor","hPadShift","getMainTitleY","vPadShift","layoutStyles","getMainTitleTextAnchor","getMainTitleDy","doTraceStyle","editStyleCalls","editStyle","doColorBars","layoutReplot","doLegend","doTicksRelayout","updateGrid","doModeBar","doCamera","sceneIds","sceneLayout","setViewport","drawData","cartesianIds","_splomGrid","doAutoRangeAndConstraints","axRng","groupLoop","finalDraw","drawMarginPushers","SHOWISOLATETIP","itemClick","itemclick","itemDoubleClick","itemdoubleclick","attrUpdate","attrIndices","carrs","carrIdx","thisLabelIndex","hasLegendgroup","traceIndicesInGroup","nextVisibility","setVisibility","isClicked","isInGroup","notInLegend","otherState","isIsolated","updateKeys","insertUpdate","attrIndex","valueArray","lastGroupbyIndex","curState","cn","cbbg","cbfill","cbfills","cbline","cblines","cbaxis","cbtitleunshift","cbtitle","cboutline","jsPlaceholder","styleOne","_pielayer","traceSelection","extendedColorWayList","makePullColorFn","colorMap","generateExtendedColors","colorList","extendedColorWays","colorString","toHexString","hiddenLabels","hasValues","_hasValues","allThisTraceLabels","pullColor","vTotal","isAggregated","hidden","colorWay","dfltColorCount","ASCEND","SIMPLEATTR","baseAttr","noLine","HOUR_PATTERN","WEEKDAY_PATTERN","isValidCategory","clip","dt2ms","ms2dt","getCategoryName","setCategoryIndex","curLength","getCategoryIndex","getCategoryPosition","_l2p","_p2l","px","_b","flip","signAx","b2","_B","_m2","l2c","l2d","d2p","p2d","r2c_just_indices","ind0","ind1","cleanRange","rangeAttr","DFLTRANGEY","DFLTRANGEX","linCenter","usePrivateRange","sign","bnds","b0","b1","vb","vDate","rangebreaksIn","getUTCDay","dvalue","addBreak","isNewBreak","brkj","bndDelta","t0Date","cal","setMultiCategoryIndex","isValidRange","emptyCategories","found","categoriesMap","ExtendModule","basePlotAttributes","baseLayoutAttributes","registerTraceModule","categoriesIn","plotType","componentName","findArrayRegexps","mergeComponentAttrsToSubplot","registerSubplot","categoryObj","allCategories","mergeComponentAttrsToTrace","traceLayoutAttributes","bpmName","styleRules","PlotlyGeoAssets","topojson","registerComponentModule","subplotName","transformType","mergeComponentAttrsToTransform","registerTransformModule","registerLocale","newDict","hasDict","hasFormat","localeObj","baseLocaleObj","arrayAttrRegexps","componentSchema","traceAttrs","transformAttrs","subplotModule","componentLayoutAttrs","getTraceType","apiMethodRegistry","register","newModule","ax1","var1Name","var2Name","arrayVarNames","colLen","col1","col2","textCol","hasColumnText","hoverTextCol","hasColumnHoverText","col1dv","col1vals","col2dv","col2vals","newArrays","after2before","i1","arrayVar","_after2before","plotApi","methodNames","PlotlyLocales","Icons","Snapshot","cursorset","drawShape","_shapeUpperLayer","_shapeLowerLayer","shapeLayer","getPathString","setClipPath","shapePath","shapeOptions","xAnchor","yAnchor","n0","e0","optN","optS","optW","optE","pathIn","dragMode","xPixelSized","xsizemode","yPixelSized","ysizemode","isLine","isPath","x2p","y2p","p2x","p2y","sensoryElement","sensoryWidth","circleStyle","circleRadius","createLineDragHandles","updateDragMode","renderVisualCues","clipAxes","deactivateClipPathTemporarily","moveShape","resizeShape","removeVisualCues","noOp","moveX","moveY","movePath","newX0","newY0","newX1","newY1","newN","newS","newW","newE","isNotPath","visualCues","paramIsX","paramIsY","crossPath","vBarPath","hBarPath","renderAnchor","setupDragElement","x2r","y2r","xSizemode","ySizemode","paramNumber","segmentType","xParams","yParams","nParams","numParams","paramString","param","convertPath","xAnchorPos","yAnchorPos","rArc","rightPt","handleCartesian","currentTarget","mag","rangeNow","rangeNew","handleDrag3d","val2d","handleCamera3d","didUpdate","sceneId","aspectratio","aspectmode","viewInitial","getNextHover3d","_previousVal","currentSpikes","hovermodeAStr","spikeAStr","handleGeo","geoIds","geoLayout","projection","newScale","resetView","getNextHover","toggleHover","newHover","handleMapboxZoom","mapbox","aObj","viewKeys","icon","disk","editInChartStudio","pencil","zoom2d","zoombox","pan2d","pan","select2d","selectbox","lasso2d","lasso","zoomIn2d","zoom_plus","zoomOut2d","zoom_minus","autoScale2d","autoscale","resetScale2d","home","hoverClosestCartesian","tooltip_basic","gravity","hoverCompareCartesian","tooltip_compare","zoom3d","pan3d","orbitRotation","tableRotation","resetCameraDefault3d","resetCameraLastSave3d","movie","hoverClosest3d","toggle","zoomInGeo","zoomOutGeo","resetGeo","hoverClosestGeo","hoverClosestGl2d","hoverClosestPie","resetViewSankey","_viewInitial","resetViews","toggleSpikelines","spikeline","areSpikesOn","setSpikelineVisibility","resetViewMapbox","zoomInMapbox","zoomOutMapbox","calcColorscale","groupnorm","stackgaps","smoothing","simplify","maxdisplayed","polybool","MINSELECT","filteredPolygon","polygonTester","getAxId","polygonOutlines","searchTraces","searchInfo","currentSelectionDef","selectionTester","thisTracesSelection","pointOrBinSelected","subtract","sendEvents","hoverOnBox","isHoverDataSet","coerceSelectionsCache","clickedPtInfo","hoverDatum","binNumber","extractClickedPtInfo","determineSearchTraces","tracesWithSelectedPts","isOnlyThisBinSelected","isOnlyOnePointSelected","isPointOrBinSelected","updateSelectedState","clearSelectionsCache","newPointSelectionDef","multiTester","selectionDefs","fillSelectionItem","drawSelection","mergedPolygons","isPointSelectionDef","newPointNumTester","pointSelectionDef","omitFirstEdge","idxWantedTrace","isRect","degenerate","testers","contained","selectingOnSameSubplot","_lastSelectedSubplot","hasModifierKey","altKey","xAxisIds","yAxisIds","_xaxes","_yaxes","createSearchInfo","sankeyInfo","outlines","paths","ppts","ptNum","ptNums","ptNumToTest","fullInputTrace","hasRegl","node3","nodeRangePlot3","filterPoly","currentPolygon","zoomLayer","allAxes","BENDPX","fillRangeItems","throttleID","SELECTID","axValue","ascending","poly","ranges","dataPts","lassoPoints","filtered","selectdirection","addPt","regions","inverted","mergePolygons","SELECTDELAY","thisSelection","traceSelections","doneFnCompleted","objIn","valOut","nestedSchema","getNestedSchema","nestedValType","isInfoArray","isColorscale","isInSchema","valInPart","valOutPart","arrayItems","len2","_p","_nestedSchema","indexList","valInj","valOutj","fillLayoutSchema","layoutSchema","traceSchema","traceLayoutAttr","errorList","transformsIn","transformsOut","transformSchema","code2msgFunc","inBase","unused","dynamic","invisible","convertPathToAttributeString","splitKey","keyMinusId","idMatch","SHOW_PLACEHOLDER","HIDE_PLACEHOLDER","z2","xx","yx","yy","zx","zy","zz","wx","wy","wz","xyAttrs","copy_zstyle","xyzAttrs","error_z","scatter","histogram","scatter3d","scattergl","hoverInfo","calcPoint","hoverPoint","yh","xh","bindingValueHasChanged","binding","computeLayoutBindings","bindings","computeDataBindings","thisTraces","nAttr","tmp","thisPath","commandList","onchange","_commandObserver","lookupTable","check","checkEvents","bindingsByValue","refBinding","command","_method","allArgs","computeAnimateBindings","subtypes","hoverOnBars","posVal","sizeLetter","pRangeCalc","isClosest","thisBarMinPos","thisBarMaxPos","minPos","bardelta","maxPos","_positionFn","_minPos","_maxPos","positionFn","sizeFn","sa","bargroupwidth","extents","thisBarPositionFn","barPointData","locationCache","workingPath","workingTextWidth","det","perpDistance2","xab","yab","llab","xac","yac","fcAB","xbc","ybc","crossProduct","x12","y12","x34","y34","ll12","ll34","dist2","totalPathLen","positionOnPath","getPointAtLength","atan","pCenter","buffer","pt0","ptTotal","pMin","pTotal","getTotalLength","pMax","getDistToPlot","distToPlot","isClosed","mid","pathLength","iterationLimit","mul","objName","copyAttr","inherit","contour","yl","nx","ny","zmask","zVal","handleShapeDefaults","shapeIn","shapeOut","shapeType","xSizeMode","ySizeMode","pos2r","r2pos","attrAnchor","sizeMode","attr0","attr1","in0","in1","inAnchor","xAxisMatch","yAxisMatch","AX_NAME_PATTERN","attributeTextFont","attributeInsideTextFont","attributeOutsideTextFont","styleTextPoints","determineFont","getTextFont","getFontValue","defaultFont","attributeValue","familyValue","sizeValue","colorValue","barcount","txs","selectedFontColor","styleTextInSelectionMode","stylePointsInSelectionMode","flipScale","handleAxisPositionDefaults","axisLayoutAttrs","colorBars","initOpts","_fillcolor","_line","_levels","_filllevels","_fillgradient","_zrange","calcOpts","moduleOpts","allowsMultiplotCbs","contName","showscale","_traceIndex","_propPrefix","colorAxOpts","makeColorBarData","titleSide","zrange","lineColormap","fillColormap","levelsIn","levelsOut","lineLevels","fillLevels","l0","ls","zr0","zr1","fillLevelsIn","calcLevels","thickPx","thickFrac","lenPx","lenFrac","xpadFrac","xpad","yExtraPx","outlinewidth","ypadFrac","ypad","xLeftFrac","yBottomFrac","yBottomPx","yTopPx","_lenFrac","_thickFrac","_xLeftFrac","_yBottomFrac","_axis","cbAxisIn","cbAxisOut","axisOptions","noHover","noTickson","mockColorBarAxis","titlex","titley","autoNtick","dtFactor","dtexp","titleCont","axLayer","titleHeight","titleClass","titleOpts","dfltTitleOpts","containerGroup","otherClass","titleGroup","titleTrans","mathJaxNode","lineSize","nlines","fills","zBounds","fillEl","lines","tickSign","maxShift","titleWidth","outerwidth","outerheight","outlinecolor","xoffset","marginOpts","tFrac","bFrac","lFrac","rFrac","extraThickness","drawColorBar","mouseOffset","coverSlip","cover","zIndex","pointerOffset","raw","dragCover","initialTarget","rightClick","onStart","_ontouchstart","ontouchstart","clampFn","onMove","dxdy","e2","MouseEvent","createEvent","initMouseEvent","bubbles","cancelable","view","screenX","screenY","metaKey","relatedTarget","dispatchEvent","lessThan","greaterThan","linelow","n1","n2","binSize","valsIn","errDiff","low","high","dlow","dhigh","rounded","sortFn","notOrdered","notReversed","pairOrder","xformMatrix","model","cloneLayoutOverride","tileClass","override","graphObj","keyName","oldData","oldLayout","axesImageOverride","showaxeslabels","linetickenable","plotTile","td","defaultLayout","mergeTemplates","oldTemplate","newTemplate","oldKeys","mergeOne","oldVal","oldItem","templateitemname","getBaseKey","key2","baseKey2","walkStyleKeys","templateOut","getAttributeInfo","basePath","pathAttr","nextPath","getNextPath","nextBasePath","baseKey","dfltDone","namedIndex","dfltPath","pathInArray","itemPropInArray","getLayoutInfo","getLayoutValObject","getTraceInfo","getTraceValObject","hasPlainObject","templateCount","makeTemplate","figure","traceTemplate","oldTypeTemplates","oldTypeLen","typeLen","oldLayoutTemplate","oldDataTemplate","validateTemplate","figureIn","layoutTemplate","layoutPaths","crawlLayoutForContainers","nextPaths","crawlLayoutTemplateForContainers","typeCount","crawlForMissingTemplates","LinkedList","selfIntersection","eps","segmentCopy","event_root","eventAdd","other_pt","here","p1_isStart","p1_1","p1_2","p2_isStart","p2_1","p2_2","comp","pointsCompare","pointsSame","pointAboveOrOnLine","eventCompare","other","eventAddSegment","primary","ev_start","status","eventAddSegmentStart","ev_end","eventAddSegmentEnd","eventDivide","segmentChop","eventUpdateEnd","calculate","primaryPolyInverted","secondaryPolyInverted","status_root","statusFindSurrounding","findTransition","ev1","ev2","a1","a2","pointsCollinear","checkIntersection","seg1","seg2","linesIntersect","a1_equ_b1","a2_equ_b2","a1_between","pointBetween","a2_between","alongA","alongB","isEmpty","getHead","vert","segmentNew","surrounding","before","after","checkBothIntersections","eve","tempStatus","segmentUpdate","rewind","st","exists","statusRemove","addRegion","region","pt1","pt2","forward","segments1","inverted1","segments2","inverted2","my","nextSegmentId","curVert","segmentRemove","reset","segs","chainStart","chainRemoveHead","chainRemoveTail","chainNew","chainMatch","chainClose","chainAddHead","chainAddTail","chainConnect","index1","index2","chainReverse","chainJoin","barLength","barRadius","barPad","boxL","boxR","boxT","boxB","isDown","isLeft","isUp","boxW","boxH","_box","needsHorizontalScrollBar","hbarW","hbarH","hbarL","hbarT","_hbarXMin","_hbarTranslateMax","needsVerticalScrollBar","vbarW","vbarH","vbarL","vbarT","_vbarYMin","_vbarTranslateMax","clipL","clipR","clipT","clipB","_clipRect","onBoxDrag","_onBoxDrag","_onBoxWheel","onBarDrag","_onBarDrag","xMin","xMax","yMin","yMax","translateXMax","translateYMax","imageDataAbove","imageDataSubplot","imageDataBelow","sizing","setImage","thisImage","_imgSrc","imagePromise","errorHandler","dataURL","applyAttributes","sizex","sizey","xOffset","yOffset","xPos","imagesBelow","_imageLowerLayer","imagesAbove","_imageUpperLayer","imagesOnSubplot","drawBg","rangeSlider","axisOpts","bgClassName","borderCorrect","offsetShift","_offsetShift","addClipPath","_clipId","drawRangePlot","rangePlots","rangePlotClassName","isMainPlot","oppAxisOpts","oppAxisName","oppAxisRangeOpts","mockFigure","filterRangePlotCalcData","drawMasks","maskMinClassName","maskColor","maskMaxClassName","maskMinOppAxisClassName","maskOppAxisColor","maskMaxOppAxisClassName","maskOppBorder","drawSlideBox","slideBoxClassName","slideBoxCursor","slideBoxFill","drawGrabbers","grabberMin","grabberMinClassName","grabberMax","grabberMaxClassName","handleFixAttrs","handleWidth","handleRadius","handleStrokeWidth","handleDynamicAttrs","handleMinClassName","handleMaxClassName","grabAreaFixAttrs","grabAreaWidth","grabAreaFill","grabAreaCursor","grabAreaMinClassName","grabAreaMaxClassName","rangeSliderData","_rangeSliderData","rangeSliders","newRng","extraPad","drl","rsBreaks","m2","range0OppAxis","distOppAxis","d2pOppAxis","slideBox","grabAreaMin","grabAreaMax","minVal","maxVal","mouseMove","pixelMin","pixelMax","_pixelMin","_pixelMax","clamp","requestAnimationFrame","setDataRange","mouseUp","hw2","clampOppAxis","clampHandle","pixelMinOppAxis","pixelMaxOppAxis","setPixelRange","legendLayout","isReversed","LOG_CLIP_PLUS","LOG_CLIP_MINUS","clusterStartPt","clusterEndPt","clusterHighPt","clusterLowPt","clusterHighFirst","clusterUnitVector","thisVector","clusterRefDist","clusterHighVal","clusterLowVal","clusterMinDeviation","clusterMaxDeviation","thisDeviation","latestXFrac","latestYFrac","xLog","yLog","xLen","yLen","connectGaps","baseTolerance","getPt","linearized","crossesViewport","xFrac0","yFrac0","xFrac1","yFrac1","norm2","getTolerance","nextPt","xFrac","yFrac","offScreenFraction","ptDist","lastXEdge","lastYEdge","lastFarPt","edgePt","getEdgeIntersections","xEdge0","xEdge1","yEdge0","yEdge1","onlyConstrainedPoint","sameEdge","getABAEdgeIntersections","dim","limit0","limit1","ptInt1","ptInt2","midShift","updateEdge","xSame","ySame","xSame2","ySame2","updateEdgesForReentry","intersections","lastPt","ptCount","edge","ptInt","handleDomainDefaults","handleText","handleLabelsAndValues","hasLabels","hasPositive","_hasLabels","textInfo","textTemplate","moduleHasSelected","moduleHasUnselected","moduleHasConstrain","moduleHasCliponaxis","moduleHasTextangle","moduleHasInsideanchor","titlePosition","v0In","dvIn","numbricks","down","handleXYDefaults","handleStackDefaults","handleMarkerDefaults","handleLineDefaults","handleLineShapeDefaults","handleTextDefaults","handleFillColorDefaults","stackGroupOpts","defaultMode","dfltHoverOn","markerColor","errorBarsSupplyDefaults","currentVal","noDash","getToggleSets","anni","showMode","pointj","onSet","offSet","explicitOffSet","hoverLen","clickData2r","_xclick","_yclick","explicitOff","sets","onClick","toggleSets","annotationsOut","drawModule","clickModule","convertCoords","hasBars","shouldBeGapless","gappedAnyway","usedSubplots","versions","NEIGHBORSHIFTS","correctionOvershoot","maxFractionalChange","iterateInterp2d","emptyPoints","overshoot","neighborShift","neighborRow","neighborVal","neighborSum","minNeighbor","maxNeighbor","stepsAttrs","currentvalue","activebgcolor","minorticklen","handleAnnotationCommonDefaults","handleAnnotationDefaults","clickToShow","arrowPosDflt","arrowPosAttr","aaxRef","aDflt","xClick","yClick","formatPiePercent","vRounded","lastIndexOf","formatPieValue","getFirstFilled","zref","sceneLayoutIn","sceneLayoutOut","JUNK","baseAttributes","frameAttributes","animationAttributes","polarAreaAttrs","polarAxisAttrs","editTypes","UNDERSCORE_ATTRS","recurseIntoValObject","valObject","newValObject","getLayoutAttributes","handleBasePlotModule","assignPolarLayoutAttrs","xkey","insertAttrs","formatAttributes","getFramesAttributes","makeSrcAttr","isValObject","mergeValTypeAndRole","itemName","formatArrayContainers","walk","newAttrs","IS_SUBPLOT_OBJ","IS_LINKED_TO_ARRAY","DEPRECATED","copyBaseAttributes","copyModuleAttributes","fullAttrString","Boolean","getTraceAttributes","getTransformAttributes","defs","valObjects","metaKeys","animation","specifiedLevel","attrString","baseContainer","baseAttrName","arrayAttributes","stack","isArrayStack","crawlIntoTrace","astrPartial","newAstrPartial","moduleAttrs","tNum","layoutAttrOverrides","baseOverrides","baseLayoutAttrOverrides","layoutHeadAttr","baseTraceAttrs","colorscales","valObjectDef","validateFunction","propMock","coerceFunction","data_array","requiredOpts","otherOpts","propOut","enumerated","integer","okToCoerce","colorlist","every","subplotid","regex","flaglist","vParts","any","info_array","coercePart","twoD","vNew","vOut","arrayItems2D","innerItemsOnly","attribute","propIn","dfltObj","valObj","smoDflt","usmoDflt","getUpdateObject","selectorKeyFunc","drawButtonRect","selectorLayout","_isActive","_isHovered","getFillColor","drawButtonText","getLabel","selectors","makeSelectorData","axisLayout","reposition","colorMix","mix","dfltColor","gridColor","blend","gridWidth","noZeroLine","zeroLineColor","zeroLineWidth","ptsIn","rectFirstEdgeTest","xmini","ycross","crossings","isSegmentBent","partParallel","startPt","segmentSquared","segmentLen","unitPerp","ptsFiltered","doneRawIndex","doneFilteredIndex","prevFilterLen","iLast","rangeLinear","buttonLayout","xrange","range0","currentRange","base2","range1","getXRange","listAxes","attachFxHandlers","sliceTop","_hasHoverLabel","_hasHoverEvent","fullLayout2","rInscribed","hoverCenterX","pxmid","hoverCenterY","percentLabel","originalEvent","determineInsideTextFont","customColor","prerenderTitles","dummyTitle","titleBox","transformInsideText","rpx1","startangle","stopangle","rCenter","textPosAngle","ring","isCircle","halfAngle","halfangle","midAngle","midangle","isTangential","allTransforms","considerCrossing","stop","isCrossing","dStart","dStop","closestEdge","calcTanTransform","calcRadTransform","textDiameter","calcMaxHalfSize","calcRCenter","calcRotate","tan","getInscribedRadiusFraction","transformOutsideText","outside","positionTitleOutside","plotSize","scaleX","scaleY","maxPull","topMiddle","ty","getMaxPull","getTitleSpace","pieBoxHeight","layoutAreas","scaleGroups","area","baseratio","groupScale","getCoords","formatSliceLabel","hasLabel","hasValue","hasPercent","makeTemplateVariables","ptTx","computeTransform","cosA","sinA","midX","midY","plotGroups","currentCoords","angleFactor","firstPt","largeArc","setCoords","slices","quadrants","hasOutsideText","slicePath","cxFinal","cyFinal","outerCircle","px0","outerArc","px1","rim","sliceTextGroup","sliceText","determineOutsideTextFont","newFont","textXY","yLabelMin","yLabelMid","yLabelMax","labelExtraX","labelExtraY","finish","cw","titleTextGroup","positionTitleInside","xHalf","yHalf","equatorFirst","farthestX","farthestY","xDiffSign","yDiffSign","thisQuad","oppositeQuad","wholeSide","thisQuadOutside","firstOppositeOutsidePt","topFirst","bottomFirst","scootOneLabel","prevPt","xBuffer","otherPt","newExtraX","prevOuterY","thisInnerY","thisOuterY","thisSliceOuterY","newExtraY","scootLabels","lineStartX","textLinePath","finalX","yFromX","yNet","plotTextLines","traceBbox","vpw","vph","calcSelection","serieslen","firstScatter","firstScatterGroup","stackOrientation","getStackOpts","xOptions","yOptions","openEnded","calcMarkerSize","markerTrans","sizeOut","setFirstScatter","stackAx","isV","interpolateGaps","posAttr","xAttr","yAttr","xValid","yValid","getAxisGroup","Sieve","setGroupPositions","excluded","included","scalendar","hasBase","initBase","setGroupPositionsInOverlayMode","sieve","sepNegVal","overlapNoMerge","positions","distinctPositions","overlap","barGroupWidth","alignmentGroups","barWidthPlusGap","offsetFromCenter","alignmentGroupOpts","alignmentgroup","nOffsetGroups","offsetGroups","_offsetIndex","barwidth","poffset","binWidth","setBarCenterAndWidth","updatePositionAxis","setOffsetAndWidthInGroupMode","inTraceSieve","put","unhideBarsWithinTrace","sieveBars","normalizeBars","setBaseAndTop","setGroupPositionsInGroupMode","setOffsetAndWidth","sLetter","getAxisLetter","stackBars","setGroupPositionsInStackOrRelativeMode","roundFactor","poffsetIsArray","pVal","collectExtents","newPoffset","calcTrace0","initialPoffset","initialBarwidth","newBarwidth","barwidthIsArray","allowMinDtick","calcBarOffset","calcBarWidth","allBaseAboveZero","sTop","sTiny","sMin","sMax","needsPadding","fullTraces","calcTracesHorz","calcTracesVert","paste","makeCoerceHoverInfo","fillFn","chains","first_match","matches_head","matches_pt1","second_match","next_match","chain","setMatch","addToHead","grow","grow2","oppo","oppo2","F","reverseF","reverseChain","appendChain","chain1","chain2","tail2","head2","makeIncrements","nonuniform","binsToCalc","getRanges","uniqueVals","gapLow","gapHigh","xr2c","yr2c","xBinsAndPos","xBinSpec","xPos0","yBinsAndPos","yBinSpec","yPos0","onecol","zerocol","nonuniformBinsX","nonuniformBinsY","xEdges","yEdges","densitynorm","sizeinit","binfunc","normfunc","doavg","xinc","xBinSize","xBinStart","xBinEnd","yBinSize","yBinStart","yBinEnd","ipCol","yc2r","uniqueValsPerX","uniqueValsPerY","xVals","yVals","xGapLow","xGapHigh","yGapLow","yGapHigh","hoverConstants","messages","handleGroupingDefaults","posAxId","alignmentOpts","alignmentIndex","offsetgroup","offsetGroupOpts","offsetIndex","hasPathbar","hasBoth","hasInside","hasOutside","dfltFont","insideTextFontDefault","isColorInheritedFromLayoutFont","pathbarTextFontDefault","hoverMode","rootPosition","srcElement","titleside","sliderOpts","sliderLabels","maxLabelWidth","labelHeight","stepOpts","drawLabel","inputAreaWidth","outerLength","inputAreaStart","inputAreaLength","availableSpacePerLabel","computedSpacePerLabel","labelStride","currentValueMaxWidth","currentValueHeight","currentValueTotalHeight","currentValueMaxLines","dummyGroup","curValPrefix","drawCurrentValue","curValSize","sliderGroup","valueOverride","curVal","drawGrip","attachGripEvents","drawLabelGroup","labelItems","labelSteps","normalizedValueToPosition","fraction","handleInput","normalizedPosition","doTransition","quantizedPosition","quantizedIndex","doCallback","previousActive","setGripPosition","slider","interaction","_nextMethod","_nextMethodRaf","$gd","getSliderOpts","grip","positionToNormalizedValue","tick","isMajor","_invokingCommand","drawTouchRect","drawRail","computedLength","sliderData","contOpts","makeSliderData","sliders","clearSlider","sliderGroups","gSlider","nsteps","computeLabelSteps","drawSlider","t2","raf","easeFn","unsetSubplotTransform","transitionInterrupt","doFrame","tInterp","progress","updateSubplot","transitionComplete","dx1","dy1","fracDx","fracDy","dfltAnchor","dfltDomain","dfltPosition","containerArrayMatch","isAddVal","isRemoveVal","applyContainerArrayChanges","_nestedProperty","componentType","supplyComponentDefaults","replotLater","replot","recalc","fullVal","componentNum","objEdits","objKeys","objVal","adding","componentNums","componentArrayIn","componentArray","componentArrayFull","deletes","firstIndexChange","maxIndex","indicesToDraw","colorbarAttrs","palettes","paletteStr","colorAttrFull","onlyIfNumerical","noScale","colorscaleDflt","contextHead","effectDesc","autoFull","minFull","maxFull","minmaxFull","autoImpliedEdits","minmaxImpliedEdits","containerArrayName","cartesianList","hasCartesianOrGL2D","itemi","hasXref","hasYref","newAxis","_sync","lgroupToTraces","lgroups","hasOneNonBlankGroup","slicesShown","lgroupi","addOneItem","legendGroup","uniqueGroup","lgroup","labelj","ltraces","lgroupsLength","colLength","maxlen","zlen","yTranspose","alpha","at","xys","extractScale","makeColorScaleFunc","baseObj","valueName","baseProp","changeTypes","indexLookup","isSimpleValueProp","changeType","newValue","rename","undoFunc","undoArgs","redoFunc","redoArgs","queueObj","queueIndex","undoQueue","inSequence","beginSequence","calls","plotDo","copyArgArray","0","L","V","Q","2","C","4","T","Z","1","3","5","inheritColorFromMarker","markerLineColor","axNum","only2d","idList","sceneIds3D","subplotLists","id1","id2","letter1","letter2","hasAnimation","sparse","errorbars","errorbar","coords","noYS","noXS","errorCoords","vis","yerror","yw","xerror","xw","xlink","PolyBool","BuildLog","Epsilon","Intersecter","SegmentChainer","GeoJSON","epsilon","operate","poly1","poly2","seg3","bl","combined","selectUnion","selectIntersect","selectDifference","selectDifferenceRev","selectXor","polygonFromGeoJSON","geojson","toPolygon","polygonToGeoJSON","fromPolygon","twoPI","aBnds","a0","_path","aStart","aMid","aEnd","rStart","rEnd","rBnds","undoCommands","isExecuting","setCallback","callbackFunc","hasUndo","hasRedo","getCommands","getPreviousCommand","getIndex","matchBeginning","fullTail","startWithPrefix","NOTEDATA","displayLength","notifierContainer","thisText","note","html","killNote","thisIndex","Ax","Ay","Bx","By","Cx","d_py_ly","d_rx_lx","d_px_lx","d_ry_ly","pointsSameX","pointsSameY","pt3","dx2","dy2","adx","ady","bdx","bdy","axb","A","B","pointInsideRegion","last_x","last_y","curr_x","curr_y","insertBlank","hasAnyBlanks","newEntry","prevEntry","getInterp","posj","sumj","valAttr","allPositions","_rawLength","cdj","arrayPad","ppadRaw","ends","startRot","endRot","headStyle","startHeadStyle","startScale","doStart","doEnd","backOff","startBackOff","hideLine","backOffX","backOffY","startBackOffX","startbackOffY","pathlen","start0","dstart","end0","dend","drawhead","arrowHeadStyle","rot","arrowScale","getShowAttrDflt","showAttrs","tickformatstopDefaults","showAttrDflt","tickSuffixDflt","handlePrefixSuffix","contColor","dfltFontColor","tickFormat","handleOtherDefaults","DOUBLEQUOTE_REGEX","DUMMY_REGEX","toppaper","_toppaper","nodes","topGroups","topGroup","queryParts","setAttributeNS","XMLSerializer","serializeToString","hiddenDiv","replaced","htmlEntityDecode","noMultiCategory","dcnt","ncnt","ai","stri","moreDates","curvenums","curvecats","linearOK","namePart","contPart","dfltDomains","dfltX","dfltY","newPlot","restyle","relayout","_guiRestyle","_guiRelayout","_guiUpdate","_storeDirectGUIEdit","react","extendTraces","prependTraces","addTraces","deleteTraces","moveTraces","addFrames","deleteFrames","animate","setPlotConfig","downloadImage","templateApi","calcXPaddingOptions","calcPaddingOptions","calcYPaddingOptions","isYAxis","axisDirectionReverted","maxValue","minValue","beforePad","afterPad","shapeBounds","convertVal","drawnParam","shapeList","vx0","vx1","vy0","vy1","Polar","manageArrays","subroutines","numericNameWarningCount","emitAfterPlot","opaqueSetBackground","setPlotContext","plot3dPixelRatio","clientHeight","clientWidth","szIn","szOut","positivifyIndices","parentLength","positiveIndices","assertIndexArray","arrayName","checkMoveTracesArgs","currentIndices","newIndices","spliceTraces","maxPoints","updateArray","maxPointsIsObject","assertExtendTracesArgs","updateProps","maxp","getExtendProperties","undoUpdate","undoPoints","concatTypedArray","arr0","arr1","arr2","_traces","specs","_restyle","fullReplot","markerSize","addAxRangeSequence","colorbars","redoit","plotDone","undefinedToNull","makeNP","preGUI","guiEditFlag","storeCurrent","arrayNew","maxLen","objNew","objBoth","_guiEditing","layoutNP","cleanDeprecatedAttributeKeys","addToAxlist","axid","autorangeAttr","getFullTrace","doextra","extraparam","allBins","arrayBins","vij","contFull","finalPart","prefixDot","innerContFull","impliedKey","labelsTo","valuesTo","topOrBottom","thicknorm","lennorm","defaultOrientation","oldAxisTitleRegex","colorbarRegex","oldAttrStr","newAttrStr","_relayout","axRangeSupplyDefaultsByPass","layoutstyle","axrange","rangesAltered","axOut","drawAxes","AX_RANGE_RE","AX_AUTORANGE_RE","AX_DOMAIN_RE","arrayEdits","axisAttr","newkey","recordAlteredAxis","pleafPlus","pend","pleaf","ptrunk","parentFull","vOld","oppositeAttr","axFull","fullProp","updateValObject","constraints","groupAxId","updateAutosize","traceUpdate","restyleSpecs","relayoutSpecs","guiEdit","layoutUIControlPatterns","traceUIControlPatterns","findUIPattern","patternSpecs","spec","getNewRev","revAttr","newRev","getFullTraceIndexFromUid","getTraceIndexFromUid","valsMatch","v1IsObj","v1IsArray","getDiffFlags","oldContainer","outerparts","getValObject","immutable","inArray","arrayIndex","arrays","nChanges","nChangesAnim","newDataRevision","valObjectCanBeDataArray","tickMode","_compareAsJSON","canBeDataArray","wasArray","nowArray","inputKey","oldValIn","newValIn","arrayEditIndices","extraIndices","makePlotFramework","gd3","_modebardiv","_hoverpaper","otherUids","layerBelow","_polarlayer","_ternarylayer","_geolayer","_funnelarealayer","_treemaplayer","_sunburstlayer","_indicatorlayer","layerAbove","frameOrGroupNameOrFrameList","animationOpts","trans","_frameQueue","getTransitionOpts","getFrameOpts","callbackOnNthTime","cb","_frameWaitingCnt","nextFrame","_currentFrame","newFrame","stringName","_lastFrameAt","_timeToNext","beginAnimationLoop","_runningTransitions","configCounter","setTransitionConfig","frameList","allFrames","isFrameArray","frameOrName","onInterrupt","discardExistingFrames","currentFrame","filteredFrameList","computedFrame","queueFrames","bigIndex","insertions","_frameHashLocal","lookupName","collisionPresent","ops","revops","frameCount","checkAddTracesArgs","startSequence","stopSequence","deletedTrace","newArray","remainder","none","both","numberOfItemsFromInsert","numberOfItemsFromTarget","targetBegin","movingTraceMap","newIndex","graphWasEmpty","plotContainer","polarPlotSVG","titleLayout","placeholderText","setContenteditable","plotLegacyPolar","drawFrameworkCalls","marginPushers","pick","_gl","drawingBufferWidth","drawingBufferHeight","configChanged","oldConfig","diffConfig","newConfig","oldRev","preGUIVal","newNP","layoutPreGUI","bothInheritAutorange","newRangeAccepted","newAx","allTracePreGUI","fulli","newTracei","applyUIRevisions","diffLayout","sameTraceLength","diffOpts","seenUIDs","diffData","project","glplot","cameraParams","graphDiv","constantAttrs","letterAttrs","cont2","N","sclNew","_range","_sclFunc","colorArray2rbga","colorObj","colorKey","isArrayWithOneNumber","legendTraceCount","legendReallyHasATrace","defaultOrder","defaultX","defaultY","defaultYAnchor","sizeRef","sizeMin","baseFn","baseSize","linePoints","linkTraces","cdscatter","cdscatterAll","yr","mnum","tnum","selectMarkers","errorBarGroup","ownFillEl3","tonext","ownFillDir","thispath","thisrevpath","prevRevpath","prevPolygons","prevtrace","_prevtrace","_prevRevpath","_nextFill","pathfn","revpathbase","revpathfn","lastSegment","thisPolygons","fullpath","revpath","makeUpdate","_ownFill","isEnter","lineJoin","clearFill","_prevPolygons","markerFilter","hideFilter","textFilter","showFilter","isInferZero","_needsCull","visFilterWithGaps","visFilter","gapFilter","makePoints","clipUrl","scatterLayer","isFullReplot","cdscatterSorted","traceJoin","fillData","_ownfill","_nexttrace","fillJoin","createFills","zOld","rowlen","collen","getCollen","old2new","cleanZvalue","padOld2new","axisMapping","axMapping","traceCategories","xMap","yMap","zNew","bottomDepth","days","shortDays","months","shortMonths","periods","dateTime","grouping","currency","Plotly","PlotlyComponent","_Component","props","_this","instance","_classCallCheck","_typeof","_assertThisInitialized","_possibleConstructorReturn","_getPrototypeOf","resizeHandler","syncWindowResize","syncEventHandlers","attachUpdateEvents","getRef","handleUpdate","figureCallback","updatePlotly","subClass","superClass","writable","configurable","_setPrototypeOf","_inherits","protoProps","staticProps","_defineProperties","_createClass","shouldInvokeResizeHandler","figureCallbackFunction","shouldAttachUpdateEvents","_this2","unmounting","onError","onInitialized","prevProps","numPrevFrames","numNextFrames","figureChanged","revisionDefined","revision","revisionChanged","onUpdate","onPurge","removeUpdateEvents","_this3","updateEvents","updateEvent","_this4","_this$el","invoke","_this5","useResizeHandler","debug","_this6","eventName","hasHandler","addEventHandler","removeEventHandler","getPlotlyEventName","_react","divId","Component","propTypes","_propTypes","arrayOf","bool","defaultProps","__esModule","_getRequireWildcardCache","newObj","hasPropertyDescriptor","getOwnPropertyDescriptor","desc","_interopRequireWildcard","WeakMap","Symbol","iterator","descriptor","setPrototypeOf","__proto__","ReferenceError","rangeContainerIn","rangeContainerOut","rangemodeDflt","yAxOut","coerceRange","traceref","tracerefminus","supported","detect","filli","tracej","scatterMarkerAttrs","LINKEDFILLS","tonextx","tonexty","groupIndex","groupIndices","needsSort","prevGroupIndex","nextGroupIndex","prevUnstackedGroupIndex","_groupIndex","traceA","traceB","prevtraces","handleCategoryOrderDefaults","handleLineGridDefaults","DAY_OF_WEEK","HOUR","rangebreaksDefaults","dfltPattern","indexOfDay","axTemplate","autorangeDflt","ticksonDflt","isMultiCategory","dayStrToNum","sun","mon","tue","wed","thu","fri","sat","isImpliedOrValid","layoutImage","configImage","wait","cleanup","urlToImageData","annAttrs","scatterLineAttrs","inputs","isDeep","keepAllKeys","noArrayCopies","copyIsArray","primitivesLoopSplice","interactConstants","numStripRE","editAttr","isplaceholder","elShouldExist","scootTitle","transformVal","titleElIn","backside","shiftSign","titlebb","paperbb","maxshift","avoidbb","shiftTemplate","Parser","graphInfo","proto","modeBarId","bgSelector","needsNewButtons","hasButtons","needsNewLogo","hasLogo","needsNewLocale","updateButtons","logoGroup","getLogo","updateActiveButton","buttonElements","buttonsNames","createGroup","buttonConfig","buttonName","createButton","createIcon","question","thisIcon","iconHeight","ascent","descent","svgNS","buttonClicked","dataAttrClicked","thisval","isToggleButton","button3","currentButtons","newplotlylogo","_privateplot","getBoxPosLetter","isBoxWithoutPositionCoords","isBox","isCandlestick","getFirstNonEmptyTrace","calAttr","_hasPreCompStats","boxPositions","setAutoType","getCentroid","ct","allBlankCharCodes","original","avg","GeoPoly","LineString","reg","coordinates","regionInsideRegion","children","roots","addChild","forceWinding","clockwise","winding","geopolys","addExterior","getInterior","oldValue"],"mappings":"mHAWA,IAAIA,EAAK,EAAQ,YAEbC,EAAQ,EAAQ,YAGpBC,EAAOC,QAAU,SAAeC,GAC5BA,EAAOC,MAAK,SAASC,GACjB,IAAIC,EAAQD,EAAE,GAAGC,MACbC,EAAOD,EAAME,SAAW,GACxBC,EAAOH,EAAMI,SAAW,GAExBC,EAAIZ,EAAGa,OAAOC,MAElBF,EAAEG,UAAU,eACPC,MAAM,eAAgBR,EAAKS,UAAY,MACvCC,KAAKjB,EAAMkB,OAAQX,EAAKY,OAE1BV,EAAKW,cAAaX,EAAOF,GAE5BI,EAAEG,UAAU,eACPC,MAAM,eAAgBN,EAAKO,UAAY,MACvCC,KAAKjB,EAAMkB,OAAQT,EAAKU,Y,8CCrBrC,IAAIpB,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YACpBC,EAAY,EAAQ,YAEpBC,EAAW,EAAQ,YACnBvB,EAAQ,EAAQ,YAChBwB,EAAa,EAAQ,YACrBC,EAAM,EAAQ,YACdC,EAAe,EAAQ,YAEvBC,EAAkB,EAAQ,YAE1BC,EADY,EAAQ,YACKA,aACzBC,EAAc,EAAQ,YAAgCA,YAEtDC,EAAW,EAAQ,YACnBC,EAAmB,EAAQ,YAC3BC,EAAwB,EAAQ,YAA+BA,sBAE/DC,EAAUhC,EAAOC,QAAU,GAM/B+B,EAAQC,KAAO,SAASvB,EAAGwB,EAAQC,EAAMjB,GAElCM,EAAIY,cAAcF,KACjBhB,EAAQgB,EAAOhB,MACfiB,EAAOD,EAAOC,KACdD,EAASA,EAAOA,QAEjBA,GAAQxB,EAAEI,MAAM,cAAeoB,GAC/BC,EAAO,GAAGzB,EAAEI,MAAM,YAAaqB,EAAO,MACtCjB,GAAOR,EAAEM,KAAKjB,EAAMsC,KAAMnB,IASjCc,EAAQM,YAAc,SAAS5B,EAAG6B,EAAGC,GAAK9B,EAAE+B,KAAK,IAAKF,GAAGE,KAAK,IAAKD,IACnER,EAAQU,QAAU,SAAShC,EAAGiC,EAAGC,GAAKlC,EAAE+B,KAAK,QAASE,GAAGF,KAAK,SAAUG,IACxEZ,EAAQa,QAAU,SAASnC,EAAG6B,EAAGC,EAAGG,EAAGC,GACnClC,EAAEM,KAAKgB,EAAQM,YAAaC,EAAGC,GAAGxB,KAAKgB,EAAQU,QAASC,EAAGC,IAc/DZ,EAAQc,eAAiB,SAAS1C,EAAG2C,EAAKC,EAAIC,GAC1C,IAAIV,EAAIS,EAAGE,IAAI9C,EAAEmC,GACbC,EAAIS,EAAGC,IAAI9C,EAAEoC,GAEjB,SAAGpB,EAAUmB,IAAMnB,EAAUoB,IAAMO,EAAII,UAER,SAAxBJ,EAAII,OAAOC,SACVL,EAAIN,KAAK,IAAKF,GAAGE,KAAK,IAAKD,GAE3BO,EAAIN,KAAK,YAAa,aAAeF,EAAI,IAAMC,EAAI,MAMpD,IAGXR,EAAQqB,gBAAkB,SAAS3C,EAAGsC,EAAIC,GACtCvC,EAAEP,MAAK,SAASC,GACZ,IAAI2C,EAAMjD,EAAGa,OAAOC,MACpBoB,EAAQc,eAAe1C,EAAG2C,EAAKC,EAAIC,OAI3CjB,EAAQsB,sBAAwB,SAASlD,EAAG2C,EAAKC,EAAIC,EAAIM,EAAWC,GAChET,EAAIN,KACA,UACCO,EAAGS,gBAAgBrD,EAAGmD,IAAcN,EAAGQ,gBAAgBrD,EAAGoD,GAAc,KAAO,SAIxFxB,EAAQ0B,uBAAyB,SAASC,EAAaC,GACnD,GAAIA,EAAQC,oBAAZ,CAEA,IAAIb,EAAKY,EAAQE,MACbb,EAAKW,EAAQG,MAEjBJ,EAAYxD,MAAK,SAASC,GACtB,IAAIC,EAAQD,EAAE,GAAGC,MACbkD,EAAYlD,EAAMkD,UAClBC,EAAYnD,EAAMmD,UAClBQ,EAAW1C,EAAS2C,QAAQ5D,EAAO,YAAc,WAAa,oBAElEsD,EAAY9C,UAAUmD,GAAU7D,MAAK,SAASC,GAC1C4B,EAAQsB,sBAAsBlD,EAAGN,EAAGa,OAAOC,MAAOoC,EAAIC,EAAIM,EAAWC,WAKjFxB,EAAQkC,WAAa,SAASC,EAAIC,EAAWC,GAIzC,OAAID,GAAchD,EAAUgD,GAGzBD,EAAGG,SAASC,WAAmBH,EAE/BA,EAAY,EAAU,EAClBI,KAAKC,MAAML,GAN6BC,GAAQ,GAS3DrC,EAAQ0C,gBAAkB,SAAStE,EAAGM,EAAGiE,EAAIC,EAAIC,GAC7CnE,EAAEI,MAAM,OAAQ,QAChB,IAAIgE,KAAU1E,GAAK,IAAI,IAAM,IAAIC,OAAS,IAAIyE,MAAQ,GAClDC,EAAMJ,GAAMG,EAAKE,OAAS,EAC1BC,EAAOJ,GAAMC,EAAKG,MAAQ,GAE9BlF,EAAMkB,OAAOP,EAAGkE,GAAME,EAAK5D,OAC3Bc,EAAQkD,SAASxE,EAAGuE,EAAMF,IAG9B/C,EAAQmD,eAAiB,SAASzE,EAAGiE,EAAIC,EAAIC,GACzCnE,EAAEI,MAAM,OAAQ,QACfX,MAAK,SAASC,GACX,IAAI0E,KAAU1E,GAAK,IAAI,IAAM,IAAIC,OAAS,IAAIyE,MAAQ,GAClDC,EAAMJ,GAAMG,EAAKE,OAAS,EAC1BC,EAAOJ,GAAMC,EAAKG,MAAQ,GAE9BnF,EAAGa,OAAOC,MACLI,KAAKjB,EAAMkB,OAAQ2D,GAAME,EAAK5D,OAC9BF,KAAKgB,EAAQkD,SAAUD,EAAMF,OAI1C/C,EAAQkD,SAAW,SAASxE,EAAGuE,EAAMb,GACjCA,GAAaA,GAAa,EAE1Ba,EAAOjD,EAAQoD,UAAUH,EAAMb,GAE/B1D,EAAEI,MAAM,CACJ,mBAAoBmE,EACpB,eAAgBb,EAAY,QAIpCpC,EAAQoD,UAAY,SAASH,EAAMb,GAC/BA,GAAaA,GAAa,EAC1B,IAAIiB,EAAMb,KAAKc,IAAIlB,EAAW,GAa9B,MAXY,UAATa,EAAkBA,EAAO,GACX,QAATA,EAAgBA,EAAOI,EAAM,MAAQA,EAAM,KAClC,SAATJ,EAAiBA,EAAQ,EAAII,EAAO,MAAS,EAAIA,EAAO,KAC/C,aAATJ,EAAqBA,EAAQ,EAAII,EAAO,MAAS,EAAIA,EAAO,KACnD,YAATJ,EACJA,EAAQ,EAAII,EAAO,MAAQA,EAAM,MAAQA,EAAM,MAAQA,EAAM,KAC9C,gBAATJ,IACNA,EAAQ,EAAII,EAAO,MAAS,EAAIA,EAAO,MAAQA,EAAM,MAAS,EAAIA,EAAO,MAItEJ,GAIXjD,EAAQuD,gBAAkB,SAASxC,GAC/B,IAEIyC,KAFO1F,EAAGa,OAAOoC,EAAII,QACTsC,OACQ,IAAM,IAAI,IAAM,IAAIpF,OAAS,IAAImF,UACtDA,GACCzC,EAAI/B,KAAKjB,EAAMsC,KAAMmD,IAI7BxD,EAAQ0D,eAAiB,SAAShF,GAC9BA,EAAEI,MAAM,eAAgB,GACvBX,MAAK,SAASC,GACX,IAAIuF,EAAQ7F,EAAGa,OAAOC,MAGnBR,EAAE,GAAGC,OACJsF,EAAM3E,KAAKjB,EAAMsC,KAAMjC,EAAE,GAAGC,MAAMmF,eAK9C,IAAII,EAAa,EAAQ,YAEzB5D,EAAQ6D,YAAc,GACtB7D,EAAQ8D,YAAc,GACtB9D,EAAQ+D,gBAAkB,GAC1B/D,EAAQgE,YAAc,GACtBhE,EAAQiE,aAAe,GACvBjE,EAAQkE,WAAa,GAErBC,OAAOC,KAAKR,GAAYS,SAAQ,SAASC,GACrC,IAAIC,EAASX,EAAWU,GACpBE,EAAID,EAAOC,EACfxE,EAAQkE,WAAWO,KACfD,EACAF,EACAE,EAAI,IACJF,EAAI,SAERtE,EAAQ6D,YAAYW,GAAKF,EACzBtE,EAAQ8D,YAAYU,GAAKD,EAAOG,EAE7BH,EAAOI,WACN3E,EAAQ+D,gBAAgBS,IAAK,GAE9BD,EAAOK,MACN5E,EAAQgE,YAAYQ,IAAK,EAEzBxE,EAAQkE,WAAWO,KACfD,EAAI,IACJF,EAAI,OACJE,EAAI,IACJF,EAAI,aAGTC,EAAOM,SACN7E,EAAQiE,aAAaO,IAAK,MAIlC,IAAIM,EAAY9E,EAAQ6D,YAAYkB,OAuBpC,SAASC,EAAcC,EAAcC,GACjC,IAAIC,EAAOF,EAAe,IAC1B,OAAOjF,EAAQ8D,YAAYqB,GAAMD,IAAMD,GAAgB,IAvB7C,8BAuB6D,IArB3EjF,EAAQiF,aAAe,SAASG,GAC5B,GAAgB,iBAANA,EAAgB,CACtB,IAAIC,EAAQ,EACTD,EAAEE,QAAQ,SAAW,IACpBD,EAAQ,IACRD,EAAIA,EAAEG,QAAQ,QAAS,KAExBH,EAAEE,QAAQ,QAAU,IACnBD,GAAS,IACTD,EAAIA,EAAEG,QAAQ,OAAQ,MAE1BH,EAAIpF,EAAQ6D,YAAYyB,QAAQF,KACxB,IAAKA,GAAKC,GAGtB,OAAQD,EAAI,KAAON,GAAaM,GAAK,IACjC,EAAI5C,KAAKgD,MAAMhD,KAAKc,IAAI8B,EAAG,KAQnC,IAAIK,EAAe,CAACC,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,GACzCC,EAAe,CAACJ,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,GACzCE,EAAgBjI,EAAGkI,OAAO,QAC1BC,EAAe,CACfC,OAAQ,CAAC/E,KAAM,kBACfgF,eAAgB,CAAChF,KAAM,iBAAkBiF,UAAU,GACnDC,WAAY,CAAClF,KAAM,iBAAkBmF,MAAOb,GAC5Cc,mBAAoB,CAACpF,KAAM,iBAAkBmF,MAAOb,EAAcW,UAAU,GAC5EI,SAAU,CAACrF,KAAM,iBAAkBmF,MAAOR,GAC1CW,iBAAkB,CAACtF,KAAM,iBAAkBmF,MAAOR,EAAcM,UAAU,IAiB9EpG,EAAQ0G,SAAW,SAAS3F,EAAKoB,EAAIwE,EAAYC,EAAMC,EAAYC,GAI/D,IAHA,IAAIC,EAAMF,EAAW9B,OACjBiC,EAAOf,EAAaW,GACpBK,EAAa,IAAIC,MAAMH,GACnBI,EAAI,EAAGA,EAAIJ,EAAKI,IACjBH,EAAKZ,SACJa,EAAWF,EAAM,EAAII,GAAK,CAACpB,EAAuC,KAAxB,EAAIc,EAAWM,GAAG,KAAYN,EAAWM,GAAG,IAEtFF,EAAWE,GAAK,CAACpB,EAAiC,IAAnBc,EAAWM,GAAG,IAAWN,EAAWM,GAAG,IAI9E,IAAIC,EAAajF,EAAGkF,YAChBC,EAAS,IAAMF,EAAWG,KAAO,IAAMZ,EAEvCD,EAAWU,EAAWI,MAAM7I,OAAO,cAClCE,UAAU,IAAMyI,GAChB7D,KAAK,CAACmD,EAAOK,EAAWQ,KAAK,MAAOjI,EAAIkI,UAE7ChB,EAASiB,OAAOC,SAEhBlB,EAASmB,QACJC,OAAOd,EAAK7F,MACZhD,MAAK,WACF,IAAI4J,EAAKjK,EAAGa,OAAOC,MAChBoI,EAAKV,OAAOyB,EAAGtH,KAAKuG,EAAKV,OAE5ByB,EAAGtH,KAAK,KAAM6G,GAEd,IAAIU,EAAQD,EAAGlJ,UAAU,QACpB4E,KAAKwD,GACVe,EAAML,OAAOC,SACbI,EAAMH,QAAQC,OAAO,QAErBE,EAAM7J,MAAK,SAASC,GAChB,IAAI6J,EAAK5I,EAAUjB,EAAE,IACrBN,EAAGa,OAAOC,MAAM6B,KAAK,CACjByH,OAAQ9J,EAAE,GAAK,IACf,aAAcL,EAAMoK,QAAQF,GAC5B,eAAgBA,EAAGG,mBAKnCrH,EAAIjC,MAAMgI,EAAMuB,EAAWf,EAAQnF,IAC9BrD,MAAMgI,EAAO,WAAY,MAE9B,IAAIwB,EAAkB,SAAS5J,GAC3B,MAAO,IAAMA,EAAE+B,KAAK,SAAS8E,QAAQ,MAAO,MAE5CjB,EAAIgE,EAAgBxK,EAAGa,OAAOoC,EAAII,OAAOoH,aACzC,IAAMD,EAAgBvH,GAC1BqG,EAAWoB,uBAAuBlE,GAAK,GAU3CtE,EAAQyI,cAAgB,SAAStG,GAC7B,IAAIiF,EAAajF,EAAGkF,YAEC7H,EAAIkJ,aAAatB,EAAWI,MAAO,IAAK,aAC9C3I,UAAU,iCAAiC+I,SAI1DR,EAAWoB,uBAAyB,IAIxCxI,EAAQ2I,WAAa,SAASjK,EAAGL,EAAO8D,GACpC,GAAIzD,EAAEyB,OAAN,CAEA,IAAIyI,EAAM5I,EAAQ6I,kBAAkBxK,GAEpCK,EAAEP,MAAK,SAASC,GACZ4B,EAAQ8I,iBAAiB1K,EAAGN,EAAGa,OAAOC,MAAOP,EAAOuK,EAAKzG,QAIjEnC,EAAQ8I,iBAAmB,SAAS1K,EAAG2C,EAAK1C,EAAOuK,EAAKzG,GACpD,IAAI4G,EAAS1K,EAAM0K,OACfC,EAAaD,EAAOjG,KAOxB,GALA/B,EAAIjC,MAAM,UACN8J,EAAIK,kBAAoBL,EAAIK,kBAAkB7K,QAChC8K,IAAT9K,EAAE+K,GAAmBJ,EAAOK,QAAUhL,EAAE+K,IAG9CP,EAAIS,OAAQ,CACX,IAAInE,EAIAA,EADQ,YAAT9G,EAAEkL,IAAoC,YAAhBP,EAAO5I,KACxB,EAEAyI,EAAIS,OAAOjL,EAAEkL,IAIrBlL,EAAEmL,IAAMrE,EAEL0D,EAAIY,iBACHtE,EAAI9G,EAAEmL,IAAMX,EAAIY,eAAepL,IAInC,IAAImC,EAAIP,EAAQiF,aAAa7G,EAAEqL,IAAMV,EAAOW,SAAW,EAIvDtL,EAAEuL,GAAKpJ,EAAI,KAAO,IAElBQ,EAAIN,KAAK,IAAKuE,EAAczE,EAAG2E,IAGnC,IACI0E,EAAWC,EAAWzH,EADtB0H,GAAmB,EAIvB,GAAG1L,EAAE2L,GACD3H,EAAY4G,EAAWgB,aACvBH,EAAYb,EAAWiB,aACvBL,EAAYb,EAAOkB,iBAChB,CACH,IAAIC,GAAmBlB,GAAc,IAAIhG,MAEzCZ,GACIhE,EAAE+L,IAAM,GACRD,EAAkB,IAEjB9L,EAAEC,OAASD,EAAEC,MAAM0K,OAAOjG,MAAQ,IAAIE,MAAQ,GAAK,GACpD,GAAK,EAEM6G,EAAZ,QAASzL,EAAeA,EAAEgM,KAAOxB,EAAIyB,UAAUjM,EAAEkM,KAE5C9K,EAAI+K,oBAAoBvB,EAAW9J,OAAoBnB,EAAMyM,YACpDxB,EAAW9J,MAEzBM,EAAI+K,oBAAoBxB,EAAO7J,SAC9B0K,EAAY7L,EAAMyM,YAClBV,GAAmB,GAInBF,EADD,OAAQxL,EACKA,EAAEqM,IAAM7B,EAAI8B,YAAYtM,EAAEuM,IAE1B5B,EAAO7J,OAAS,gBAG7B0J,EAAIgC,kBACHhB,EAAYhB,EAAIgC,gBAAgBxM,IAIxC,GAAGA,EAAEuL,GAGD5I,EAAI/B,KAAKjB,EAAMkB,OAAQ2K,GAClB9K,MAAM,CACH,gBAAiBsD,GAAa,GAAK,KACnC/B,KAAM,aAEX,CACHU,EAAIjC,MAAM,gBAAiBV,EAAEyM,QAAU,EAAIzI,GAAa,MAExD,IAAI0I,EAAiB/B,EAAOrC,SAExBqE,EAAe3M,EAAE4M,IAWrB,GAVGD,EAAcjB,GAAmB,EAC/BiB,EAAeD,GAAkBA,EAAelE,KAIlDM,MAAM+D,QAAQF,KACbA,EAAeA,EAAa,GACxB9E,EAAa8E,KAAeA,EAAe,IAGhDA,GAAiC,SAAjBA,EAAyB,CACxC,IAAIG,EAAgB9M,EAAE+M,IACnBD,EAAepB,GAAmB,EAChCoB,EAAgBJ,EAAe5L,MAEpC,IAAIyH,EAAatI,EAAM+M,IACpBtB,IAAkBnD,GAAc,IAAMvI,EAAE+I,GAE3CnH,EAAQ0G,SAAS3F,EAAKoB,EAAIwE,EAAYoE,EAClC,CAAC,CAAC,EAAGG,GAAgB,CAAC,EAAGtB,IAAa,aAE1C7L,EAAMsC,KAAKU,EAAK6I,GAGjBxH,GACCrE,EAAMkB,OAAO8B,EAAK8I,KAK9B7J,EAAQ6I,kBAAoB,SAASxK,GACjC,IAAIgN,EAAM,GACNtC,EAAS1K,EAAM0K,OAiBnB,OAbAsC,EAAIX,YAAc1K,EAAQsL,cAAcvC,EAAQ,IAChDsC,EAAIhB,UAAYrK,EAAQsL,cAAcvC,EAAQ,QAE3CzJ,EAAS2C,QAAQ5D,EAAO,aACvBgN,EAAIhC,OAASxJ,EAAS0L,SAASlN,GAC3ByB,EAAiBzB,GACjB,WAAa,OAAQ0K,EAAO5I,MAAQ,GAAK,IAG9C9B,EAAMmN,gBACLhM,EAAIiM,WAAWJ,EAAKrL,EAAQ0L,0BAA0BrN,IAGnDgN,GAGXrL,EAAQ0L,0BAA4B,SAASrN,GACzC,IAAIgN,EAAM,GAENM,EAAgBtN,EAAMuN,UAAY,GAClCC,EAAkBxN,EAAMyN,YAAc,GAEtC/C,EAAS1K,EAAM0K,QAAU,GACzBgD,EAAiBJ,EAAc5C,QAAU,GACzCiD,EAAmBH,EAAgB9C,QAAU,GAE7CI,EAAKJ,EAAOK,QACZ6C,EAAMF,EAAe3C,QACrB8C,EAAOF,EAAiB5C,QACxB+C,OAAuBjD,IAAR+C,EACfG,OAAyBlD,IAATgD,GAEjB1M,EAAI+K,oBAAoBpB,IAAOgD,GAAgBC,KAC9Cf,EAAIpC,kBAAoB,SAAS7K,GAC7B,IAAI+G,OAAgB+D,IAAT9K,EAAE+K,GAAmBJ,EAAOK,QAAUhL,EAAE+K,GAEnD,OAAG/K,EAAEwN,SACMO,EAAeF,EAAM9G,EAErBiH,EAAgBF,EAAOtM,EAAcuF,IAKxD,IAAIwF,EAAK5B,EAAO7J,MACZmN,EAAMN,EAAe7M,MACrBoN,EAAON,EAAiB9M,OAEzBmN,GAAOC,KACNjB,EAAIT,gBAAkB,SAASxM,GAC3B,IAAI+G,EAAO/G,EAAEqM,KAAOE,EAEpB,OAAGvM,EAAEwN,SACMS,GAAOlH,EAEPmH,GAAQnH,IAK3B,IAAImE,EAAKP,EAAO5I,KACZoM,EAAMR,EAAe5L,KACrBqM,EAAOR,EAAiB7L,KACxBsM,OAAuBvD,IAARqD,EACfG,OAAyBxD,IAATsD,EAcpB,OAZGlN,EAAS2C,QAAQ5D,EAAO,aAAeoO,GAAgBC,KACtDrB,EAAI7B,eAAiB,SAASpL,GAC1B,IAAI+G,EAAO/G,EAAEmL,KAAOD,EAAK,EAEzB,OAAGlL,EAAEwN,SACMa,EAAeF,EAAM,EAAIpH,EAEzBuH,EAAgBF,EAAO,EAAIrH,IAKvCkG,GAGXrL,EAAQ2M,yBAA2B,SAAStO,GACxC,IAAIgN,EAAM,GAENM,EAAgBtN,EAAMuN,UAAY,GAClCC,EAAkBxN,EAAMyN,YAAc,GAEtCc,EAAWvO,EAAMwO,UAAY,GAC7BC,EAAmBnB,EAAckB,UAAY,GAC7CE,EAAqBlB,EAAgBgB,UAAY,GAEjD5E,EAAK2E,EAAS1N,MACd8N,EAAMF,EAAiB5N,MACvB+N,EAAMF,EAAmB7N,MAa7B,OAXAmM,EAAI6B,oBAAsB,SAAS9O,GAC/B,IAAI+G,EAAO/G,EAAE6J,IAAMA,EAEnB,OAAG7J,EAAEwN,SACMoB,GAAO7H,EAEX8H,IACSD,EAAM7H,EAAOpH,EAAMoP,WAAWhI,EAAMvF,KAIjDyL,GAGXrL,EAAQoN,mBAAqB,SAAS1O,EAAGL,GACrC,GAAIK,EAAEyB,QAAW9B,EAAMmN,eAAvB,CAEA,IAAI5C,EAAM5I,EAAQ0L,0BAA0BrN,GACxC0K,EAAS1K,EAAM0K,QAAU,GACzBsE,EAAM,GAEPzE,EAAIK,mBACHoE,EAAI5I,MAAK,SAAS6I,EAAIlP,GAClBkP,EAAGxO,MAAM,UAAW8J,EAAIK,kBAAkB7K,OAI/CwK,EAAIgC,iBACHyC,EAAI5I,MAAK,SAAS6I,EAAIlP,GAClBL,EAAMsC,KAAKiN,EAAI1E,EAAIgC,gBAAgBxM,OAIxCwK,EAAIY,gBACH6D,EAAI5I,MAAK,SAAS6I,EAAIlP,GAClB,IAAIqL,EAAKrL,EAAEqL,IAAMV,EAAOW,QAAU,EAC9B6D,EAAO3E,EAAIY,eAAepL,GAE9BkP,EAAG7M,KAAK,IAAKuE,EAAchF,EAAQiF,aAAawE,GAAK8D,IAGrDnP,EAAEmP,KAAOA,KAIdF,EAAItI,QACHrG,EAAEP,MAAK,SAASC,GAEZ,IADA,IAAIkP,EAAKxP,EAAGa,OAAOC,MACXuI,EAAI,EAAGA,EAAIkG,EAAItI,OAAQoC,IAC3BkG,EAAIlG,GAAGmG,EAAIlP,QAM3B4B,EAAQsL,cAAgB,SAASvC,EAAQyE,GACrC,IAAIC,EAAOD,EAAShO,EAAIkO,eAAe3E,EAAQyE,GAAQG,MAAQ5E,EAE/D,GAAG0E,EAAM,CACL,IAAIG,EAAaH,EAAKvO,MACtB,IAAIuO,EAAK5G,YAAc4G,EAAKI,WAAarO,EAAI+K,oBAAoBqD,GAC7D,OAAOrO,EAAWuO,4BAA4BL,GAGtD,OAAOjO,EAAIkI,UAGf,IAAIqG,EAAiB,CACjBC,MAAO,EAAGC,KAAM,EAAGC,OAAQ,EAAGC,OAAQ,EAAGC,KAAM,GAGnD,SAASC,EAAkB3P,EAAG4P,EAAcC,EAAUC,GAClD,IAAIC,EAAQ3Q,EAAGa,OAAOD,EAAEyC,OAAOoH,YAE3BnD,GAAqC,IAAjCkJ,EAAahJ,QAAQ,OACzB,OACoC,IAApCgJ,EAAahJ,QAAQ,UAAmB,SAAW,SACnD1E,GAAsC,IAAlC0N,EAAahJ,QAAQ,QACzB,OACmC,IAAnCgJ,EAAahJ,QAAQ,SAAkB,QAAU,SAKjDJ,EAAIsJ,EAAeA,EAAe,GAAM,EAAI,EAE5CE,GAAYjP,EAAakP,UAAUjQ,GAAK,GAAKiB,EAAe,EAC5DiP,EAAKb,EAAenN,GAAKsE,EACzB2J,EAAgB,IAAXN,EAAkBR,EAAe3I,GAAKF,GAC1C6I,EAAe3I,GAAK,GAAKsJ,EAAWH,EAAW,EAGpD7P,EAAE+B,KAAK,cAAeG,GACtB6N,EAAMhO,KAAK,YAAa,aAAemO,EAAK,IAAMC,EAAK,KAG3D,SAASC,EAAmB1Q,EAAGC,GAC3B,IAAIkQ,EAAWnQ,EAAE2Q,IAAM1Q,EAAMwO,SAAS1M,KACtC,OAAQf,EAAUmP,IAAaA,EAAW,EAAKA,EAAW,EAI9DvO,EAAQgP,eAAiB,SAAStQ,EAAGL,EAAO8D,GACxC,GAAIzD,EAAEyB,OAAN,CAEA,IAAI+M,EACJ,GAAG7O,EAAMmN,eAAgB,CACrB,IAAI5C,EAAM5I,EAAQ2M,yBAAyBtO,GAC3C6O,EAAsBtE,EAAIsE,oBAG9B,IAAI+B,EAAe5Q,EAAM4Q,aACrB7H,EAAajF,EAAGkF,YAEpB3I,EAAEP,MAAK,SAASC,GACZ,IAAI8Q,EAAIpR,EAAGa,OAAOC,MAEduQ,EAAOF,EACPzP,EAAI4P,cAAchR,EAAGC,EAAO,MAAO,gBACnCmB,EAAI4P,cAAchR,EAAGC,EAAO,KAAM,QAEtC,GAAI8Q,GAAiB,IAATA,EAAZ,CAKA,GAAGF,EAAc,CACb,IAAII,EAAShR,EAAMiR,QAAQC,aAAelR,EAAMiR,QAAQC,aAAanR,EAAGC,EAAO+I,GAAc,GACzFoI,EAAc,GAClBzP,EAAsByP,EAAanR,EAAOD,EAAE+I,GAC5C,IAAIsI,EAAOpR,EAAMqR,OAAS,GAC1BP,EAAO3P,EAAImQ,mBAAmBR,EAAME,EAAQjI,EAAWwI,UAAWJ,EAAapR,EAAGqR,GAGtF,IAAII,EAAMzR,EAAE0R,IAAMzR,EAAM0R,aACpBxB,EAAWO,EAAmB1Q,EAAGC,GACjC2R,EAAY9C,EACZA,EAAoB9O,GACnBA,EAAE6J,IAAM5J,EAAMwO,SAAS3N,MAE5BgQ,EAAElQ,KAAKgB,EAAQC,KACP7B,EAAE6R,IAAM5R,EAAMwO,SAAS3M,OACvBqO,EACAyB,GACHb,KAAKA,GACLnQ,KAAKS,EAAayQ,gBAAiB/N,GACnCnD,KAAKqP,EAAmBwB,EAAKtB,EAAUnQ,EAAEmL,UAxB1C2F,EAAEtH,cA4Bd5H,EAAQmQ,kBAAoB,SAASzR,EAAGL,GACpC,GAAIK,EAAEyB,QAAW9B,EAAMmN,eAAvB,CAEA,IAAI5C,EAAM5I,EAAQ2M,yBAAyBtO,GAE3CK,EAAEP,MAAK,SAASC,GACZ,IAAIgS,EAAKtS,EAAGa,OAAOC,MACfqJ,EAAKW,EAAIsE,oBAAoB9O,GAC7B0R,EAAK1R,EAAE0R,IAAMzR,EAAM0R,aACnBxB,EAAWO,EAAmB1Q,EAAGC,GAErCN,EAAMsC,KAAK+P,EAAInI,GACfoG,EAAkB+B,EAAIN,EAAIvB,EAAUnQ,EAAEmP,MAAQnP,EAAEmL,UA2CxD,SAAS8G,EAAYC,EAAQC,EAAQC,EAAQC,GACzC,IAAIC,EAAMJ,EAAO,GAAKC,EAAO,GACzBI,EAAML,EAAO,GAAKC,EAAO,GACzBK,EAAMJ,EAAO,GAAKD,EAAO,GACzBM,EAAML,EAAO,GAAKD,EAAO,GACzBO,EAAMtO,KAAKuO,IAAIL,EAAMA,EAAMC,EAAMA,EAAKK,KACtCC,EAAMzO,KAAKuO,IAAIH,EAAMA,EAAMC,EAAMA,EAAKG,KACtCE,GAAQD,EAAMA,EAAMP,EAAMI,EAAMA,EAAMF,GAAOH,EAC7CU,GAAQF,EAAMA,EAAMN,EAAMG,EAAMA,EAAMD,GAAOJ,EAC7CW,EAAS,EAAIH,GAAOH,EAAMG,GAC1BI,EAAS,EAAIP,GAAOA,EAAMG,GAC9B,MAAO,CACH,CACInT,EAAG2E,MAAM8N,EAAO,IAAMa,GAAUF,EAAOE,GAAS,GAChDtT,EAAG2E,MAAM8N,EAAO,IAAMa,GAAUD,EAAOC,GAAS,IACjD,CACCtT,EAAG2E,MAAM8N,EAAO,IAAMc,GAAUH,EAAOG,GAAS,GAChDvT,EAAG2E,MAAM8N,EAAO,IAAMc,GAAUF,EAAOE,GAAS,KArD5DrR,EAAQsR,WAAa,SAASC,EAAKd,GAC/B,GAAGc,EAAIxM,OAAS,EAAK,MAAO,IAAMwM,EAAI9J,KAAK,KAC3C,IAEIN,EAFAqK,EAAO,IAAMD,EAAI,GACjBE,EAAW,GAEf,IAAItK,EAAI,EAAGA,EAAIoK,EAAIxM,OAAS,EAAGoC,IAC3BsK,EAAShN,KAAK4L,EAAYkB,EAAIpK,EAAI,GAAIoK,EAAIpK,GAAIoK,EAAIpK,EAAI,GAAIsJ,IAG9D,IADAe,GAAQ,IAAMC,EAAS,GAAG,GAAK,IAAMF,EAAI,GACrCpK,EAAI,EAAGA,EAAIoK,EAAIxM,OAAS,EAAGoC,IAC3BqK,GAAQ,IAAMC,EAAStK,EAAI,GAAG,GAAK,IAAMsK,EAAStK,EAAI,GAAG,GAAK,IAAMoK,EAAIpK,GAG5E,OADAqK,GAAQ,IAAMC,EAASF,EAAIxM,OAAS,GAAG,GAAK,IAAMwM,EAAIA,EAAIxM,OAAS,IAIvE/E,EAAQ0R,aAAe,SAASH,EAAKd,GACjC,GAAGc,EAAIxM,OAAS,EAAK,MAAO,IAAMwM,EAAI9J,KAAK,KAAO,IAClD,IAGIN,EAHAqK,EAAO,IAAMD,EAAI,GACjBI,EAAQJ,EAAIxM,OAAS,EACrB0M,EAAW,CAACpB,EAAYkB,EAAII,GAAQJ,EAAI,GAAIA,EAAI,GAAId,IAExD,IAAItJ,EAAI,EAAGA,EAAIwK,EAAOxK,IAClBsK,EAAShN,KAAK4L,EAAYkB,EAAIpK,EAAI,GAAIoK,EAAIpK,GAAIoK,EAAIpK,EAAI,GAAIsJ,IAM9D,IAJAgB,EAAShN,KACL4L,EAAYkB,EAAII,EAAQ,GAAIJ,EAAII,GAAQJ,EAAI,GAAId,IAGhDtJ,EAAI,EAAGA,GAAKwK,EAAOxK,IACnBqK,GAAQ,IAAMC,EAAStK,EAAI,GAAG,GAAK,IAAMsK,EAAStK,GAAG,GAAK,IAAMoK,EAAIpK,GAGxE,OADAqK,GAAQ,IAAMC,EAASE,GAAO,GAAK,IAAMF,EAAS,GAAG,GAAK,IAAMF,EAAI,GAAK,KA4B7E,IAAIK,EAAW,CACXC,GAAI,SAASC,EAAIC,GACb,MAAO,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,GAAK,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,IAE5DC,GAAI,SAASF,EAAIC,GACb,MAAO,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,GAAK,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,IAE5DE,IAAK,SAASH,EAAIC,GACd,MAAO,IAAMjU,EAAG2E,OAAOqP,EAAG,GAAKC,EAAG,IAAM,EAAG,GAAK,IAC5CjU,EAAG2E,MAAMsP,EAAG,GAAI,GAAK,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,IAEnDG,IAAK,SAASJ,EAAIC,GACd,MAAO,IAAMjU,EAAG2E,OAAOqP,EAAG,GAAKC,EAAG,IAAM,EAAG,GAAK,IAC5CjU,EAAG2E,MAAMsP,EAAG,GAAI,GAAK,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,KAGnDI,EAAa,SAASL,EAAIC,GAC1B,MAAO,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,GAAK,IAAMjU,EAAG2E,MAAMsP,EAAG,GAAI,IAE5D/R,EAAQoS,MAAQ,SAASzO,GACrB,IAAI0O,EAAUT,EAASjO,IAAUwO,EACjC,OAAO,SAASZ,GAEZ,IADA,IAAIC,EAAO,IAAM1T,EAAG2E,MAAM8O,EAAI,GAAG,GAAI,GAAK,IAAMzT,EAAG2E,MAAM8O,EAAI,GAAG,GAAI,GAC5DpK,EAAI,EAAGA,EAAIoK,EAAIxM,OAAQoC,IAC3BqK,GAAQa,EAAQd,EAAIpK,EAAI,GAAIoK,EAAIpK,IAEpC,OAAOqK,IAMfxR,EAAQsS,WAAa,WACjB,IAAIC,EAAS/S,EAAIgT,iBAAiB1U,EAAGa,OAAO,QAAS,MAAO,oBAAoB,SAASD,GACrFA,EAAE+B,KAAKf,EAAgB+S,UAClB3T,MAAM,CACH4T,SAAU,WACVC,KAAM,WACNvE,IAAK,WACLpL,MAAO,SACP4P,OAAQ,SACR,UAAW,SAOnBC,EAAUrT,EAAIkJ,aAAa6J,EAAQ,OAAQ,sBAAsB,SAAS7T,GAC1EA,EAAE+B,KAAK,IAAK,eACP3B,MAAM,CACH,eAAgB,EAChBuB,KAAM,aAIlBL,EAAQuS,OAASA,EACjBvS,EAAQ6S,QAAUA,GAyBtB7S,EAAQ8S,YAAc,GACtB,IAAIC,EAAmB,EA+GvB,SAASC,EAAS7R,GACd,IAAI8R,EAAY9R,EAAK+R,aAAa,oBAClC,GAAiB,OAAdD,EACH,OAAOA,EACH9R,EAAK+R,aAAa,aAClB/R,EAAK+R,aAAa,eAClB/R,EAAK+R,aAAa,SAmB1B,SAAS7K,EAAW8K,EAAShR,GACzB,IAAIgR,EAAS,OAAO,KAEpB,IAAIC,EAAUjR,EAAGG,SAEjB,MAAO,SADO8Q,EAAQC,cAAgB,GAAMD,EAAQE,UAAY,IACpC,IAAMH,EAAU,KA1IhDnT,EAAQuT,KAAO,SAASpS,EAAMqS,EAAUC,GAUpC,IAAIpI,EAiDAqI,EAAUnB,EAhDd,GAFIkB,IAAMA,EAAOT,EAAS7R,IAEvBsS,GAEC,GADApI,EAAMrL,EAAQ8S,YAAYW,GAClB,OAAOjU,EAAIiM,WAAW,GAAIJ,QAC/B,GAA8B,IAA3BlK,EAAKwS,WAAW5O,OAAc,CAOpC,IAAI6O,EAAYzS,EAAKwS,WAAW,GAGhC,GADAF,EAAOT,EAASY,GACP,CACL,IAAIrT,GAAKqT,EAAUV,aAAa,MAAQ,EACpC1S,GAAKoT,EAAUV,aAAa,MAAQ,EACpCW,EAAYD,EAAUV,aAAa,aAEvC,IAAIW,EAAW,CAGX,IAAIC,EAAU9T,EAAQuT,KAAKK,GAAW,EAAOH,GAS7C,OARGlT,IACCuT,EAAQnB,MAAQpS,EAChBuT,EAAQC,OAASxT,GAElBC,IACCsT,EAAQ1F,KAAO5N,EACfsT,EAAQ3F,QAAU3N,GAEfsT,EAeX,GAHAL,GAAQ,IAAMlT,EAAI,IAAMC,EAAI,IAAMqT,EAElCxI,EAAMrL,EAAQ8S,YAAYW,GAClB,OAAOjU,EAAIiM,WAAW,GAAIJ,IAIvCmI,EACCE,EAAWvS,GAEXoR,EAASvS,EAAQuS,OAAOpR,OAGxBuS,EAAWvS,EAAK6S,WAAU,GAC1BzB,EAAO0B,YAAYP,IAIvB5V,EAAGa,OAAO+U,GACLjT,KAAK,YAAa,MAClBzB,KAAKS,EAAayU,aAAc,EAAG,GAExC,IAAIC,EAAWT,EAASU,wBACpBC,EAAUrU,EAAQ6S,QACjB1R,OACAiT,wBAEDZ,GAAUjB,EAAO+B,YAAYZ,GAEjC,IAAIa,EAAK,CACL3B,OAAQuB,EAASvB,OACjB5P,MAAOmR,EAASnR,MAChB2P,KAAMwB,EAASxB,KAAO0B,EAAQ1B,KAC9BvE,IAAK+F,EAAS/F,IAAMiG,EAAQjG,IAC5B2F,MAAOI,EAASJ,MAAQM,EAAQ1B,KAChCxE,OAAQgG,EAAShG,OAASkG,EAAQjG,KAetC,OATG2E,GAhGc,MAiGb/S,EAAQ8S,YAAc,GACtBC,EAAmB,GAIpBU,IAAMzT,EAAQ8S,YAAYW,GAAQc,GACrCxB,IAEOvT,EAAIiM,WAAW,GAAI8I,IA0B9BvU,EAAQwU,WAAa,SAAS9V,EAAGyU,EAAShR,GACtCzD,EAAE+B,KAAK,YAAa4H,EAAW8K,EAAShR,KAW5CnC,EAAQyU,aAAe,SAASC,GAG5B,IAIIC,GAFYD,EADHA,EAAQjU,KAAO,OAAS,gBACL,cAAgB,IAEtB8E,QAJjB,2DAI6B,SAASqP,EAAO7C,EAAI8C,GACtD,MAAO,CAAC9C,EAAI8C,GAAIpN,KAAK,QAExBqN,MAAM,KAEP,MAAO,CACHvU,GAAIoU,EAAU,IAAM,EACpBnU,GAAImU,EAAU,IAAM,IAI5B3U,EAAQ+U,aAAe,SAASL,EAASnU,EAAGC,GACxC,IACIwU,EAASN,EAAQjU,KAAO,OAAS,eACjCwU,EAASP,EAAQjU,KAAO,OAAS,eACjCoT,EAAYa,EAAQM,GAAQ,cAAgB,GAWhD,OATAzU,EAAIA,GAAK,EACTC,EAAIA,GAAK,EAETqT,EAAYA,EAAUtO,QARb,yBAQyB,IAAI2P,OAEtCrB,GADAA,GAAa,cAAgBtT,EAAI,KAAOC,EAAI,KACtB0U,OAEtBR,EAAQO,GAAQ,YAAapB,GAEtBA,GAGX7T,EAAQmV,SAAW,SAAST,GACxB,IAIIC,GAFYD,EADHA,EAAQjU,KAAO,OAAS,gBACL,cAAgB,IAEtB8E,QAJjB,kDAI6B,SAASqP,EAAO7C,EAAI8C,GACtD,MAAO,CAAC9C,EAAI8C,GAAIpN,KAAK,QAExBqN,MAAM,KAEP,MAAO,CACHvU,GAAIoU,EAAU,IAAM,EACpBnU,GAAImU,EAAU,IAAM,IAI5B3U,EAAQoV,SAAW,SAASV,EAASnU,EAAGC,GACpC,IACIwU,EAASN,EAAQjU,KAAO,OAAS,eACjCwU,EAASP,EAAQjU,KAAO,OAAS,eACjCoT,EAAYa,EAAQM,GAAQ,cAAgB,GAWhD,OATAzU,EAAIA,GAAK,EACTC,EAAIA,GAAK,EAETqT,EAAYA,EAAUtO,QARb,qBAQyB,IAAI2P,OAEtCrB,GADAA,GAAa,UAAYtT,EAAI,KAAOC,EAAI,KAClB0U,OAEtBR,EAAQO,GAAQ,YAAapB,GAEtBA,GAGX,IAAIwB,EAAW,UAEfrV,EAAQsV,mBAAqB,SAASC,EAAWC,EAAQC,GAIrD,GAHAD,EAASA,GAAU,EACnBC,EAASA,GAAU,EAEfF,EAAJ,CAGA,IAAIG,EAAoB,IAAXF,GAA2B,IAAXC,EACzB,GACA,UAAYD,EAAS,IAAMC,EAAS,IAExCF,EAAUpX,MAAK,WACX,IAAIwX,GAAK/W,KAAKsU,aAAa,cAAgB,IAAI3N,QAAQ8P,EAAU,IAEjEM,GADAA,GAAKD,GACCR,OACNtW,KAAKgX,aAAa,YAAaD,QAIvC,IAAIE,EAAiC,yBAErC7V,EAAQ8V,mBAAqB,SAASP,EAAWC,EAAQC,GACjDF,GAEJA,EAAUpX,MAAK,WACX,IAAI4X,EACAhO,EAAKjK,EAAGa,OAAOC,MACfuQ,EAAOpH,EAAGpJ,OAAO,QAErB,GAAIwQ,EAAKhO,OAAT,CAEA,IAAIZ,EAAIyV,WAAW7G,EAAK1O,KAAK,MAAQ,GACjCD,EAAIwV,WAAW7G,EAAK1O,KAAK,MAAQ,GAEjCwV,GAAqBlO,EAAGtH,KAAK,cAAgB,IAAImU,MAAMiB,GAGvDE,EADU,IAAXP,GAA2B,IAAXC,EACF,GAEA,CACT,aAAelV,EAAI,IAAMC,EAAI,IAC7B,SAAWgV,EAAS,IAAMC,EAAS,IACnC,cAAiBlV,EAAK,KAAQC,EAAK,KAIxCyV,GACCF,EAAWtR,KAAKwR,GAGpBlO,EAAGtH,KAAK,YAAasV,EAAWtO,KAAK,Y,8CCppC7C,IAAIjI,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAChBmY,EAAiB,EAAQ,YAA+BA,eACxDC,EAA0B,EAAQ,YAClCC,EAAW,EAAQ,YACnBC,EAA2B,EAAQ,YAEnCC,EAAmB,EAAQ,YAC3BC,EAAqB,EAAQ,YAC7BC,EAAqB,EAAQ,YAC7BC,EAA2B,EAAQ,YAAiBA,yBACpDC,EAAyB,EAAQ,YAEjCC,EAAU,EAAQ,YAClBC,EAAUD,EAAQC,QAClBC,EAAUF,EAAQE,QAElBC,EAAgB,EAAQ,YAAeA,cAEvCxX,EAAW,EAAQ,YACnB2C,EAAU3C,EAAS2C,QACnB8U,EAAqBzX,EAASyX,mBAElC,SAASC,EAAWvJ,EAAMnJ,EAAG2S,GACtB/P,MAAM+D,QAAQwC,EAAKnJ,IAAKmJ,EAAKnJ,GAAGG,KAAKwS,GACnCxJ,EAAKnJ,GAAK,CAAC2S,GAGpBjZ,EAAOC,QAAU,SAA8BiZ,EAAUC,EAAWC,GAChE,IAUIjQ,EAAGkQ,EAVHC,EAAY,GACZC,EAAY,GACZC,EAAY,GACZC,EAAgB,GAChBC,EAAgB,GAChBC,EAAmB,GACnBC,EAAe,GACfC,EAAa,GACbC,EAAa,GACbC,EAAU,GAId,IAAI5Q,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK,CACjC,IAAI9I,EAAQ+Y,EAASjQ,GACrB,GAAIlF,EAAQ5D,EAAO,cAAiB4D,EAAQ5D,EAAO,QAAnD,CAEA,IAAI2Z,EAUAC,EATJ,GAAG5Z,EAAMyD,MACLkW,EAASpB,EAAQvY,EAAMyD,OACvBkV,EAAWM,EAAWU,EAAQ3Z,QAC3B,GAAGA,EAAM6Z,MACZ,IAAIb,EAAI,EAAGA,EAAIhZ,EAAM6Z,MAAMnT,OAAQsS,IAC/BL,EAAWM,EAAWV,EAAQvY,EAAM6Z,MAAMb,IAAKhZ,GAKvD,GAAGA,EAAM0D,MACLkW,EAASrB,EAAQvY,EAAM0D,OACvBiV,EAAWM,EAAWW,EAAQ5Z,QAC3B,GAAGA,EAAM8Z,MACZ,IAAId,EAAI,EAAGA,EAAIhZ,EAAM8Z,MAAMpT,OAAQsS,IAC/BL,EAAWM,EAAWV,EAAQvY,EAAM8Z,MAAMd,IAAKhZ,GA4CvD,GAvCkB,WAAfA,EAAMuI,KACoB,MAAtBvI,EAAM+Z,aACFJ,IAAQT,EAAUS,IAAU,GAC5BC,IAAQL,EAAaK,IAAU,IAE/BA,IAAQT,EAAUS,IAAU,GAEd,UAAf5Z,EAAMuI,MACTqR,IAAQJ,EAAWI,IAAU,GAC7BD,IAAQH,EAAWG,IAAU,KAE7BC,IACCP,EAAcO,IAAU,EACxBN,EAAiBM,IAAU,GAG3BhW,EAAQ5D,EAAO,YAA6B,WAAfA,EAAMuI,MAAsBvI,EAAMga,WAC5DL,IAAQP,EAAcO,IAAU,IAYzB,WAAf3Z,EAAMuI,MAAqBvI,EAAMga,UAC7BL,IAAQT,EAAUS,IAAU,GAIhC/V,EAAQ5D,EAAO,WACdyZ,EAAWE,IAAU,EACrBF,EAAWG,IAAU,GAGtBhW,EAAQ5D,EAAO,YAEd0Z,EADyC,MAAtB1Z,EAAM+Z,YAAsBH,EAASD,IAChC,GAIhC,IAAIM,EAAWnB,EAAUoB,UACrBC,EAAOF,EAASxW,MAChB2W,EAAOH,EAASvW,MAChB2W,EAASlZ,EAAImZ,UAAUH,EAAM5B,GAC7BgC,EAASpZ,EAAImZ,UAAUF,EAAM7B,GAC7BiC,EAAUH,EAAOI,OAAOF,GAIxBG,EAAchb,EAAMib,WACrBR,EAAKzT,QAAU0T,EAAK1T,SACnBgU,EAAcvZ,EAAIyZ,OAAO/B,EAAUC,EAAWd,EAA0B,iBAG5E,IAGI6C,EAEAC,EAEAC,EAEAC,EAEAC,EAXAC,EAAUxb,EAAMyb,QAAQT,EAAa5B,EAAUsC,eAanD,SAASC,IACL,IAAIxb,EAASoZ,EAAU4B,IAAW,GAClCI,EAAYK,cAAgBzb,EAAO0b,KAAI,SAASjE,GAAK,OAAOA,EAAEkE,kBAC9DP,EAAYQ,YAAc,GAC1BR,EAAYS,cAAgB,GAC5BT,EAAYU,YAAc,GAC1BV,EAAYW,cAAgB,GAC5BX,EAAYY,aAAe,GAC3BZ,EAAYa,MAAQb,EAAYc,MAAQlB,EACxCI,EAAYe,IAAMlB,EAGtB,SAASF,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOI,EAAYC,EAAahD,EAAkB7V,EAAM4B,GAGvE,SAASiY,EAAQ7Z,EAAM4B,GACnB,OAAO7C,EAAI8a,QAAQjB,EAAYC,EAAahD,EAAkB7V,EAAM4B,GAGxE,SAASkY,EAAenB,GACpB,MAAqB,MAAbA,EAAoBX,EAAOD,EAGvC,SAASgC,EAAmBpB,EAAUF,GAIlC,IAHA,IAAIuB,EAAqB,MAAbrB,EAAoBV,EAASE,EACrCvN,EAAM,GAEFgM,EAAI,EAAGA,EAAIoD,EAAK1V,OAAQsS,IAAK,CACjC,IAAIqD,EAAUD,EAAKpD,GAEhBqD,IAAYxB,IAAYhC,EAASwD,IAAY,IAAIC,YAChDtP,EAAI5G,KAAKoS,EAAQ6D,IAIzB,OAAOrP,EAIX,IAAIuP,GAAc,CAACra,EAAGga,EAAe,KAAM/Z,EAAG+Z,EAAe,MAEzDM,GAAaD,GAAYra,EAAEuY,OAAO8B,GAAYpa,GAG9Csa,GAA8B,GAC9BC,GAAwB,GAK5B,SAASC,KACL,IAAIC,EAAY5B,EAAW6B,QACxBpE,EAAcqE,KAAKF,KAAiD,IAAnCJ,GAAWvV,QAAQ2V,KACnDH,GAA4BG,GAAa5B,EAAWzS,KACpDmU,GAAwB5W,OAAOC,KAAK0W,KAI5C,IAAIM,GAAYjF,EAAwBe,EAAUC,EAAWC,GACzDiE,GAAenF,EAAekF,IAGlC,IAAIjU,EAAI,EAAGA,EAAI0R,EAAQ9T,OAAQoC,IAAK,CAChC+R,EAASL,EAAQ1R,GACjBgS,EAAOtC,EAAQqC,GACfE,EAAWF,EAAOoC,OAAO,GAErB9b,EAAIY,cAAc8W,EAASgC,MAC3BhC,EAASgC,GAAU,IAGvBG,EAAanC,EAASgC,GACtBI,EAAclD,EAASmF,aAAapE,EAAW+B,EAAQE,EAAW,QAClEM,IAEA,IAAI8B,GACc,MAAbpC,IAAqB3B,EAAcyB,IAAW3B,EAAU2B,IAC3C,MAAbE,IAAqB1B,EAAcwB,IAAW1B,EAAU0B,GAEzDuC,GACc,MAAbrC,KAEKzB,EAAiBuB,IAAWtB,EAAasB,IAC3CrB,EAAWqB,IAGfwC,GAAiB,CACjBC,OAAQvC,EACRnZ,KAAMkX,EAAUlX,KAChB6X,WAAYA,EAAWoB,GACvB0C,UAAW7D,EAAQmB,GACnBzV,KAAM6T,EAAU4B,IAAW,GAC3BK,QAASA,EACTsC,SAAU1E,EAAU0E,SACpBC,YAAY,EACZN,YAAaA,GACbC,YAAaA,GACbM,aAAc5E,EAAU6E,YAAc,IAAI5C,IAAa,IAAID,IAG/DF,EAAO,aAAc9B,EAAU8E,YAE/B1F,EAAmB8C,EAAYC,EAAaL,EAAQyC,IACpDlF,EAAmB6C,EAAYC,EAAaL,EAAQyC,GAAgBvE,GAEpE,IAAI+E,GAAeb,IAAgBjC,IAAagC,GAAUE,OAAO,GAC7Da,GAAa7B,EAAQ,aAAce,GAAe/B,EAAYpa,WAAQgK,GACtEkT,GAAiB9B,EAAQ,iBAAkBe,GAAe,SAAMnS,GAChEmT,GAAY/B,EAAQ,YAAae,GAAe,WAAQnS,GACxDoT,GAAYhC,EAAQ,YAAae,GAAe,cAAWnS,GAC3DqT,GAAYjC,EAAQ,YAAae,GAAe,oBAAiBnS,GACpD+P,EAAO,gBAAgBiD,IAAkBC,IAAgBC,IAAoBC,IAAeC,IAAeC,cAGjHjD,EAAY6C,kBACZ7C,EAAY8C,sBACZ9C,EAAY+C,iBACZ/C,EAAYgD,iBACZhD,EAAYiD,WAGvB7F,EAAuB2C,EAAYC,EAAaL,EAAQ,CACpD0C,OAAQvC,EACRwB,YAAaA,GAAYxB,GACzBoD,gBAAiBhC,EAAmBpB,EAAUF,GAC9CuD,KAAMtF,EAAUsF,OAGpBxD,EAAO,kBAEP+B,KAEA1B,EAAYoD,OAASrD,EAKzB,IADAlS,EAAI,EACEA,EAAI4T,GAAsBhW,QAAQ,CACpCoU,EAAO4B,GAAsB5T,KAE7BiS,GADAF,EAAStC,EAAQuC,IACCmC,OAAO,GAErB9b,EAAIY,cAAc8W,EAASgC,MAC3BhC,EAASgC,GAAU,IAGvBG,EAAanC,EAASgC,GACtBI,EAAclD,EAASmF,aAAapE,EAAW+B,EAAQE,EAAW,QAClEM,IAEA,IAAIiD,GAAkB,CAClBhB,OAAQvC,EACRnZ,KAAMkX,EAAUlX,KAChB6X,WAAYA,EAAWoB,GACvB0C,UAAW7D,EAAQmB,GACnBzV,KAAM,GACN8V,QAASA,EACTsC,SAAU1E,EAAU0E,SACpBC,YAAY,EACZN,aAAa,EACbC,aAAa,EACbM,aAAc5E,EAAU6E,YAAc,IAAI5C,IAAa,IAAID,IAG/DF,EAAO,aAAc9B,EAAU8E,YAE/B3C,EAAY1S,KAAOkU,GAA4B3B,IAAS,SAExD3C,EAAmB6C,EAAYC,EAAaL,EAAQ0D,GAAiBxF,GAErET,EAAuB2C,EAAYC,EAAaL,EAAQ,CACpD0C,OAAQvC,EACRwB,YAAaA,GAAYxB,GACzBoD,gBAAiBhC,EAAmBpB,EAAUF,GAC9CuD,KAAMtF,EAAUsF,OAGpBxD,EAAO,cAEP+B,KAEA1B,EAAYoD,OAASrD,EAIzB,IAAIuD,GAAsB7F,EAAmB,cAAe,kBACxD8F,GAAwB9F,EAAmB,gBAAiB,kBAEhE,IAAI5P,EAAI,EAAGA,EAAIuR,EAAO3T,OAAQoC,IAC1B+R,EAASR,EAAOvR,GAChBkS,EAAanC,EAASgC,GACtBI,EAAcnC,EAAU+B,GAExB0D,GAAoB1F,EAAUC,EAAW+B,GAEjB,SAArBI,EAAY1S,MACXiW,GACIxD,EACAC,EACAnC,EACAyB,EACAU,EAAYuC,UAIpB5C,EAAO,cAGX,IAAI9R,EAAI,EAAGA,EAAIyR,EAAO7T,OAAQoC,IAAK,CAC/B+R,EAASN,EAAOzR,GAChBkS,EAAanC,EAASgC,GACtBI,EAAcnC,EAAU+B,GAExB,IAAI4D,GAAe3F,EAAUP,EAAQ0C,EAAYyD,SAIjD9D,EAAO,aAFclC,EAAmB,cAAe,YAAlCA,CAA+C+F,KAaxE,IAAIE,GAAmB7F,EAAU8F,sBAAwB,GAErDC,GAAc/F,EAAUgG,iBAAmB,GAE3CC,GAA6BvC,GAAW/B,OAAOiC,IAC/CsC,GAA0BxE,EAAQC,OAAOtZ,EAAImZ,UAAUoC,GAAuBnE,IAElF,IAAIzP,EAAI,EAAGA,EAAIkW,GAAwBtY,OAAQoC,IAAK,CAMhD,IAAImW,GAOAC,GAXJnE,GADAF,EAASmE,GAAwBlW,IACfmU,OAAO,GACzBjC,EAAanC,EAASgC,GACtBI,EAAcnC,EAAU+B,GAIpBoE,GADY,MAAblE,IAAqBC,EAAWmE,eAAe,gBAAkB3F,EAAWqB,GACzDI,EAAYyD,YAEZ7T,EAKlBqU,IADAlE,EAAWmE,eAAe,cAAgB3F,EAAWqB,GACrC,cAEAhQ,EAGpBuN,EAAyB4C,EAAYC,EAAaL,EAAQ,CACtD4B,WAAYuC,GACZjG,UAAWA,EACXmG,gBAAiBA,GACjBC,cAAeA,KAIvB,IAAIpW,EAAI,EAAGA,EAAI+V,GAAYnY,OAAQoC,IAAK,CACpC,IAAIsH,GAAQyO,GAAY/V,GACpBsW,GAAM,KACNC,GAAY,KAGhB,IAAIvE,KAAQ1K,IACR6K,EAAcnC,EAAUP,EAAQuC,KAChB+B,UACZuC,GAAMnE,EAAYqE,MAClBD,GAAYpE,EAAYoE,WAKhC,GAAW,OAARD,IAA8B,OAAdC,GACf,IAAIvE,KAAQ1K,GAAO,CAEfgP,IADAnE,EAAcnC,EAAUP,EAAQuC,KACdwE,MAClBD,GAAYpE,EAAYoE,UACxB,MAIR,IAAIvE,KAAQ1K,IACR6K,EAAcnC,EAAUP,EAAQuC,KACjB+B,UACX5B,EAAYqE,MAAQF,GAAIG,QACxBtE,EAAYoE,UAAYA,IAE5BpE,EAAYuE,YAAcpP,GAI9B,GAAGuO,GAAiBjY,OAChB,IAAIoU,KAAQ1K,GACR,IAAI4I,EAAI,EAAGA,EAAI2F,GAAiBjY,OAAQsS,IAAK,CACzC,IAAIyG,GAASd,GAAiB3F,GAC9B,IAAI,IAAI0G,MAASD,GACV3E,IAAS4E,KACRve,EAAIwe,KAAK,QAAUD,GAAQ,qGAIpBD,GAAOC,IACX5Z,OAAOC,KAAK0Z,IAAQ/Y,OAAS,GAC5BiY,GAAiBiB,OAAO5G,EAAG,Q,8CCjc3D,IAAIjY,EAAY,EAAQ,YACpBmL,EAAsB,EAAQ,YAAWA,oBAgE7C,SAAS2T,EAAMzQ,EAAM0Q,GACjB,OAAO,WACH,IACIC,EACAC,EACAhT,EACAlE,EACAkQ,EALAiH,EAAU7Q,EAOd,IAAItG,EAAI,EAAGA,EAAIgX,EAAMpZ,OAAS,EAAGoC,IAAK,CAElC,IAAgB,KADhBiX,EAAUD,EAAMhX,IACG,CAGf,IAFAkX,GAAU,EACVhT,EAAM,GACFgM,EAAI,EAAGA,EAAIiH,EAAQvZ,OAAQsS,IAC3BhM,EAAIgM,GAAK6G,EAAMI,EAAQjH,GAAI8G,EAAMP,MAAMzW,EAAI,GAAlC+W,GACN7S,EAAIgM,KAAOhM,EAAI,KAAIgT,GAAU,GAEpC,OAAOA,EAAUhT,EAAI,GAAKA,EAE9B,GAAsB,iBAAZ+S,IAAyB7T,EAAoB+T,GACnD,OAGJ,GAAsB,iBADtBA,EAAUA,EAAQF,KAC4B,OAAZE,EAC9B,OAKR,GAAsB,iBAAZA,GAAoC,OAAZA,GAGvB,QADXjT,EAAMiT,EAAQH,EAAMhX,KAEpB,OAAOkE,GAlFfrN,EAAOC,QAAU,SAAwBsgB,EAAWC,GAChD,GAAGpf,EAAUof,GAAUA,EAAUC,OAAOD,QACnC,GAAsB,iBAAZA,GACgC,SAAvCA,EAAQE,OAAOF,EAAQzZ,OAAS,GACpC,KAAM,sBAUV,IAPA,IAEI4Z,EACAC,EACAzX,EAJAkQ,EAAI,EACJwH,EAAYL,EAAQ1J,MAAM,KAMxBuC,EAAIwH,EAAU9Z,QAAQ,CAGxB,GADA4Z,EAAUF,OAAOI,EAAUxH,IAAIzC,MAAM,kCACzB,CACR,GAAG+J,EAAQ,GAAIE,EAAUxH,GAAKsH,EAAQ,OAEjC,IAAS,IAANtH,EACH,KAAM,sBADMwH,EAAUZ,OAAO,EAAG,GAOrC,IAJAW,EAAUD,EAAQ,GACbD,OAAO,EAAGC,EAAQ,GAAG5Z,OAAS,GAC9B+P,MAAM,MAEP3N,EAAI,EAAGA,EAAIyX,EAAQ7Z,OAAQoC,IAC3BkQ,IACAwH,EAAUZ,OAAO5G,EAAG,EAAGyH,OAAOF,EAAQzX,KAG9CkQ,IAGJ,MAAwB,iBAAdkH,EA4Kd,SAAsBA,EAAWC,EAASK,GACtC,MAAO,CACHE,IAAK,WAAa,KAAM,iBACxBpR,IAAK,aACLqR,KAAMR,EACNL,MAAOU,EACPI,IAAKV,GAjLEW,CAAaX,EAAWC,EAASK,GAGrC,CACHE,IAAKI,EAAMZ,EAAWM,EAAWL,GACjC7Q,IAAKuQ,EAAMK,EAAWM,GACtBG,KAAMR,EACNL,MAAOU,EACPI,IAAKV,IAuDb,IAAIa,EAAe,eACnB,SAASC,EAAYC,EAAKd,GACtB,YAAgBtV,IAARoW,GAA+B,OAARA,IAAiBd,EAAQ5J,MAAMwK,GAGlE,SAASD,EAAM1R,EAAM0Q,EAAOK,GACxB,OAAO,SAASc,GACZ,IAIIlB,EACAjX,EALAmX,EAAU7Q,EACV8R,EAAW,GACXC,EAAkB,CAAC,CAAC/R,EAAM8R,IAC1BE,EAAWJ,EAAYC,EAAKd,GAIhC,IAAIrX,EAAI,EAAGA,EAAIgX,EAAMpZ,OAAS,EAAGoC,IAAK,CAGlC,GAAsB,iBAFtBiX,EAAUD,EAAMhX,MAEmBoD,EAAoB+T,GACnD,KAAM,4CAIV,IAAgB,IAAbF,EAAgB,CAEf,GADAqB,GAAYC,EAAYpB,EAASH,EAAMP,MAAMzW,EAAI,GAAImY,EAAKd,GAC7C,MACR,OAGT,IAAImB,EAAkBrB,EAASF,EAASD,EAAMhX,EAAI,GAAIsY,GAClD,MAKJ,GAAsB,iBAFtBnB,EAAUA,EAAQF,KAE4B,OAAZE,EAC9B,KAAM,6BAGViB,EAAWK,EAAYL,EAAUnB,GAEjCoB,EAAgB/a,KAAK,CAAC6Z,EAASiB,IAGnC,GAAGE,GACC,GAAGtY,IAAMgX,EAAMpZ,OAAS,WACbuZ,EAAQH,EAAMhX,IAKlBD,MAAM+D,QAAQqT,KAAaH,EAAMhX,IAAOmX,EAAQvZ,OAAS,GACxD,KAAMuZ,EAAQvZ,aAA0CmE,IAAhCoV,EAAQA,EAAQvZ,OAAS,IAC7CuZ,EAAQuB,WAIjBvB,EAAQH,EAAMhX,IAAMmY,GAInC,SAASM,EAAYpB,EAASsB,GAC1B,IAAIC,EAAQD,EAIZ,OAHG1gB,EAAU0gB,GAAUC,EAAQ,IAAMD,EAAU,IACvCtB,IAASuB,EAAQ,IAAMD,GAExBtB,EAAUuB,EAIrB,SAASL,EAAYM,EAAgBC,EAAYX,EAAKd,GAClD,IAMIrX,EANA+Y,EAAW3V,EAAoB+U,GAC/Ba,GAAS,EACTC,EAAUd,EACVe,EAAc7B,EAAQjZ,QAAQ,KAAM,GACpC+a,GAAaJ,GAAmBb,EAAYC,EAAKe,GACjDE,EAAYN,EAAW,GAG3B,IAAI9Y,EAAI,EAAGA,EAAI6Y,EAAejb,OAAQoC,IAClCkZ,EAAc7B,EAAQjZ,QAAQ,KAAM4B,GACjC+Y,IAECI,EAAajB,EADbe,EAAUd,EAAInY,EAAImY,EAAIva,QACYsb,IAEnCC,IAAYH,GAAS,GACpBR,EAAkBK,EAAgB7Y,EAAGoZ,EAAWD,IAGpDnB,EAAMa,EAAe7Y,GAAI8Y,EAAYzB,EAAQjZ,QAAQ,KAAM4B,GAA3DgY,CAA+DiB,GAEnE,OAAOD,EAQX,SAASR,EAAkBpB,EAAWiC,EAAMC,EAAUhB,GAClD,QAAuBvW,IAApBqV,EAAUiC,GAAqB,CAC9B,GAAGf,EAAU,OAAO,EAEalB,EAAUiC,GAApB,iBAAbC,EAAyC,GAC5B,GAE3B,OAAO,I,8CC9NX,IAAIC,EAAQ,EAAQ,YAEpBziB,QAAQ0iB,KAAO,MAEf1iB,QAAQ2iB,KAAO,SAASze,EAAIjE,EAAQ2iB,EAAgBC,GAChDJ,EAAMK,aAAa9iB,QAAQ0iB,KAAMxe,EAAIjE,EAAQ2iB,EAAgBC,IAGjE7iB,QAAQ+iB,MAAQ,SAASC,EAAaC,EAAeC,EAAaC,GAC9DV,EAAMW,cAAcpjB,QAAQ0iB,KAAMM,EAAaC,EAAeC,EAAaC,K,8CCT/E,IAAI9hB,EAAW,EAAQ,YAEvBrB,QAAQqjB,SAAW,SAASla,GACxB,OAAIA,EAAWma,OAGXna,EAAWma,KAAK,SAChBna,EAAWma,KAAK,SAChBna,EAAWma,KAAK,WAChB,IANwB,GAShCtjB,QAAQujB,cAAgB,SAASrf,GAC7B,OAAO,WACH,IAAIiF,EAAajF,EAAGkF,aAAe,KACpBD,EAAWma,MAAQna,EAAWma,KAAK,WAChBpf,EAAGsB,MAAQtB,EAAGsB,KAAK,IAAMtB,EAAGsB,KAAK,GAAGyB,GAGlE5F,EAASyX,mBAAmB,WAAY,OAAxCzX,CAAgD6C,KAK5DlE,QAAQwjB,UAAY,SAASC,GACzB,MAAO,sBAAwBC,mBAAmBD,IAGtDzjB,QAAQ2jB,WAAa,SAASC,GAC1B,MAAO,yBAA2BF,mBAAmBE,IAGzD,IAAIC,EAAUC,OAAOC,KAAOD,OAAOE,UAEnChkB,QAAQikB,gBAAkB,SAASC,GAC/B,OAAOL,EAAQI,gBAAgBC,IAGnClkB,QAAQmkB,gBAAkB,SAASC,GAC/B,OAAOP,EAAQM,gBAAgBC,IAGnCpkB,QAAQqkB,WAAa,SAASD,EAAKrc,GAC/B,GAAc,QAAXA,EACC,OAAO,IAAI+b,OAAOQ,KAAK,CAACF,GAAM,CAACzb,KAAM,gCAClC,GAAc,cAAXZ,EACN,OAAO,IAAI+b,OAAOQ,KAAK,CAACF,GAAM,CAACzb,KAAM,mCAErC,IAAI4b,EAUZ,SAAmBC,GAIf,IAHA,IAAI1b,EAAM0b,EAAE1d,OACR2d,EAAM,IAAIC,YAAY5b,GACtB6b,EAAM,IAAIC,WAAWH,GACjBvb,EAAI,EAAGA,EAAIJ,EAAKI,IACpByb,EAAIzb,GAAKsb,EAAEK,WAAW3b,GAE1B,OAAOub,EAjBUK,CAAUhB,OAAOiB,KAAKX,IACnC,OAAO,IAAIN,OAAOQ,KAAK,CAACC,GAAS,CAAC5b,KAAM,SAAWZ,KAI3D/H,QAAQglB,YAAc,SAASvkB,GAC3BwkB,SAASC,SAASC,KAAO,gCAAkC1kB,GAc/DT,QAAQolB,iBAAmB,2BAE3BplB,QAAQqlB,kBAAoB,kF,8CCrE5B,IAAI9jB,EAAM,EAAQ,YAMlBxB,EAAOC,QAAU,SAASslB,EAASC,EAAUC,EAAQxK,EAAQyK,GACzDA,EAAOA,GAAQ,GAEfzK,EAAO,gBACPzZ,EAAImkB,WAAW1K,EAAQ,WAAYwK,EAAOxjB,MAEtCyjB,EAAKE,WACL3K,EAAO,2BACPA,EAAO,gC,8CCff,IAAI4K,EAAa,EAAQ,YAEzB7lB,EAAOC,QAAU,SAAiC6lB,EAAaC,EAAc9K,EAAQ+K,GACjF,SAASC,EAAUxjB,GACf,IAAI2E,EAAI0e,EAAYrjB,GACpB,YACUyI,IAAN9D,EACAA,GAAK2e,EAAaG,WAAa,IAAIzjB,GAG3C,IAII0jB,EAJAC,EAASH,EAAU,SACnBI,EAASJ,EAAU,SACnBK,EAAYL,EAAU,YAIT,UAHDA,EAAU,aAIN,QAAXD,GAA+B,SAAXA,EAMzBG,EAAWlL,EAAO,WAHI/R,MAAM+D,QAAQqZ,GAAa,QAC7CD,EAAS,SACT,QAJJF,EAAWJ,EAAaI,SAAW,OAQvC,GAAgB,SAAbA,EAAqBlL,EAAO,eAC1B,GAAgB,WAAbkL,EAAuB,CAI3B,IAAII,EAAQR,EAAaQ,MAAQV,EAAWU,MACxCF,EAAQL,GACZD,EAAaS,MAAQX,EAAWW,MAC5BJ,EAAQJ,EAAQD,EAAalI,SAAU0I,QACxC,GAAc,kBAAXP,EAA4B,MAElB9a,IADD+P,EAAO,YACK8K,EAAaI,SAAW,OAC9ClL,EAAO,e,8CCjCpBjb,EAAOC,QAAU,SAAyBkE,GACnCA,EAAGsiB,0BACF1C,OAAO2C,oBAAoB,SAAUviB,EAAGsiB,gCACjCtiB,EAAGsiB,2B,8CCPlB,IAAIplB,EAAY,EAAQ,YACpBD,EAAY,EAAQ,YAEpBF,EAAQlB,EAAOC,QAAU,GAEzB0mB,EAAa,EAAQ,YACzBzlB,EAAM0lB,SAAWD,EAAWC,SAC5B,IAAIpa,EAActL,EAAMsL,YAAcma,EAAWna,YACjDtL,EAAM2lB,UAAYF,EAAWE,UAC7B,IAAI7L,EAAa9Z,EAAM8Z,WAAa2L,EAAW3L,WA+G/C,SAAS8L,EAASxF,GACd,GAAGlgB,EAAUkgB,IAAuB,iBAARA,EAAkB,OAAOA,EAErD,IAAIyF,EAAUzF,EAAIpK,OAClB,GAA4B,QAAzB6P,EAAQrG,OAAO,EAAG,GAAc,OAAOY,EAE1C,IAAI1K,EAAQmQ,EAAQnQ,MAAM,0BAC1B,IAAIA,EAAO,OAAO0K,EAElB,IAAInB,EAAQvJ,EAAM,GAAGM,OAAOJ,MAAM,eAC9BkQ,EAA6B,MAAtBD,EAAQzJ,OAAO,IAA+B,IAAjB6C,EAAMpZ,OAC9C,IAAIigB,GAAyB,IAAjB7G,EAAMpZ,OAAc,OAAOua,EAEvC,IAAI,IAAInY,EAAI,EAAGA,EAAIgX,EAAMpZ,OAAQoC,IAAK,CAClC,IAAIgX,EAAMhX,GAAGpC,OAAQ,OAAOua,EAG5B,GAFAnB,EAAMhX,GAAK2X,OAAOX,EAAMhX,MAEnBgX,EAAMhX,IAAM,GAGb,OAAOmY,EAGX,GAAS,IAANnY,EAGIgX,EAAMhX,GAAK,IAAGgX,EAAMhX,GAAK,QACzB,GAAGgX,EAAMhX,IAAM,EAGlB,OAAOmY,EAIf,IAAI2F,EAASziB,KAAKC,MAAiB,IAAX0b,EAAM,IAAY,KACtC3b,KAAKC,MAAiB,IAAX0b,EAAM,IAAY,KAC7B3b,KAAKC,MAAiB,IAAX0b,EAAM,IAErB,OAAG6G,EAAa,QAAUC,EAAS,KAAO9G,EAAM,GAAK,IAC9C,OAAS8G,EAAS,IAhJ7B/lB,EAAMiJ,QAAU,SAASF,GACrB,IAAIid,EAAIjd,EAAGkd,QACX,MAAO,OAAS3iB,KAAKC,MAAMyiB,EAAEhgB,GAAK,KAC9B1C,KAAKC,MAAMyiB,EAAEE,GAAK,KAAO5iB,KAAKC,MAAMyiB,EAAEzC,GAAK,KAGnDvjB,EAAMmmB,IAAM,SAASC,GAAQ,OAAOpmB,EAAMiJ,QAAQ9I,EAAUimB,KAE5DpmB,EAAMkK,QAAU,SAASkc,GAAQ,OAAOA,EAAOjmB,EAAUimB,GAAMld,WAAa,GAE5ElJ,EAAMiO,WAAa,SAASmY,EAAMC,GAC9B,IAAIL,EAAI7lB,EAAUimB,GAAMH,QACxB,MAAO,QAAU3iB,KAAKC,MAAMyiB,EAAEhgB,GAAK,KAC/B1C,KAAKC,MAAMyiB,EAAEE,GAAK,KAAO5iB,KAAKC,MAAMyiB,EAAEzC,GAAK,KAAO8C,EAAK,KAM/DrmB,EAAMsa,QAAU,SAASgM,EAAOC,GAC5B,IAAIC,EAAKrmB,EAAUmmB,GAAOL,QAC1B,GAAY,IAATO,EAAGC,EAAS,OAAOtmB,EAAUmmB,GAAOI,cAEvC,IAAIC,EAAKxmB,EAAUomB,GAAQzM,GAAYmM,QACnCW,EAAkB,IAATD,EAAGF,EAAUE,EAAK,CAC3B3gB,EAAG,KAAO,EAAI2gB,EAAGF,GAAKE,EAAG3gB,EAAI2gB,EAAGF,EAChCP,EAAG,KAAO,EAAIS,EAAGF,GAAKE,EAAGT,EAAIS,EAAGF,EAChClD,EAAG,KAAO,EAAIoD,EAAGF,GAAKE,EAAGpD,EAAIoD,EAAGF,GAEhCI,EAAS,CACT7gB,EAAG4gB,EAAO5gB,GAAK,EAAIwgB,EAAGC,GAAKD,EAAGxgB,EAAIwgB,EAAGC,EACrCP,EAAGU,EAAOV,GAAK,EAAIM,EAAGC,GAAKD,EAAGN,EAAIM,EAAGC,EACrClD,EAAGqD,EAAOrD,GAAK,EAAIiD,EAAGC,GAAKD,EAAGjD,EAAIiD,EAAGC,GAEzC,OAAOtmB,EAAU0mB,GAAQH,eAW7B1mB,EAAM8mB,SAAW,SAASV,EAAMW,EAAaC,GACzC,IAAIje,EAAK5I,EAAUimB,GAQnB,OANqB,IAAlBrd,EAAGG,aAAkBH,EAAK5I,EAAUH,EAAMsa,QAAQ8L,EAAMtM,MAE5C/Q,EAAGke,SACbF,EAAche,EAAGme,QAAQH,GAAejN,EACxCkN,EAAaje,EAAGoe,OAAOH,GAAc1b,GAE1B8b,YAGpBpnB,EAAMD,OAAS,SAASP,EAAGwmB,GACvB,IAAIjd,EAAK5I,EAAU6lB,GACnBxmB,EAAEI,MAAM,CAAC,OAAUI,EAAMiJ,QAAQF,GAAK,iBAAkBA,EAAGG,cAG/DlJ,EAAMmB,KAAO,SAAS3B,EAAGwmB,GACrB,IAAIjd,EAAK5I,EAAU6lB,GACnBxmB,EAAEI,MAAM,CACJ,KAAQI,EAAMiJ,QAAQF,GACtB,eAAgBA,EAAGG,cAM3BlJ,EAAM8hB,MAAQ,SAASzC,GACnB,GAAIA,GAAkC,iBAAdA,EAAxB,CAEA,IACIpX,EAAGkQ,EAAGkP,EAAKjH,EADXlb,EAAOD,OAAOC,KAAKma,GAGvB,IAAIpX,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAIxB,GAFAmY,EAAMf,EADNgI,EAAMniB,EAAK+C,IAGuB,UAA/Bof,EAAI7H,OAAO6H,EAAIxhB,OAAS,GAGvB,GAAGmC,MAAM+D,QAAQqU,GACb,IAAIjI,EAAI,EAAGA,EAAIiI,EAAIva,OAAQsS,IAAKiI,EAAIjI,GAAKyN,EAASxF,EAAIjI,SACnDkH,EAAUgI,GAAOzB,EAASxF,QAC9B,GAAmC,eAAhCiH,EAAI7H,OAAO6H,EAAIxhB,OAAS,KAAwBmC,MAAM+D,QAAQqU,GAGpE,IAAIjI,EAAI,EAAGA,EAAIiI,EAAIva,OAAQsS,IACpBnQ,MAAM+D,QAAQqU,EAAIjI,MAAKiI,EAAIjI,GAAG,GAAKyN,EAASxF,EAAIjI,GAAG,UAEvD,GAAGnQ,MAAM+D,QAAQqU,GAAM,CAG1B,IAAIkH,EAAMlH,EAAI,GACd,IAAIpY,MAAM+D,QAAQub,IAAQA,GAAsB,iBAARA,EACpC,IAAInP,EAAI,EAAGA,EAAIiI,EAAIva,OAAQsS,IAAKnY,EAAM8hB,MAAM1B,EAAIjI,SAE9CiI,GAAsB,iBAARA,GAAkBpgB,EAAM8hB,MAAM1B,M,8CCpH9D,IAAI9f,EAAM,EAAQ,YAEdinB,EAAoB,EAAQ,YAC5BC,EAAsB,EAAQ,YAC9BC,EAAqB,EAAQ,YAC7BC,EAAa,EAAQ,YAGzB5oB,EAAOC,QAAU,SAAwBslB,EAASC,EAAUqD,EAAcpD,GACtE,SAASxK,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOsK,EAASC,EAAUoD,EAAYnmB,EAAM4B,GAG3CokB,EAAkBlD,EAASC,EAAUvK,EAAQwK,IAM7DxK,EAAO,QACPA,EAAO,aACPA,EAAO,iBAEPyN,EAAoBnD,EAASC,EAAUvK,EAAQwK,GAE/CxK,EAAO,eACPA,EAAO,cAAezZ,EAAIsnB,UAAUtD,EAASuD,KAA4B,IAArBvD,EAASwD,SAE7DL,EAAmBpD,EAASC,EAAUC,EAAQxK,EAAQ,CAACzL,OAAQ,GAAIyZ,QAAS,OAbxEzD,EAAS0D,SAAU,I,8CCf3B,IAAI5nB,EAAW,EAAQ,YAevBtB,EAAOC,QAAU,SAA6B+gB,GAS1C,IARA,IAGImI,EACAvS,EAJAwS,EAAiB9nB,EAAS+nB,sBAC1BC,EAAmBhoB,EAASioB,mBAC5BC,EAAWxI,EAAKlK,MAAM,KAAK,GAMvB3N,EAAI,EAAGA,EAAImgB,EAAiBviB,OAAQoC,IAExC,IADAyN,EAAQoK,EAAKpK,MAAM0S,EAAiBngB,MACR,IAAhByN,EAAM6S,MAAa,CAC3BN,EAAWvS,EAAM,GACjB,MAOR,GAFIuS,IAAUA,EAAWC,EAAeA,EAAe9hB,QAAQkiB,MAE3DL,EAAU,OAAO,EAErB,IAAIO,EAAO1I,EAAKN,OAAOyI,EAASpiB,QAChC,OAAI2iB,KAEJ9S,EAAQ8S,EAAK9S,MAAM,oCAGZ,CAAC+S,MAAOR,EAAUM,MAAO3I,OAAOlK,EAAM,IAAKgT,SAAUhT,EAAM,IAAM,IALvD,CAAC+S,MAAOR,EAAUM,MAAO,GAAIG,SAAU,M,8CCtC5D,IAAI9pB,EAAK,EAAQ,YAEb+pB,EAAQ,EAAQ,YAChB9pB,EAAQ,EAAQ,YAChB+pB,EAAU,EAAQ,YAClBtoB,EAAM,EAAQ,YACdC,EAAe,EAAQ,YACvBsoB,EAAc,EAAQ,YAAgCA,YAEtDpoB,EAAe,EAAQ,YAA6BA,aAEpDqoB,EAAY,EAAQ,YACpBC,EAAY,EAAQ,YAwHxB,SAASC,EAAYC,GACjB,OAAOA,EAASC,OAOpB,SAASC,EAASC,EAASH,GACvB,OAAQG,EAAQ7nB,KAAKunB,EAAUO,qBAAuBJ,EAASC,OAGnE,SAASI,EAAUrmB,EAAIgmB,EAAUM,EAAYC,EAASJ,EAASK,EAAWC,EAAaC,GAEnFV,EAASW,OAASF,EAGlBb,EAAY5lB,EAAGshB,OAAQuE,EAAUrH,KAAMwH,GAClCY,YAAY,SAAUH,GAEN,YAAlBT,EAASvhB,KACRoiB,EAAY7mB,EAAIumB,EAAS,KAAM,KAAMP,GACb,aAAlBA,EAASvhB,OAEf0hB,EAAQ7nB,KAAKunB,EAAUO,kBAAmB,MAE1CU,EAAW9mB,EAAIumB,EAASJ,EAASK,EAAWR,GAExCU,GACAG,EAAY7mB,EAAIumB,EAASJ,EAASK,EAAWR,IAKzD,SAASc,EAAW9mB,EAAIumB,EAASJ,EAASK,EAAWR,GACjD,IAAIe,EAAS1pB,EAAIkJ,aAAaggB,EAAS,IAAKV,EAAUmB,iBAAiB,SAASzqB,GAC5EA,EAAEI,MAAM,iBAAkB,UAG1BsqB,EAAOjB,EAASkB,MAChBP,EAASX,EAASW,OAClBQ,EAAanB,EAASoB,QAAQT,IAAWd,EAAUwB,gBACnDC,EAAU,CAAEjpB,EAAG2nB,EAASuB,IAAI/T,EAAGgU,KAAM,EAAGppB,EAAG4nB,EAASuB,IAAIE,EAAGC,KAAM,EAAGpC,MAAO,GAC3EqC,EAAoB,CACpB9mB,MAAOomB,EAAKW,YACZnX,OAAQwW,EAAKY,cAGjBd,EACKlqB,KAAKirB,EAAU9B,EAAUmB,EAAYnnB,GACrCnD,KAAKkrB,EAAiB/B,EAAUsB,EAASK,GAGlCtqB,EAAIkJ,aAAaggB,EAAS,OAAQV,EAAUmC,sBAAsB,SAASzrB,GACnFA,EAAE0rB,QAAQ,oBAAoB,GACzB3pB,KAAK,cAAe,OACpBzB,KAAK8oB,EAAQ7nB,KAAMkoB,EAASloB,MAC5BkP,KAAK6Y,EAAUqC,YAAYlC,EAASmC,eAGvC7pB,KAAK,CACPF,EAAG6oB,EAAKW,YAAc/B,EAAUuC,aAAepC,EAASuB,IAAIE,EAC5DppB,EAAG4oB,EAAKY,aAAe,EAAIhC,EAAUwC,YAAcrC,EAASuB,IAAI/T,IAGpEuT,EAAOuB,GAAG,SAAS,WACfnC,EAAQtpB,KAAK0rB,EACTjM,OAAO4J,EAASC,EAASH,IAAa,EAAIA,EAASC,SAGvDY,EAAY7mB,EAAIumB,EAASJ,EAASK,EAAWR,MAGjDe,EAAOuB,GAAG,aAAa,WACnBvB,EAAOlqB,KAAK2rB,MAGhBzB,EAAOuB,GAAG,YAAY,WAClBvB,EAAOlqB,KAAK4rB,EAAiBzC,MAIjCL,EAAQ/S,aAAa2T,EAASU,EAAKyB,GAAIzB,EAAK0B,IAGhD,SAAS9B,EAAY7mB,EAAIumB,EAASJ,EAASK,EAAWR,GAI9CG,IACAA,EAAUI,GACFjoB,KAAK,iBAAkB,OAGnC,IAAIsqB,EA1FR,SAAkBzC,GACd,OAAuD,IAA/CA,EAAQ7nB,KAAKunB,EAAUO,mBAyFZyC,CAAS1C,IAA8B,YAAlBH,EAASvhB,KAE7C,GADAuhB,EAASoB,QAGT0B,EAA0B,aAAlB9C,EAASvhB,KAAsBohB,EAAUkD,wBAA0BlD,EAAUmD,gBAErF5B,EAAUjB,EAAQzpB,UAAU,KAAOosB,GAClCxnB,KAAKjE,EAAI4rB,cAAcL,IAExBljB,EAAQ0hB,EAAQ1hB,QAAQC,OAAO,KAC9BsiB,QAAQa,GAAO,GAEhBtjB,EAAO4hB,EAAQ5hB,OAEE,aAAlBwgB,EAASvhB,MACRiB,EAAMpH,KAAK,UAAW,KACjB4qB,aACA5qB,KAAK,UAAW,KAErBkH,EAAK0jB,aACA5qB,KAAK,UAAW,KAChBmH,UAELD,EAAKC,SAGT,IAAI0jB,EAAK,EACLC,EAAK,EACLnC,EAAOjB,EAASkB,MAEhBmC,GAA6D,IAAhD,CAAC,KAAM,QAAQlmB,QAAQ6iB,EAASmC,WAE5B,aAAlBnC,EAASvhB,OACL4kB,EACCD,EAAKnC,EAAKY,aAAehC,EAAUyD,gBAEnCH,EAAKlC,EAAKW,YAAc/B,EAAUyD,iBAIrB,aAAlBtD,EAASvhB,MAA8C,OAAvBuhB,EAASmC,YACxCiB,GAAMvD,EAAUyD,gBAAkBzD,EAAU0D,UAAYtC,EAAKuC,YAG5C,aAAlBxD,EAASvhB,MAA8C,SAAvBuhB,EAASmC,YACxCgB,GAAMtD,EAAUyD,gBAAkBzD,EAAU0D,UAAYtC,EAAKwC,WAGjE,IAAInC,EAAU,CACVlpB,EAAG6oB,EAAKyB,GAAKS,EAAKnD,EAASuB,IAAIE,EAC/BppB,EAAG4oB,EAAK0B,GAAKS,EAAKpD,EAASuB,IAAI/T,EAC/BgU,KAAM3B,EAAU0D,UAChB7B,KAAM7B,EAAU0D,UAChBjE,MAAO,GAGPoE,EAAoB,CACpBjC,EAAGH,EAAQlpB,EAAI4nB,EAAS2D,YACxBnW,EAAG8T,EAAQjpB,EAAI2nB,EAAS2D,aAG5BvC,EAAQprB,MAAK,SAASsqB,EAAYG,GAC9B,IAAImD,EAASjuB,EAAGa,OAAOC,MAEvBmtB,EACK/sB,KAAKirB,EAAU9B,EAAUM,EAAYtmB,GACrCnD,KAAKkrB,EAAiB/B,EAAUsB,GAErCsC,EAAOtB,GAAG,SAAS,WAEZ3sB,EAAGkuB,MAAMC,mBAETxD,EAAWyD,UACPzD,EAAW0D,OAAShE,EAASW,SAAWF,GACvCJ,EAAUrmB,EAAIgmB,EAAUM,EAAYC,EAASJ,EAASK,GAAY,GAClEd,EAAMuE,kBAAkBjqB,EAAIsmB,EAAW4D,OAAQ5D,EAAW0D,SAE1D3D,EAAUrmB,EAAIgmB,EAAUM,EAAYC,EAASJ,EAASK,EAAWC,GACjEf,EAAMuE,kBAAkBjqB,EAAIsmB,EAAW4D,OAAQ5D,EAAW6D,QAIlEnqB,EAAGoqB,KAAK,uBAAwB,CAACC,KAAMrE,EAAU4D,OAAQtD,EAAYK,OAAQX,EAASW,aAG1FiD,EAAOtB,GAAG,aAAa,WACnBsB,EAAO/sB,KAAK2rB,MAGhBoB,EAAOtB,GAAG,YAAY,WAClBsB,EAAO/sB,KAAK4rB,EAAiBzC,GAC7BoB,EAAQvqB,KAAKytB,EAActE,SAInCoB,EAAQvqB,KAAKytB,EAActE,GAExBqD,GACCK,EAAkBlrB,EAAI6B,KAAKc,IAAI8lB,EAAKwC,UAAWxC,EAAKW,aACpD8B,EAAkBjrB,EAAI6oB,EAAQjpB,EAAIqrB,EAAkBlW,IAEpDkW,EAAkBlrB,EAAI8oB,EAAQlpB,EAAIsrB,EAAkBjC,EACpDiC,EAAkBjrB,EAAI4B,KAAKc,IAAI8lB,EAAKuC,WAAYvC,EAAKY,eAGzD6B,EAAkBvB,UAAYnC,EAASmC,UAEpC3B,IACIY,EAAQppB,OAQnB,SAAuBgC,EAAIumB,EAASJ,EAASK,EAAWR,EAAUzV,GAE9D,IAKIga,EAAYC,EACZxlB,EANAmjB,EAAYnC,EAASmC,UACrBkB,EAA4B,OAAdlB,GAAoC,SAAdA,EACpClB,EAAOjB,EAASkB,MAEhBP,EAASX,EAASW,OAGtB,GAAG0C,EAEC,IADAmB,EAAa,EACTxlB,EAAI,EAAGA,EAAI2hB,EAAQ3hB,IACnBwlB,GAAcvD,EAAKwD,QAAQzlB,GAAK6gB,EAAU0D,eAI9C,IADAgB,EAAa,EACTvlB,EAAI,EAAGA,EAAI2hB,EAAQ3hB,IACnBulB,GAActD,EAAKyD,OAAO1lB,GAAK6gB,EAAU0D,UAIjD/C,EAAUmE,OAAOpa,EAAUga,EAAYC,GAEpChE,EAAUoE,MACTpE,EAAUoE,KACLtsB,KAAK,UAAW,KAChB4qB,aACA5qB,KAAK,UAAW,KAGtBkoB,EAAUqE,MACTrE,EAAUqE,KACLvsB,KAAK,UAAW,KAChB4qB,aACA5qB,KAAK,UAAW,KAzCjBwsB,CAAc9qB,EAAIumB,EAASJ,EAASK,EAAWR,EAAU0D,GA6CrE,SAAuBlD,GACnB,IAAIuE,IAAYvE,EAAUoE,KACtBI,IAAYxE,EAAUqE,KAEvBE,GACCvE,EAAUoE,KACL1B,aACA5qB,KAAK,UAAW,KAChBtC,KAAK,OAAO,WACT+uB,GAAU,EACNC,GAASxE,EAAUyE,aAIhCD,GACCxE,EAAUqE,KACL3B,aACA5qB,KAAK,UAAW,KAChBtC,KAAK,OAAO,WACTgvB,GAAU,EACND,GAASvE,EAAUyE,aA/D3BC,CAAc1E,IAoE1B,SAASsB,EAAShT,EAAMkR,EAAUmF,EAAUnrB,GACxC8U,EAAKjY,KAAKuuB,EAAcpF,GACnBnpB,KAAKwuB,EAAcrF,EAAUmF,EAAUnrB,GAGhD,SAASorB,EAAatW,EAAMkR,GACb3oB,EAAIkJ,aAAauO,EAAM,OAAQ+Q,EAAUyF,mBAAmB,SAAS/uB,GAC5EA,EAAE+B,KAAK,CACHitB,GAAI1F,EAAU0F,GACdC,GAAI3F,EAAU2F,GACd,kBAAmB,kBAItB3uB,KAAKjB,EAAMkB,OAAQkpB,EAASyF,aAC5B5uB,KAAKjB,EAAMsC,KAAM8nB,EAAS0F,SAC1B/uB,MAAM,eAAgBqpB,EAAS2D,YAAc,MAGtD,SAAS0B,EAAavW,EAAMkR,EAAUmF,EAAUnrB,GAC5C,IAAIgN,EAAO3P,EAAIkJ,aAAauO,EAAM,OAAQ+Q,EAAU8F,mBAAmB,SAASpvB,GAC5EA,EAAE0rB,QAAQ,oBAAoB,GACzB3pB,KAAK,CACF,cAAe,QACf,aAAc,OAItB2P,EAAKkd,EAASS,MACdre,EAAQvN,EAAGkF,YAAYqI,MACxBA,IAAOU,EAAK5Q,EAAIwuB,eAAe5d,EAAIV,IAEtCP,EAAKnQ,KAAK8oB,EAAQ7nB,KAAMkoB,EAASloB,MAC5BkP,KAAKiB,GACLpR,KAAKS,EAAayQ,gBAAiB/N,GAG5C,SAASsqB,EAAalD,EAASpB,GAC3B,IAAIW,EAASX,EAASW,OAEtBS,EAAQprB,MAAK,SAASsqB,EAAYthB,GAC9B,IAAI4kB,EAASjuB,EAAGa,OAAOC,MAEpBuI,IAAM2hB,GAAUX,EAAS8F,YACxBlC,EAAOptB,OAAO,QAAUqpB,EAAUyF,mBAC7BzuB,KAAKjB,EAAMsC,KAAM2nB,EAAUkG,gBAK5C,SAASvD,EAAiB1T,GACtBA,EAAKtY,OAAO,QAAUqpB,EAAUyF,mBAC3BzuB,KAAKjB,EAAMsC,KAAM2nB,EAAUmG,YAGpC,SAASvD,EAAgB3T,EAAMkR,GAC3BlR,EAAKtY,OAAO,QAAUqpB,EAAUyF,mBAC3BzuB,KAAKjB,EAAMsC,KAAM8nB,EAAS0F,SAInC,SAASO,EAAejsB,EAAIgmB,GACxB,IAAIiB,EAAOjB,EAASkB,MAAQ,CACxBgF,OAAQ,EACRC,QAAS,EACT1B,QAAS,GACTC,OAAQ,GACR0B,WAAY,EACZC,YAAa,EACb5C,UAAW,EACXD,WAAY,EACZd,GAAI,EACJC,GAAI,GAGJ2D,EAAc3G,EAAQvV,OAAO1T,UAAU,KAAOmpB,EAAUkD,yBACvDznB,KAAKjE,EAAI4rB,cAAcjD,EAASoB,UAErCkF,EAAY5mB,QAAQC,OAAO,KACtBsiB,QAAQpC,EAAUkD,yBAAyB,GAEhD,IAAIM,GAA6D,IAAhD,CAAC,KAAM,QAAQlmB,QAAQ6iB,EAASmC,WAGjDmE,EAAYtwB,MAAK,SAASsqB,EAAYthB,GAClC,IAAI4kB,EAASjuB,EAAGa,OAAOC,MAEvBmtB,EAAO/sB,KAAKirB,EAAU9B,EAAUM,EAAYtmB,GAE5C,IAAIgN,EAAO4c,EAAOptB,OAAO,IAAMqpB,EAAU8F,mBAGrCY,EAASvf,EAAKhO,QAAU2mB,EAAQvU,KAAKpE,EAAKhO,QAAQ6B,MAClD2rB,EAAOnsB,KAAKc,IAAIorB,EAAS1G,EAAU4G,SAAU5G,EAAU6G,UAGvDC,EAAU3G,EAASloB,KAAKE,KAAOR,EAC/BovB,EAAStvB,EAAakP,UAAUQ,GAChC6f,EAAOxsB,KAAKc,IAAIwrB,EAAUC,EAAQ/G,EAAUiH,WAAajH,EAAUwC,YAEvEwE,EAAOxsB,KAAK0sB,KAAKF,GACjBL,EAAOnsB,KAAK0sB,KAAKP,GAIjBvF,EAAKyD,OAAO1lB,GAAKwnB,EACjBvF,EAAKwD,QAAQzlB,GAAK6nB,EAGlB5F,EAAKkF,QAAU9rB,KAAKc,IAAI8lB,EAAKkF,QAASU,GACtC5F,EAAKiF,OAAS7rB,KAAKc,IAAI8lB,EAAKiF,OAAQM,GAEjCnD,GACCpC,EAAKmF,WAAa/rB,KAAKc,IAAI8lB,EAAKmF,WAAYI,GAC5CvF,EAAKwC,UAAYxC,EAAKmF,WACtBnF,EAAKoF,aAAeQ,EAAOhH,EAAU0D,UACrCtC,EAAKuC,YAAcqD,EAAOhH,EAAU0D,YAEpCtC,EAAKmF,YAAcI,EAAO3G,EAAU0D,UACpCtC,EAAKwC,WAAa+C,EAAO3G,EAAU0D,UACnCtC,EAAKoF,YAAchsB,KAAKc,IAAI8lB,EAAKoF,YAAaQ,GAC9C5F,EAAKuC,WAAavC,EAAKoF,gBAI5BhD,EACCpC,EAAKoF,aAAexG,EAAU0D,UAE9BtC,EAAKmF,YAAcvG,EAAU0D,UAIjCtC,EAAKW,YAAcX,EAAKiF,OAASrG,EAAUmH,UAC3C/F,EAAKY,aAAeZ,EAAKkF,QAEJ,aAAlBnG,EAASvhB,OACL4kB,GACCpC,EAAKiF,QAAUrG,EAAUmH,UACzB/F,EAAKoF,YAAcpF,EAAKkF,SAExBlF,EAAKmF,WAAanF,EAAKiF,OAE3BjF,EAAKmF,YAAcvG,EAAUmH,WAGjCV,EAAY7mB,SAEZ,IAAIwnB,EAAchG,EAAKmF,WAAapG,EAASuB,IAAIE,EAAIzB,EAASuB,IAAIxkB,EAC9DmqB,EAAejG,EAAKoF,YAAcrG,EAASuB,IAAI/T,EAAIwS,EAASuB,IAAIjH,EAEhE6M,EAAYntB,EAAGkF,YAAYkoB,MAC/BnG,EAAKyB,GAAKyE,EAAU1F,EAAI0F,EAAU3uB,EAAIwnB,EAAS5nB,EAC/C6oB,EAAK0B,GAAKwE,EAAU3Z,EAAI2Z,EAAU1uB,GAAK,EAAIunB,EAAS3nB,GAEpD,IAAIgvB,EAAU,OACXhwB,EAAIiwB,cAActH,KACjBiB,EAAKyB,IAAMuE,EACXI,EAAU,SAEXhwB,EAAIkwB,eAAevH,KAClBiB,EAAKyB,IAAMuE,EAAc,EACzBI,EAAU,UAGd,IAAIG,EAAU,MACXnwB,EAAIowB,eAAezH,KAClBiB,EAAK0B,IAAMuE,EACXM,EAAU,UAEXnwB,EAAIqwB,eAAe1H,KAClBiB,EAAK0B,IAAMuE,EAAe,EAC1BM,EAAU,UAGdvG,EAAKmF,WAAa/rB,KAAK0sB,KAAK9F,EAAKmF,YACjCnF,EAAKoF,YAAchsB,KAAK0sB,KAAK9F,EAAKoF,aAClCpF,EAAKyB,GAAKroB,KAAKC,MAAM2mB,EAAKyB,IAC1BzB,EAAK0B,GAAKtoB,KAAKC,MAAM2mB,EAAK0B,IAE1BjD,EAAMiI,WAAW3tB,EAAI4tB,EAAa5H,GAAW,CACzC5nB,EAAG4nB,EAAS5nB,EACZC,EAAG2nB,EAAS3nB,EACZopB,EAAGwF,GAAe,CAACrb,MAAO,EAAGic,OAAQ,IAAKR,IAAY,GACtDtqB,EAAGkqB,GAAe,CAACzc,KAAM,EAAGqd,OAAQ,IAAKR,IAAY,GACrD/M,EAAG4M,GAAgB,CAACjhB,IAAK,EAAGF,OAAQ,IAAKyhB,IAAY,GACrDha,EAAG0Z,GAAgB,CAAClhB,OAAQ,EAAGD,OAAQ,IAAKyhB,IAAY,KAIhE,SAASI,EAAa5H,GAClB,OAAOH,EAAUiI,iBAAmB9H,EAASC,OAIjD,SAAS8B,EAAgBjT,EAAMkR,EAAUsB,EAASyG,GAC9CA,EAAeA,GAAgB,GAC/B,IAAIC,EAAOlZ,EAAKtY,OAAO,IAAMqpB,EAAUyF,mBACnCte,EAAO8H,EAAKtY,OAAO,IAAMqpB,EAAU8F,mBACnCsC,EAAcjI,EAAS2D,YACvBrE,EAAQgC,EAAQhC,MAChB2B,EAAOjB,EAASkB,MAEpBvB,EAAQ/S,aAAakC,EAAMmZ,EAAc3G,EAAQlpB,EAAG6vB,EAAc3G,EAAQjpB,GAE1E,IAAIgrB,GAA6D,IAAhD,CAAC,KAAM,QAAQlmB,QAAQ6iB,EAASmC,WAC7C+F,EAAcH,EAAatd,SAAW4Y,EAAapC,EAAKwD,QAAQnF,GAAS2B,EAAKkF,SAElF6B,EAAK1vB,KAAK,CACNF,EAAG,EACHC,EAAG,EACHwC,MAAOktB,EAAaltB,QAAUwoB,EAAapC,EAAKiF,OAASjF,EAAKyD,OAAOpF,IACrE7U,OAAQyd,IAGZ,IAAIvB,EAAU3G,EAASloB,KAAKE,KAAOR,EAE/B2wB,GADS7wB,EAAakP,UAAUQ,GACR,GAAK2f,EAAU,EAE3CrvB,EAAayU,aAAa/E,EAAM6Y,EAAUuI,YACtCF,EAAc,EAAIC,EAAatI,EAAUwC,aAE1CgB,EACC/B,EAAQjpB,GAAK4oB,EAAKwD,QAAQnF,GAASgC,EAAQE,KAE3CF,EAAQlpB,GAAK6oB,EAAKyD,OAAOpF,GAASgC,EAAQI,KAG9CJ,EAAQhC,QAGZ,SAASiD,EAAiBpC,EAASkI,GAC/BlI,EACK7nB,KAAKunB,EAAUO,kBAAmBiI,GAAoB,MACtD3xB,UAAU,KAAOmpB,EAAUkD,yBAAyBtjB,SAhnB7D5J,EAAOC,QAAU,SAAckE,GAC3B,IAAIiF,EAAajF,EAAGkF,YAChBopB,EAAWjxB,EAAI4rB,cAAchkB,EAAW4gB,EAAUrH,OA6BtD,SAAS+P,EAAgBvI,GACrBN,EAAMiI,WAAW3tB,EAAI4tB,EAAa5H,IAItC,IAAIwI,EAAQvpB,EAAWwpB,WAClB/xB,UAAU,KAAOmpB,EAAU6I,oBAC3BptB,KAAKgtB,EAAS1rB,OAAS,EAAI,CAAC,GAAK,IAiBtC,GAfA4rB,EAAM9oB,QAAQC,OAAO,KAChBsiB,QAAQpC,EAAU6I,oBAAoB,GACtC/xB,MAAM,SAAU,WAErB6xB,EAAMhpB,OAAOxJ,MAAK,WAMdL,EAAGa,OAAOC,MAAMC,UAAU,KAAOmpB,EAAU8I,sBACtC3yB,KAAKuyB,MACX9oB,SAGoB,IAApB6oB,EAAS1rB,OAAZ,CAGA,IAAIgsB,EAAeJ,EAAM9xB,UAAU,KAAOmpB,EAAU8I,sBAC/CrtB,KAAKgtB,EAAUvI,GAEpB6I,EAAalpB,QAAQC,OAAO,KACvBsiB,QAAQpC,EAAU8I,sBAAsB,GAQ7C,IALA,IAAIxI,EAAU9oB,EAAIkJ,aAAaioB,EAAO,IAAK3I,EAAUgJ,8BAA8B,SAAStyB,GACxFA,EAAEI,MAAM,iBAAkB,UAItBqI,EAAI,EAAGA,EAAIspB,EAAS1rB,OAAQoC,IAAK,CACrC,IAAIghB,EAAWsI,EAAStpB,GACxBinB,EAAejsB,EAAIgmB,GAIvB,IAAI8I,EAAc,cAAgB7pB,EAAWG,KACzCohB,EAAY,IAAIV,EAAU9lB,EAAImmB,EAAS2I,GAGxCF,EAAalpB,QAAQ1H,SAEpBmoB,EAAQnnB,OAAOoH,WAAW0L,YAAYqU,EAAQnnB,QAC9CmnB,EAAQtpB,KAAK0rB,IAGjBqG,EAAappB,OAAOxJ,MAAK,SAASgqB,GAC9BG,EAAQtpB,KAAK0rB,GACbgG,EAAgBvI,MACjBvgB,SAGHmpB,EAAa5yB,MAAK,SAASgqB,GACvB,IAAIO,EAAU5qB,EAAGa,OAAOC,MAEpBsyB,EAA6B,aAAlB/I,EAASvhB,KAAsB0hB,EAAU,KAExDT,EAAMsJ,sBAAsBhvB,EAAIgmB,EAAUA,EAASoB,SAAS,SAAS9lB,GACjE+kB,EAAUrmB,EAAIgmB,EAAUA,EAASoB,QAAQ9lB,EAAKgkB,OAAQiB,EAASwI,EAAUvI,EAAWllB,EAAKgkB,OAAO,MAG/E,aAAlBU,EAASvhB,MACRqiB,EAAW9mB,EAAIumB,EAASJ,EAASK,EAAWR,GAGzCE,EAASC,EAASH,IACjBa,EAAY7mB,EAAIumB,EAASJ,EAASK,EAAWR,IAGjDa,EAAY7mB,EAAIumB,EAAS,KAAM,KAAMP,S,8CC5HjD,IAAIrqB,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YAEpBgyB,EAAe,EAAQ,YACvBC,EAAUD,EAAaC,QACvBC,EAASF,EAAaE,OAEtBC,EAAMvzB,EAAOC,QAAU,GAE3BszB,EAAI7jB,eAAiB,EAAQ,YAC7B6jB,EAAIC,eAAiB,EAAQ,YAC7BD,EAAIE,aAAe,EAAQ,YAC3BF,EAAInxB,cAAgB,EAAQ,YAC5BmxB,EAAIG,WAAa,EAAQ,YACzBH,EAAII,kBAAoB,EAAQ,YAEhC,IAAIC,EAAc,EAAQ,YAC1BL,EAAIM,aAAeD,EAAYC,aAC/BN,EAAIhnB,oBAAsBqnB,EAAYrnB,oBACtCgnB,EAAIzK,UAAY8K,EAAY9K,UAC5ByK,EAAIO,YAAcF,EAAYE,YAC9BP,EAAIzY,OAAS8Y,EAAY9Y,OACzByY,EAAIQ,aAAeH,EAAYG,aAC/BR,EAAIS,aAAeJ,EAAYI,aAE/B,IAAIC,EAAY,EAAQ,YACxBV,EAAIW,IAAMD,EAAUC,IACpBX,EAAIY,QAAUF,EAAUE,QAExB,IAAIC,EAAe,EAAQ,YAC3Bb,EAAIc,cAAgBD,EAAaC,cACjCd,EAAItY,OAASmZ,EAAanZ,OAC1BsY,EAAIjX,QAAU8X,EAAa9X,QAC3BiX,EAAI5N,WAAayO,EAAazO,WAC9B4N,EAAIe,gBAAkBF,EAAaE,gBACnCf,EAAIgB,6BAA+BH,EAAaG,6BAChDhB,EAAIiB,SAAWJ,EAAaI,SAE5B,IAAIC,EAAc,EAAQ,YAC1BlB,EAAImB,YAAcD,EAAYC,YAC9BnB,EAAIoB,WAAaF,EAAYE,WAC7BpB,EAAIqB,YAAcH,EAAYG,YAC9BrB,EAAIsB,iBAAmBJ,EAAYI,iBACnCtB,EAAIuB,UAAYL,EAAYK,UAC5BvB,EAAIwB,SAAWN,EAAYM,SAC3BxB,EAAIyB,WAAaP,EAAYO,WAC7BzB,EAAI0B,eAAiBR,EAAYQ,eACjC1B,EAAI2B,UAAYT,EAAYS,UAC5B3B,EAAI4B,UAAYV,EAAYU,UAC5B5B,EAAI6B,eAAiBX,EAAYW,eACjC7B,EAAI8B,OAASZ,EAAYY,OACzB9B,EAAI+B,OAASb,EAAYa,OAEzB,IAAIC,EAAe,EAAQ,YAC3BhC,EAAIiC,QAAUD,EAAaC,QAC3BjC,EAAIkC,UAAYF,EAAaE,UAC7BlC,EAAImC,UAAYH,EAAaG,UAC7BnC,EAAIoC,aAAeJ,EAAaI,aAChCpC,EAAIqC,QAAUL,EAAaK,QAC3BrC,EAAIsC,KAAON,EAAaM,KACxBtC,EAAIuC,eAAiBP,EAAaO,eAElC,IAAIC,EAAc,EAAQ,YAC1BxC,EAAIyC,QAAUD,EAAYC,QAC1BzC,EAAIxqB,IAAMgtB,EAAYhtB,IACtBwqB,EAAI0C,KAAOF,EAAYE,KACvB1C,EAAI2C,OAASH,EAAYG,OACzB3C,EAAI4C,SAAWJ,EAAYI,SAC3B5C,EAAI6C,SAAWL,EAAYK,SAC3B7C,EAAI8C,MAAQN,EAAYM,MACxB9C,EAAI+C,OAASP,EAAYO,OAEzB,IAAIC,EAAe,EAAQ,YAC3BhD,EAAIiD,YAAcD,EAAaC,YAC/BjD,EAAIkD,gBAAkBF,EAAaE,gBACnClD,EAAImD,IAAMH,EAAaG,IACvBnD,EAAIoD,kBAAoBJ,EAAaI,kBACrCpD,EAAIqD,eAAiBL,EAAaK,eAClCrD,EAAIsD,iBAAmBN,EAAaM,iBACpCtD,EAAIuD,iBAAmBP,EAAaO,iBACpCvD,EAAIwD,kBAAoBR,EAAaQ,kBAErC,IAAIC,EAAe,EAAQ,YAC3BzD,EAAI0D,QAAUD,EAAaC,QAC3B1D,EAAI2D,QAAUF,EAAaE,QAC3B3D,EAAI4D,WAAaH,EAAaG,WAC9B5D,EAAI6D,UAAYJ,EAAaI,UAC7B7D,EAAI8D,aAAeL,EAAaK,aAChC9D,EAAI+D,oBAAsBN,EAAaM,oBACvC/D,EAAIgE,iBAAmBP,EAAaO,iBACpChE,EAAIiE,QAAUR,EAAaQ,QAC3BjE,EAAIkE,WAAaT,EAAaS,WAC9BlE,EAAImE,YAAcV,EAAaU,YAE/B,IAAIC,EAAc,EAAQ,YAC1BpE,EAAIqE,aAAeD,EAAYC,aAC/BrE,EAAI7B,eAAiBiG,EAAYjG,eACjC6B,EAAI9B,cAAgBkG,EAAYlG,cAChC8B,EAAIsE,YAAcF,EAAYE,YAC9BtE,EAAI1B,eAAiB8F,EAAY9F,eACjC0B,EAAI3B,eAAiB+F,EAAY/F,eAEjC,IAAIkG,EAAe,EAAQ,YAC3BvE,EAAIwE,kBAAoBD,EAAaC,kBACrCxE,EAAIyE,gBAAkBF,EAAaE,gBACnCzE,EAAI0E,gBAAkBH,EAAaG,gBACnC1E,EAAI2E,mBAAqBJ,EAAaI,mBACtC3E,EAAI4E,kBAAoBL,EAAaK,kBACrC5E,EAAI6E,gBAAkBN,EAAaM,gBAEnC,IAAIC,EAAe,EAAQ,YAC3B9E,EAAI9lB,WAAa4qB,EAAa5qB,WAC9B8lB,EAAI+E,WAAaD,EAAaC,WAC9B/E,EAAIgF,cAAgBF,EAAaE,cACjChF,EAAIiF,mBAAqBH,EAAaG,mBAEtC,IAAIC,EAAgB,EAAQ,YAC5BlF,EAAImF,IAAMD,EAAcC,IACxBnF,EAAIvT,KAAOyY,EAAczY,KACzBuT,EAAIoF,MAAQF,EAAcE,MAE1B,IAAIC,EAAc,EAAQ,YAC1BrF,EAAIsF,aAAeD,EAAYE,QAE/B,IAAIC,EAAiB,EAAQ,YAC7BxF,EAAIyF,SAAWD,EAAeC,SAC9BzF,EAAI0F,aAAeF,EAAeG,KAClC3F,EAAI4F,cAAgBJ,EAAeK,MAEnC,IAAIC,EAAY,EAAQ,YAsZxB,SAASC,EAAqBC,GAC1B,IAAIC,EAAmB,GACvB,IAAI,IAAIlzB,KAAKizB,EAET,IADA,IAAIhmB,EAAMgmB,EAAcjzB,GAChB+S,EAAI,EAAGA,EAAI9F,EAAIxM,OAAQsS,IAC3BmgB,EAAiBjmB,EAAI8F,KAAO/S,EAGpC,OAAOkzB,EA7ZXjG,EAAIkG,YAAcJ,EAAUI,YAC5BlG,EAAImG,UAAYL,EAAUK,UAC1BnG,EAAIoG,cAAgBN,EAAUM,cAC9BpG,EAAIqG,aAAeP,EAAUO,aAC7BrG,EAAIsG,oBAAsBR,EAAUQ,oBACpCtG,EAAIuG,uBAAyBT,EAAUS,uBAEvCvG,EAAIwG,gBAAkB,EAAQ,YAE9BxG,EAAIyG,gBAAkB,EAAQ,YAE9BzG,EAAI0G,EAAI,EAAQ,YAEhB1G,EAAI2G,SAAW,EAAQ,YAEvB3G,EAAI4G,aAAe,EAAQ,YAC3B5G,EAAInG,cAAgB,EAAQ,YAC5BmG,EAAI6G,WAAa,EAAQ,YAEzB7G,EAAI8G,YAAc,EAAQ,YAE1B9G,EAAI+G,aAAe,SAAsBlzB,GACrC,OAAIhG,EAAUgG,IACdA,EAAI0Z,OAAO1Z,KACHisB,GAAWjsB,EAAIisB,EAAgBC,EAChClyB,EAAUgG,GAAK0Z,OAAO1Z,GAAKksB,EAHTA,GAc7BC,EAAIgH,QAAU,SAASnzB,EAAG2B,GACtB,aAAWmC,IAARnC,GAAqB3B,GAAK2B,KACtB3H,EAAUgG,IAAOA,GAAK,GAAOA,EAAI,GAAM,IAGlDmsB,EAAIiH,KAAO,EAAQ,YACnBjH,EAAI7pB,SAAW,EAAQ,YASvB6pB,EAAIkH,OAAS,SAASrzB,EAAGszB,GAErB,IADA,IAAIrtB,EAAM,IAAInE,MAAMwxB,GACZvxB,EAAI,EAAGA,EAAIuxB,EAAKvxB,IACpBkE,EAAIlE,GAAK/B,EAEb,OAAOiG,GAQXkmB,EAAIoH,UAAY,SAASlrB,EAAMmrB,EAAUC,EAAOC,GACxCD,IAAOA,EAAQ,KACfC,IAAOA,EAAQ,KACnB,IAAI,IAAI3xB,EAAI,EAAGA,EAAIyxB,EAAS7zB,OAAQoC,IAAK,CACrC,IAAI1G,EAAOm4B,EAASzxB,GAChB4xB,EAAKxH,EAAI7jB,eAAeD,EAAMhN,EAAK8E,QAAQ,IAAKszB,IAChDG,EAAKzH,EAAI7jB,eAAeD,EAAMhN,EAAK8E,QAAQ,IAAKuzB,IAChDG,EAAOF,EAAGprB,MACdorB,EAAGha,IAAIia,EAAGrrB,OACVqrB,EAAGja,IAAIka,KAOf1H,EAAI2H,WAAa,SAAoBC,GACjCA,EAAK5wB,WAAW0L,YAAYklB,IAMhC5H,EAAI6H,iBAAmB,SAAS7jB,GAC5B,OAAOA,EAAU8V,aAAagO,SAAS,IAI3C9H,EAAI+H,UAAY,SAASl0B,EAAGm0B,EAAIC,GAC5B,OAAGD,EAAKC,EAAWh3B,KAAKc,IAAIk2B,EAAIh3B,KAAKi3B,IAAIF,EAAIn0B,IACtC5C,KAAKc,IAAIi2B,EAAI/2B,KAAKi3B,IAAID,EAAIp0B,KAQrCmsB,EAAImI,cAAgB,SAAS/T,EAAGlD,EAAGiH,GAE/B,OADAA,EAAMA,GAAO,EACL/D,EAAEhT,MAAQ8P,EAAE1O,MAAQ2V,GACpBjH,EAAE9P,MAAQgT,EAAE5R,MAAQ2V,GACpB/D,EAAEvX,KAAOqU,EAAEtU,OAASub,GACpBjH,EAAErU,KAAOuX,EAAExX,OAASub,GAYhC6H,EAAI5Y,UAAY,SAASgP,EAAOgS,EAAMj0B,EAAIC,GAGtC,IAFA,IAAIoB,EAAM4gB,EAAM5iB,OACZsG,EAAM,IAAInE,MAAMH,GACZI,EAAI,EAAGA,EAAIJ,EAAKI,IAAKkE,EAAIlE,GAAKwyB,EAAKhS,EAAMxgB,GAAIzB,EAAIC,GACzD,OAAO0F,GAaXkmB,EAAIqI,QAAU,SAASA,EAAQC,EAAUC,EAAM30B,EAAM40B,GAGjD,GAFI50B,IAAMA,EAAO,SACL+D,IAAT4wB,IAAoBA,EAAO,IAC3BA,GAAQ,EAAG,MAAO,IAErB,IAEI3yB,EAAGsb,EAFHuX,EAASx3B,KAAKk0B,IAAIl0B,KAAKuO,IAAI,EAAG+oB,IAASt3B,KAAKk0B,IAAIvxB,GAChD80B,EAAM,GAGV,IAAI9yB,EAAI,EAAG6yB,IAAWE,IAAU/yB,GAAK,EACjC6yB,EAASx3B,KAAKk0B,IAAIl0B,KAAKuO,IAAI,EAAG+oB,EAAO3yB,IAAM3E,KAAKk0B,IAAIvxB,GAAQgC,EAGhE,IAAIgzB,EAAMH,EAASx3B,KAAKgD,MAAMw0B,GAE9B,IAAI7yB,EAAI,EAAGA,EAAI3E,KAAKgD,MAAMw0B,GAAS7yB,IAE/B8yB,EADIz3B,KAAKgD,MAAMhD,KAAK43B,SAAWj1B,GAAMmhB,SAASnhB,GACpC80B,EAGXE,IACC1X,EAAIjgB,KAAKuO,IAAI5L,EAAMg1B,GAEnBF,EADIz3B,KAAKgD,MAAMhD,KAAK43B,SAAW3X,GAAG6D,SAASnhB,GACjC80B,GAGd,IAAII,EAASC,SAASL,EAAK90B,GAC3B,OAAI00B,GAAYA,EAASI,IACnBI,IAAWH,KAAYG,GAAU73B,KAAKuO,IAAI,EAAG+oB,GAC5CC,EAAa,IACZxI,EAAIvT,KAAK,6BACFic,GAEJL,EAAQC,EAAUC,EAAM30B,GAAO40B,GAAc,GAAK,GAC/CE,GAGlB1I,EAAIgJ,cAAgB,SAASC,EAAKC,GAU1BD,IAAKA,EAAM,IACXC,IAASA,EAAU,OAEvB,IAAIC,EAAO,CACX,WAAkB,GAElB,WAAkB,SAASC,GACvBA,EAAOF,GAAWD,EAClBE,EAAKC,EAAOha,MAAQga,EACpBD,EAAKE,WAAWn2B,KAAKk2B,KAIzB,OADAD,EAAK,IAAMD,GAAWD,EACfE,GAQXnJ,EAAIsJ,OAAS,SAASC,EAASC,GAE3B,IADAA,EAAOv4B,KAAKC,MAAMs4B,IAAS,GACjB,EAAG,OAAOD,EAEpB,IAKI3zB,EACAkQ,EACA/S,EACAc,EARA41B,EAAOF,EAAQ/1B,OACfk2B,EAAQ,EAAID,EACZE,EAAO,EAAIH,EAAO,EAClBp6B,EAAI,IAAIuG,MAAMg0B,GACdC,EAAW,IAAIj0B,MAAM8zB,GAOzB,IAAI7zB,EAAI,EAAGA,EAAI+zB,EAAM/zB,IACjBxG,EAAEwG,IAAM,EAAI3E,KAAK44B,IAAI54B,KAAK64B,IAAMl0B,EAAI,GAAK4zB,KAAU,EAAIA,GAI3D,IAAI5zB,EAAI,EAAGA,EAAI6zB,EAAM7zB,IAAK,CAEtB,IADA/B,EAAI,EACAiS,EAAI,EAAGA,EAAI6jB,EAAM7jB,KACjB/S,EAAI6C,EAAIkQ,EAAI,EAAI0jB,IAGRC,EAAM12B,GAAK22B,EAAQz4B,KAAKC,MAAM6B,EAAI22B,GAClC32B,GAAK22B,IAAO32B,GAAK22B,EAAQz4B,KAAKgD,MAAMlB,EAAI22B,IAG7C32B,EAAI,EAAGA,GAAM,EAAIA,EACZA,GAAK02B,IAAM12B,EAAI22B,EAAQ,EAAI32B,GAEnCc,GAAK01B,EAAQx2B,GAAK3D,EAAE0W,GAExB8jB,EAASh0B,GAAK/B,EAGlB,OAAO+1B,GAcX5J,EAAI+J,YAAc,SAASC,EAAUC,EAAKC,GACtC,IAAIC,EAEJ,SAASC,IACL,OAAOpK,EAAI+J,YAAYC,EAAUC,EAAKC,GAG1C,KAAMF,EAASx2B,QAIX,IAFA22B,GADAE,EAAML,EAAStd,OAAO,EAAG,GAAG,IAClBud,KAEAE,EAAIG,KACV,OAAOH,EAAIG,KAAKF,GACXE,UAAK3yB,EAAWqoB,EAAIuK,cAIjC,OAAOL,GAAaA,EAAUD,IAQlCjK,EAAIwK,mBAAqB,SAASC,GAC9B,MAAsB,MAAnBA,EAAItd,QAAQ,GAAmBsd,EAAItd,OAAO,EAAGsd,EAAIj3B,OAAS,GACtDi3B,GAGXzK,EAAI0K,UAAY,SAASnY,EAAaC,EAAc6U,GAMhD,GAAI9U,EAAJ,CAEA,IAEI3c,EAFA+0B,GAAS,EACTC,GAAS,EAIb,IAAIh1B,EAAI,EAAGA,EAAIyxB,EAAS7zB,OAAQoC,IAEzBmY,MADGwE,EAAY8U,EAASzxB,IACW+0B,GAAS,EAC1CC,GAAS,EAGlB,GAAGD,IAAWC,EACV,IAAIh1B,EAAI,EAAGA,EAAIyxB,EAAS7zB,OAAQoC,IAC5B2c,EAAY8U,EAASzxB,IAAM4c,EAAa6U,EAASzxB,MAc7DoqB,EAAI6K,WAAa,SAASC,EAAWC,EAAIC,EAAQC,GAC7C,IAAIC,EAAsB,mBAAPD,EACnB,GAAGjL,EAAIhnB,oBAAoB8xB,GAEvB,IADA,IAAIK,EAAOl6B,KAAKi3B,IAAI4C,EAAUt3B,OAAQu3B,EAAGv3B,QACjCoC,EAAI,EAAGA,EAAIu1B,EAAMv1B,IAAK,CAC1B,IAAI/B,EAAIi3B,EAAUl1B,GAClBm1B,EAAGn1B,GAAGo1B,GAAUE,EAAQD,EAAGp3B,GAAKA,IAM5CmsB,EAAIoL,uBAAyB,SAASN,EAAWC,EAAIC,GACjD,OAAOhL,EAAI6K,WAAWC,EAAWC,EAAIC,GAAQ,SAASn3B,GAClD,IAAIzE,GAAKyE,EACT,OAAQw3B,SAASj8B,IAASA,EAAI,EAAIA,EAAZ,MAc9B4wB,EAAIsL,UAAY,SAASR,EAAWC,EAAIC,EAAQC,GAG5C,GAFAA,EAAKA,GAAMjL,EAAI7pB,SAEZ6pB,EAAIhnB,oBAAoB8xB,GACvB,IAAI,IAAIl1B,EAAI,EAAGA,EAAIm1B,EAAGv3B,OAAQoC,IAC1Bm1B,EAAGn1B,GAAGo1B,GAAUC,EAAGH,EAAUl1B,KAczCoqB,EAAIuL,WAAa,SAASz+B,EAAO0+B,EAAU/d,EAAMwd,GAC7CA,EAAKA,GAAMjL,EAAI7pB,SAEf,IAAI4X,EAAMiS,EAAI7jB,eAAerP,EAAO2gB,GAAMrR,MAE1C,OAAG4jB,EAAIhnB,oBAAoB+U,GACpBpY,MAAM+D,QAAQ8xB,IAAaxL,EAAIhnB,oBAAoB+U,EAAIyd,EAAS,KACxDP,EAAGld,EAAIyd,EAAS,IAAIA,EAAS,KAE7BP,EAAGld,EAAIyd,IAGXzd,GAafiS,EAAIniB,cAAgB,SAAS4tB,EAAQ3+B,EAAO4+B,EAASC,GACjD,GAAGD,KAAWD,EAAQ,OAAOA,EAAOC,GAMpC,IAAIE,EAAW5L,EAAI7jB,eAAerP,EAAO6+B,GAAUvvB,MACnD,OAAIzG,MAAM+D,QAAQkyB,QAAlB,EAAoCA,GA2BxC5L,EAAI6L,YAAc,SAASC,EAAWh/B,EAAOi/B,GACzC,IAEI9F,EAOoBpyB,EATpBoG,EAAiBnN,EAAMmN,eACvB+rB,EAAgBl5B,EAAMk/B,eAIvBhG,IACCC,EAAmBF,EAAqBC,IAO5C,IAAI,IAAIpwB,EAAI,EAAGA,EAAIqE,EAAezG,OAAQoC,IAAK,CAC3C,IAAIq2B,EAAUhyB,EAAerE,GAE7B,GAAGoqB,EAAIgH,QAAQiF,IACXjM,EAAIhnB,oBAAoBizB,IAAYjM,EAAIgH,QAAQiF,EAAQ,KAAOjM,EAAIgH,QAAQiF,EAAQ,IACrF,CACE,IAAIT,EAAWvF,EAAmBA,EAAiBgG,GAAWA,EAC1DC,EAAUH,EAAmBA,EAAiBP,GAAYA,OAVrD7zB,KADO9D,EAaEq4B,IAZIr4B,EAAIi4B,EAAUt4B,SAahCs4B,EAAUI,GAAS7xB,SAAW,MAM9C2lB,EAAImM,qBAAuB,SAASr/B,GAChC,IAAImN,EAAiBnN,EAAMmN,eACvB+rB,EAAgBl5B,EAAMk/B,eAE1B,GAAGhG,EAAe,CAId,IAHA,IAAIC,EAAmBF,EAAqBC,GACxClsB,EAAM,GAEFlE,EAAI,EAAGA,EAAIqE,EAAezG,OAAQoC,IAAK,CAC3C,IAAIq2B,EAAUhyB,EAAerE,GAC7B,GAAGoqB,EAAIgH,QAAQiF,GAAU,CACrB,IAAIT,EAAWvF,EAAiBgG,GAC7BjM,EAAIgH,QAAQwE,IACX1xB,EAAI5G,KAAKs4B,IAKrB,OAAO1xB,EAEP,OAAOG,GAcf+lB,EAAIoM,eAAiB,SAASt/B,EAAOu/B,GACjC,IAAIC,EAASD,EAAcC,OAE3B,GAAqB,iBAAXA,GAAuBA,EAAQ,CACrC,IAAIlW,EAAQ4J,EAAI7jB,eAAerP,EAAOw/B,GAAQlwB,MAC9C,QAAOzG,MAAM+D,QAAQ0c,IAASA,EAC3B,QAAGzgB,MAAM+D,QAAQ4yB,IACbA,GAYftM,EAAIuM,UAAY,SAASC,EAAMC,GAC3B,IAAIC,EAAS,GACM,iBAATD,IAAmBA,EAAO,IACpC,IAEI72B,EAAG7C,EAAGc,EADNhB,EAAOD,OAAOC,KAAK25B,GAGvB,IAAI52B,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAExB/B,EAAI24B,EADJz5B,EAAIF,EAAK+C,IAEU,MAAhB7C,EAAEgX,OAAO,IAA2B,mBAANlW,IACnB,WAANd,EAAgB25B,EAAO35B,GAAKc,EAC5B8B,MAAM+D,QAAQ7F,GAEd64B,EAAO35B,GADF,eAANA,EACac,EAAEwY,QAEFxY,EAAEwY,MAAM,EAbjB,GAeD2T,EAAIM,aAAazsB,GACvB64B,EAAO35B,GAAKc,EAAE84B,SAAS,EAhBhB,GAiB6BD,EAAO35B,GAArCc,GAAmB,iBAANA,EAA6BmsB,EAAIuM,UAAUC,EAAKz5B,GAAI05B,EAAK15B,IAC/Dc,GAIrB,IADAhB,EAAOD,OAAOC,KAAK45B,GACf72B,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAGR,iBADhB/B,EAAI44B,EADJ15B,EAAIF,EAAK+C,MAEqB7C,KAAK25B,GAAgC,iBAAdA,EAAO35B,KACxD25B,EAAO35B,GAAKc,GAIpB,OAAO64B,GAGX1M,EAAI4M,UAAY,SAASz/B,GACrB,OAAOA,EAAE4c,OAAO,GAAG8iB,cAAgB1/B,EAAEggB,OAAO,IAGhD6S,EAAI8M,YAAc,SAAS3/B,EAAG4/B,GAC1B,IAAI,IAAIn3B,EAAI,EAAGA,EAAIm3B,EAAUv5B,OAAQoC,IACjC,IAAgC,IAA7BzI,EAAE4G,QAAQg5B,EAAUn3B,IAAY,OAAO,EAE9C,OAAO,GAGXoqB,EAAIgN,KAAO,WACP,YAA8C,IAAhCxc,OAAOyc,UAAUC,YAGnC,IAAIC,EAAwB,eAC5BnN,EAAIoN,aAAe,WACf,OAAOpN,EAAIgN,QAAUG,EAAsBvjB,KAAK4G,OAAOyc,UAAUI,YAGrE,IAAIC,EAAkB,2BACtBtN,EAAIuN,SAAW,WACX,OAAOD,EAAgB1jB,KAAK4G,OAAOyc,UAAUI,YAOjDrN,EAAIwN,cAAgB,SAAS9f,GACzB,OAAOA,GAA+B,mBAAhBA,EAAImL,SA+B9BmH,EAAI7oB,aAAe,SAASs2B,EAAQC,EAAUC,EAAWC,GACrD,IAAIp+B,EAAMi+B,EAAOrgC,OAAOsgC,GAAYC,EAAY,IAAMA,EAAY,KAClE,GAAGn+B,EAAIZ,OAAQ,OAAOY,EAEtB,IAAIq+B,EAAQJ,EAAOl3B,OAAOm3B,GAI1B,OAHGC,GAAWE,EAAMhV,QAAQ8U,GAAW,GACpCC,GAASC,EAAMpgC,KAAKmgC,GAEhBC,GAaX7N,EAAI/e,iBAAmB,SAASwsB,EAAQC,EAAUI,EAAIF,GAClD,IAAIp+B,EAAMi+B,EAAOrgC,OAAOsgC,EAAW,IAAMI,GACzC,GAAGt+B,EAAIZ,OAAQ,OAAOY,EAEtB,IAAIq+B,EAAQJ,EAAOl3B,OAAOm3B,GAAUx+B,KAAK,KAAM4+B,GAG/C,OAFGF,GAASC,EAAMpgC,KAAKmgC,GAEhBC,GAkBX7N,EAAI+N,eAAiB,SAAS9tB,EAAM+tB,GAKhC,IAJA,IACIC,EADAp7B,EAAOoN,EAAKsD,MAAM,KAElBmK,EAAMugB,EAAS,GAEXr4B,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAAK,CACjC,IAAIof,EAAMniB,EAAK+C,GACXY,EAAK,KAELoW,EAAQ/Z,EAAK+C,GAAGyN,MAAM,oBAEvBuJ,GACCoI,EAAMpI,EAAM,GACZpW,EAAKoW,EAAM,GAEXqhB,EAASA,EAAOjZ,GAAO,GAEpBpf,IAAM/C,EAAKW,OAAS,EACnBy6B,EAAOz3B,GAAMw3B,EAEbC,EAAOz3B,GAAM,GAGjBy3B,EAASA,EAAOz3B,KAEbZ,IAAM/C,EAAKW,OAAS,EACnBy6B,EAAOjZ,GAAOgZ,EAEdC,EAAOjZ,GAAO,GAGlBiZ,EAASA,EAAOjZ,IAIxB,OAAOtH,GA+BX,IAAIwgB,EAAsB,qBACtBC,EAAuB,kCAE3BnO,EAAIoO,kBAAoB,SAASl8B,GAC7B,IAAImR,EAAO2R,EAAKzf,EAAM84B,EAAOC,EAAKC,EAAMC,EACxC,GAAmB,iBAATt8B,IAAsByD,MAAM+D,QAAQxH,GAC1C,IAAI8iB,KAAO9iB,EACJA,EAAK+Z,eAAe+I,MACf3R,EAAQ2R,EAAI3R,MAAM6qB,KAClBG,EAAQn8B,EAAK8iB,GACbzf,EAAO8N,EAAM,UAENnR,EAAK8iB,GAEZ9iB,EAAKqD,GAAQyqB,EAAIiF,mBAAmB/yB,EAAKqD,IAAS,GAAIyqB,EAAI+N,eAAe/Y,EAAKgL,EAAIoO,kBAAkBC,IAAQ94B,MACrG8N,EAAQ2R,EAAI3R,MAAM8qB,KACzBE,EAAQn8B,EAAK8iB,GAEbzf,EAAO8N,EAAM,GACbirB,EAAMvF,SAAS1lB,EAAM,WAEdnR,EAAK8iB,GAEZ9iB,EAAKqD,GAAQrD,EAAKqD,IAAS,GAEX,MAAb8N,EAAM,IAGLmrB,EAAenrB,EAAM,GACrBkrB,EAAOr8B,EAAKqD,GAAM+4B,GAAOp8B,EAAKqD,GAAM+4B,IAAQ,GAc5CtO,EAAIiF,mBAAmBsJ,EAAMvO,EAAI+N,eAAeS,EAAcxO,EAAIoO,kBAAkBC,MAIpFn8B,EAAKqD,GAAM+4B,GAAOtO,EAAIoO,kBAAkBC,IAG5Cn8B,EAAK8iB,GAAOgL,EAAIoO,kBAAkBl8B,EAAK8iB,KAMvD,OAAO9iB,GAwBX8tB,EAAIyO,YAAc,SAAST,EAAOU,EAAYC,GAG1C,GAFIA,IAAmBA,GAAoB,GAElB,iBAAfD,GAAiD,IAAtBA,EAAWl7B,OAC5C,MAAM,IAAIo7B,MAAM,6CAGA,iBAAVZ,IACNA,EAAQ9gB,OAAO8gB,IAGnB,IAAIa,EAAc,eACdC,EAAaJ,EAAW3kB,OAAO,GAC/BglB,EAAUL,EAAW3kB,OAAO,GAE5B/a,EAAIg/B,EAAMzqB,MAAM,KAChBpP,EAAKnF,EAAE,GACPoF,EAAKpF,EAAEwE,OAAS,EAAIs7B,EAAa9/B,EAAE,GAAK,GAG5C,GAAG+/B,IAAY//B,EAAEwE,OAAS,GAAKW,EAAGX,OAAS,GAAKm7B,GAC5C,KAAME,EAAYjlB,KAAKzV,IACnBA,EAAKA,EAAGH,QAAQ66B,EAAa,KAAOE,EAAU,MAItD,OAAO56B,EAAKC,GAGhB4rB,EAAIgP,sBAAwB,iCAC5B,IAAIC,EAAwB,QAc5BjP,EAAIvD,eAAiB,SAASyS,EAAQxhB,GAGlC,IAAIyhB,EAAc,GAElB,OAAOD,EAAOl7B,QAAQgsB,EAAIgP,uBAAuB,SAASI,EAAOpa,GAC7D,IAAInhB,EAOJ,OANGo7B,EAAsBrlB,KAAKoL,GAC1BnhB,EAAI6Z,EAAIsH,IAERma,EAAYna,GAAOma,EAAYna,IAAQgL,EAAI7jB,eAAeuR,EAAKsH,GAAK5Y,IACpEvI,EAAIs7B,EAAYna,MAEbgL,EAAIqP,iBAAiBx7B,GAAKA,EAAI,OAI7C,IAAIy7B,EAAwB,CACxBv9B,IAAK,GACLw9B,MAAO,EACPngB,KAAM,iBAEV4Q,EAAIwP,oBAAsB,WACtB,OAAOC,EAAqBC,MAAMJ,EAAuBK,YAG7D,IAAIC,EAAuB,CACvB79B,IAAK,GACLw9B,MAAO,EACPngB,KAAM,gBAEV4Q,EAAI5hB,mBAAqB,WACrB,OAAOqxB,EAAqBC,MAAME,EAAsBD,YAG5D,IAAIE,EAAmC,UAiBvC,SAASJ,EAAqBP,EAAQpxB,EAAQgyB,GAC1C,IAAI3d,EAAO9kB,KACP0tB,EAAO4U,UACP7xB,IAAQA,EAAS,IAGrB,IAAIqxB,EAAc,GAElB,OAAOD,EAAOl7B,QAAQgsB,EAAIgP,uBAAuB,SAAS3rB,EAAO2R,EAAKvgB,GAClE,IAAIiZ,EAAKsgB,EAAOp4B,EA+BRm6B,EA9BR,IAAIn6B,EAAI,EAAGA,EAAImlB,EAAKvnB,OAAQoC,IAExB,GADA8X,EAAMqN,EAAKnlB,GACX,CACA,GAAG8X,EAAIzB,eAAe+I,GAAM,CACxBgZ,EAAQtgB,EAAIsH,GACZ,MAOJ,GAJIia,EAAsBrlB,KAAKoL,KAC3BgZ,EAAQmB,EAAYna,IAAQgL,EAAI7jB,eAAeuR,EAAKsH,GAAK5Y,SAC/C+yB,EAAYna,GAAOgZ,QAEpBr2B,IAAVq2B,EAAqB,MAG5B,QAAar2B,IAAVq2B,GAAuB7b,EAWtB,OAVGA,EAAKod,MAAQpd,EAAKpgB,MACjBiuB,EAAIvT,KAAK,aAAgBuI,EAAM,QAAW7C,EAAK/C,KAAO,wBACtD4e,EAAQ3qB,GAGT8O,EAAKod,QAAUpd,EAAKpgB,KACnBiuB,EAAIvT,KAAK,YAAc0F,EAAK/C,KAAO,sDAEvC+C,EAAKod,QAEElsB,EAGX,GAAG5O,GAOC,GALiB,MAAdA,EAAO,KAENu5B,GADA+B,EAAMD,EAAWA,EAASE,aAAezjC,EAAGkI,QAChCA,EAAOT,QAAQ67B,EAAkC,IAArDE,CAA0D/B,IAGrD,MAAdv5B,EAAO,GAAY,CAClBs7B,EAAMD,EAAWA,EAASG,WAAWv0B,IAAMnP,EAAG2jC,KAAKz7B,OAAOiH,IAC1D,IAAI3D,EAAKioB,EAAImB,YAAY6M,GACzBA,EAAQhO,EAAIyB,WAAW1pB,EAAItD,EAAOT,QAAQ67B,EAAkC,KAAK,EAAOE,SAGzFjyB,EAAOmO,eAAe+I,EAAM,WAAUgZ,EAAQlwB,EAAOkX,EAAM,UAElE,OAAOgZ,KASfhO,EAAImQ,YAAc,SAAS/b,EAAGlD,GAI1B,IAHA,IAAImH,EAAIpnB,KAAKi3B,IAAI9T,EAAE5gB,OAAQ0d,EAAE1d,QAAU,EACnC48B,EAAO,EACPC,EAAO,EACHz6B,EAAI,EAAGA,EAAIyiB,EAAGziB,IAAK,CACvB,IAAI06B,EAAQlc,EAAE7C,WAAW3b,IAAM,EAC3B26B,EAAQrf,EAAEK,WAAW3b,IAAM,EAC3B46B,EAASF,GATT,IAS2BA,GAR3B,GASAG,EAASF,GAVT,IAU2BA,GAT3B,GAcJ,GAHGC,IAAQJ,EAAO,GAAKA,EAAOE,EAZ1B,IAaDG,IAAQJ,EAAO,GAAKA,EAAOE,EAb1B,KAeAC,IAAWC,EAAQ,CACnB,GAAGL,IAASC,EAAM,OAAOD,EAAOC,EAChC,GAAGC,IAAUC,EAAO,OAAOD,EAAQC,GAG3C,OAAOF,EAAOD,GAIlB,IAAIM,EAAW,IAEf1Q,EAAI2Q,iBAAmB,WACnBD,EAAW,KAGf1Q,EAAI4Q,aAAe,WACf,IAAIC,EAAUH,EAId,OAHAA,GAAY,MAAQA,EAAW,GAAK,WAGjCz/B,KAAK6/B,IAAIJ,EAAWG,GAAW,UAAkB7Q,EAAI4Q,eACjDF,EAAW,YAiBtB1Q,EAAI+Q,SAAW,SAAStF,EAAQ3+B,EAAOkkC,GACnC,IAAIliC,EAAO6G,MAAM+D,QAAQs3B,GACrB,SAASn9B,GAAKm9B,EAAQ99B,KAAKW,IAC3B,SAASA,GAAKm9B,EAAQpzB,KAAO/J,GAE7Bo9B,EAAMjR,EAAIniB,cAAc4tB,EAAQ3+B,EAAO,MAAO,aAClD,GAAGkzB,EAAIqP,iBAAiB4B,GAAM,OAAOniC,EAAKmiC,GAE1C,IAAIpyB,EAAKmhB,EAAIniB,cAAc4tB,EAAQ3+B,EAAO,KAAM,QAChD,OAAGkzB,EAAIqP,iBAAiBxwB,GAAY/P,EAAK+P,QAAzC,GAIJmhB,EAAIqP,iBAAmB,SAASx7B,GAC5B,OAAOA,GAAW,IAANA,GAOhBmsB,EAAIkR,cAAgB,SAASC,EAAOl+B,GAChCA,EAAIA,GAAK,EAET,IADA,IAAIw3B,GAAOx5B,KAAKC,MAAM,IAAMigC,EAAQlgC,KAAKuO,IAAI,GAAIvM,IAAMhC,KAAKuO,IAAI,GAAKvM,IAAIm+B,QAAQn+B,GAAK,IAC9E2C,EAAI,EAAGA,EAAI3C,EAAG2C,KACO,IAAtB60B,EAAI12B,QAAQ,OAEX02B,GADAA,EAAMA,EAAIz2B,QAAQ,KAAM,MACdA,QAAQ,KAAM,MAGhC,OAAOy2B,GAGXzK,EAAIqR,SAAW,SAASzgC,GACpB,IAAI0gC,EAAU9gB,OAAO+gB,iBAAiB3gC,GAAI0gC,QAC1C,OAAQA,GAAuB,SAAZA,GAevBtR,EAAIwR,iBAAmB,SAASlvB,GAC5B,IAAImvB,EAAWnvB,EAAUmvB,SACrBC,EAAQpvB,EAAUovB,MAClBC,EAAQrvB,EAAUqvB,MAClBC,EAAUtvB,EAAUsvB,QACpBC,EAAUvvB,EAAUuvB,QACpBC,EAAUxvB,EAAUwvB,SAAW,EAC/BC,EAAUzvB,EAAUyvB,SAAW,EAC/BC,EAAS1vB,EAAU0vB,OACnB7tB,EAAQ7B,EAAU6B,MAItB,OAHIA,EACIA,EAAQ,IAAGA,EAAQ,GADhBA,EAAQ,EAIf,cACKytB,EAAUztB,GAASutB,EAAQI,IAAY,KACvCD,EAAU1tB,GAASwtB,EAAQI,IAChC,KACC5tB,EAAQ,EACL,SAAWA,EAAQ,IAAM,KAE5B6tB,EACG,UAAYA,GACPP,EAAW,GAAK,IAAMC,EAAQ,IAAMC,GACzC,IAAM,KAKlB3R,EAAIiS,sBAAwB,SAASrhC,EAAIshC,GACrC,IAAIp4B,EAAMkmB,EAAI9lB,WAAW,GAAIg4B,GAK7B,OAJAp4B,EAAIlL,KAAOqC,KAAKc,IACZmgC,EAAStjC,KACTgC,EAAGkF,YAAYq8B,YAAYC,SAAW,GAEnCt4B,I,8CCvrCXrN,EAAOC,QAAU,CACbi0B,IAhBJ,SAAa9sB,EAAGhH,GACZ,IAAIiN,EAAMjG,EAAIhH,EACd,OAAOiN,EAAM,EAAIA,EAAMjN,EAAIiN,GAe3B8mB,QARJ,SAAiB/sB,EAAGhH,GAChB,OAAOoE,KAAK6/B,IAAIj9B,GAAMhH,EAAI,EACtBgH,EAAI5C,KAAKC,MAAM2C,EAAIhH,GAAKA,EACxBgH,K,8CChBR,IAAI5F,EAAM,EAAQ,YACdF,EAAW,EAAQ,YAEvBtB,EAAOC,QAAU,SAA0BslB,EAASC,EAAUC,EAAQxK,GAClE,IAEIlS,EAFAxG,EAAI0Y,EAAO,KACXzY,EAAIyY,EAAO,KAMf,GAH6B3Z,EAASyX,mBAAmB,YAAa,sBACtE6sB,CAAuBrgB,EAASC,EAAU,CAAC,IAAK,KAAMC,GAEnDljB,EAAG,CACF,IAAIsjC,EAAOrkC,EAAIwyB,aAAazxB,GACzBC,EACCuG,EAAMvE,KAAKi3B,IAAIoK,EAAMrkC,EAAIwyB,aAAaxxB,KAEtCuG,EAAM88B,EACN5qB,EAAO,MACPA,EAAO,WAER,CACH,IAAIzY,EAAG,OAAO,EAEduG,EAAMvH,EAAIwyB,aAAaxxB,GACvByY,EAAO,MACPA,EAAO,MAKX,OAFAuK,EAASsgB,QAAU/8B,EAEZA,I,8CC5BX/I,EAAOC,QAAU,WACS,oBAAZ8lC,UAC2D,WAA7ChiB,OAAOiiB,cAAgB,IAAIC,gBAG3CF,QAAQG,IAAIC,OAAO,CACfC,aAAc,OACdC,oBAAoB,EACpBC,aAAc,OACdC,QAAS,CACLC,WAAY,CAAC,CAAC,IAAK,KAAM,CAAC,MAAO,WAGzCT,QAAQG,IAAIO,iB,8CCdxB,IAAIrlC,EAAY,EAAQ,YACpBmL,EAAsB,EAAQ,YAAWA,oBAe7CtM,QAAQ+1B,QAAU,SAAStvB,EAAGU,EAAGugB,EAAG5e,GAChC,IAAII,EACAsb,EAGJ,KAFI1b,GAAOA,EAAM4e,EAAE5gB,UAAQgC,EAAM4e,EAAE5gB,QAC/B3F,EAAUgG,KAAIA,GAAI,GACnBmF,EAAoBob,EAAE,IAAK,CAE1B,IADAlD,EAAI,IAAIvb,MAAMH,GACVI,EAAI,EAAGA,EAAIJ,EAAKI,IAAKsb,EAAEtb,GAAKlJ,QAAQ+1B,QAAQtvB,EAAGU,EAAGugB,EAAExe,IACxDwe,EAAIlD,EAGR,IAAItb,EAAI,EAAGA,EAAIJ,EAAKI,IACZ/H,EAAUgG,GACNhG,EAAUumB,EAAExe,MAAK/B,EAAIV,GAAGU,GAAIugB,EAAExe,KADpB/B,EAAIugB,EAAExe,GAG5B,OAAO/B,GAOXnH,QAAQ8I,IAAM,SAAStD,GACnB,OAAOxF,QAAQ+1B,SAAQ,SAASrO,GAAK,OAAOA,EAAI,IAAM,EAAGliB,IAG7DxF,QAAQg2B,KAAO,SAASxwB,EAAMsD,GAE1B,OADIA,IAAKA,EAAM9I,QAAQ8I,IAAItD,IACpBxF,QAAQ+1B,SAAQ,SAASrO,EAAGlD,GAAK,OAAOkD,EAAIlD,IAAM,EAAGhf,GAAQsD,GAGxE9I,QAAQk2B,SAAW,SAASuQ,GACxB,QAAcx7B,IAAXw7B,GAA0C,IAAlBA,EAAO3/B,OAClC,OAAQ9G,QAAQ+1B,QAAQxxB,KAAKc,IAAK,KAAMohC,GAAUzmC,QAAQ+1B,QAAQxxB,KAAKi3B,IAAK,KAAMiL,IAAW,GAGjGzmC,QAAQm2B,SAAW,SAAS3wB,EAAMsD,EAAKktB,GAInC,OAHIltB,IAAKA,EAAM9I,QAAQ8I,IAAItD,IACvBrE,EAAU60B,KAAOA,EAAOh2B,QAAQg2B,KAAKxwB,EAAMsD,IAExC9I,QAAQ+1B,SAAQ,SAASrO,EAAGlD,GAC/B,OAAOkD,EAAInjB,KAAKuO,IAAI0R,EAAIwR,EAAM,KAC/B,EAAGxwB,GAAQsD,GAGlB9I,QAAQo2B,MAAQ,SAAS5wB,EAAMsD,EAAKktB,GAChC,OAAOzxB,KAAKmiC,KAAK1mC,QAAQm2B,SAAS3wB,EAAMsD,EAAKktB,KAOjDh2B,QAAQi2B,OAAS,SAASzwB,GACtB,IAAIgf,EAAIhf,EAAKma,QAAQiW,OACrB,OAAO51B,QAAQq2B,OAAO7R,EAAG,KAkB7BxkB,QAAQq2B,OAAS,SAAS1R,EAAKpe,GAC3B,IAAIpF,EAAUoF,GAAI,KAAM,8BAExB,IADAA,EAAIA,EAAIoe,EAAI7d,OAAS,IACd,EAAG,OAAO6d,EAAI,GACrB,GAAGpe,EAAIoe,EAAI7d,OAAS,EAAG,OAAO6d,EAAIA,EAAI7d,OAAS,GAC/C,IAAI6/B,EAAOpgC,EAAI,EACf,OAAOogC,EAAOhiB,EAAIpgB,KAAK0sB,KAAK1qB,KAAO,EAAIogC,GAAQhiB,EAAIpgB,KAAKgD,MAAMhB,M,8CChGlE,IAAIhF,EAAM,EAAQ,YACdqlC,EAAU,EAAQ,YAkEtB7mC,EAAOC,QApDP,SAAmBokB,EAAK1B,EAAM3a,GAC1B,IAAI8+B,EAAW5hB,SAAS6hB,cAAc,KAClCC,EAAiB,aAAcF,EA8CnC,OA5Cc,IAAIG,SAAQ,SAASC,EAASC,GACxC,IAAIhjB,EACAijB,EAOJ,GALG5lC,EAAIm/B,gBACHwG,EAAO,IAAIhF,MAAM,wBAIlB3gC,EAAIs/B,WAAY,CACf,IAAItxB,EAAoB,QAAXxH,EAAmB,IAAM,WAEtC,OADA6+B,EAAQ5hB,YAAYzV,EAASmU,mBAAmBU,IACzC6iB,EAAQvkB,GAInB,OAAGnhB,EAAI++B,QAGHpc,EAAO0iB,EAAQviB,WAAWD,EAAK,OAC/BN,OAAOyc,UAAUC,WAAWtc,EAAMxB,GAClCwB,EAAO,KACA+iB,EAAQvkB,IAGhBqkB,GACC7iB,EAAO0iB,EAAQviB,WAAWD,EAAKrc,GAC/Bo/B,EAAYP,EAAQ3iB,gBAAgBC,GAEpC2iB,EAAS1hB,KAAOgiB,EAChBN,EAASO,SAAW1kB,EACpBuC,SAASoiB,KAAKrxB,YAAY6wB,GAC1BA,EAASS,QAETriB,SAASoiB,KAAKhxB,YAAYwwB,GAC1BD,EAAQziB,gBAAgBgjB,GACxBjjB,EAAO,KAEA+iB,EAAQvkB,SAGnBwkB,EAAO,IAAIhF,MAAM,wB,8CC5DzB,IAAIriC,EAAK,EAAQ,YAEbwB,EAAW,EAAQ,YACnBuoB,EAAQ,EAAQ,YAChBroB,EAAM,EAAQ,YACdgmC,EAAO,EAAQ,YACfznC,EAAQ,EAAQ,YAChB+pB,EAAU,EAAQ,YAClB2d,EAAK,EAAQ,YACbhmC,EAAe,EAAQ,YACvBimC,EAAY,EAAQ,YACpBC,EAAc,EAAQ,YACtB5d,EAAc,EAAQ,YAAgCA,YAEtD6d,EAAgB,EAAQ,YAuC5B,SAASC,EAAQ1jC,EAAIslB,GACjB,IACIqe,EADa3jC,EAAGkF,YACK0+B,YAAYte,IAAU,GAC3CzmB,EAAKwkC,EAAKQ,UAAU7jC,EAAI2jC,EAAQG,MAChChlC,EAAKukC,EAAKQ,UAAU7jC,EAAI2jC,EAAQI,MAEjCllC,GAAIA,EAAGoU,WACPnU,GAAIA,EAAGmU,WAEV+wB,EAAQhkC,EAAI2jC,EAASre,GAAO,EAAOzmB,EAAIC,GAc3C,SAASklC,EAAQhkC,EAAI2jC,EAASre,EAAO2e,EAAWplC,EAAIC,GAChD,IAIIi+B,EAAWmH,EAJXj/B,EAAajF,EAAGkF,YAChBi/B,EAAKnkC,EAAGkF,YAAYkoB,MACpBgX,EAAQpkC,EAAGG,SAASikC,MAIrBH,GACClH,EAAY,cAAgBkH,EAC5BC,EAAeD,EAAY,iBAE3BlH,EAAY,aACZmH,EAAe,eAGnB,IAAIG,EAAcze,EAAY5lB,EAAGshB,OAAQ4iB,EAAcP,GACnDW,EAAaD,EAAYC,WACzBC,EAAaF,EAAYE,WACzBC,EAAeH,EAAYG,aAG/Bv/B,EAAWw/B,WACN/nC,UAAU,IAAMqgC,EAAY,gBAAkBzX,EAAQ,MACtD7f,SAEL,IAAIi/B,EAAY,OAASz/B,EAAWG,KAAO,OAASkgB,EAIpD,GAAIqe,EAAQppB,SAA8B,IAApBopB,EAAQ5e,QAA9B,CAOA,IAAI4f,EAAW,CAACvmC,EAAG,GAAIC,EAAG,IACtBumC,GAAajB,EAAQiB,WAAa,EAMlCC,EAAW5/B,EAAWw/B,WAAW9+B,OAAO,KACvCsiB,QAAQ8U,GAAW,GACnBz+B,KAAK,aAAcge,OAAOgJ,IAC1B3oB,MAAM,UAAWgnC,EAAQ18B,SAG1B69B,EAAeD,EAASl/B,OAAO,KAC9BsiB,QAAQ,qBAAqB,GAE9B8c,EAAmBX,EAAMT,EAAQqB,UAAY,iBAAmB,sBAChEC,EAAatB,EAAQuB,eAAiBd,EAAMe,gBAAkBJ,EAe9DK,EAAoBN,EAAan/B,OAAO,KACvChJ,MAAM,iBAAkBsoC,EAAa,MAAQ,MAC7CpoC,KAAK0mC,EAAW,WAChBjb,GAAG,SAAS,WACTtoB,EAAGqlC,WAAY,EACfrlC,EAAGoqB,KAAK,yBAA0Bkb,EAAc3pC,EAAGkuB,WAGxD8Z,EAAQ4B,WACPH,EACC9c,GAAG,aAAa,WACb,IAAIkd,EAAe7B,EAAQ8B,WACvBC,EAAYF,EAAa1nC,KACzBsT,EAAO3U,KAAKwV,wBACZ0zB,EAAU3lC,EAAGiS,wBAEjBqxB,EAAGsC,UAAU,CACTzc,GAAI/X,EAAKZ,KAAOm1B,EAAQn1B,KACxBjN,GAAI6N,EAAKQ,MAAQ+zB,EAAQn1B,KACzBnS,GAAI+S,EAAKnF,IAAMmF,EAAKpF,QAAU,EAAI25B,EAAQ15B,IAC1Ce,KAAM22B,EAAQ4B,UACdxoC,MAAOyoC,EAAa9Z,QACpBma,YAAaL,EAAa/Z,YAC1Bqa,WAAYJ,EAAU3nC,OACtBqO,SAAUs5B,EAAU1nC,KACpB6P,UAAW63B,EAAU3oC,OACtB,CACCqf,UAAWnX,EAAW8gC,YAAY/mC,OAClCgnC,eAAgB/gC,EAAWghC,OAAOjnC,OAClCgB,GAAIA,OAGXsoB,GAAG,YAAY,WACZgb,EAAG4C,YAAYjhC,EAAW8gC,YAAY/mC,WAI9C,IAAI2qB,EAAcga,EAAQha,YACtBwc,EAAYxC,EAAQwC,UACpBC,EAAazc,EAAcwc,EAE3BE,EAAYjB,EAAkBz/B,OAAO,QACpCrH,KAAK,QAAS,MACd3B,MAAM,eAAgBgtB,EAAc,MACpC9sB,KAAKjB,EAAMkB,OAAQ6mC,EAAQlY,aAC3B5uB,KAAKjB,EAAMsC,KAAMylC,EAAQjY,SAE1B4a,EAAoB3C,EAAQ9iC,OAAS8iC,EAAQlzB,OAE7C81B,EAActhC,EAAWuhC,UACxB9pC,UAAU,IAAMgoC,GAChBpjC,KAAKglC,EAAoB,CAAC,GAAK,IAEpCC,EAAY7gC,QAAQC,OAAO,YACtBsiB,QAAQ,WAAW,GACnB3pB,KAAK,KAAMomC,GACb/+B,OAAO,QACV4gC,EAAY/gC,OAAOC,SAEnB,IAAI3H,EAAO6lC,EAAQ7lC,KAEfkP,EAAO/H,EAAWsI,MAClBlQ,EAAIwuB,eAAe8X,EAAQ32B,KAAM/H,EAAWsI,OAC5Co2B,EAAQ32B,KAERy5B,EAAUrB,EAAkBz/B,OAAO,QAClCsiB,QAAQ,mBAAmB,GAC3Bjb,KAAKA,GAwcPo3B,EAAMe,eACLsB,EAAQ5pC,KAAKS,EAAaopC,aAAc,CAACC,SAAUvB,EAAmBplC,GAAIA,IACrEnD,KAAK+pC,GACLte,GAAG,QAAQ,SAASue,GACjBlD,EAAQ32B,KAAO65B,EAEfpqC,KAAKI,KAAK+pC,GAEVrC,EAAW,OAAQsC,GAEhBhoC,GAAMA,EAAG0c,WACR+oB,EAAWzlC,EAAGmZ,MAAQ,cAAc,GAErClZ,GAAMA,EAAGyc,WACR+oB,EAAWxlC,EAAGkZ,MAAQ,cAAc,GAGxC7a,EAASN,KAAK,eAAgBmD,EAAIwkC,QAEvCiC,EAAQ5pC,KAAK+pC,QApkBhBjrC,EAAGe,UAAU,IAAMgoC,GAAWj/B,SAyBlC,SAAS6/B,EAAcwB,GACnB,IAAIC,EAAY,CACZzhB,MAAOA,EACP0hB,WAAYrD,EAAQppB,OACpB0sB,eAAgBtD,EAChB9Z,MAAOid,GAKX,OAHG7C,IACC8C,EAAU9C,UAAYA,GAEnB8C,EAwEX,SAASH,EAAWrqC,GAUhB,OATAA,EAAEM,KAAK8oB,EAAQ7nB,KAAMA,GACpBQ,KAAK,CACF,cAAe,CACXkS,KAAM,QACNoB,MAAO,OACT+xB,EAAQuD,QAAU,WAGxB5pC,EAAayQ,gBAAgBxR,EAAGyD,EAAImnC,GAC7B5qC,EAGX,SAAS4qC,IAEL,IAAIC,EAAUX,EAAQ/pC,UAAU,KACV,IAAnB0qC,EAAQppC,QAAgBopC,EAAQp6B,SAAWy5B,EAAQz5B,QAClCo4B,EAAkBiC,OAAO,IAAK,gBAAgB/oC,KAAK,CAC/D,mBAAoB8oC,EAAQ9oC,KAAK,cACjC,mBAAoB8oC,EAAQ9oC,KAAK,gBAEpC3B,MAAM,CAAC2qC,OAAQ,YAENtoC,OAAO8S,YAAYu0B,EAAUrnC,QAG3C,IAAIuoC,EAAenC,EAAkB5oC,OAAO,+BACxCgrC,GAAcD,EAAaE,QAC3BC,EAAY/hB,EAAQvU,MACfo2B,EAAaD,EAAed,GAASznC,QAC1C2oC,EAAYD,EAAU7mC,MACtB+mC,EAAaF,EAAUj3B,OACvBo3B,EAAWlE,EAAQ9iC,OAAS8mC,EAC5BG,EAAYnE,EAAQlzB,QAAUm3B,EAC9BG,EAAa1nC,KAAKC,MAAMunC,EAAW,EAAIzB,GACvC4B,EAAc3nC,KAAKC,MAAMwnC,EAAY,EAAI1B,GAE7C,SAAS6B,EAAchlC,EAAG2X,GAMtB,MALc,SAAXA,IACeA,EAAX3X,EAAI,EAAI,EAAY,OACfA,EAAI,EAAI,EAAY,QACd,UAEX,CACH4qB,OAAQ,EACR9hB,OAAQ,EACRyE,KAAM,GACNxE,QAAS,GACT4F,OAAQ,GACR3F,IAAK,IACP2O,GAMN,IAHA,IAAIstB,GAAwB,EACxBC,EAAU,CAAC,IAAK,KAEZnjC,EAAI,EAAGA,EAAImjC,EAAQvlC,OAAQoC,IAAK,CACpC,IAaIojC,EACAC,EACAC,EACAC,EACAC,EAjBAvxB,EAAWkxB,EAAQnjC,GACnByjC,GAAQ9E,EAAQ1sB,EAAW,QAAUA,EACrCyxB,GAAU/E,EAAQ,IAAM1sB,EAAW,OACnC0xB,GAAK,CAACvqC,EAAGS,EAAIR,EAAGS,GAAImY,GACpB2xB,IAAYhE,GAA0B,MAAb3tB,EAAmB,GAAK,KAAO5W,KAAK64B,GAAK,IAElE2P,GAAmBd,EAAa1nC,KAAK44B,IAAI2P,IACzCE,GAAoBd,EAAc3nC,KAAK0oC,IAAIH,IAE3CI,GAAU3oC,KAAK6/B,IAAI2I,IAAoBxoC,KAAK6/B,IAAI4I,IAChDluB,GAAS+oB,EAAQ1sB,EAAW,UAC5BgyB,GAAetF,EAAQ1sB,EAAW,UAAyB,MAAbA,EAAmB,GAAK,GACtEiyB,GAAQvE,EAAS1tB,GAYrB,GAAG0xB,GAAI,CAEH,IAAIQ,GAAcR,GAAGS,WAAWzF,EAAQ1sB,KACrCkyB,GAAc,GAAKA,GAAc,KAC7BT,KAAYD,KACXU,GAAcR,GAAGS,WAAWzF,EAAQ,IAAM1sB,KACzB,GAAKkyB,GAAc,KAChCjB,GAAwB,GAG5BA,GAAwB,GAGhCE,EAASO,GAAGU,QAAUV,GAAGW,IAAI3F,EAAQ1sB,IACrCsxB,EAAoB,OAEJ,MAAbtxB,GACCqxB,EAAgB3E,EAAQ1sB,GACxBmxB,EAASjE,EAAG1c,EAAI0c,EAAG3lC,EAAI8pC,IAEvBA,EAAgB,EAAI3E,EAAQ1sB,GAC5BmxB,EAASjE,EAAG3wB,EAAI2wB,EAAG1lC,EAAI6pC,GAE3BC,EAAoB5E,EAAQqB,UAAY,GAAMsD,EAKlD,GAAG3E,EAAQqB,UAAW,CAClBkE,GAAMK,KAAOnB,EAEb,IAAIoB,GAAc7F,EAAQ,IAAM1sB,GAGhCuxB,EAAYK,GAAmBZ,EAAc,GAAKtE,EAAQtW,SACtDyb,GAAoBb,EAAc,GAAKtE,EAAQnW,SAEhDkb,KAAYD,IACXS,GAAM3jB,KAAOojB,GAAGU,QAAUV,GAAGW,IAAIE,IAEjCnB,EAAeG,IAEfU,GAAM3jB,KAAO6iB,EAASoB,GAEtBnB,EAAeG,EAAYgB,IAG/BN,GAAMl8B,KAAOk8B,GAAM3jB,KAAOijB,EAI1B,IAAIiB,GAAQxkC,EAAyB,MAAbgS,EAAoB,QAAU,UAItD,GAHa,UAAVwxB,KACCS,GAAMK,KAAOlsC,EAAI85B,UAAU+R,GAAMK,KAAM,EAAGE,GAAQ,IAEvC,UAAZf,GAAqB,CACpB,IAAIgB,IAAarpC,KAAKc,IAAI+nC,GAAM3jB,KAAO,EAAG2jB,GAAMl8B,MAC5C28B,GAAatpC,KAAKi3B,IAAI4R,GAAM3jB,KAAO,EAAG2jB,GAAMl8B,MAAQy8B,GACrDC,GAAY,GACXR,GAAM3jB,MAAQmkB,GACdR,GAAMl8B,MAAQ08B,IACRC,GAAa,IACnBT,GAAM3jB,MAAQokB,GACdT,GAAMl8B,MAAQ28B,IAItBT,GAAM3jB,MAAQ0jB,GACdC,GAAMK,MAAQN,QAKdZ,EADAG,EAAYQ,GAAUf,EAAcM,EAAmB3tB,IAEvDsuB,GAAMl8B,KAAOo7B,EAASI,EAG1BU,GAAMl8B,MAAQi8B,GACdT,GAAaS,GACbZ,GAAgBY,GAGhBtF,EAAQ,IAAM1sB,EAAW,WAAc+xB,GAAU,EAAKX,EACtD1E,EAAQ,IAAM1sB,EAAW,YAAe+xB,GAAU,EAAKX,EAGvD1E,EAAQ,IAAM1sB,EAAW,QAAU+xB,GACnCrF,EAAQ,IAAM1sB,EAAW,SAAWuxB,EAGxC,GAAGN,EACC9C,EAAkB3/B,aADtB,CAKA,IAAImkC,GAAS,EACTC,GAAS,EASb,GAPqB,SAAlBlG,EAAQuD,QACP0C,IAAU/B,EAAWF,IAAgC,WAAlBhE,EAAQuD,MAAqB,GAAM,IAEpD,QAAnBvD,EAAQmG,SACPD,IAAU/B,EAAYF,IAAkC,WAAnBjE,EAAQmG,OAAsB,GAAM,IAG1EtC,EACCD,EAAa/qC,OAAO,OAAO8B,KAAK,CAC5BF,EAAGgoC,EAAawD,GAAS,EACzBvrC,EAAG+nC,EAAayD,KAEnBhtC,KAAK8oB,EAAQtT,WAAYi0B,EAAoB5B,EAAY,KAAM1kC,OAC7D,CACH,IAAI+pC,GAAQ3D,EAAayD,GAASnC,EAAUz7B,IACxC+9B,GAAQ5D,EAAawD,GAASlC,EAAUl3B,KAE5Ci2B,EAAQ5pC,KAAKS,EAAayU,aAAci4B,GAAOD,IAC1CltC,KAAK8oB,EAAQtT,WAAYi0B,EAAoB5B,EAAY,KAAM1kC,GAGxEumC,EAAY/pC,OAAO,QAAQK,KAAK8oB,EAAQjnB,QAAS0nC,EAAYA,EACzDyB,EAAUC,GAEdzB,EAAUxpC,KAAK8oB,EAAQjnB,QAASirB,EAAc,EAAGA,EAAc,EAC3Doe,EAAape,EAAaqe,EAAcre,GAE5Cyb,EAAkBvoC,KAAK8oB,EAAQ/S,aAC3BvS,KAAKC,MAAMqkC,EAASvmC,EAAE4O,KAAO+6B,EAAa,GAC1C1nC,KAAKC,MAAMqkC,EAAStmC,EAAE2O,KAAOg7B,EAAc,IAQ/ClD,EAAaxmC,KAAK,CAACoT,UAAW,UAAYkzB,EAAY,IAClCD,EAASvmC,EAAE4O,KAAO,IAAM23B,EAAStmC,EAAE2O,KAAO,MAQ9D,IAsJQi9B,GAtJJC,GAAY,SAASz9B,EAAIC,GACzBm4B,EACKnoC,UAAU,uBACV+I,SAEL,IAAI0kC,EAAQxF,EAASvmC,EAAEmrC,KACnBa,EAAQzF,EAAStmC,EAAEkrC,KACnBc,EAAQ1F,EAASvmC,EAAEmnB,KAAO9Y,EAC1B69B,EAAQ3F,EAAStmC,EAAEknB,KAAO7Y,EAC1Bo0B,EAAQ6D,EAASvmC,EAAE4O,KAAOP,EAC1Bs0B,EAAQ4D,EAAStmC,EAAE2O,KAAON,EAI1BgF,EAAYrU,EAAIq1B,iBAAiBkS,EAAW9D,EAAOC,GACnDwJ,EAAiBltC,EAAIs1B,iBAAiBjhB,GACtC84B,EAAkBntC,EAAIu1B,kBAAkBlhB,GAGxC7Q,GAASwlC,EAAU/nC,KAAK,SACxBmS,GAAU41B,EAAU/nC,KAAK,UACzBmsC,EAAQ3J,EAAQ,GAAMjgC,EACtB6pC,EAASD,EAAQ5pC,EACjB8pC,EAAO5J,EAAQ,GAAMtwB,EACrBm6B,EAAUD,EAAOl6B,EACjBo6B,EAAQ,CACR,CAACJ,EAAOE,EAAMF,EAAOG,GACrB,CAACH,EAAOG,EAASF,EAAQE,GACzB,CAACF,EAAQE,EAASF,EAAQC,GAC1B,CAACD,EAAQC,EAAMF,EAAOE,IACxBlzB,IAAI+yB,GAMN,IAAGK,EAAMC,QAAO,SAAStnB,EAAGplB,GACxB,OAAOolB,IACDnmB,EAAIu2B,kBAAkBuW,EAAOC,EAAOD,EAAQ,IAAKC,EAAQ,IACnDhsC,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,OACjC,GAJH,CASAysC,EAAM3oC,SAAQ,SAAS9D,GACnB,IAAI2O,EAAI1P,EAAIu2B,kBAAkByW,EAAOC,EAAOH,EAAOC,EACvChsC,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,IAC7B2O,IACCs9B,EAAQt9B,EAAE3O,EACVksC,EAAQv9B,EAAE1O,MAIlB,IAAI0sC,EAAcpH,EAAQqH,WACtBC,EAAatH,EAAQuH,WACrBC,EAAYxH,EAAQyH,UAEpBC,EAAaxG,EAASl/B,OAAO,KAC5BhJ,MAAM,CAACsK,QAASrL,EAAMqL,QAAQgkC,KAC9BhjB,QAAQ,sBAAsB,GAE/BqjB,EAAQD,EAAW1lC,OAAO,QACzBrH,KAAK,IAAK,IAAM+rC,EAAQ,IAAMC,EAAQ,IAAMH,EAAQ,IAAMC,GAC1DztC,MAAM,eAAgBouC,EAAc,MACpCluC,KAAKjB,EAAMkB,OAAQlB,EAAMsnB,IAAI+nB,IAMlC,GAJAxH,EAAc6H,EAAOH,EAAWxH,GAI7BS,EAAMmH,oBAAsBD,EAAMtsC,OAAOoH,aAAe69B,EAAW,CAClE,IAAIuH,EAAiBrB,EACjBsB,EAAiBrB,EACrB,GAAGzG,EAAQ+H,SAAU,CACjB,IAAIlC,EAAcnpC,KAAKmiC,KAAKniC,KAAKuO,IAAIu7B,EAAQE,EAAO,GAAKhqC,KAAKuO,IAAIw7B,EAAQE,EAAO,IACjFkB,GAAkB7H,EAAQ+H,UAAYrB,EAAQF,GAASX,EACvDiC,GAAkB9H,EAAQ+H,UAAYpB,EAAQF,GAASZ,EAE3D,IAYImC,EAAOC,EAZPC,EAAYR,EAAW1lC,OAAO,QAC7BsiB,QAAQ,oBAAoB,GAC5BA,QAAQ,WAAW,GACnBA,QAAQ,eAAe,GACvB3pB,KAAK,CACFrC,EAAG,sBAAwBouC,EAAQmB,GAAkB,KAAOlB,EAAQmB,GACpE/5B,UAAW,aAAe85B,EAAiB,IAAMC,EAAiB,MAErE9uC,MAAM,eAAiBouC,EAAc,EAAK,MAC1CluC,KAAKjB,EAAMkB,OAAQ,iBACnBD,KAAKjB,EAAMsC,KAAM,iBAMtBslC,EAAYsI,KAAK,CACbv5B,QAASs5B,EAAU7sC,OACnBgB,GAAIA,EACJ+rC,OAAQ,WACJ,IAAIr+B,EAAMiY,EAAQrT,aAAa8yB,GAE/BuG,EAAQj+B,EAAItP,EACZwtC,EAAQl+B,EAAIrP,EACTQ,GAAMA,EAAG0c,WACR+oB,EAAWzlC,EAAGmZ,MAAQ,cAAc,GAErClZ,GAAMA,EAAGyc,WACR+oB,EAAWxlC,EAAGkZ,MAAQ,cAAc,IAG5Cg0B,OAAQ,SAASv/B,EAAIC,GACjB,IAAIu/B,EAAS1B,EAAeoB,EAAOC,GAC/BM,EAAUD,EAAO,GAAKx/B,EACtB0/B,EAAUF,EAAO,GAAKv/B,EAC1B04B,EAAkBvoC,KAAK8oB,EAAQ/S,aAAcs5B,EAASC,GAEtD5H,EAAW,IAAK1lC,EACZA,EAAGutC,IAAIvtC,EAAGyqC,IAAI3F,EAAQvlC,GAAKqO,GAC1Bk3B,EAAQvlC,EAAKqO,EAAK03B,EAAG3lC,GAC1B+lC,EAAW,IAAKzlC,EACZA,EAAGstC,IAAIttC,EAAGwqC,IAAI3F,EAAQtlC,GAAKqO,GAC1Bi3B,EAAQtlC,EAAKqO,EAAKy3B,EAAG1lC,GAEvBklC,EAAQ0I,QAAU1I,EAAQG,MACzBS,EAAW,KAAM1lC,EAAGutC,IAAIvtC,EAAGyqC,IAAI3F,EAAQgF,IAAMl8B,IAG9Ck3B,EAAQ2I,QAAU3I,EAAQI,MACzBQ,EAAW,KAAMzlC,EAAGstC,IAAIttC,EAAGwqC,IAAI3F,EAAQ4I,IAAM7/B,IAGjD2+B,EAAW/sC,KAAK,YAAa,aAAemO,EAAK,IAAMC,EAAK,KAC5Do4B,EAAaxmC,KAAK,CACdoT,UAAW,UAAYkzB,EAAY,IAC5BsH,EAAU,IAAMC,EAAU,OAGzCK,OAAQ,WACJrvC,EAASN,KAAK,eAAgBmD,EAAIwkC,KAClC,IAAIiI,EAAW1rB,SAAS2rB,cAAc,uBACnCD,GAAUA,EAASE,OAAOF,EAASG,mBAStD,GAHGjJ,EAAQqB,WAAWkF,GAAU,EAAG,GAGhCnF,EAKCvB,EAAYsI,KAAK,CACbv5B,QAAS6yB,EAAkBpmC,OAC3BgB,GAAIA,EACJ+rC,OAAQ,WACJ9B,GAAoBnF,EAAaxmC,KAAK,cAE1C0tC,OAAQ,SAASv/B,EAAIC,GACjB,IAAImgC,EAAM,UACV,GAAGlJ,EAAQqB,UACJrB,EAAQ0I,QAAU1I,EAAQG,KACzBS,EAAW,KAAM1lC,EAAGutC,IAAIvtC,EAAGyqC,IAAI3F,EAAQgF,IAAMl8B,IAE7C83B,EAAW,KAAMZ,EAAQgF,GAAKl8B,GAG/Bk3B,EAAQ2I,QAAU3I,EAAQI,KACzBQ,EAAW,KAAMzlC,EAAGstC,IAAIttC,EAAGwqC,IAAI3F,EAAQ4I,IAAM7/B,IAE7C63B,EAAW,KAAMZ,EAAQ4I,GAAK7/B,GAGlCw9B,GAAUz9B,EAAIC,OACX,IAAIu3B,EA8BJ,OA7BH,IAAI6I,EAASC,EACb,GAAGluC,EACCiuC,EAAUjuC,EAAGutC,IAAIvtC,EAAGyqC,IAAI3F,EAAQvlC,GAAKqO,OAClC,CACH,IAAIugC,EAAgBrJ,EAAQsJ,OAAS9I,EAAG3lC,EACpCisC,EAAQ9G,EAAQvlC,GAAKulC,EAAQuJ,QAAUvJ,EAAQwJ,QAAUhJ,EAAG3lC,EAAIwuC,EAAgB,EAEpFF,EAAUtJ,EAAY0D,MAAMuD,EAAQh+B,EAAK03B,EAAG3lC,EACxCwuC,EAAe,EAAG,EAAGrJ,EAAQtW,SAGrC,GAAGvuB,EACCiuC,EAAUjuC,EAAGstC,IAAIttC,EAAGwqC,IAAI3F,EAAQtlC,GAAKqO,OAClC,CACH,IAAI0gC,EAAiBzJ,EAAQ0J,OAASlJ,EAAG1lC,EACrCmsC,EAAUjH,EAAQtlC,GAAKslC,EAAQ2J,QAAU3J,EAAQ4J,QAAUpJ,EAAG1lC,EAAI2uC,EAAiB,EAEvFL,EAAUvJ,EAAY0D,MAAM0D,EAAUl+B,EAAKy3B,EAAG1lC,EAC1C2uC,EAAgB,EAAG,EAAGzJ,EAAQnW,SAEtC+W,EAAW,IAAKuI,GAChBvI,EAAW,IAAKwI,GACZluC,GAAOC,IACP+tC,EAAMrJ,EAAYgK,UACd3uC,EAAK,GAAMiuC,EACXhuC,EAAK,GAAMiuC,EACXpJ,EAAQtW,QAASsW,EAAQnW,UAKrCsX,EAAaxmC,KAAK,CACdoT,UAAW,aAAejF,EAAK,IAAMC,EAAK,IAAMu9B,KAGpD1G,EAAU6B,EAAmByH,IAEjCY,QAAS,SAAS3X,EAAGgR,GACdnD,EAAQuB,eACPllC,EAAGoqB,KAAK,yBAA0Bkb,EAAcwB,KAGxD0F,OAAQ,WACJjJ,EAAU6B,GACVjoC,EAASN,KAAK,eAAgBmD,EAAIwkC,KAClC,IAAIiI,EAAW1rB,SAAS2rB,cAAc,uBACnCD,GAAUA,EAASE,OAAOF,EAASG,kBA5nB1D/wC,EAAOC,QAAU,CACb4xC,KAQJ,SAAc1tC,GACV,IAAIiF,EAAajF,EAAGkF,YAEpBD,EAAWw/B,WAAW/nC,UAAU,eAAe+I,SAE/C,IAAI,IAAIT,EAAI,EAAGA,EAAIC,EAAW2+B,YAAYhhC,OAAQoC,IAC3CC,EAAW2+B,YAAY5+B,GAAG+f,SACzB2e,EAAQ1jC,EAAIgF,GAIpB,OAAO0gB,EAAMioB,iBAAiB3tC,IAlB9B0jC,QAASA,EACTM,QAASA,I,8CC5Bb,IAAIroC,EAAK,EAAQ,YAEb0B,EAAM,EAAQ,YACdqoB,EAAQ,EAAQ,YAChBvoB,EAAW,EAAQ,YACnBywC,EAAS,EAAQ,YACjBpK,EAAc,EAAQ,YACtB7d,EAAU,EAAQ,YAClB/pB,EAAQ,EAAQ,YAChB0B,EAAe,EAAQ,YACvBuwC,EAAc,EAAQ,YAEtBhoB,EAAY,EAAQ,YACpBioB,EAAqB,EAAQ,YAC7BtwC,EAAeswC,EAAmBtwC,aAClCuwC,EAAUD,EAAmBC,QAC7BC,EAAUF,EAAmBE,QAE7BC,EAAgB,EAAQ,YACxBtxC,EAAQ,EAAQ,YAChB+lC,EAAU,EAAQ,YAiUtB,SAASwL,EAAmBluC,EAAImuC,EAAQC,EAAYC,EAAWC,GAC3D,IAAIpyC,EAAQkyC,EAAW9sC,OAAO,GAAG,GAAGpF,MAChCqyC,EAAU,CACV1kB,MAAOykB,EACPtvC,KAAMovC,EAAWpvC,OACjBwvC,YAAatyC,EAAMopB,MACnBmpB,cAAevyC,EAAMwb,eACrBpW,KAAMtB,EAAGsB,KACTggB,OAAQthB,EAAGshB,OACXotB,OAAQ1uC,EAAG2uC,gBAAgBC,QAC3BC,OAAQ7uC,EAAGG,SACX8U,SAAUjV,EAAG8uC,UACb7pC,WAAYjF,EAAGkF,aAWnB,GARGhJ,EAAM6yC,SACLR,EAAQjiC,MAAQpQ,EAAM6yC,QAEvB5xC,EAAS2C,QAAQ5D,EAAO,cACvBqyC,EAAQ3iB,MAAQwiB,EAAW3Q,QAAQ,GAAG7R,QAI1B,IADDgiB,EAAOoB,eAAehvC,EAAI,qBAAsBuuC,GAG/D,GAAiB,IAAdF,EACCF,EAAOc,cAAgBC,YAAW,WAC9BrB,EAAYO,EAAYpuC,EAAIquC,KAC7BruC,EAAGG,SAASgvC,uBACZ,GAAiB,IAAdd,EAAiB,CACpBF,EAAOc,eAAeG,aAAajB,EAAOc,eAC7CjvC,EAAGqvC,qBAAuB,GAGP,IADDzB,EAAOoB,eAAehvC,EAAI,2BAA4BuuC,IAC9CV,EAAYO,EAAYpuC,EAAIquC,IAI9D,SAASiB,EAAUrsB,EAAGjjB,EAAIuhB,GACtB,IAOI/C,EAPA4vB,EAAanrB,EAAE3hB,OAAO,GAAG,GACzBpF,EAAQkyC,EAAWlyC,MACnBqzC,EAAYpyC,EAAS2C,QAAQ5D,EAAO,YACpCszC,EAAatzC,EAAMopB,MACnBmqB,EAAaluB,EAAKmuB,OAAS1vC,EAAGG,SAASikC,MAAMuL,aAAeJ,EAC5DK,EAAgBruB,EAAKsuB,eAGrBtuB,EAAKuuB,QAMLtxB,EAAO4vB,EAAWphC,MALlBwR,EAAO+wB,EAAYnB,EAAWxiB,MAAQ1vB,EAAMsiB,KACzCtiB,EAAMqR,QACLiR,EAAOnhB,EAAIwuB,eAAerN,EAAMtiB,EAAMqR,SAM9C,IAAIwiC,EAAS1yC,EAAIkJ,aAAa0c,EAAG,OAAQ,cAEzC8sB,EAAOzxC,KAAK,cAAe,SACtB2pB,QAAQ,oBAAoB,GAC5BprB,KAAK8oB,EAAQ7nB,KAAMyjB,EAAKzjB,MACxBkP,KAAKyiC,EAAaO,EAAaxxB,EAAMoxB,GAAiBpxB,GAE3DlhB,EAAayU,aAAag+B,EAAQlqB,EAAUoqB,QAAS,GAElDR,EACCM,EAAOlzC,KAAKS,EAAaopC,aAAc,CAAC1mC,GAAIA,EAAIgN,KAAMwR,IACjD3hB,KAAK+pC,EAAY3jB,EAAGjjB,EAAIuhB,GACxB+G,GAAG,QAAQ,SAAS4nB,GACjBzzC,KAAKuQ,KAAKgjC,EAAaE,EAASN,IAC3B/yC,KAAK+pC,EAAY3jB,EAAGjjB,EAAIuhB,GAE7B,IAAI4uB,EAAY/B,EAAWlyC,MAAMk0C,YAAc,GAC3CC,EAAS,GAEb,GAAGlzC,EAASmzC,aAAaH,EAAW,WAAY,CAC5C,IAAII,EAAiBpzC,EAASqzC,oBAAoBL,EAAW,WACzD7qB,EAAQirB,EAAeA,EAAe3tC,OAAS,GAE/C6tC,EAAQpzC,EAAIgyB,eAAe8gB,EAAW,cAAgB7qB,EAAQ,WAAY,SAAU,cAExFmrB,EAAM7zB,IAAIwxB,EAAWlyC,MAAM6yC,OAAQmB,GAEnCG,EAASI,EAAMC,uBAEfL,EAAO7xB,KAAO0xB,EAGlB,OAAO/yC,EAASN,KAAK,cAAemD,EAAIqwC,EAAQb,MAGxD5I,EAAWmJ,EAAQ9sB,EAAGjjB,EAAIuhB,GAWlC,SAASyuB,EAAanW,EAAK8W,GACvB,IAAIC,EAAevwC,KAAKc,IAAI,EAAGwvC,GAC/B,GAAG9W,GAAOA,EAAI9mB,OAAOnQ,QAAUguC,EAAe,EAAG,OAAO/W,EAExD,IAAI,IAAI70B,EAAI4rC,GADZ/W,EAAMA,GAAO,IACkBj3B,OAAQoC,EAAI,EAAGA,IAAK60B,GAAO,IAC1D,OAAOA,EAGX,SAASgX,EAAiB5tB,EAAGjjB,GACzB,IACI8wC,EADA3B,EAAmBnvC,EAAGG,SAASgvC,iBAE/Bd,EAAY,EAEZ0C,EAAc1zC,EAAIkJ,aAAa0c,EAAG,OAAQ,gBAAgB,SAAS1mB,GACnEA,EAAEI,MAAM,SAAU,WACb2B,KAAK,iBAAkB,OACvBzB,KAAKjB,EAAMsC,KAAM,oBAG1B6yC,EAAYzoB,GAAG,aAAa,YACxBwoB,GAAmB,IAAKE,MAAQC,WACVjxC,EAAGqvC,qBAAuBF,EAE5Cd,GAAa,GAGbA,EAAY,EACZruC,EAAGqvC,qBAAuByB,MAGlCC,EAAYzoB,GAAG,WAAW,WACtB,IAAGtoB,EAAGkxC,WAAYlxC,EAAGmxC,SAArB,CACA,IAAIhD,EAASnuC,EAAGkF,YAAYipC,QAEzB,IAAK6C,MAAQC,UAAYjxC,EAAGqvC,qBAAuBF,IAClDd,EAAYhuC,KAAKc,IAAIktC,EAAY,EAAG,IAGxCH,EAAmBluC,EAAImuC,EAAQlrB,EAAGorB,EAAW1yC,EAAGkuB,WAIxD,SAAS+c,EAAWrqC,EAAG0mB,EAAGjjB,EAAIuhB,GACtBA,EAAKmuB,OAAOnzC,EAAE+B,KAAK,cAAc,GACrChB,EAAayQ,gBAAgBxR,EAAGyD,GAAI,YAKxC,SAA+BijB,EAAGjjB,EAAIuhB,GAClC,IAAI6sB,EAAanrB,EAAE3hB,OAAO,GAAG,GAC7B,GAAGigB,EAAKmuB,OAAStB,IAAeA,EAAWlyC,MAAMk1C,WAE7C,YADAnuB,EAAExd,SAIN,IAAI8hC,EAAetkB,EAAEzmB,OAAO,wBACxB60C,EAAc9J,EAAavoC,OAC3BuiB,IAAMA,EAAOvhB,EAAGkF,YAAYipC,QAChC,IAEI19B,EAAQ5P,EAFRywC,EAAK/vB,EAAKoI,YACV4nB,GAAcnD,EAAa7sB,EAAOA,EAAKiwB,OAAO1zC,KAAKE,KAAOR,EAG9D,GAAG6zC,EAAa,CACZ,IAAII,EAAY9rB,EAAQvU,KAAKigC,GAE7B5gC,EAASghC,EAAUhhC,OACnB5P,EAAQ4wC,EAAU5wC,MAEfutC,EACCzoB,EAAQ/S,aAAa20B,EAAc,EAAY,IAAT92B,GAEtCkV,EAAQ/S,aAAa20B,EAAc+J,EAAa,IAAT7gC,EAAgB6gC,OAExD,CACH,IAAIvB,EAAS9sB,EAAEzmB,OAAO4xC,EAClB,cAAgB,oBAEhBsD,EAAYp0C,EAAakP,UAAUujC,GACnC4B,EAAW5B,EAAO/wC,OAEtByR,EAAS8gC,EAAaG,EACtB7wC,EAAQ8wC,EAAWhsB,EAAQvU,KAAKugC,GAAU9wC,MAAQ,EAIlD,IAAIkgC,EAAQwQ,IAAeG,EAAY,GAAK,EAAI,IAC7CtD,EACC9wC,EAAayU,aAAag+B,EAAQlqB,EAAUoqB,SAAUlP,GAEtDzjC,EAAayU,aAAag+B,EAAQlqB,EAAU+rB,SAAWN,EAAIC,EAAaD,GAI7ElD,GACCA,EAAWmD,WAAaA,EACxBnD,EAAW39B,OAASpQ,KAAKc,IAAIsP,EAAQ,IAAM,EAC3C29B,EAAWvtC,MAAQA,IAEnB0gB,EAAKswB,YAAchxC,EACnB0gB,EAAKuwB,aAAerhC,GAvDpBshC,CAAsB9uB,EAAGjjB,EAAIuhB,MAyRrC,SAASywB,EAAWzwB,GAChB,OAAOlkB,EAAIiwB,cAAc/L,GAAQ,QAC7BlkB,EAAIkwB,eAAehM,GAAQ,SAC3B,OAGR,SAAS0wB,EAAW1wB,GAChB,OAAOlkB,EAAIowB,eAAelM,GAAQ,SAC9BlkB,EAAIqwB,eAAenM,GAAQ,SAC3B,MApvBR1lB,EAAOC,QAAU,SAAckE,EAAIuhB,GAC/B,IAEI0b,EAFAh4B,EAAajF,EAAGkF,YAChBgtC,EAAS,SAAWjtC,EAAWG,KAanC,GATImc,GAKA0b,EAAQ1b,EAAK0b,MACbiV,GAAU,YALV3wB,EAAOtc,EAAWkpC,QAAU,IACvBuB,OAAQ,EACbzS,EAAQh4B,EAAWw/B,YAMnBxH,EAAJ,CAIA,IAAIkV,EACJ,GAHInyC,EAAGqvC,uBAAsBrvC,EAAGqvC,qBAAuB,GAGpD9tB,EAAKmuB,MAAO,CACX,IAAI1vC,EAAGoyC,SAAU,OACjBD,EAAaltC,EAAWmsC,YAAcnD,EAAcjuC,EAAGoyC,SAAU7wB,OAC9D,CACH,IAAIA,EAAKuuB,QAAS,OAClBqC,EAAalE,EAAc1sB,EAAKuuB,QAASvuB,GAG7C,IAAI8wB,EAAeptC,EAAWqtC,cAAgB,GAE9C,GAAG/wB,EAAKmuB,SAAWzqC,EAAWmsC,aAAee,EAAWvvC,QAGpD,OAFAq6B,EAAMvgC,UAAU,WAAW+I,SAC3BR,EAAWstC,SAAS/1C,OAAO,IAAM01C,GAAQzsC,SAClCigB,EAAMiI,WAAW3tB,EAAI,UAGhC,IAAImuC,EAAS9wC,EAAIkJ,aAAa02B,EAAO,IAAK,UAAU,SAAS1gC,GACtDglB,EAAKmuB,OAAOnzC,EAAE+B,KAAK,iBAAkB,UAGxCk0C,EAAWn1C,EAAIgT,iBAAiBpL,EAAWstC,SAAU,WAAYL,GAAQ,SAAS31C,GAClFA,EAAEoJ,OAAO,WAGT8sC,EAAKp1C,EAAIkJ,aAAa4nC,EAAQ,OAAQ,MAAM,SAAS5xC,GACrDA,EAAE+B,KAAK,kBAAmB,iBAE9Bm0C,EAAG51C,KAAKjB,EAAMkB,OAAQykB,EAAKkK,aACtB5uB,KAAKjB,EAAMsC,KAAMqjB,EAAKmK,SACtB/uB,MAAM,eAAgB4kB,EAAKoI,YAAc,MAE9C,IAAInD,EAAYnpB,EAAIkJ,aAAa4nC,EAAQ,IAAK,aAE1CqD,EAAQjwB,EAAKiwB,MAGjB,GAFAjwB,EAAKswB,YAAc,EACnBtwB,EAAKuwB,aAAe,EACjBN,EAAMxkC,KAAM,CACX,IAAI0lC,EAAUr1C,EAAIkJ,aAAaigB,EAAW,OAAQ,mBAClDksB,EAAQp0C,KAAK,cAAe,SACvB2pB,QAAQ,oBAAoB,GAC5BprB,KAAK8oB,EAAQ7nB,KAAM0zC,EAAM1zC,MACzBkP,KAAKwkC,EAAMxkC,MAEhB45B,EAAW8L,EAASlsB,EAAWxmB,EAAIuhB,GAGvC,IAAIoxB,EAAYt1C,EAAIkJ,aAAa4nC,EAAQ,OAAQ,aAAa,SAAS5xC,GACnEA,EAAE+B,KAAKunB,EAAU+sB,qBACf/1C,KAAKjB,EAAMsC,KAAM2nB,EAAUgtB,mBAG7BC,EAAStsB,EAAU9pB,UAAU,YAAY4E,KAAK6wC,GAClDW,EAAOptC,QAAQC,OAAO,KAAKrH,KAAK,QAAS,UACzCw0C,EAAOttC,OAAOC,SAEd,IAAI1J,EAAS+2C,EAAOp2C,UAAU,YAAY4E,KAAKjE,EAAIkI,UACnDxJ,EAAO2J,QAAQC,OAAO,KAAKrH,KAAK,QAAS,UACzCvC,EAAOyJ,OAAOC,SAEd1J,EAAOY,MAAM,WAAW,SAASV,GAC7B,IAAIC,EAAQD,EAAE,GAAGC,MACjB,OAAGiB,EAAS2C,QAAQ5D,EAAO,aACsB,IAAtCm2C,EAAalvC,QAAQlH,EAAE,GAAG2vB,OAAgB,GAAM,EAE9B,eAAlB1vB,EAAM6oB,QAA2B,GAAM,KAGrD/oB,MAAK,WAAaL,EAAGa,OAAOC,MAAMI,KAAKyyC,EAAWtvC,EAAIuhB,MACtD1kB,KAAKF,EAAOqD,EAAIuhB,GAChBvlB,MAAK,WAAgBulB,EAAKmuB,OAAO/zC,EAAGa,OAAOC,MAAMI,KAAKg0C,EAAkB7wC,MAEzE3C,EAAI87B,YAAY,CACZzT,EAAMioB,iBACN,WAAa,OA2crB,SAAiC3tC,EAAI8yC,EAAQ/2C,EAAQwlB,GACjD,IAAItc,EAAajF,EAAGkF,YAChBqc,IAAMA,EAAOtc,EAAWkpC,QAC5B,IAAIhK,EAAKl/B,EAAWmoB,MAEhB/D,EAAaqZ,EAAQrZ,WAAW9H,GAChCwxB,EAAYrQ,EAAQqQ,UAAUxxB,GAE9B+vB,EAAK/vB,EAAKoI,YACVqpB,EAAM,EAAI1B,EACVrB,EAAUpqB,EAAUoqB,QACpBgD,EAAUptB,EAAUotB,QACpBC,EAAS,GAAK5B,EAAK2B,GAEnBzlB,EAAUykB,EAAW1wB,GACrB4xB,EAAkB5xB,EAAKljB,EAAI,GAAiB,IAAXkjB,EAAKljB,GAAuB,QAAZmvB,EACjD4lB,EAAkB7xB,EAAKljB,EAAI,GAAiB,IAAXkjB,EAAKljB,GAAuB,WAAZmvB,EAIrDjM,EAAK8xB,WAAahzC,KAAKc,IAClBgyC,GAAmBC,EAAmBnuC,EAAWwL,OAAS,EAAI0zB,EAAG1lC,EAClE,IAGJ,IAAI60C,EAAkB,EACtB/xB,EAAKgyB,OAAS,EACdhyB,EAAKiyB,QAAU,EACf,IAAIC,EAvDR,SAAsBlyB,GAClB,IAAI/iB,EAAI,EACJC,EAAI,EAEJi1C,EAAOnyB,EAAKiwB,MAAMkC,KACnBA,KAC8B,IAA1BA,EAAKvwC,QAAQ,UACZ3E,EAAI+iB,EAAKswB,cAEe,IAAzB6B,EAAKvwC,QAAQ,SACZ1E,EAAI8iB,EAAKuwB,eAIjB,MAAO,CAACtzC,EAAGC,GAyCKk1C,CAAapyB,GAE7B,GAAG8H,EACCttB,EAAOC,MAAK,SAASC,GACjB,IAAIwC,EAAIxC,EAAE,GAAGwU,OACbkV,EAAQ/S,aAAanW,KACjB60C,EAAKmC,EAAU,GACfnC,EAAKmC,EAAU,GAAKlyB,EAAKiyB,QAAU/0C,EAAI,EAAIw0C,GAE/C1xB,EAAKiyB,SAAW/0C,EAChB8iB,EAAKgyB,OAASlzC,KAAKc,IAAIogB,EAAKgyB,OAAQt3C,EAAE,GAAG4E,UAG7CyyC,EAAkBrD,EAAU1uB,EAAKgyB,OACjChyB,EAAKgyB,QAAUN,EAAUhD,EAAU+C,EACnCzxB,EAAKiyB,SAAWN,EAEbH,IACCD,EAAO92C,MAAK,SAASC,EAAG+I,GACpB2gB,EAAQ/S,aAAanW,KAAM,EAAGuI,EAAIuc,EAAKqyB,kBAE3CryB,EAAKiyB,UAAYjyB,EAAKsyB,eAAiB,GAAKtyB,EAAKqyB,mBAElD,CACH,IAAIvmB,EAAU2kB,EAAWzwB,GACrBuyB,EAAmBvyB,EAAKnjB,EAAI,GAAiB,IAAXmjB,EAAKnjB,GAAuB,UAAZivB,EAClD0mB,EAAoBxyB,EAAKnjB,EAAI,GAAiB,IAAXmjB,EAAKnjB,GAAuB,SAAZivB,EACnD2mB,EAAoBZ,GAAmBD,EACvCc,EAAKhvC,EAAWpE,MAAQ,EAK5B0gB,EAAK2yB,UAAY7zC,KAAKc,IAClB2yC,EAAqBE,GAAiC,SAAZ3mB,EAAsB8W,EAAG1c,EAAI0c,EAAG3lC,EAAIy1C,EAC9EF,EAAsBC,GAAiC,UAAZ3mB,EAAuB8W,EAAGphC,EAAIohC,EAAG3lC,EAAIy1C,EAChF9P,EAAG3lC,EACP,EAAIyxC,GACJ,IAAIkE,EAAe,EACfC,EAAoB,EACxBr4C,EAAOC,MAAK,SAASC,GACjB,IAAIuC,EAAIvC,EAAE,GAAG4E,MAAQovC,EACrBkE,EAAe9zC,KAAKc,IAAIgzC,EAAc31C,GACtC41C,GAAqB51C,KAGzB80C,EAAkB,KAClB,IAAIe,EAAc,EAElB,GAAGtB,EAAW,CACV,IAAIuB,EAAsB,EACtBC,EAAe,EACfC,EAAe,EACnB1B,EAAO92C,MAAK,WACR,IAAIy4C,EAAkB,EAClBC,EAAU,EACd/4C,EAAGa,OAAOC,MAAMC,UAAU,YAAYV,MAAK,SAASC,GAChD,IAAIwC,EAAIxC,EAAE,GAAGwU,OACbkV,EAAQ/S,aAAanW,KACjBg3C,EAAU,GACVA,EAAU,GAAKnC,EAAK2B,EAAUx0C,EAAI,EAAIi2C,GAE1CA,GAAWj2C,EACXg2C,EAAkBp0C,KAAKc,IAAIszC,EAAiBxE,EAAUh0C,EAAE,GAAG4E,UAE/DyzC,EAAsBj0C,KAAKc,IAAImzC,EAAqBI,GAEpD,IAAIC,EAAOF,EAAkBxB,EAEzB0B,EAAOrD,EAAKiD,EAAgBhzB,EAAK2yB,YACjCG,EAAch0C,KAAKc,IAAIkzC,EAAaE,GACpCA,EAAe,EACfC,GAAgBF,EAAsB/yB,EAAKqyB,cAC3CU,EAAsBI,GAG1B/uB,EAAQ/S,aAAanW,KAAM83C,EAAcC,GAEzCD,GAAgBI,KAGpBpzB,EAAKgyB,OAASlzC,KAAKc,IAAIkzC,EAAaE,GAAgBjD,EACpD/vB,EAAKiyB,QAAUgB,EAAeF,EAAsBpB,MACjD,CACH,IAAI0B,EAAU74C,EAAOiC,OACjB62C,EAAgBT,EAAoBpB,GAAO4B,EAAU,GAAK3B,EAAW1xB,EAAK2yB,UAE1EY,EAAqB,EACrBC,EAAU,EACVL,EAAU,EACVM,EAAW,EACfj5C,EAAOC,MAAK,SAASC,GACjB,IAAIwC,EAAIxC,EAAE,GAAGwU,OACTjS,EAAIyxC,EAAUh0C,EAAE,GAAG4E,MACnB8zC,GAAQE,EAAer2C,EAAI21C,GAAgBlB,EAE3C0B,EAAOrD,EAAKyD,EAAWxzB,EAAK2yB,YAC5BG,EAAch0C,KAAKc,IAAIkzC,EAAaW,GACpCD,EAAU,EACVL,GAAWI,EACXvzB,EAAKiyB,SAAWsB,EAChBA,EAAqB,GAGzBnvB,EAAQ/S,aAAanW,KACjBg3C,EAAU,GAAKnC,EAAKyD,EACpBtB,EAAU,GAAKnC,EAAKoD,EAAUj2C,EAAI,EAAIw0C,GAG1C+B,EAAWD,EAAUv2C,EAAIy0C,EACzB8B,GAAWJ,EACXG,EAAqBz0C,KAAKc,IAAI2zC,EAAoBr2C,MAGnDo2C,GACCtzB,EAAKgyB,OAASwB,EAAU/B,EACxBzxB,EAAKiyB,QAAUsB,EAAqB5B,IAEpC3xB,EAAKgyB,OAASlzC,KAAKc,IAAIkzC,EAAaW,GAAYhC,EAChDzxB,EAAKiyB,SAAWsB,EAAqB5B,IAKjD3xB,EAAKgyB,OAASlzC,KAAK0sB,KACf1sB,KAAKc,IACDogB,EAAKgyB,OAASE,EAAU,GACxBlyB,EAAKswB,YAAc,GAAKP,EAAKzrB,EAAU+rB,YAI/CrwB,EAAKiyB,QAAUnzC,KAAK0sB,KAChB1sB,KAAKc,IACDogB,EAAKiyB,QAAUC,EAAU,GACzBlyB,EAAKuwB,aAAe,GAAKR,EAAKzrB,EAAUotB,WAIhD1xB,EAAK0zB,WAAa50C,KAAKi3B,IAAI/V,EAAKiyB,QAASjyB,EAAK8xB,YAE9C,IAAIjP,EAAQpkC,EAAGG,SAASikC,MACpBqL,EAAarL,EAAMuL,YAAcvL,EAAM8Q,eAC3Cn5C,EAAOC,MAAK,SAASC,GACjB,IAAI80C,EAAcp1C,EAAGa,OAAOC,MAAMD,OAAO,iBACrCiC,EAAIxC,EAAE,GAAGwU,OACTjS,EAAIixC,EAAaQ,EAAWqD,GAAoBrD,EAAUh0C,EAAE,GAAG4E,MAC/DwoB,IAAY7qB,GAAKy0C,EAAU,GAC/BttB,EAAQjnB,QAAQqyC,EAAa,GAAItyC,EAAI,EAAGD,EAAGC,MA1nBvB02C,CAAwBn1C,EAAI8yC,EAAQ/2C,EAAQwlB,IAChE,WAII,IAAGA,EAAKmuB,QAynBpB,SAAsB1vC,GAClB,IACIuhB,EADavhB,EAAGkF,YACEipC,OAClB9gB,EAAU2kB,EAAWzwB,GACrBiM,EAAUykB,EAAW1wB,GAEzB,OAAOmE,EAAMiI,WAAW3tB,EAAI,SAAU,CAClC5B,EAAGmjB,EAAKnjB,EACRC,EAAGkjB,EAAKljB,EACRopB,EAAGlG,EAAKgyB,OAAUxF,EAAQ1gB,GAC1BtqB,EAAGwe,EAAKgyB,OAAUvF,EAAQ3gB,GAC1B/M,EAAGiB,EAAK0zB,WAAcjH,EAAQxgB,GAC9Bha,EAAG+N,EAAK0zB,WAAclH,EAAQvgB,KAroBT4nB,CAAap1C,GAA9B,CAEA,IAgLQq1C,EAAIC,EAAInsB,EAAIC,EAhLhB+a,EAAKl/B,EAAWmoB,MAChBkkB,EAAK/vB,EAAKoI,YAEVjB,EAAKyb,EAAG1c,EAAI0c,EAAG3lC,EAAI+iB,EAAKnjB,EAAI2vC,EAAQiE,EAAWzwB,IAASA,EAAKgyB,OAC7D5qB,EAAKwb,EAAG3wB,EAAI2wB,EAAG1lC,GAAK,EAAI8iB,EAAKljB,GAAK0vC,EAAQkE,EAAW1wB,IAASA,EAAK0zB,WAEvE,GAAG1zB,EAAKmuB,OAASzqC,EAAWswC,OAAOC,WAAY,CAC3C,IAAIC,EAAM/sB,EACNgtB,EAAM/sB,EAEVD,EAAKrrB,EAAI85B,UAAUzO,EAAI,EAAGzjB,EAAWpE,MAAQ0gB,EAAKgyB,QAClD5qB,EAAKtrB,EAAI85B,UAAUxO,EAAI,EAAG1jB,EAAWwL,OAAS8Q,EAAK0zB,YAEhDvsB,IAAO+sB,GACNp4C,EAAIk3B,IAAI,sDAET5L,IAAO+sB,GACNr4C,EAAIk3B,IAAI,sDAYhB,GANGhT,EAAKmuB,OAAO/pB,EAAQ/S,aAAau7B,EAAQzlB,EAAIC,GAGhDgqB,EAAUrqB,GAAG,QAAS,MACtB6lB,EAAO7lB,GAAG,QAAS,OAEf/G,EAAKmuB,OAASnuB,EAAKiyB,SAAWjyB,EAAK8xB,YAAcrzC,EAAGG,SAASC,WAAY,CAEzE,IAAIqQ,EAAS8Q,EAAK0zB,WAGd1zB,EAAKmuB,QAAOj/B,EAAS8Q,EAAKiyB,SAE9Bf,EAAGn0C,KAAK,CACJuC,MAAO0gB,EAAKgyB,OAASjC,EACrB7gC,OAAQA,EAAS6gC,EACjBlzC,EAAGkzC,EAAK,EACRjzC,EAAGizC,EAAK,IAGZ3rB,EAAQ/S,aAAa4T,EAAW,EAAG,GAEnCgsB,EAASh2C,OAAO,QAAQ8B,KAAK,CACzBuC,MAAO0gB,EAAKgyB,OAAS,EAAIjC,EACzB7gC,OAAQA,EAAS,EAAI6gC,EACrBlzC,EAAGkzC,EACHjzC,EAAGizC,IAGP3rB,EAAQtT,WAAWmU,EAAW0rB,EAAQlyC,GAEtC2lB,EAAQjnB,QAAQi0C,EAAW,EAAG,EAAG,EAAG,UAC7BpxB,EAAKo0B,aACT,CACH,IAgDIC,EAASC,EAASC,EAhDlBC,EAAkB11C,KAAKc,IAAI0kB,EAAUmwB,mBACrCz0B,EAAK0zB,WAAa1zB,EAAK0zB,WAAa1zB,EAAKiyB,SACzCyC,EAAgB10B,EAAK0zB,WACrBc,EACA,EAAIlwB,EAAUqwB,gBACdC,EAAgB50B,EAAKiyB,QAAUjyB,EAAK0zB,WACpCmB,EAAcH,EAAgBE,EAE9BE,EAAah2C,KAAKi3B,IAAI/V,EAAKo0B,UAAY,EAAGQ,GAI9C1D,EAAGn0C,KAAK,CACJuC,MAAO0gB,EAAKgyB,OACR,EAAIjC,EACJzrB,EAAUywB,eACVzwB,EAAUqwB,gBACdzlC,OAAQ8Q,EAAK0zB,WAAa3D,EAC1BlzC,EAAGkzC,EAAK,EACRjzC,EAAGizC,EAAK,IAGZkB,EAASh2C,OAAO,QAAQ8B,KAAK,CACzBuC,MAAO0gB,EAAKgyB,OACR,EAAIjC,EACJzrB,EAAUywB,eACVzwB,EAAUqwB,gBACdzlC,OAAQ8Q,EAAK0zB,WAAa,EAAI3D,EAC9BlzC,EAAGkzC,EACHjzC,EAAGizC,EAAK+E,IAGZ1wB,EAAQtT,WAAWmU,EAAW0rB,EAAQlyC,GAEtCu2C,EAAcF,EAAYN,EAAiBK,GAG3CjI,EAAO7lB,GAAG,SAAS,WAKfiuB,EAJAF,EAAah5C,EAAI85B,UACb5V,EAAKo0B,SACCh6C,EAAGkuB,MAAM2sB,OAASP,EAAiBE,EACzC,EAAGA,GACmBJ,EAAiBK,GACzB,IAAfC,GAAoBA,IAAeF,GAClCx6C,EAAGkuB,MAAM4sB,oBAMjB,IAWIC,EAAgB/6C,EAAGg7C,SAASC,OAC/BtuB,GAAG,aAAa,WACb,IAAIuuB,EAAIl7C,EAAGkuB,MAAMitB,YAEblB,EADU,eAAXiB,EAAEpyC,KACSoyC,EAAEE,eAAe,GAAGC,QAEpBH,EAAEG,QAEhBlB,EAAcO,KAEjB/tB,GAAG,QAAQ,WACR,IAAIuuB,EAAIl7C,EAAGkuB,MAAMitB,YACA,IAAdD,EAAEzvB,SAAiByvB,EAAEI,UAEpBpB,EADU,cAAXgB,EAAEpyC,KACSoyC,EAAEE,eAAe,GAAGC,QAEpBH,EAAEG,QAGhBT,EADAF,EA7BoB,SAASP,EAAaF,EAASC,GACnD,IAAIx3C,GAAMw3C,EAAUD,GAAWQ,EAAeN,EAC9C,OAAOz4C,EAAI85B,UAAU94B,EAAG,EAAG83C,GA2Bde,CAAkBpB,EAAaF,EAASC,GAC3BE,EAAiBK,OAE/CzD,EAAU91C,KAAK65C,GAGf,IAAIS,EAAqBx7C,EAAGg7C,SAASC,OACpCtuB,GAAG,aAAa,WACb,IAAIuuB,EAAIl7C,EAAGkuB,MAAMitB,YACH,eAAXD,EAAEpyC,OACDmxC,EAAUiB,EAAEE,eAAe,GAAGC,QAC9BlB,EAAcO,MAGrB/tB,GAAG,QAAQ,WACR,IAAIuuB,EAAIl7C,EAAGkuB,MAAMitB,YACH,cAAXD,EAAEpyC,OACDoxC,EAAUgB,EAAEE,eAAe,GAAGC,QAE9BT,EADAF,EA1Cc,SAASP,EAAaF,EAASC,GACjD,IAAIx3C,GAAMu3C,EAAUC,GAAWO,EAAeN,EAC9C,OAAOz4C,EAAI85B,UAAU94B,EAAG,EAAG83C,GAwCViB,CAAgBtB,EAAaF,EAASC,GACzBE,EAAiBK,OAGnD5vB,EAAU3pB,KAAKs6C,GAiBnB,GAAGn3C,EAAGG,SAASikC,MAAM8Q,eAGjB/G,EAAOlmB,QAAQ,eAAe,GAE9Bub,EAAYsI,KAAK,CACbv5B,QAAS47B,EAAOnvC,OAChBgB,GAAIA,EACJ+rC,OAAQ,WACJ,IAAIr6B,EAAYiU,EAAQrT,aAAa67B,GACrChlB,EAAKzX,EAAUtT,EACfgrB,EAAK1X,EAAUrT,GAEnB2tC,OAAQ,SAASv/B,EAAIC,GACjB,IAAI2qC,EAAOluB,EAAK1c,EACZ6qC,EAAOluB,EAAK1c,EAEhBiZ,EAAQ/S,aAAau7B,EAAQkJ,EAAMC,GAEnCjC,EAAK7R,EAAY0D,MAAMmQ,EAAM,EAAGlT,EAAG1c,EAAG0c,EAAG1c,EAAI0c,EAAG3lC,EAAG+iB,EAAK8L,SACxDioB,EAAK9R,EAAY0D,MAAMoQ,EAAM,EAAGnT,EAAG3wB,EAAI2wB,EAAG1lC,EAAG0lC,EAAG3wB,EAAG+N,EAAKiM,UAE5Dgf,OAAQ,gBACMzlC,IAAPsuC,QAA2BtuC,IAAPuuC,GACnBn4C,EAASN,KAAK,eAAgBmD,EAAI,CAAC,WAAYq1C,EAAI,WAAYC,KAGvE7H,QAAS,SAASY,EAAWwI,GACzB,IAAIU,EAAeta,EAAMvgC,UAAU,YAAY86C,QAAO,WAClD,IAAIC,EAAOh7C,KAAKwV,wBAChB,OACI4kC,EAAEa,SAAWD,EAAKjnC,MAAQqmC,EAAEa,SAAWD,EAAK7lC,OAC5CilC,EAAEG,SAAWS,EAAKxrC,KAAO4qC,EAAEG,SAAWS,EAAKzrC,UAGhDurC,EAAav5C,OAAS,GACrBkwC,EAAmBluC,EAAImuC,EAAQoJ,EAAclJ,EAAWwI,MAlDxE,SAASN,EAAcF,EAAYN,EAAiBK,GAChD70B,EAAKo0B,SAAW31C,EAAGkF,YAAYipC,OAAOwH,SAAWU,EACjD1wB,EAAQ/S,aAAa4T,EAAW,GAAI6vB,GAEpC1wB,EAAQjnB,QACJi0C,EACApxB,EAAKgyB,OACL1tB,EAAUqwB,gBAAkBG,EAAaD,EACzCvwB,EAAUywB,eACVP,GAEJvD,EAASh2C,OAAO,QAAQ8B,KAAK,IAAKgzC,EAAK+E,MA4C3Cr2C,M,8CCjVZ,IAAIivB,EAAe,EAAQ,YACvB0oB,EAAU1oB,EAAa2oB,WACvBC,EAAW5oB,EAAa6oB,YACxBC,EAAS9oB,EAAa+oB,OACtBC,EAAUhpB,EAAaipB,QACvBC,EAASlpB,EAAampB,OACtBC,EAASppB,EAAaqpB,OACtBC,EAAgB,EAAQ,YAA8BA,cA6F1D,SAASC,EAAoBnhB,EAAIohB,EAAIC,EAAIh/B,GAGrC,GAAG2d,EAAKohB,GAAM,EAAG,OAAO1gB,IAMxB,IAJA,IAAI4gB,EAAKt4C,KAAK6/B,IAAIuY,EAAKphB,GACnBuhB,EAAqB,SAAZF,EAAGj0C,KACZo0C,EAAQC,EAA8BH,EAAIC,GAEtC5zC,EAAI,EAAGA,EAAI,GAAIA,IAAK,CAGxB,IAAI+zC,EAAYD,EAAsC,GAARD,EAAYD,GAE1D,GAAGC,IAAUE,EAAW,MACxB,IAAGC,EAAeD,EAAW1hB,EAAIohB,EAAIG,EAAQF,EAAIh/B,GAC5C,MADuDm/B,EAAQE,EAGxE,OAAOF,EAOX,SAASC,EAA8BH,EAAIC,GACvC,OAAGA,GAAUD,EAAKN,EAMXM,EAAKZ,EACDY,EAAe,IAAVhB,EAAsBA,EAC3BgB,EAAgB,IAAXd,EAAuBA,EACxBE,EAGRY,EAAKV,EAAgBA,EACrBU,EAAKR,EAAeA,EAChBE,EAEJh4C,KAAKuO,IAAI,GAAIvO,KAAKgD,MAAMhD,KAAKk0B,IAAIokB,GAAMt4C,KAAK44C,OAGvD,SAASD,EAAeH,EAAOxhB,EAAIohB,EAAIG,EAAQF,EAAIh/B,GAC/C,GAAGk/B,GAAUC,EAAQd,EAAQ,CACzB,IAAImB,EAAaC,EAAU9hB,EAAIqhB,EAAIh/B,GAC/B0/B,EAAaD,EAAUV,EAAIC,EAAIh/B,GAC/B2/B,EAASR,IAAUlB,EAAW,EAAI,EACtC,OAAOuB,EAAWG,KAAWD,EAAWC,GAE5C,OAAOh5C,KAAKgD,MAAMo1C,EAAKI,GAASx4C,KAAKgD,MAAMg0B,EAAKwhB,GAAS,GAG7D,SAASM,EAAUl2C,EAAGy1C,EAAIh/B,GACtB,IAAIsC,EAAQ08B,EAAGY,IAAIr2C,EAAG00C,EAASj+B,GAAU/G,MAAM,KAK/C,MAJgB,KAAbqJ,EAAM,KACLA,EAAMu9B,UACNv9B,EAAM,GAAK,IAAMA,EAAM,IAEpBA,EA5IXngB,EAAOC,QAAU,SAA8B09C,EAASC,EAAUC,EAAUhB,EAAIh/B,GAK5E,IAmBIm/B,EAAOc,EAnBPC,GAAO,IAAMH,EACbI,GAAO,GAAMJ,EACbK,EAAMN,EAAUK,EAChBE,EAAQL,EAAS,GACjBM,EAAQN,EAAS,GACjBO,EAAY55C,KAAKi3B,IACjBkhB,EAAoBuB,EAAQF,EAAKE,EAAQD,EAAKpB,EAAIh/B,GAClD8+B,EAAoBwB,EAAQH,EAAKG,EAAQF,EAAKpB,EAAIh/B,IAElDwgC,EAAa75C,KAAKi3B,IAClBkhB,EAAoBuB,EAAQH,EAAKG,EAAQF,EAAKnB,EAAIh/B,GAClD8+B,EAAoBwB,EAAQJ,EAAKI,EAAQH,EAAKnB,EAAIh/B,IAiBtD,GARGugC,EAAYC,GAAcA,EAAa75C,KAAK6/B,IAAI8Z,EAAQD,GAAS,KAChElB,EAAQoB,EACRN,GAAoB,IAEpBd,EAAQx4C,KAAKi3B,IAAI2iB,EAAWC,GAC5BP,GAAoB,GAGT,SAAZjB,EAAGj0C,MAAmBo0C,EAAQd,EAAQ,CACrC,IAAIoC,EAAetB,IAAUlB,EAAW,EAAI,EACxCyC,EAAavB,IAAUlB,EAAW,MAAQ,KAE9C,OAAO,SAAS10C,EAAGo3C,GACf,IAAIC,EAAU5B,EAAGY,IAAIr2C,EAAG00C,EAASj+B,GAC7B6gC,EAAUD,EAAQn3C,QAAQ,IAAKg3C,GAChCI,EAAU,IAAGD,EAAUA,EAAQ/9B,OAAO,EAAGg+B,IAC5C,IAAIC,EAAW9B,EAAG+B,IAAIH,EAAS,EAAG5gC,GAElC,GAAG8gC,EAAWv3C,EAAG,CACb,IAAIy3C,EAAQnC,EAAciC,EAAUJ,GAAW,EAAO1gC,IAClD8gC,EAAWE,GAAS,EAAIz3C,EAAIu2C,IAASgB,EAAWE,GAGxD,OAAGL,GAAeV,EACPpB,EAAciC,EAAUJ,GAAW,EAAM1gC,GAG7C8gC,GAIf,OAAO,SAASv3C,EAAGo3C,GACf,IAAIG,EAAW3B,EAAQx4C,KAAKC,MAAM2C,EAAI41C,GAWtC,OARG2B,EAAY3B,EAAQ,GAAM51C,GAAKu3C,EAAoB,GAAR3B,EAAe51C,EAAIu2C,IAC7DgB,GAAY3B,GAIbwB,GAAeV,IACda,GAAY3B,GAET2B,K,8CC7Cf3+C,EAAOC,QAAU,SAAqC6lB,EAAaC,EAAc9K,EAAQyK,GACrF,GAAyB,aAAtBK,EAAand,KAAhB,CAEA,IAIIk2C,EAJAhiB,EAAUhX,EAAYi5B,cACtBC,EAAgB91C,MAAM+D,QAAQ6vB,IAAYA,EAAQ/1B,OAAS,EAI5Di4C,IAAcF,EAAe,SAEhC,IACIn1B,EADAs1B,EAAQhkC,EAAO,gBAAiB6jC,GAIvB,UAAVG,IACCt1B,EAAQ1O,EAAO,kBAIf+jC,GAA0B,UAAVC,IAChBA,EAAQl5B,EAAam5B,cAAgB,SAI5B,UAAVD,EACCl5B,EAAao5B,mBAAqB,GAClB,UAAVF,EACNl5B,EAAao5B,mBAAqBx1B,EAAM/J,SAExC+J,EA1ER,SAAwBmjB,EAAIpnB,GACxB,IAEI05B,EACAj2C,EAAGkQ,EAHHgmC,EAAW35B,EAAK25B,UAAYvS,EAAGzwB,IAAIiB,OAAO,GAC1CgiC,EAAS,GAIb,GAAG55B,EAAK05B,OAEJA,EAAS15B,EAAK05B,YAId,IADAA,EAAS,GACLj2C,EAAI,EAAGA,EAAIuc,EAAKjgB,KAAKsB,OAAQoC,IAAK,CAClC,IAAI9I,EAAQqlB,EAAKjgB,KAAK0D,GACnB9I,EAAMg/C,EAAW,UAAYvS,EAAGzwB,KAC/B+iC,EAAO34C,KAAKpG,GAKxB,IAAI8I,EAAI,EAAGA,EAAIi2C,EAAOr4C,OAAQoC,IAAK,CAC/B,IAAIo2C,EAAOH,EAAOj2C,GAAGk2C,GACrB,IAAIhmC,EAAI,EAAGA,EAAIkmC,EAAKx4C,OAAQsS,IAAK,CAC7B,IAAIjS,EAAIm4C,EAAKlmC,GACVjS,UACCk4C,EAAOl4C,GAAK,IAKxB,OAAOjB,OAAOC,KAAKk5C,GA4CPE,CAAez5B,EAAcL,GAAMmQ,OAC9B,uBAAVopB,EACCl5B,EAAao5B,mBAAqBx1B,EAClB,wBAAVs1B,IACNl5B,EAAao5B,mBAAqBx1B,EAAM81B,e,8CC3EpDz/C,EAAOC,QAAU,SAAiCslB,EAASC,EAAUvK,GAEpD,WADDA,EAAO,eACIA,EAAO,oB,8CCLlC,IAAIykC,EAAY,EAAQ,YACpB/4B,EAAa,EAAQ,YACrBlZ,EAAa,EAAQ,YAAoBA,WACzCkyC,EAAc,EAAQ,YAA6BA,YACnDC,EAAW,EAAQ,YACnBC,EAAiB,EAAQ,YAAgCA,eAEzDC,EAAeD,EAAe,SAAU,CACxC32B,QAAS,CACL62B,QAAS,UACTC,KAAM,OACNC,YAAa,qDAEjB5xB,OAAQ,CACJ0xB,QAAS,aACTG,OAAQ,CAAC,UAAW,WAAY,UAAW,SAAU,QACrD77C,KAAM,UACN27C,KAAM,OACNC,YAAa,CACT,gDACA,2EACA,yEACA,0EACA,8CACFx2C,KAAK,MAEX6kB,KAAM,CACFyxB,QAAS,aACTC,KAAM,OACNG,YAAY,EACZC,MAAO,CACH,CAACL,QAAS,OACV,CAACA,QAAS,OACV,CAACA,QAAS,QAEdE,YAAa,CACT,uDACA,oCACFx2C,KAAK,MAEX0kB,MAAO,CACH4xB,QAAS,aACTC,KAAM,OACNG,YAAY,EACZC,MAAO,CACH,CAACL,QAAS,OACV,CAACA,QAAS,OACV,CAACA,QAAS,QAEdE,YAAa,CACT,4BACA,kDACA,8EACA,sCACFx2C,KAAK,MAEXsmB,MAAO,CACHgwB,QAAS,SACTC,KAAM,OACN37C,KAAM,GACN47C,YAAa,gDAEjB/xB,QAAS,CACL6xB,QAAS,UACTC,KAAM,OACN37C,MAAM,EACN47C,YAAa,CACT,sFACA,uFACA,0FACA,2FACA,yCACFx2C,KAAK,QAIfzJ,EAAOC,QAAU0/C,EAAYE,EAAe,aAAc,CACtDQ,kBAAmB,CAAC,4CAEpBn3B,QAAS,CACL62B,QAAS,UACTC,KAAM,OACNC,YAAa,CACT,yDACFx2C,KAAK,MAGXb,KAAM,CACFm3C,QAAS,aACTG,OAAQ,CAAC,WAAY,WACrB77C,KAAM,WACN27C,KAAM,OACNC,YAAa,CACT,oEACA,iEACFx2C,KAAK,MAGX6iB,UAAW,CACPyzB,QAAS,aACTG,OAAQ,CAAC,OAAQ,QAAS,KAAM,QAChC77C,KAAM,OACN27C,KAAM,OACNC,YAAa,CACT,sEACA,sEACA,wEACA,iBACFx2C,KAAK,MAGXqhB,OAAQ,CACJi1B,QAAS,UACTC,KAAM,OACNvkB,KAAM,EACNp3B,KAAM,EACN47C,YAAa,CACT,wDACA,sBACFx2C,KAAK,MAGXwmB,WAAY,CACR8vB,QAAS,UACTC,KAAM,OACN37C,MAAM,EACN47C,YAAa,6DAGjB10B,QAASu0B,EAETv9C,EAAG,CACCw9C,QAAS,SACTtkB,KAAM,EACNn2B,IAAK,EACLjB,MAAO,IACP27C,KAAM,QACNC,YAAa,uEAEjBzuB,QAAS,CACLuuB,QAAS,aACTG,OAAQ,CAAC,OAAQ,OAAQ,SAAU,SACnC77C,KAAM,QACN27C,KAAM,OACNC,YAAa,CACT,qDACA,6DACA,qCACFx2C,KAAK,MAEXjH,EAAG,CACCu9C,QAAS,SACTtkB,KAAM,EACNn2B,IAAK,EACLjB,KAAM,EACN27C,KAAM,QACNC,YAAa,uEAEjBtuB,QAAS,CACLouB,QAAS,aACTG,OAAQ,CAAC,OAAQ,MAAO,SAAU,UAClC77C,KAAM,MACN27C,KAAM,OACNC,YAAa,CACT,kDACA,4DACA,sCACFx2C,KAAK,MAGXiiB,IAAKje,EAAWmyC,EAAS,CAACU,SAAU,cAAe,CAC/CL,YAAa,0DAGjBh+C,KAAMy9C,EAAU,CACZO,YAAa,kDAGjBpwB,QAAS,CACLkwB,QAAS,QACTC,KAAM,QACNC,YAAa,yDAEjBrwB,YAAa,CACTmwB,QAAS,QACT17C,KAAMsiB,EAAW45B,WACjBP,KAAM,QACNC,YAAa,2DAEjBnyB,YAAa,CACTiyB,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,qEAEjB,YAAa,c,8CC5LjBjgD,EAAOC,QAAU,SAASylB,GACtB,IAAI46B,EAAW56B,EAAK46B,SACpB,MAAO,CACH3oC,EAAG,CACCooC,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAUA,EACVL,YAAa,iEAEjB/4C,EAAG,CACC64C,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAUA,EACVL,YAAa,qEAEjBx7B,EAAG,CACCs7B,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAUA,EACVL,YAAa,oEAEjBr0B,EAAG,CACCm0B,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAUA,EACVL,YAAa,oEAEjBK,SAAUA,K,8CChDlB,IAAI9+C,EAAM,EAAQ,YACdg/C,EAAQ,CACR,UAAW,wFACX,mBAAoB,uDACpB,+BAAgC,gBAChC,MAAO,wBACP,YAAa,wBACb,WAAY,8BACZ,sBAAuB,4GACvB,QAAS,mBACT,UAAW,gBACX,gBAAiB,gBACjB,cAAe,sDACf,yBAA0B,sBAC1B,oBAAqB,kBACrB,oBAAqB,kBACrB,sBAAuB,oBACvB,iBAAkB,eAClB,uBAAwB,qBACxB,uBAAwB,qBACxB,sBAAuB,oBACvB,sBAAuB,oBACvB,sBAAuB,oBACvB,qBAAsB,mBACtB,sBAAuB,oBACvB,qBAAsB,mBACtB,qBAAsB,mBACtB,sBAAuB,oBACvB,qBAAsB,mBACtB,sBAAuB,oBACvB,iBAAkB,mCAClB,aAAc,uCACd,aAAc,oOACd,qCAAsC,iMACtC,yCAA0C,aAC1C,mBAAoB,qIACpB,iBAAkB,wHAClB,qBAAsB,6BACtB,sBAAuB,4FACvB,0BAA2B,YAC3B,qCAAsC,gEACtC,kDAAmD,mCACnD,6CAA8C,+QAC9C,yDAA0D,2BAC1D,wBAAyB,gKACzB,uBAAwB,oKACxB,iEAAkE,qBAClE,kCAAmC,4FACnC,oBAAqB,uDACrB,sBAAuB,gBACvB,sBAAuB,yCACvBC,EAAG,2GACH,MAAO,YACP,mBAAoB,wQACpB,oBAAqB,iIACrB,0BAA2B,mDAG/B,IAAI,IAAIz8C,KAAYw8C,EAAO,CACvB,IAAIE,EAAe18C,EAASuD,QAAQ,KAAK,MACpCA,QAAQ,KAAM,2BACdA,QAAQ,KAAM,oBACnB/F,EAAIo4B,aAAa8mB,EAAcF,EAAMx8C,M,8CCtDzC,IAAI07C,EAAY,EAAQ,YACpB/4B,EAAa,EAAQ,YAGrBg6B,GAAcd,EAFG,EAAQ,YAAgCA,gBAE5B,SAAU,CACvC32B,QAAS,CACL62B,QAAS,UACTC,KAAM,OACN37C,MAAM,EACNi8C,SAAU,OACVL,YAAa,qDAEjBW,KAAM,CACFb,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,QAAS,OAAQ,MAAO,OAAQ,SAAU,SAAU,OAC7D77C,KAAM,QACNi8C,SAAU,OACVL,YAAa,CACT,yEACFx2C,KAAK,MAEXo3C,SAAU,CACNd,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,WAAY,UACrB77C,KAAM,WACNi8C,SAAU,OACVL,YAAa,CACT,8BACA,4DACA,0CACA,0DACA,iDACA,4BACA,gEACA,yDACA,kCACA,uDACA,0CACFx2C,KAAK,MAEXq5B,MAAO,CACHid,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,wDACA,mDACFx2C,KAAK,MAEXsmB,MAAO,CACHgwB,QAAS,SACTC,KAAM,OACNM,SAAU,OACVL,YAAa,gDAEjBK,SAAU,OACVL,YAAa,CACT,4CACA,uDACFx2C,KAAK,OAGXzJ,EAAOC,QAAU,CACbipB,QAAS,CACL62B,QAAS,UACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,4DACA,6DACA,0CACFx2C,KAAK,MAGX8hB,QAASo1B,EAETp+C,EAAG,CACCw9C,QAAS,SACTtkB,KAAM,EACNn2B,IAAK,EACL06C,KAAM,QACNM,SAAU,OACVL,YAAa,0EAEjBzuB,QAAS,CACLuuB,QAAS,aACTG,OAAQ,CAAC,OAAQ,OAAQ,SAAU,SACnC77C,KAAM,OACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,wDACA,6DACA,qCACFx2C,KAAK,MAEXjH,EAAG,CACCu9C,QAAS,SACTtkB,KAAM,EACNn2B,IAAK,EACL06C,KAAM,QACNM,SAAU,OACVL,YAAa,0EAEjBtuB,QAAS,CACLouB,QAAS,aACTG,OAAQ,CAAC,OAAQ,MAAO,SAAU,UAClC77C,KAAM,SACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,qDACA,4DACA,sCACFx2C,KAAK,MAGXxH,KAAMy9C,EAAU,CACZY,SAAU,OACVL,YAAa,qDAGjBpwB,QAAS,CACLkwB,QAAS,QACT17C,KAAMsiB,EAAWE,UACjBm5B,KAAM,QACNM,SAAU,OACVL,YAAa,4DAEjBa,YAAa,CACTf,QAAS,QACTC,KAAM,QACNM,SAAU,OACVL,YAAa,kEAEjBrwB,YAAa,CACTmwB,QAAS,QACT17C,KAAMsiB,EAAWna,YACjBwzC,KAAM,QACNM,SAAU,OACVL,YAAa,8DAEjBnyB,YAAa,CACTiyB,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,OACVL,YAAa,sEAEjBK,SAAU,S,8CC1Jd,IAAIxgD,EAAK,EAAQ,YAEbwB,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdsoB,EAAU,EAAQ,YAClB/pB,EAAQ,EAAQ,YAChBghD,EAAc,EAAQ,YAAyBA,YAE/Cl/C,EAAW,EAAQ,YACnBm/C,EAAW,EAAQ,YACnBC,EAAgB,EAAQ,YAA4BniB,WAylBxD,SAASoiB,EAAqBC,EAAcC,GAExC,OADUA,EAAW,SAAW,eAClBD,EAAe,GAAK,YAnlBtCnhD,EAAOC,QAAU,SAAeS,EAAGyD,EAAImuC,GACnC,IAAIlpC,EAAajF,EAAGkF,YAChBipC,IAAQA,EAASlpC,EAAWkpC,QAChC,IAAI+O,EAA2C,aAAtB/O,EAAOgP,WAE5BC,EAAiB,SAASp1C,EAAKsD,EAAMnK,EAAKk8C,GAC1C,IAAIp6C,EACJ,GAAG+E,EAAM,EACL/E,EAAI+E,MACD,MAAGsD,GAAQA,EAAKzK,MAAQ,GAG3B,OAAO,EAFPoC,EAAIqI,EAAKzK,MAIb,OAAOq8C,EAAqBG,EAAMh9C,KAAKi3B,IAAIr0B,EAAG9B,IA0SlD,SAASm8C,EAAarhD,EAAGshD,EAAOC,GAC5B,IAAIthD,EAAQD,EAAE,GAAGC,MACb0K,EAAS1K,EAAM0K,QAAU,GACzBC,EAAaD,EAAOjG,MAAQ,GAE5B88C,EAAcD,EACbthD,EAAM6oB,SAAW7oB,EAAMuI,OAAS+4C,EADJrgD,EAAS2C,QAAQ5D,EAAO,OAGrDwhD,EAAU/hD,EAAGa,OAAO+gD,GAAO/gD,OAAO,kBACjCE,UAAU,cAAgB8gD,GAC1Bl8C,KAAKm8C,EAAY,CAACxhD,GAAK,IAC5ByhD,EAAQh4C,QAAQC,OAAO,QAAQsiB,QAAQ,SAAWu1B,GAAa,GAC1Dl/C,KAAK,IAAK,iBACVA,KAAK,YAAa,mBACvBo/C,EAAQl4C,OAAOC,SAEfi4C,EAAQ1hD,MAAK,SAASC,GAClB,IAAI8Q,EAAIpR,EAAGa,OAAOC,MACdkhD,EAAK1hD,EAAE,GACPuC,EAAI4+C,EAAeO,EAAG31C,IAAKpB,EAAOjG,KA7UtB,EAFA,GAiVhBoM,EAAEpQ,MAAM,eAAgB6B,EAAI,MACvB3B,KAAKjB,EAAMsC,KAAMy/C,EAAGn1C,IAAM5B,EAAO7J,OAEnCyB,GAAG5C,EAAMkB,OAAOiQ,EAAG4wC,EAAGx1C,KAAOtB,EAAW9J,UAwGnD,SAAS6gD,EAAa3hD,EAAGshD,EAAOC,GAC5B,IAAIG,EAAK1hD,EAAE,GACPC,EAAQyhD,EAAGzhD,MAEXuhD,EAAcD,EACbthD,EAAM6oB,SAAW7oB,EAAMuI,OAAS+4C,EADJrgD,EAAS2C,QAAQ5D,EAAOshD,GAGrDpuC,EAAMzT,EAAGa,OAAO+gD,GAAO/gD,OAAO,kBAC7BE,UAAU,cAAgB8gD,GAC1Bl8C,KAAKm8C,EAAY,CAACxhD,GAAK,IAM5B,GALAmT,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,SAAWu1B,GAAa,GACtDl/C,KAAK,IAAK,iBACVA,KAAK,YAAa,mBACvB8Q,EAAI5J,OAAOC,SAER2J,EAAIpR,OAAQ,CACX,IAAIsN,GAAQpP,EAAM0K,QAAU,IAAIjG,KAC5BH,EAAK48C,EAAeN,EAAcxxC,EAAKzK,MAAO88C,EAAGvuC,KAAM9D,EA3c3C,EAFA,GA+cZuyC,EAAOxgD,EAAIs+B,UAAUz/B,EAAO,CAAC0K,OAAQ,CAACjG,KAAM,CAACE,MAAOL,MAExDq9C,EAAKj3C,OAAOjG,KAAK5D,MAAQuO,EAAKvO,MAE9B,IAAI+gD,EAAQzgD,EAAIs+B,UAAUgiB,EAAI,CAACzhD,MAAO2hD,IAEtChB,EAASztC,EAAK0uC,EAAOD,IAhc7BthD,EAAEP,MAAK,SAASC,GACZ,IAAI8hD,EAAapiD,EAAGa,OAAOC,MAEvBuhD,EAAS3gD,EAAIkJ,aAAaw3C,EAAY,IAAK,UAC/CC,EAAOrhD,MAAM,UAAWV,EAAE,GAAGC,MAAM+K,SAEnC,IAAI6iC,EAASqE,EAAOrE,OAChByH,EAAat1C,EAAE,GAAGs1C,WAClB9gC,EAASxU,EAAE,GAAGwU,OAElB,GAAc,WAAXq5B,GAAwByH,GAAe9gC,EAEnC,CACH,IACIwtC,EADS,CAAChyC,IAAK,EAAGD,QAAS,GAAG89B,IACJ,IAAOyH,EAAa9gC,EAAS,IAC3DutC,EAAO1/C,KAAK,YAAa,eAAiB2/C,EAAgB,UAJ1DD,EAAO1/C,KAAK,YAAa,MAOlB0/C,EACNthD,UAAU,gBACN4E,KAAK,CAACrF,IACVyJ,QAAQC,OAAO,KACfsiB,QAAQ,cAAc,GAEhB+1B,EACNthD,UAAU,iBACN4E,KAAK,CAACrF,IACVyJ,QAAQC,OAAO,KACfsiB,QAAQ,eAAe,GAE5B,IAAI1gB,EAASy2C,EACRthD,UAAU,mBACN4E,KAAK,CAACrF,IACfsL,EAAO7B,QAAQC,OAAO,KACjBsiB,QAAQ,iBAAiB,GAE9B1gB,EAAO7K,UAAU,kBACZ4E,KAAK,CAACrF,IACRyJ,QAAQC,OAAO,KACbsiB,QAAQ,gBAAgB,MAEhCjsB,MA2ZD,SAAsBC,GAClB,IAEIiiD,EAFAhiD,EAAQD,EAAE,GAAGC,MAGbiiD,EAAU,GACd,GAAGjiD,EAAM6oB,QACL,OAAO7oB,EAAMuI,MACT,IAAK,cACL,IAAK,UACD05C,EAAU,CACN,CAAC,qBAELD,GAAc,EACd,MACJ,IAAK,aACL,IAAK,mBACDC,EAAU,CACN,CAAC,mBAELD,GAAc,EACd,MACJ,IAAK,gBACDC,EAAU,CACN,CAAC,4CAELD,EAAc,SACd,MACJ,IAAK,OACDC,EAAU,CACN,CAAC,iCACD,CAAC,kCACD,CAAC,iCAELD,GAAc,EACd,MACJ,IAAK,aACDC,EAAU,CACN,CAAC,6CACD,CAAC,gDACD,CAAC,gDAELD,GAAc,EACd,MACJ,IAAK,UACDC,EAAU,CACN,CAAC,+CACD,CAAC,8CAELD,GAAc,EACd,MACJ,IAAK,SACDC,EAAU,CACN,CAAC,kBACD,CAAC,gBACD,CAAC,kBAELD,GAAc,EACd,MACJ,IAAK,SACDC,EAAU,CACN,CAAC,kBACD,CAAC,gBACD,CAAC,kBAELD,GAAc,EACd,MACJ,IAAK,aACDC,EAAU,CACN,CAAC,kBACD,CAAC,gBACD,CAAC,mCAELD,GAAc,EAK1B,IAAI9uC,EAAMzT,EAAGa,OAAOC,MAAMD,OAAO,kBAC5BE,UAAU,2BACV4E,KAAK68C,GACV/uC,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,sBAAsB,GACpD3pB,KAAK,YAAa,mBAClB3B,MAAM,oBAAqB,GAChCyS,EAAI5J,OAAOC,SAEX2J,EAAIpT,MAAK,SAASoiD,EAAIp5C,GAClB,IAcIyC,EAdA0D,EAAKxP,EAAGa,OAAOC,MAEf4hD,EAAQzB,EAAY1gD,GACpBwI,EAAa25C,EAAM35C,WACnBs4C,EAAeqB,EAAMrB,aAWzB,GAAIt4C,GAIA,IAAIw5C,EAAa,CACb,IAAIt5C,EAAMF,EAAW9B,OACrB6E,EACU,IAANzC,EAAUN,EAAWs4C,EAAep4C,EAAM,EAAI,GAAG,GAC3C,IAANI,EAAUN,EAAWs4C,EAAe,EAAIp4C,EAAM,GAAG,GAC7CF,EAAWrE,KAAKgD,OAAOuB,EAAM,GAAK,IAAI,QATtC,CACZ,IAAI7H,EAAQb,EAAMoiD,aAAepiD,EAAMqiD,WAAariD,EAAMa,MAC1D0K,EAAYpK,EAAI+K,oBAAoBrL,GAAUA,EAAMiI,IAAMjI,EAAM,GAAMA,EAW1EoO,EAAG7M,KAAK,IAAK8/C,EAAG,IACb32C,EACC0D,EAAGtO,KAAKjB,EAAMsC,KAAMuJ,GAEpB0D,EAAGtO,MA3BY,SAASN,GACxB,GAAGA,EAAEyB,OAAQ,CACT,IAAIwG,EAAa,cAAgBtI,EAAM+M,IACvC0c,EAAQphB,SAAShI,EAAGyD,EAAIwE,EACpBu4C,EAAqBC,EAA8B,WAAhBkB,GACnCx5C,EAAY,kBA1f/B1I,MA2MD,SAAyBC,GACrB,IAAIC,EAAQD,EAAE,GAAGC,MACbsiD,EAA6B,cAAftiD,EAAMuI,KAExB,GAAGxI,EAAE,GAAGwiD,WAAaD,EAAa,CAC9B,IAAIlzC,EAAOrP,EAAE,GAAGC,MAAMD,EAAE,GAAGyiD,KAAK93C,OAIhC,OAHA3K,EAAE,GAAGuM,GAAK8C,EAAKvO,MACfd,EAAE,GAAG+L,IAAMsD,EAAK3K,KAAKE,MACrB5E,EAAE,GAAGkM,IAAMmD,EAAK3K,KAAK5D,MACdugD,EAAarhD,EAAGQ,KAAM,aAGjC,IAAI0hD,EAAU,GACXjiD,EAAM6oB,SAAWy5B,IAChBL,EAAUliD,EAAE,GAAG0iD,UACX,CAAC,CAAC,aAAc,eAAgB,CAAC,SAAU,oBAAqB,CAAC,aAAc,eAC/E,CAAC,CAAC,aAAc,eAAgB,CAAC,aAAc,iBAGvD,IAAIvvC,EAAMzT,EAAGa,OAAOC,MAAMD,OAAO,kBAC5BE,UAAU,wBACV4E,KAAK68C,GACV/uC,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,mBAAmB,GACjD3pB,KAAK,YAAa,mBAClB3B,MAAM,oBAAqB,GAChCyS,EAAI5J,OAAOC,SAEX2J,EAAIpT,MAAK,SAASoiD,GACd,IAAIjzC,EAAKxP,EAAGa,OAAOC,MACf6O,EAAOpP,EAAMkiD,EAAG,IAAIx3C,OACpBpG,EAAK48C,OAAer2C,EAAWuE,EAAK3K,KAtSxB,EAFA,GA0ShBwK,EAAG7M,KAAK,IAAK8/C,EAAG,IACXzhD,MAAM,eAAgB6D,EAAK,MAC3B3D,KAAKjB,EAAMsC,KAAMoN,EAAKvO,OAExByD,GACC2K,EAAGtO,KAAKjB,EAAMkB,OAAQwO,EAAK3K,KAAK5D,aA/O3Cf,MAwPD,SAAsBC,GAClBqhD,EAAarhD,EAAGQ,KAAM,aAxPzBT,MAmPD,SAAmBC,GACfqhD,EAAarhD,EAAGQ,SAnPnBT,MAsRD,SAAoBC,GAChB,IAAIC,EAAQD,EAAE,GAAGC,MAEbkT,EAAMzT,EAAGa,OAAOC,MAAMD,OAAO,kBAC5BE,UAAU,kBACV4E,KAAKpF,EAAM6oB,SAAW5nB,EAAS2C,QAAQ5D,EAAO,cAAgB,CAACD,GAAK,IACzEmT,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,aAAa,GAE3C3pB,KAAK,IAAK,iBACVA,KAAK,YAAa,mBACvB8Q,EAAI5J,OAAOC,SAEX2J,EAAIpT,MAAK,WACL,IAAI+Q,EAAIpR,EAAGa,OAAOC,MAElB,GAAwB,QAApBP,EAAM0iD,WAAwC,QAAjB1iD,EAAM2iD,QACA,IAAnCjjD,EAAMqL,QAAQ/K,EAAMmF,YAAgE,IAA5CzF,EAAMqL,SAAS/K,EAAMyE,MAAQ,IAAI5D,OAWtE,CACH,IAAIyB,EAAI4+C,OAAer2C,EAAW7K,EAAMyE,KAlX5B,EAFA,GAsXZoM,EAAEpQ,MAAM,eAAgB6B,EAAI,MACvB3B,KAAKjB,EAAMsC,KAAMhC,EAAMmF,WAEzB7C,GAAG5C,EAAMkB,OAAOiQ,EAAG7Q,EAAMyE,KAAK5D,WAhBnC,CACE,IAAI8gD,EAAOxgD,EAAIs+B,UAAUz/B,EAAO,CAC5B0K,OAAQ,CACJ5I,KAAMk/C,EA9WR,GA8W+C7/C,EAAI85B,UAAUj7B,EAAM0K,OAAO5I,KAAM,EAAG,IACjF8gD,QAAS,EACTC,QAAS,EACTC,SAAU,cAGlB5vC,EAAIvS,KAAK8oB,EAAQnf,WAAYq3C,EAAM79C,UA/S9ChE,MAqXD,SAA0BC,GACtB2hD,EAAa3hD,EAAGQ,KAAM,iBArXzBT,MAgXD,SAAmBC,GACf2hD,EAAa3hD,EAAGQ,KAAM,UAhXzBT,MAKD,SAAoBC,GAChB,IAOIgjD,EAAMpB,EAPNF,EAAK1hD,EAAE,GACPC,EAAQyhD,EAAGzhD,MACXgjD,EAAWhjD,EAAM6oB,SAAW7oB,EAAMgC,MAAuB,SAAfhC,EAAMgC,KAChDihD,EAAWzhD,EAAS0hD,SAASljD,GAC7BmjD,EAAWnjD,EAAMmjD,SACjBC,GAAmB,EACnBC,GAAmB,EAGnBlB,EAAQzB,EAAY1gD,GACpBwI,EAAa25C,EAAM35C,WACnBs4C,EAAeqB,EAAMrB,aAqBzB,GAAGqC,EAAU,CACT,IAAIG,EAAWH,EAASG,SAER,UAAbA,EACCF,GAAmB,EAEnBH,EAAwB,SAAbK,GAAoC,YAAbA,GAA0BH,EAASI,UAGpD,eAAlBJ,EAAS56C,KACRy6C,EAAmC,MAAxBG,EAASK,WACD,SAAbF,GAAoC,YAAbA,IAC7BD,GAAmB,GAM3B,IAAII,EAAgBjiD,EAASkiD,WAAW1jD,IAAUwB,EAASmiD,QAAQ3jD,GAC/D4jD,EAAUZ,GAAYK,EACtBQ,EAAUZ,GAAYG,EACtBU,EAAaL,IAAkBG,EAAW,OAG1CC,EAAU,QAAU,QAEpBE,EAAQtkD,EAAGa,OAAOC,MAElByB,EAAO+hD,EAAMzjD,OAAO,eAAeE,UAAU,QAC5C4E,KAAK49C,GAAYK,EAAmB,CAACtjD,GAAK,IAM/C,GALAiC,EAAKwH,QAAQC,OAAO,QAAQsiB,QAAQ,WAAW,GAC/C/pB,EAAKsH,OAAOC,SACZvH,EAAKI,KAAK,IAAK0hD,EAAY,cACtBnjD,KAAKqiD,EAAWv5B,EAAQpkB,eApDV,SAAShF,GACxB,GAAGA,EAAEyB,OAAQ,CACT,IAAIwG,EAAa,cAAgBtI,EAAM+M,IACvC0c,EAAQphB,SAAShI,EAAGyD,EAAIwE,EACpBu4C,EAAqBC,GACrBt4C,EAAY,WAiDrBy6C,GAAYG,EAAkB,CAC7B,IAAI9+C,EAAK48C,OAAer2C,EAAW7K,EAAMyE,KA9IhC,GAFA,GAiJTk9C,EAAOxgD,EAAIs+B,UAAUz/B,EAAO,CAACyE,KAAM,CAACE,MAAOL,KAC3Cy+C,EAAO,CAAC5hD,EAAIs+B,UAAUgiB,EAAI,CAACzhD,MAAO2hD,KAGtC,IAAIl9C,EAAOs/C,EAAMzjD,OAAO,gBAAgBE,UAAU,QAC7C4E,KAAK69C,GAAYG,EAAmB,CAACL,GAAQ,IAClDt+C,EAAK+E,QAAQC,OAAO,QAAQsiB,QAAQ,WAAW,GAC/CtnB,EAAK6E,OAAOC,SAQZ9E,EAAKrC,KAAK,IAAK0hD,GAAaV,EAAmB,aAAe,QACzDziD,KAAKsiD,EAAWx5B,EAAQ3kB,eA/DV,SAASzE,GACxB,GAAGA,EAAEyB,OAAQ,CACT,IAAIwG,EAAa,cAAgBtI,EAAM+M,IACvC0c,EAAQ3kB,eAAezE,GACvBopB,EAAQphB,SAAShI,EAAGyD,EAAIwE,EACpBu4C,EAAqBC,GACrBt4C,EAAY,gBAjC3B1I,MA6FD,SAAqBC,GACjB,IAKIgjD,EAAMpB,EALNF,EAAK1hD,EAAE,GACPC,EAAQyhD,EAAGzhD,MACXgkD,EAAcxiD,EAASkiD,WAAW1jD,GAClCikD,EAAWziD,EAASmiD,QAAQ3jD,GAC5BkkD,EAAY1iD,EAAS0hD,SAASljD,GAMlC,SAASmkD,EAASC,EAAQC,EAAcC,EAAQnD,GAC5C,IAAIoD,EAAQpjD,EAAIkO,eAAerP,EAAOokD,GAAQ90C,MAC1Ck1C,EAAcrjD,EAAI+K,oBAAoBq4C,IAAUF,EAChDA,EAAaE,GACbA,EAMJ,GAJGvD,GAAsBwD,QAAsB35C,IAARs2C,IACnCqD,EAAarD,GAGdmD,EAAQ,CACP,GAAGE,EAAaF,EAAO,GAAI,OAAOA,EAAO,GACpC,GAAGE,EAAaF,EAAO,GAAI,OAAOA,EAAO,GAElD,OAAOE,EAGX,SAASC,EAAUn7B,GACf,OAAGm4B,EAAGc,WAAad,EAAGr4B,OAASE,EAAMm4B,EAAGr4B,OAAeE,EAAMm4B,EAAGr4B,OACzDE,EAAM,GAIjB,GAAG06B,GAAeC,GAAYC,EAAW,CACrC,IAAIQ,EAAQ,GACRC,EAAQ,GAEZ,GAAGX,EAAa,CACZU,EAAMp4C,GAAK63C,EAAS,eAAgBM,GACpCC,EAAMt5C,GAAK+4C,EAAS,gBAAiBM,GACrCC,EAAM55C,GAAKq5C,EAAS,iBAAkBhjD,EAAIy0B,KAAM,CAAC,GAAK,IACtD8uB,EAAMz4C,IAAMk4C,EAAS,oBAAqBM,GAC1CC,EAAM54C,IAAMq4C,EAAS,oBAAqBhjD,EAAIy0B,KAAM,CAAC,EAAG,GA9M5C,GA+MZ+uB,EAAMj6C,OAAS,CACXk4C,QAAS,EACTC,QAAS,EACTC,SAAU,YAGd,IAAI73C,EAAKk5C,EAAS,cAAehjD,EAAIy0B,KAAM,CAAC,EAAG,IAvNzC,IAwNN8uB,EAAMz5C,GAAKA,EACX05C,EAAMj6C,OAAO5I,KAAOmJ,EAGrBi5C,IACCS,EAAMlgD,KAAO,CACTE,MAAOw/C,EAAS,aAAcM,EAAW,CAAC,EAAG,IA7N5C,KAiONR,IACCS,EAAM3yC,GAAK,KACX2yC,EAAMjzC,GAAK0yC,EAAS,eAAgBM,GACpCC,EAAMh0C,GAAK,GACXg0C,EAAM96C,GAAKu6C,EAAS,iBAAkBM,GACtCC,EAAM9yC,GAAKuyC,EAAS,kBAAmBM,IAG3C1B,EAAO,CAAC5hD,EAAIs+B,UAAUgiB,EAAIiD,KAC1B/C,EAAOxgD,EAAIs+B,UAAUz/B,EAAO2kD,IAGvBx3C,eAAiB,KAGtBw0C,EAAK/wC,aAAe,KAGxB,IAAIg0C,EAAUnlD,EAAGa,OAAOC,MAAMD,OAAO,kBAEjC4S,EAAM0xC,EAAQpkD,UAAU,mBACvB4E,KAAK4+C,EAAcjB,EAAO,IAE/B7vC,EAAI1J,QAAQ2hC,OAAO,OAAQ,gBACtBpf,QAAQ,cAAc,GACtB3pB,KAAK,YAAa,mBACvB8Q,EAAI5J,OAAOC,SACX2J,EAAIvS,KAAK8oB,EAAQnf,WAAYq3C,EAAM79C,GAIhCkgD,IAAajB,EAAK,GAAG73C,IAAM,GAE9B,IAAI25C,EAAMD,EAAQpkD,UAAU,eACvB4E,KAAK6+C,EAAWlB,EAAO,IAC5B8B,EAAIr7C,QACCC,OAAO,KAAKsiB,QAAQ,aAAa,GAC7BtiB,OAAO,QAAQrH,KAAK,YAAa,mBAC1CyiD,EAAIv7C,OAAOC,SACXs7C,EAAIrkD,UAAU,QAAQG,KAAK8oB,EAAQ9Y,eAAgBgxC,EAAM79C,MAhM5DhE,MAuTD,SAAsBC,GAClB,IAAIC,EAAQD,EAAE,GAAGC,MAEbkT,EAAMzT,EAAGa,OAAOC,MAAMD,OAAO,kBAC5BE,UAAU,qBACV4E,KAAKpF,EAAM6oB,SAA0B,gBAAf7oB,EAAMuI,KAAyB,CAACxI,EAAGA,GAAK,IACnEmT,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,gBAAgB,GAC9C3pB,KAAK,KAAK,SAASw3B,EAAG9wB,GACnB,OAAGA,EAAU,uBACN,wBAEV1G,KAAK,YAAa,mBAClB3B,MAAM,oBAAqB,GAChCyS,EAAI5J,OAAOC,SAEX2J,EAAIpT,MAAK,SAAS85B,EAAG9wB,GACjB,IAAI+H,EAAIpR,EAAGa,OAAOC,MACd6O,EAAOpP,EAAM8I,EAAI,aAAe,cAChCxG,EAAI4+C,OAAer2C,EAAWuE,EAAK3K,KA9YvB,EAFA,GAkZhBoM,EAAEpQ,MAAM,eAAgB6B,EAAI,MACvB3B,KAAKjB,EAAMsC,KAAMoN,EAAKjK,WAExB7C,GAAG5C,EAAMkB,OAAOiQ,EAAGzB,EAAK3K,KAAK5D,aA7UvCf,MAiVD,SAAmBC,GACf,IAAIC,EAAQD,EAAE,GAAGC,MAEbkT,EAAMzT,EAAGa,OAAOC,MAAMD,OAAO,kBAC5BE,UAAU,mBACV4E,KAAKpF,EAAM6oB,SAA0B,SAAf7oB,EAAMuI,KAAkB,CAACxI,EAAGA,GAAK,IAC5DmT,EAAI1J,QAAQC,OAAO,QAAQsiB,QAAQ,cAAc,GAC5C3pB,KAAK,KAAK,SAASw3B,EAAG9wB,GACnB,OAAGA,EAAU,mBACN,mBAEV1G,KAAK,YAAa,mBAClB3B,MAAM,oBAAqB,GAChCyS,EAAI5J,OAAOC,SAEX2J,EAAIpT,MAAK,SAAS85B,EAAG9wB,GACjB,IAAI+H,EAAIpR,EAAGa,OAAOC,MACd6O,EAAOpP,EAAM8I,EAAI,aAAe,cAChCxG,EAAI4+C,OAAer2C,EAAWuE,EAAK3K,KAzavB,EAFA,GA6ahBoM,EAAEpQ,MAAM,OAAQ,QACXE,KAAK8oB,EAAQ5kB,SAAUuK,EAAK3K,KAAKG,KAAMtC,GAEzCA,GAAG5C,EAAMkB,OAAOiQ,EAAGzB,EAAK3K,KAAK5D,e,8CC7b5C,IAAIpB,EAAK,EAAQ,YAEbwB,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdqoB,EAAQ,EAAQ,YAChBC,EAAU,EAAQ,YAElBq7B,EAAoB,EAAQ,YAAeA,kBAC3CxsC,EAAU,EAAQ,YAClBqR,EAAY,EAAQ,YACpBtoB,EAAkB,EAAQ,YAE1BgJ,EAAelJ,EAAIkJ,aAEvB,SAAS06C,EAAwBpkB,EAAQC,EAAUC,GAC/C,OAAO1/B,EAAIkJ,aAAas2B,EAAQC,EAAUC,GAAW,SAASxgC,GAC1DA,EAAEkhC,MAAMV,MAuKhB,SAASmkB,EAAQlhD,EAAImhD,EAAUC,EAAW1iC,EAAgBC,GAStD,IARA,IAGIxR,EAASk0C,EAAmBC,EAH5BC,EAAoB17B,EAAU07B,kBAC9Bt8C,EAAajF,EAAGkF,YAChBs8C,EAAUv8C,EAAWw8C,SAGrBC,EAAY,GACZC,EAAsB,GAElB38C,EAAI,EAAGA,EAAIw8C,EAAQ5+C,OAAQoC,IAAK,CAEpC,IAAIwZ,GADJrR,EAAUq0C,EAAQx8C,IACCwZ,KACfojC,EAAazkD,EAASqkD,QAAQhjC,GAAMojC,WAExC,GAAGA,EAAWriC,IAAK,CACf,IAAIwd,EAAa5vB,EAAQ00C,WAAarjC,EAAO,QACzCsjC,EAAa30C,EAAQsR,KAIzB6iC,GADAD,EAAoBL,EAAkBI,EAAWU,IACpB,GAG7BV,EAAYC,EAAkB,GAE3BC,EAAS1+C,QACR8+C,EAAUp/C,KAAK,CACX0C,EAAGu8C,EAAkBp+C,QAAQ45B,GAC7BA,UAAWA,EACX+kB,WAAYA,EACZR,SAAUA,IAIfM,EAAWG,WACVJ,EAAoBr/C,KAAK,IAAMy6B,IAK3C2kB,EAAUhwB,MAAK,SAASlO,EAAGlD,GAAK,OAAOkD,EAAExe,EAAIsb,EAAEtb,KAE/C,IAAIg5C,EAASmD,EAAS1iC,KAAK/hB,UAAU,YAChC4E,KAAKogD,GAAW,SAASzlD,GAAK,OAAOA,EAAE8gC,aAkC5C,GAhCAihB,EAAOt4C,QAAQC,OAAO,KACjBrH,KAAK,SAAS,SAASrC,GAAK,OAAOA,EAAE8gC,aACrC9U,QAAQ,UAAU,GAClBA,QAAQ,YAAak5B,EAASa,aAEnChE,EAAOx4C,OAAOC,SAEdu4C,EAAOlD,QAEPkD,EAAOhiD,MAAK,SAASC,GACjB,IAAI2C,EAAMjD,EAAGa,OAAOC,MAChBsgC,EAAY9gC,EAAE8gC,UAElB9gC,EAAE6lD,WACE9hD,EAAImhD,EAAUllD,EAAEqlD,SAAU1iD,EAC1B8f,EAAgBC,IAI4C,IAA7DkH,EAAUo8B,qBAAqB9+C,QAAQ,IAAM45B,IAC5CpX,EAAQtT,WAAWzT,EAAKuiD,EAASe,YAAaliD,MAKnDiF,EAAWma,KAAK,eACfjS,EAAUhQ,EAASglD,UAAU,aAC7Bb,EAAWN,EAAkBI,EAAWj0C,GAAS,GACjDA,EAAQsR,KAAKze,EAAImhD,EAAUG,KAI3BthD,EAAGG,SAASC,aACT+gD,EAASzhD,sBACRyhD,EAASiB,sBAAwBjB,EAAS1iC,KACrC/hB,UAAUmpB,EAAUo8B,qBAAqB38C,KAAK,MAC9C5I,UAAU,WAGhBilD,EAAoB/+C,QAAQ,CAC3B,IAAI7G,EAASolD,EAAS1iC,KACjB/hB,UAAUilD,EAAoBr8C,KAAK,MACnC5I,UAAU,UAEfykD,EAASkB,aAAetmD,EAAOW,UAAU,cACzCykD,EAASmB,aAAevmD,EAAOW,UAAU,eAoKrD,SAAS6lD,EAAiBviD,EAAImhD,GAC1B,IAAIqB,EAAYrB,EAASqB,UACrBtlB,EAAKikB,EAASjkB,GACdulB,EAAS58B,EAAU68B,sBAAsBvB,EAASxhD,MAAMs9B,OACxD0lB,EAAS98B,EAAU68B,sBAAsBvB,EAASvhD,MAAMq9B,OACxD2lB,EAAqB5iD,EAAGkF,YAAY29C,oBAExC,GAAI1B,EAAS2B,SA4CN,CACH,IAAIC,EAAe5B,EAAS4B,aACxBC,EAAgBD,EAAaP,UAC7BS,EAAM/lB,EAAK,KACXgmB,EAAMhmB,EAAK,KAOfikB,EAASgC,UAAYJ,EAAaI,UAClChC,EAASiC,cAAgBL,EAAaK,cAEtC78C,EAAaw8C,EAAaM,eAAgB,OAAQJ,GAClD18C,EAAaw8C,EAAaM,eAAgB,OAAQH,GAClD38C,EAAaw8C,EAAaO,cAAe,IAAKL,GAC9C18C,EAAaw8C,EAAaO,cAAe,IAAKJ,GAE9C/B,EAAS1iC,KAAOlY,EAAaw8C,EAAaQ,SAAU,IAAKrmB,GAEzD32B,EAAaw8C,EAAaS,eAAgB,OAAQP,GAClD18C,EAAaw8C,EAAaS,eAAgB,OAAQN,GAClD38C,EAAaw8C,EAAaU,cAAe,IAAKR,GAC9C18C,EAAaw8C,EAAaU,cAAe,IAAKP,GAG9C/B,EAASuC,OAASV,EAAcxmD,OAAO,cAAgBimD,GAAQjmD,OAAO,IAAMymD,GAC5E9B,EAASwC,OAASX,EAAcxmD,OAAO,cAAgBmmD,GAAQnmD,OAAO,IAAM0mD,GAC5E/B,EAASyC,WAAaZ,EAAcxmD,OAAO,aAAeimD,GAAQjmD,OAAO,IAAMymD,GAC/E9B,EAAS0C,WAAab,EAAcxmD,OAAO,aAAemmD,GAAQnmD,OAAO,IAAM0mD,QAzE/E,GAAGN,EAMCzB,EAASuC,OAASn9C,EAAai8C,EAAW,OAAQ,gBAClDrB,EAASwC,OAASp9C,EAAai8C,EAAW,OAAQ,gBAClDrB,EAASyC,WAAar9C,EAAai8C,EAAW,IAAK,oBACnDrB,EAAS0C,WAAat9C,EAAai8C,EAAW,IAAK,wBAChD,CACH,IAAIsB,EAAYv9C,EAAai8C,EAAW,IAAK,iBAC7CrB,EAAS4C,WAAax9C,EAAau9C,EAAW,IAAK,cACnD3C,EAAS6C,WAAaz9C,EAAau9C,EAAW,IAAK,cAEnD3C,EAASgC,UAAY58C,EAAai8C,EAAW,IAAK,aAClDrB,EAASiC,cAAgB78C,EAAai8C,EAAW,IAAK,iBAEtDj8C,EAAai8C,EAAW,OAAQ,gBAChCj8C,EAAai8C,EAAW,OAAQ,gBAChCrB,EAASkC,eAAiB98C,EAAai8C,EAAW,IAAK,mBAEvDj8C,EAAai8C,EAAW,IAAK,oBAC7Bj8C,EAAai8C,EAAW,IAAK,oBAC7BrB,EAASmC,cAAgB/8C,EAAai8C,EAAW,IAAK,kBAEtDrB,EAAS1iC,KAAOlY,EAAai8C,EAAW,IAAK,QAC7CrB,EAASoC,SAAWh9C,EAAai8C,EAAW,IAAK,YAEjDrB,EAASuC,OAASn9C,EAAai8C,EAAW,OAAQ,gBAClDrB,EAASwC,OAASp9C,EAAai8C,EAAW,OAAQ,gBAClDrB,EAASqC,eAAiBj9C,EAAai8C,EAAW,IAAK,mBAEvDj8C,EAAai8C,EAAW,IAAK,oBAC7Bj8C,EAAai8C,EAAW,IAAK,oBAC7BrB,EAASsC,cAAgBl9C,EAAai8C,EAAW,IAAK,kBAGtDrB,EAASuC,OAASlB,EAAUhmD,OAAO,WAAaimD,GAChDtB,EAASwC,OAASnB,EAAUhmD,OAAO,WAAammD,GAChDxB,EAASyC,WAAapB,EAAUhmD,OAAO,eAAiBimD,GACxDtB,EAAS0C,WAAarB,EAAUhmD,OAAO,eAAiBmmD,GAqC5DC,IACA3B,EAAwBE,EAASgC,UAAW,IAAKhC,EAASxhD,MAAMuY,KAChE+oC,EAAwBE,EAASgC,UAAW,IAAKhC,EAASvhD,MAAMsY,KAChEipC,EAASgC,UAAUzmD,UAAU,KACxB+a,KAAI,SAASxb,GAAK,OAAOA,EAAE,MAC3By1B,KAAKld,EAAQyvC,SAGtB9C,EAASuC,OACJ/mD,MAAM,OAAQ,QACdsrB,QAAQ,SAAS,GAEtBk5B,EAASwC,OACJhnD,MAAM,OAAQ,QACdsrB,QAAQ,SAAS,GAG1B,SAASi8B,EAAmBlG,EAAQ/4C,GAChC,GAAI+4C,EAAJ,CAEA,IAAImG,EAAqB,GAgBzB,IAAI,IAAIhiD,KAdR67C,EAAOhiD,MAAK,SAASC,GACjB,IAAIihC,EAAKjhC,EAAE,GACKN,EAAGa,OAAOC,MAEhBgJ,SACV2+C,EAAoBlnB,EAAIj4B,GACxBk/C,EAAmBjnB,IAAM,KAQhBj4B,EAAWo/C,OAIpB,IAHA,IACIC,EADcr/C,EAAWo/C,OAAOliD,GACTmiD,UAAY,GAE/BpvC,EAAI,EAAGA,EAAIovC,EAAS1hD,OAAQsS,IAAK,CACrC,IAAIqvC,EAAcD,EAASpvC,GAExBivC,EAAmBI,EAAYrnB,KAC9BqnB,EAAY9lC,KAAK/hB,UAAU,UAAU+I,WAMrD,SAAS2+C,EAAoBngB,EAAWh/B,GACpCA,EAAWu/C,UAAU9nD,UAAU,KAAOunC,GAAWx+B,SACjDR,EAAWI,MAAM7I,OAAO,QAAUyI,EAAWG,KAAO6+B,EAAY,QAAQx+B,SA3iB5E3J,QAAQ0iB,KAAO,YAEf1iB,QAAQwC,KAAO,CAAC,QAAS,SAEzBxC,QAAQ2oD,OAAS,CAAC,IAAK,KAEvB3oD,QAAQ4oD,QAAU7+B,EAAU6+B,QAE5B5oD,QAAQ6oD,UAAY9+B,EAAU8+B,UAE9B7oD,QAAQ2oB,WAAa,EAAQ,YAE7B3oB,QAAQqY,iBAAmB,EAAQ,YAEnCrY,QAAQ8oD,qBAAuB,EAAQ,YAEvC9oD,QAAQ+oD,eAAiB,EAAQ,YAEjC/oD,QAAQgpD,iBAAmB,SAAS/vC,EAAUC,GAC1C,IAOIhQ,EAAG+/C,EAAIC,EAPP7uC,EAAWnB,EAAUoB,UACrB6uC,EAAQ9uC,EAASxW,MACjBulD,EAAQ/uC,EAASvW,MACjBulD,EAAQhvC,EAASivC,UACjBC,EAAQF,EAAMxuC,OAAOR,EAASmvC,MAAQ,IACtCC,EAAO,GACPC,EAAO,GAGX,IAAIxgD,EAAI,EAAGA,EAAIqgD,EAAMziD,OAAQoC,IAAK,CAC9B,IAAIgX,EAAQqpC,EAAMrgD,GAAG2N,MAAM,KAC3B4yC,EAAKvpC,EAAM,IAAM,EACjBwpC,EAAK,IAAMxpC,EAAM,IAAM,EAI3B,IAAIhX,EAAI,EAAGA,EAAIigD,EAAMriD,OAAQoC,IAErBugD,EADJR,EAAKE,EAAMjgD,MAEPggD,GAAMjwC,EAASP,EAAQC,QAAQswC,KAAQ,IAAInqC,OACvCiL,EAAU6+B,QAAQrmD,EAAE2a,KAAKgsC,KAAKA,EAAK,KACvCG,EAAM7iD,KAAKyiD,EAAKC,GAChBK,EAAM/iD,KAAKyiD,EAAKC,GAEZQ,EAAKR,KACLQ,EAAKR,GAAM,EACX3nD,EAAI44B,WAAWivB,EAAOF,KAMlC,IAAIhgD,EAAI,EAAGA,EAAIkgD,EAAMtiD,OAAQoC,IAErBwgD,EADJR,EAAKE,EAAMlgD,MAEP+/C,GAAMhwC,EAASP,EAAQC,QAAQuwC,KAAQ,IAAIpqC,OACvCiL,EAAU6+B,QAAQtmD,EAAE4a,KAAK+rC,KAAKA,EAAK,KACvCI,EAAM7iD,KAAKyiD,EAAKC,GAChBK,EAAM/iD,KAAKyiD,EAAKC,GAEZO,EAAKR,KACLQ,EAAKR,GAAM,EACX1nD,EAAI44B,WAAWgvB,EAAOF,KAQlC,IAAIM,EAAMziD,OAAQ,CAGd,IAAI,IAAI6iD,KAFRV,EAAK,GACLC,EAAK,GACSjwC,EAAU,CACpB,GAAG8Q,EAAU8+B,UAAU3rC,KAAKysC,GAER,MADDA,EAAGtsC,OAAO,KAEjB4rC,IAAQU,EAAGlpC,OAAO,IAAMwoC,EAAGxoC,OAAO,MAClCwoC,EAAKU,KAEFT,IAAQS,EAAGlpC,OAAO,IAAMyoC,EAAGzoC,OAAO,MACzCyoC,EAAKS,GAIjBV,EAAKA,EAAKvwC,EAAQE,QAAQqwC,GAAM,IAChCC,EAAKA,EAAKxwC,EAAQE,QAAQswC,GAAM,IAChCC,EAAM3iD,KAAKyiD,GACXG,EAAM5iD,KAAK0iD,GACXG,EAAM7iD,KAAKyiD,EAAKC,KAgBxBlpD,QAAQ2iB,KAAO,SAASze,EAAIjE,EAAQ2iB,EAAgBC,GAChD,IAGI3Z,EAHAC,EAAajF,EAAGkF,YAChBiR,EAAWlR,EAAWmR,UAAUgvC,UAChChT,EAAWpyC,EAAGoyC,SAGlB,IAAIrtC,MAAM+D,QAAQ/M,GAId,IADAA,EAAS,GACLiJ,EAAI,EAAGA,EAAIotC,EAASxvC,OAAQoC,IAAKjJ,EAAOuG,KAAK0C,GAGrD,IAAIA,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAAK,CAQjC,IAPA,IAKI0gD,EALAjmD,EAAU0W,EAASnR,GACnB2gD,EAAc1gD,EAAWo/C,OAAO5kD,GAGhC2hD,EAAY,GAGRlsC,EAAI,EAAGA,EAAIk9B,EAASxvC,OAAQsS,IAAK,CACrC,IAAIilB,EAAKiY,EAASl9B,GACdhZ,EAAQi+B,EAAG,GAAGj+B,MAIfA,EAAMyD,MAAQzD,EAAM0D,QAAUH,MAKO,IAAjC1D,EAAOoH,QAAQjH,EAAMopB,QAAiBppB,EAAM0pD,UAMvCF,GACAA,EAAI,GAAGxpD,MAAMyD,MAAQ+lD,EAAI,GAAGxpD,MAAM0D,QAAUH,IACc,IAA1D,CAAC,UAAW,UAAW,UAAU0D,QAAQjH,EAAMgC,QACnB,IAA5BkjD,EAAUj+C,QAAQuiD,IAElBtE,EAAU9+C,KAAKojD,GAGnBtE,EAAU9+C,KAAK63B,IAKnBurB,EAAMvrB,GAId+mB,EAAQlhD,EAAI2lD,EAAavE,EAAW1iC,EAAgBC,KAmG5D7iB,QAAQ+iB,MAAQ,SAASC,EAAaC,EAAeC,EAAaC,GAC9D,IAGIkiC,EACAn8C,EAAG7C,EAJH0jD,EAAW5mC,EAAcolC,QAAU,GACnCyB,EAAW/mC,EAAcslC,QAAU,GACnC0B,EAAiB9mC,EAAc7I,WAAa,GAOhD,GAAG6I,EAAc4jC,sBAAwB9jC,EAAc8jC,oBACnD,IAAI1gD,KAAK0jD,GACL1E,EAAW0E,EAAS1jD,IACRqgD,WAAWrB,EAASqB,UAAU/8C,SAIlD,IAAIugD,EAAS/mC,EAAcG,MAAQH,EAAcG,KAAK,MAClD6mC,EAASlnC,EAAcK,MAAQL,EAAcK,KAAK,MAEtD,GAAG4mC,IAAUC,EACT,IAAI9jD,KAAK0jD,GACL1E,EAAW0E,EAAS1jD,IACR+jD,QAAQ/E,EAAS+E,OAAOC,UAM5C,GAAGJ,EAAepmD,OAASomD,EAAenmD,MAAO,CAC7C,IAAIwmD,EAAW5xC,EAAQ6xC,QAAQ,CAACnhD,YAAa+Z,IAC7C,IAAIja,EAAI,EAAGA,EAAIohD,EAASxjD,OAAQoC,IAAK,CACjC,IAAIshD,EAAUF,EAASphD,GACnB+Z,EAAcvK,EAAQC,QAAQ6xC,KAC9BrnC,EAAcwlB,WAAW/nC,UAAU,MAAQ4pD,EAAU,SAAS7gD,UAK1E,IAAI8gD,EAAgBtnC,EAAcG,MAAQH,EAAcG,KAAK,aACzDonC,EAAgBznC,EAAcK,MAAQL,EAAcK,KAAK,aAE7D,GAAGmnC,IAAiBC,EAGhBtC,EAAmBjlC,EAAcwnC,gBAAgB/pD,UAAU,YAAauiB,GACxEA,EAAc5Z,MAAM3I,UAAU,aAAa+I,gBACpCwZ,EAAcnE,2BAClB,GAAGirC,EAAeX,UAGrB,IAAIpgD,EAAI,EAAGA,EAAI+gD,EAAeX,UAAUxiD,OAAQoC,IAAK,CACjD,IAAI0hD,EAAeX,EAAeX,UAAUpgD,GAC5C,IAAI8gD,EAASY,GAAe,CACxB,IAAI7mD,EAAW,IAAM6mD,EAAe,KAAOA,EAAe,OAASA,EAAe,KAClFznC,EAAcwnC,gBAAgB/pD,UAAUmD,GAAU4F,SAClD2+C,EAAoBsC,EAAcznC,MAMlDnjB,QAAQ6qD,cAAgB,SAAS3mD,GAC7B,IAAIiF,EAAajF,EAAGkF,YAChB0hD,EAiCR,SAAyB5mD,GACrB,IAGIgF,EAAGkQ,EAAGgoB,EAAIikB,EAAUtiD,EAAIC,EAHxBmG,EAAajF,EAAGkF,YAChB2hD,EAAM5hD,EAAWmR,UAAUgvC,UAC3BxgD,EAAMiiD,EAAIjkD,OAIVkkD,EAAW,GACXxC,EAAW,GAEf,IAAIt/C,EAAI,EAAGA,EAAIJ,EAAKI,IAAK,CACrBk4B,EAAK2pB,EAAI7hD,GACTm8C,EAAWl8C,EAAWo/C,OAAOnnB,GAC7Br+B,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAEd,IAAImnD,EAAMloD,EAAGmoD,UACTC,EAAMnoD,EAAGkoD,UACTlE,EAAWiE,EAAI7uC,IAAM+uC,EAAI/uC,IACzB6qC,EAAe99C,EAAWo/C,OAAOvB,GACrC3B,EAASmD,SAAW,GAEjBxB,IAAa5lB,GAAM6lB,GAClB5B,EAAS2B,SAAWA,EACpB3B,EAAS4B,aAAeA,EACxBuB,EAAShiD,KAAK46B,KAEdikB,EAAS2B,cAAW/7C,EACpBo6C,EAAS+F,kBAAengD,EACxB+/C,EAASxkD,KAAK46B,IAKtB,IAAIl4B,EAAI,EAAGA,EAAIs/C,EAAS1hD,OAAQoC,IAC5Bk4B,EAAKonB,EAASt/C,IACdm8C,EAAWl8C,EAAWo/C,OAAOnnB,IACpB6lB,aAAauB,SAAShiD,KAAK6+C,GAIxC,IAAIgG,EAAaL,EAASnwC,OAAO2tC,GAC7BsC,EAAc,IAAI7hD,MAAMH,GAE5B,IAAII,EAAI,EAAGA,EAAIJ,EAAKI,IAAK,CACrBk4B,EAAKiqB,EAAWniD,GAChBm8C,EAAWl8C,EAAWo/C,OAAOnnB,GAC7Br+B,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAId,IAAI3D,EAAI,CAACihC,EAAIr+B,EAAGo+B,MAAOn+B,EAAGm+B,MAAOp+B,EAAG2Z,YAAc,GAAI1Z,EAAG0Z,YAAc,IACvE,IAAItD,EAAI,EAAGA,EAAIisC,EAASmD,SAAS1hD,OAAQsS,IACrCjZ,EAAEqG,KAAK6+C,EAASmD,SAASpvC,GAAGgoB,IAEhC0pB,EAAY5hD,GAAK/I,EAGrB,OAAO2qD,EA5FWQ,CAAgBpnD,GAE9BqnD,EAAgBpiD,EAAWwhD,gBAAgB/pD,UAAU,YACpD4E,KAAKslD,EAAatqC,QAEvB+qC,EAAc3hD,QAAQC,OAAO,KACxBrH,KAAK,SAAS,SAASrC,GAAK,MAAO,WAAaA,EAAE,MAEvDorD,EAAcvM,QAEduM,EAAc7hD,OACT3I,KAAKqnD,EAAoBj/C,GAE9BoiD,EAAcrrD,MAAK,SAASC,GACxB,IAAIihC,EAAKjhC,EAAE,GACPklD,EAAWl8C,EAAWo/C,OAAOnnB,GAEjCikB,EAASqB,UAAY7mD,EAAGa,OAAOC,MAC/B8lD,EAAiBviD,EAAImhD,GAKrBA,EAASmG,UAAY/gD,EAAatB,EAAWu/C,UAAW,IAAKtnB,OAIrEphC,QAAQyrD,UAAY,SAASvnD,EAAImhD,EAAUC,GACvCmB,EAAiBviD,EAAImhD,GACrBD,EAAQlhD,EAAImhD,EAAUC,GACtB17B,EAAM/oB,MAAMqD,IA8MhBlE,QAAQ0rD,MAAQ,SAASxnD,GACrB,IAAIynD,EAAYznD,EAAGkF,YAAYwiD,UAC3BC,EAAOhsD,EAAGa,OAAOwD,GAAItD,UAAU,kBACpBirD,EAAKnQ,QAAO,SAASv7C,EAAG+I,GAAI,OAAOA,IAAM2iD,EAAK3pD,OAAS,KACjEtB,UAAU,wCAkBNV,MAhBT,WACI,IACI4rD,EADSnrD,KACUorD,UAAU,aACrBJ,EAAU9hD,OAAO,aAEvBrH,KAAK,CACPwpD,MAAOvqD,EAAgBgiB,IACvB,aAAcqoC,EACdG,oBAAqB,OACrB3pD,EAAG,EACHC,EAAG,EACHwC,MAVSpE,KAUKoE,MACd4P,OAXShU,KAWMgU,aAO3B3U,QAAQksD,SAAW,EAAQ,YAAoBA,U,8CC3lB/CnsD,EAAOC,QAAU,CAObqzB,YAAQpoB,EAORmoB,QAASvS,OAAOsrC,UAAY,IAQ5BrQ,WAAY,SACZE,YAAa,QACbE,OAAQ,MACRE,QAAS,KACTE,OAAQ,IACRE,OAAQ,IAMR4P,QAAS,UAKTC,aAAc,EAAI,KAMlBC,SAAU,GAMVC,WAAY,M,8CCnDhB,IAAIhrD,EAAM,EAAQ,YACd8W,EAAmB,EAAQ,YAE/BtY,EAAOC,QAAU,SAAiCiZ,EAAUC,EAAWC,GACnE,SAAS6B,EAAOxY,EAAM4B,GAElB,YAAuB6G,IAApBiO,EAAU1W,GAA4B0W,EAAU1W,GAE5CjB,EAAIyZ,OAAO/B,EAAUC,EAAWb,EAAkB7V,EAAM4B,GAGnE,IAEIooD,EAFAC,EAAYzxC,EAAO,aAcvB,OAXG9B,EAAUoK,KAAK,aACXmpC,EAAUplD,QAAQ,WAAa,EAC9BmlD,EAAgB,WAIhBtzC,EAAUwzC,SAQtB,SAAiBvzC,EAAUhQ,GAGvB,IAFA,IAAIwjD,EAAYxjD,EAAWyjD,mBAAqB,GAExC1jD,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK,CACrC,IAAI9I,EAAQ+Y,EAASjQ,GACjBvF,EAAUvD,EAAMyD,MAAQzD,EAAM0D,MAE9B+oD,GADmBF,EAAUhpD,IAAY,IACZvD,EAAM0sD,aAAe,GAEtD,GAAyB,MAAtB1sD,EAAM+Z,aAAiD,MAA1B0yC,EAAU1yC,YACtC,OAAO,EAIf,OAAO,EAtBsB4yC,CAAQ5zC,EAAUD,GACvCszC,EAAgBtzC,EAAUwzC,SAAW,IAAM,KAE5CF,EAAgB,UAEhBxxC,EAAO,YAAawxC,K,8CCzB/B,IAAI3sD,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YACpByoB,EAAQ,EAAQ,YAEhBvoB,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdC,EAAe,EAAQ,YACvBwrD,EAAS,EAAQ,YACjBltD,EAAQ,EAAQ,YAChB+pB,EAAU,EAAQ,YAElBojC,EAAU,EAAQ,YAClBrnC,EAAa,EAAQ,YAErBmE,EAAY,EAAQ,YACpB+xB,EAAa/xB,EAAU+xB,WACvBE,EAAcjyB,EAAUiyB,YACxBE,EAASnyB,EAAUmyB,OACnBE,EAAUryB,EAAUqyB,QACpBE,EAASvyB,EAAUuyB,OACnBE,EAASzyB,EAAUyyB,OACnB+P,EAAaxiC,EAAUwiC,WACvBl5B,EAAStJ,EAAUsJ,OAEnB2e,EAAqB,EAAQ,YAC7Bkb,EAAYlb,EAAmBkb,UAC/BC,EAAYnb,EAAmBmb,UAC/BzrD,EAAeswC,EAAmBtwC,aAClC0rD,EAAgBpb,EAAmBob,cAEnCC,EAAOttD,EAAOC,QAAU,GAE5BqtD,EAAKC,WAAa,EAAQ,YAC1B,IAAIC,EAAW,EAAQ,YAEnB70C,EAAU,EAAQ,YACtB20C,EAAK10C,QAAUD,EAAQC,QACvB00C,EAAKz0C,QAAUF,EAAQE,QACvBy0C,EAAKG,QAAU90C,EAAQ80C,QACvBH,EAAK7wC,KAAO9D,EAAQ8D,KACpB6wC,EAAK9C,QAAU7xC,EAAQ6xC,QACvB8C,EAAKtlB,UAAYrvB,EAAQqvB,UACzBslB,EAAKI,aAAe/0C,EAAQ+0C,aAE5B,IAAIhuC,EAAY,EAAQ,YACxB4tC,EAAKK,aAAejuC,EAAUiuC,aAC9BL,EAAKM,aAAeluC,EAAUkuC,aAa9BN,EAAKO,UAAY,SAAS/nC,EAAaC,EAAc5hB,EAAI1B,EAAM4B,EAAMypD,GACjE,IAAI1yC,EAAW3Y,EAAK6a,OAAO7a,EAAKsE,OAAS,GACrCgnD,EAAS5pD,EAAGkF,YAAYkR,UAAUa,EAAW,QAC7C4yC,EAAUvrD,EAAO,MACjBwrD,EAAU,GAcd,OAZI5pD,IAAMA,EAAO0pD,EAAO,IAAMD,GAC1BA,IAAaA,EAAczpD,GAI/B4pD,EAAQD,GAAW,CACfjO,QAAS,aACTG,OAAQ6N,EAAOjzC,OAAOgzC,EAAc,CAACA,GAAe,IACpDzpD,KAAMA,GAIH7C,EAAIyZ,OAAO6K,EAAaC,EAAckoC,EAASD,IAyB1DV,EAAKY,eAAiB,SAASnoC,EAAc5hB,EAAI8W,EAAQ2xB,EAAOnqC,EAAM4B,GAClE,IAAI8pD,EAAUt8C,EAEd,GAAa,UAAV+6B,GAA+B,UAAVA,EACpBuhB,EAAW3sD,EAAI84B,aACfzoB,EAAMoJ,EAAOxY,EAAM4B,OAChB,CACH,IAAIyoC,EAAKwgB,EAAKtlB,UAAU7jC,EAAIyoC,GAE5B/6B,EAAMoJ,EAAOxY,EADb4B,EAAOyoC,EAAGshB,WAAW/pD,IAErB8pD,EAAWrhB,EAAGqhB,SAGlBpoC,EAAatjB,GAAQ0rD,EAASt8C,IAGlCy7C,EAAKe,cAAgB,SAASx8C,EAAK1N,EAAIyoC,GAKnC,OAJ0B,UAAVA,GAA+B,UAAVA,EACjCprC,EAAI84B,aACJgzB,EAAKtlB,UAAU7jC,EAAIyoC,GAAOuhB,UAEdt8C,IAGpBy7C,EAAKgB,iBAAmB,SAASnqD,EAAIoqD,GACjCA,EAAQA,GAAgBjB,EAAK9C,QAAQrmD,GAErC,IAAIiF,EAAajF,EAAGkF,YAEpB,SAASmlD,EAAeC,EAAYC,EAAYC,EAAWC,GAIvD,IAHA,IAAIvgC,EAAS/sB,EAASyX,mBAAmB01C,EAAYC,GACjDG,EAAQ,GAEJ1lD,EAAI,EAAGA,EAAIolD,EAAMxnD,OAAQoC,IAI7B,IAHA,IACIyX,EADKxX,EAAWkkD,EAAK10C,QAAQ21C,EAAMplD,KACtBwlD,GAETt1C,EAAI,EAAGA,EAAIuH,EAAQ7Z,OAAQsS,IAAK,CACpC,IAAIy1C,EAAMluC,EAAQvH,GAElB,IAAIw1C,EAAMC,KACNzgC,EAAOlqB,EAAI2qD,GACXD,EAAMC,GAAO,EAEVF,GAAc,QAQjCJ,EAAe,cAAe,UAAW,eACzCA,EAAe,SAAU,UAAW,iBACpCA,EAAe,SAAU,OAAQ,eAAe,IAGpD,IAAIO,EAAqBzB,EAAKyB,mBAAqB,SAAS5qD,EAAI9D,EAAOw/B,EAAQmvB,GAC3E,IAAIliB,EAIAmiB,EAAwB,MAAXpvB,GAA6B,MAAXA,GAA6B,MAAXA,EACjDA,EACAmvB,EAKJ,GAAG9lD,MAAM+D,QAAQgiD,IAQb,GAPAniB,EAAK,CACDlkC,KAAM4kD,EAASwB,GACfE,YAAa,IAEjB5B,EAAKC,WAAWzgB,GAGD,aAAZA,EAAGlkC,KACF,IAAI,IAAIO,EAAI,EAAGA,EAAI6lD,EAAYjoD,OAAQoC,IACnC2jC,EAAG8R,IAAIoQ,EAAY7lD,SAK3B2jC,EAAKwgB,EAAKI,aAAavpD,EAAI9D,EAAO4uD,GAKtC,OAAGniB,EAAW,CAAC8R,IAAK9R,EAAG8R,IAAKnB,IAAK3Q,EAAG2Q,KAInB,QAAdwR,EAA4B,CAACrQ,IAAKt2B,EAAUm1B,IAAKn1B,GAK7C,CAACs2B,IAAKuQ,EAAO1R,IAAK0R,IAG7B,SAASA,EAAM/nD,GAAK,OAAQA,EAC5B,SAASkhB,EAASlhB,GAAK,OAAOqZ,OAAOrZ,GAErCkmD,EAAK8B,mBAAqB,SAASjrD,EAAI9D,EAAOw/B,EAAQmvB,GAClD,OAAOD,EAAmB5qD,EAAI9D,EAAOw/B,EAAQmvB,GAAapQ,KAK9D0O,EAAK+B,cAAgB,SAAShuB,GAC1B,IAAIjmB,EAAWimB,EAAG/jB,OAAO,GACzB,MAAgB,MAAblC,EAAyB,IACZ,MAAbA,EAAyB,SAA5B,GAOJkyC,EAAKgC,SAAW,SAASxiB,EAAIyiB,EAASC,EAAUC,IAGkB,IAA3D,CAAC,MAAO,WAAY,iBAAiBnoD,QAAQwlC,EAAGlkC,OAAiB6mD,OAEzCvkD,IAAjB4hC,EAAG4iB,WAGT5iB,EAAG4iB,UAAYH,EACfziB,EAAG6iB,YAAcH,GACX1iB,EAAG4iB,aACL5iB,EAAG4iB,UAAYH,EAAU,MAAQ,EAAI,QAK9BC,EAAW1iB,EAAG6iB,aAAeJ,EAAU,EACtC,UAAY,EAAI,MACxBziB,EAAG4iB,UAAYH,EACfziB,EAAG6iB,YAAcH,KACVD,EAAUziB,EAAG4iB,UAAY,MAAQ,EAAI,QAKrCF,EAAW1iB,EAAG6iB,aAAe7iB,EAAG4iB,UAAY,EAC3C,UAAY,EAAI,QACxB5iB,EAAG4iB,UAAY,IAvBnB5iB,EAAG4iB,UAAY,GA8BvBpC,EAAKsC,iBAAmB,SAASzrD,EAAI0rD,GAIjC,IAHA,IAAIC,EAASxC,EAAK7wC,KAAKtY,EAAI,IAAI,GAC3B4rD,GAAoB,EAEhB5mD,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CACnC,IAAI2jC,EAAKgjB,EAAO3mD,GACZ6mD,OAA8B9kD,IAArB4hC,EAAGmjB,cACZC,EAAaF,KACbljB,EAAGntB,MAAM,KAAOmtB,EAAGmjB,cAAc,IACjCnjB,EAAGntB,MAAM,KAAOmtB,EAAGmjB,cAAc,KAGjCD,IAA0B,IAAjBljB,EAAGptB,WAAyBmwC,GAAaK,KAClDpjB,EAAGmjB,cAAgBnjB,EAAGntB,MAAMC,QAC5BmwC,GAAoB,GAI5B,OAAOA,GAIXzC,EAAK6C,qBAAuB,SAAShsD,EAAI0rD,GAKrC,IAJA,IAAIC,EAASxC,EAAK7wC,KAAKtY,EAAI,IAAI,GAC3B4rD,GAAoB,EACpBK,EAAmB,KAEfjnD,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CACnC,IAAI2jC,EAAKgjB,EAAO3mD,GACZ6mD,OAAkC9kD,IAAzB4hC,EAAGujB,kBACZH,EAAaF,KAAWljB,EAAGwjB,aAAexjB,EAAGyjB,cAE9CP,GAAUH,GAAaK,KACtBpjB,EAAGujB,kBAAoBvjB,EAAGwjB,WAC1BP,GAAoB,GAGA,OAArBK,GAA8BtjB,EAAGwjB,aAChCF,EAAmB,OAI3B,OADAjsD,EAAGkF,YAAYmnD,wBAA0BJ,EAClCL,GAGXzC,EAAKmD,QAAU,SAAShrD,EAAMqnC,EAAI4jB,EAAOC,EAAM9yC,EAAU1b,GACrD,IAeIyuD,EAfAC,EAAUrvD,EAAIw0B,QAAQxxB,KAAKi3B,IAAK,KAAMh2B,GACtCqrD,EAAUtvD,EAAIw0B,QAAQxxB,KAAKc,IAAK,KAAMG,GAE1C,GAAe,aAAZqnC,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,KAC5B,MAAO,CACHoH,MAAO6gD,EAAU,GACjB5gD,IAAK6gD,EAAU,GACf3uD,KAAMqC,KAAKc,IAAI,EAAGd,KAAKC,MAAMtC,IAAS,GACtC4uD,UAAWD,EAAUD,GAwB7B,GApBIhzC,IAAUA,EAAWivB,EAAGjvB,UAKxB+yC,EADW,QAAZ9jB,EAAGlkC,KACQ,CACNA,KAAM,SACN+W,MAAO,CAACkxC,EAASC,IAGX,CACNloD,KAAMkkC,EAAGlkC,KACT+W,MAAOne,EAAImZ,UAAU,CAACk2C,EAASC,GAAUhkB,EAAGkkB,IAAK,EAAGnzC,GACpDA,SAAUA,GAGlByvC,EAAKC,WAAWqD,GAEhBzuD,EAAOA,GAAQ0jB,EAAWU,MAAMpkB,EAAMyuD,EAAQhoD,MAG1CgoD,EAAQrqC,MAAQpkB,EAChByuD,EAAQpqC,MAAQX,EAAWW,WAAMtb,EAAW0lD,EAAQhoD,KAAMiV,OACvD,CACH,IAAIozC,EACJ,GAAGP,EAAOO,GAAUH,EAAUD,GAAWH,MACpC,CAKD,IAAIQ,EAAe1vD,EAAIm0B,aAAalwB,GAChC0rD,EAAQ3sD,KAAKuO,IAAI,GAAIvO,KAAKgD,MAC1BhD,KAAKk0B,IAAIw4B,EAAaE,SAAW5sD,KAAK44C,OACtCiU,EAAUF,EAAQ3vD,EAAIo0B,QACtBs7B,EAAaE,QAAUD,EAAO,CAAC,GAAK,IAAK,IAAK,MAAM,GACxDF,EAAQzsD,KAAKc,IAAI+rD,EAAS,EAAI7vD,EAAI60B,MAAM5wB,GACpCjB,KAAKuO,IAAItN,EAAKsB,OAAQ4pD,EAAO,IAAO,KAKpCvvD,EAAU6vD,KAAQA,EAAQ,GAGlC3D,EAAKgE,UAAUV,EAASK,GAG5B,IAGIM,EAHAC,EAAYZ,EAAQrqC,MACpBkrC,EAAWnE,EAAK5Q,cACZ4Q,EAAKoE,UAAUd,GAAUY,EAAW,UAAW3zC,GAMvD,GAAwB,iBAAd2zC,EAIND,GAHAE,EAiCR,SAA8BA,EAAUhsD,EAAMqnC,EAAI+jB,EAASC,GACvD,IAAIa,EAAY,EACZC,EAAW,EACXC,EAAW,EACXC,EAAa,EAEjB,SAASC,EAAS3qD,GAEd,OAAQ,EAAqB,KAAhBA,EAAIqqD,GAAkB3kB,EAAGvmB,OAAS,IAAM,EAGzD,IAAI,IAAIpd,EAAI,EAAGA,EAAI1D,EAAKsB,OAAQoC,IACzB1D,EAAK0D,GAAK,GAAM,EAAG0oD,IACbzwD,EAAUqE,EAAK0D,KAAK2oD,IAE1BC,EAAStsD,EAAK0D,KAAKwoD,IACnBI,EAAStsD,EAAK0D,GAAK2jC,EAAGvmB,MAAQ,IAAIqrC,IAEzC,IAAII,EAAYvsD,EAAKsB,OAAS+qD,EAE9B,GAAGD,IAAaG,GAAyB,SAAZllB,EAAGlkC,KACzBkkC,EAAGvmB,MAAQ,EAMVkrC,EAAWZ,EAAU,GAAM/jB,EAAGvmB,OAM9BkrC,GAAY,IACE3kB,EAAGvmB,MAAQsqC,IAASY,GAAY3kB,EAAGvmB,YAElD,GAAGqrC,EAAuB,GAAZI,IACdL,EAAwB,GAAZK,GACPD,EAASlB,IAAYkB,EAASjB,IAAU,CAG5C,IAAImB,EAAWnlB,EAAGvmB,MAAQ,EAC1BkrC,GAAaA,EAAWQ,EAAWpB,EAAWoB,GAAYA,EAGlE,OAAOR,EA9EQS,CAAqBT,EAAUhsD,EAAMmrD,EAASC,EAASC,KAEvD,EAAItsD,KAAKgD,OAAOspD,EAAUW,GAAYD,IAClBA,OAe/B,IAR+B,MAA5BZ,EAAQrqC,MAAMjJ,OAAO,KACpBm0C,EAuEZ,SAA4BA,EAAUhsD,EAAM8gB,EAAOsqC,EAAShzC,GACxD,IAAIs0C,EAAQ3wD,EAAI4zB,eAAe3vB,EAAMoY,GAKrC,GAAGs0C,EAAMC,UAFO,GAEgB,CAC5B,IAAIC,EAAYvxC,OAAOyF,EAAM7F,OAAO,IAEhCyxC,EAAMG,WALE,IAK0BD,EAAY,IAAO,EAIrDZ,EAAWnE,EAAK5Q,cAAc+U,EAAU,KAAM,WAAsB,IAATtV,EACrDgW,EAAMI,YAVJ,GAeRd,EAAWnE,EAAK5Q,cAAc+U,EAAU,KAAM,WAAsB,KAATtV,EAM3DsV,GAAYtV,EAAS,EAEzB,IAAIqW,EAAelF,EAAK5Q,cAAc+U,EAAUlrC,GAEhD,GAAGisC,GAAgB3B,EAAS,OAAO2B,EAEvC,OAAOf,EAtGYgB,CAAmBhB,EAAUhsD,EAAM+rD,EAAWX,EAAShzC,IAKtE0zC,EAASE,EACE,EACLF,GAAUT,GACZS,EAASjE,EAAK5Q,cAAc6U,EAAQC,GAAW,EAAO3zC,GAK9D,MAAO,CACH7N,MAAO88B,EAAGkkB,IAAIS,EAAU,EAAG5zC,GAC3B5N,IAAK68B,EAAGkkB,IAAIO,EAAQ,EAAG1zC,GACvB1b,KAAMqvD,EACNT,UAAWD,EAAUD,IA6F7BvD,EAAKoF,UAAY,SAAS5lB,GACtB,IAAIrtB,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KAGrC,GAAmB,SAAhB7lB,EAAG3mB,WAAwB2mB,EAAGvmB,MAAO,CACpC,IACIqsC,EADAC,EAAK/lB,EAAGgmB,OAGRD,IACe,aAAZ/lB,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,MAC5BgqD,EAAQ9lB,EAAGimB,SAAsC,KAA1BjmB,EAAGimB,SAAS5wD,MAAQ,IAAY,GACvD0wD,EAAK/lB,EAAGhH,QAAU8sB,IAElBA,EAA6B,MAArB9lB,EAAGzwB,IAAIiB,OAAO,GAAa,GAAK,GACxCu1C,EAAKrxD,EAAI85B,UAAUwR,EAAGhH,QAAU8sB,EAAO,EAAG,GAAK,GAKnC,eAAb9lB,EAAG3wB,QAAwB02C,GAAM,IAKrB,UAAhB/lB,EAAG3mB,WAAsB0sC,GAAM,KAGlC/lB,EAAGkmB,aAAexuD,KAAK6/B,IAAI5kB,EAAI,GAAKA,EAAI,KAAOqtB,EAAGmmB,UAAY,IAAMJ,EACpEvF,EAAKgE,UAAUxkB,EAAIA,EAAGkmB,aAGnBlmB,EAAG4iB,UAAY,GAAK5iB,EAAGvmB,MAAuB,EAAfumB,EAAG4iB,YACjC5iB,EAAGvmB,MAAQumB,EAAG4iB,UACd5iB,EAAGtmB,MAAQsmB,EAAGomB,IAAIpmB,EAAG6iB,cAKzB7iB,EAAGtmB,QACHsmB,EAAGtmB,MAAqB,SAAZsmB,EAAGlkC,KAAmB,aAAe,GAKtC,SAAZkkC,EAAGlkC,MAAmBkkC,EAAGvmB,MAAQ,KAAKumB,EAAGvmB,MAAQ,IAGpD4sC,EAAcrmB,IAOlBwgB,EAAK8F,UAAY,SAAmBtmB,GAChCwgB,EAAKoF,UAAU5lB,GACf,IAAIrtB,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KAIrC,GAAmB,UAAhB7lB,EAAG3mB,SAAsB,OA8HhC,SAAoB2mB,GAChB,IAAIyS,EAAOzS,EAAGumB,SACVliD,EAAO27B,EAAGwmB,SACVC,EAAW,IAAIrqD,MAAMq2C,EAAKx4C,QAC1B0Y,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KACjCa,EAAsB,OAAT/zC,EAAI,GAAuB,KAATA,EAAI,GACnCg0C,EAAsB,OAATh0C,EAAI,GAAuB,KAATA,EAAI,GACnCi0C,EAAUlvD,KAAKi3B,IAAI+3B,EAAYC,GAC/BE,EAAUnvD,KAAKc,IAAIkuD,EAAYC,GAC/Bp6C,EAAI,EAIJnQ,MAAM+D,QAAQkE,KAAOA,EAAO,IAIhC,IAAIyiD,EAAwB,aAAZ9mB,EAAGlkC,KAAsBkkC,EAAG+mB,UAAY/mB,EAAGgnB,IAI5C,QAAZhnB,EAAGlkC,MAAiD,MAA/B6X,OAAOqsB,EAAGvmB,OAAOjJ,OAAO,KAC5CwvB,EAAGvmB,MAAQ,IAAM/hB,KAAKuO,IAAI,GAAIvO,KAAKgD,MAAMhD,KAAKi3B,IAAIqR,EAAGntB,MAAM,GAAImtB,EAAGntB,MAAM,KAAO,IAGnF,IAAI,IAAIxW,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IAAK,CACjC,IAAI4qD,EAAOH,EAAUrU,EAAKp2C,IACvB4qD,EAAOL,GAAWK,EAAOJ,SACTzoD,IAAZiG,EAAKhI,GAAkBoqD,EAASl6C,GAAKi0C,EAAK0G,SAASlnB,EAAIinB,GACrDR,EAASl6C,GAAK46C,EAAYnnB,EAAIinB,EAAMtzC,OAAOtP,EAAKhI,KACrDkQ,KAILA,EAAIkmC,EAAKx4C,QAAQwsD,EAAStzC,OAAO5G,EAAGkmC,EAAKx4C,OAASsS,GAElDyzB,EAAGonB,cAEFX,EAAWA,EAAS5X,QAAO,SAASv7C,GAChC,OAAO0sC,EAAGqnB,WAAW/zD,EAAEmC,KAAO+wB,MAItC,OAAOigC,EAzK4Ba,CAAWtnB,GAG9CA,EAAGunB,MAAQ/G,EAAKoE,UAAU5kB,GAG1B,IAAIwnB,EAAqB,OAAT70C,EAAI,GAAuB,KAATA,EAAI,GAClC80C,EAAmB,OAAT90C,EAAI,GAAuB,KAATA,EAAI,GAEhC+0C,EAAS/0C,EAAI,GAAKA,EAAI,GAI1B,GAAIqtB,EAAGunB,MAAQC,IAAeE,EAAO,MAAO,GAG7B,aAAZ1nB,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,OAC5B2rD,EAAU,EAAU/vD,KAAKc,KAAK,GAAKivD,GAC/B/vD,KAAKi3B,IAAIqR,EAAGoiB,YAAYnoD,OAAS,GAAKwtD,IAG9C,IAEIE,EAFAC,EAAsB,QAAZ5nB,EAAGlkC,QAAqBxH,EAAU0rC,EAAGvmB,QAAiC,MAAvBumB,EAAGvmB,MAAMjJ,OAAO,IA6B7E,GA1BA,WACI,IAAIq3C,EAAY,KACZC,EAAWpwD,KAAKc,IAAI,IAAMwnC,EAAGhH,SAAW,GAC5C2uB,EAAW,GACX,IAAI,IAAIlyD,EAAIuqC,EAAGunB,OACP,EAAW9xD,GAAKgyD,EAAYhyD,GAAKgyD,MAIlCE,EAAS1tD,OAAS6tD,GAAYryD,IAAMoyD,GAHnCpyD,EAAI+qD,EAAK5Q,cAAcn6C,EAAGuqC,EAAGvmB,MAAOiuC,EAAO1nB,EAAGjvB,UAAW,CAI7D82C,EAAYpyD,EAEZ,IAAIsyD,GAAQ,EACTH,GAAWnyD,KAAW,EAAJA,KACjBsyD,GAAQ,GAGZJ,EAAShuD,KAAK,CACVouD,MAAOA,EACPtzB,MAAOh/B,KAKnBuyD,GAEGhoB,EAAGonB,YAAa,CAEf,GAAmB,SAAhBpnB,EAAG3mB,SACF,IAAI,IAAIxO,EAAI,EAAGA,EAAI88C,EAAS1tD,OAAQ4Q,IAAK,CACrC,IAAI4pB,EAAQkzB,EAAS98C,GAAG4pB,MACxB,GAAGuL,EAAGqnB,WAAW5yB,KAAWjO,EAExB,IAAI,IAAIhtB,EAAI,EAAGA,EAAIwmC,EAAGioB,aAAahuD,OAAQT,IAAK,CAC5C,IAAI0uD,EAAMloB,EAAGioB,aAAazuD,GAC1B,GAAGi7B,GAASyzB,EAAIv5B,KAAO8F,EAAQyzB,EAAI1vD,IAAK,CACpCmvD,EAAS98C,GAAG4pB,MAAQyzB,EAAI1vD,IACxB,QAQpB,IAAIyD,EAAM0rD,EAAS1tD,OACnB,GAAGgC,EAAM,EAAG,CASR,IARA,IAGIksD,EAHAC,EAAM,GAAKpoB,EAAGimB,SAAWjmB,EAAGimB,SAAS5wD,KAAO,IAE5CgzD,EAAc,GAGdtS,EAAM2R,EAAQ,GAAK,EAEnBY,EAAOZ,EAAQzrD,EAAM,EAAI,EACrBssD,EAFIb,EAAQ,EAAIzrD,EAAM,EAEX85C,EAAMwS,GAAKxS,EAAMuS,EAAMC,GAAKxS,EAAK,CAChD,IAAIhxC,EAAMi7B,EAAG5pC,IAAIuxD,EAASY,GAAG9zB,aAEdr2B,IAAZ+pD,GAAyBzwD,KAAK6/B,IAAIxyB,EAAMojD,GAAWC,KAClDD,EAAUpjD,EACVsjD,EAAY1uD,KAAKguD,EAASY,KAGlCZ,EAAWU,EAAY1V,WAM5B6V,GAAUxoB,IAAqC,MAA9BtoC,KAAK6/B,IAAI5kB,EAAI,GAAKA,EAAI,KACtCg1C,EAAS5yC,MAKbirB,EAAGyoB,OAASd,EAASA,EAAS1tD,OAAS,IAAM,IAAIw6B,MAMjDuL,EAAG0oB,cAAgB,GACnB1oB,EAAG2oB,cAAe,EAGlB,IADA,IAAIlC,EAAW,IAAIrqD,MAAMurD,EAAS1tD,QAC1BoC,EAAI,EAAGA,EAAIsrD,EAAS1tD,OAAQoC,IAAK,CACrC,IAAIusD,EAASjB,EAAStrD,GAAG0rD,MACrBc,EAASlB,EAAStrD,GAAGo4B,MAEzBgyB,EAASpqD,GAAKmkD,EAAK0G,SACflnB,EACA6oB,GACA,EACAD,GAMR,OAFA5oB,EAAG2oB,cAAe,EAEXlC,GAiDX,IAAIqC,EAAc,CAAC,EAAG,EAAG,IACrBC,EAAc,CAAC,EAAG,EAAG,EAAG,EAAG,IAC3BC,EAAc,CAAC,EAAG,EAAG,EAAG,GAAI,GAAI,IAEhCC,EAAY,CAAC,EAAG,EAAG,EAAG,EAAG,IAGzBC,EAAY,EAAE,KAAO,EAAG,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,KAAO,GAChFC,EAAY,EAAE,KAAO,EAAG,KAAO,KAAO,GAEtCC,EAAc,CAAC,GAAI,GAAI,GAAI,GAAI,KAEnC,SAASC,EAAWC,EAAYjvD,EAAMkvD,GAClC,OAAOlvD,EAAO3F,EAAIo0B,QAAQwgC,EAAajvD,EAAMkvD,GA6GjD,SAASlD,EAAcrmB,GACnB,IAAIvmB,EAAQumB,EAAGvmB,MAUf,GARAumB,EAAGwpB,cAAgB,EACfl1D,EAAUmlB,IAA2B,iBAAVA,IAC3BA,EAAQ,GAGG,aAAZumB,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,OAC5BkkC,EAAGypB,WAAa,MAEL,SAAZzpB,EAAGlkC,KAAiB,CAKnB,IAAI4tD,EAAU1pB,EAAG6lB,IAAI7lB,EAAGtmB,OACpBiwC,EAAW3pB,EAAGomB,IAAIsD,GAASjvD,QAAQ,UAAW,IAC9CmvD,EAAWD,EAAS1vD,OAExB,GAA+B,MAA5B0Z,OAAO8F,GAAOjJ,OAAO,GAEjBo5C,EAAW,IAA6B,UAAvBD,EAAS/1C,OAAO,GAAgBosB,EAAGypB,WAAa,IAE/DzpB,EAAGypB,YAAgBhwC,EAAM7F,OAAO,GAAM,IAAO,EAAK,IAAM,SAC1D,GAAI6F,GAAS41B,GAAUua,GAAY,IAAQnwC,GAAkB,GAAT41B,EAAcrP,EAAGypB,WAAa,SACpF,GAAIhwC,GAASg2B,GAAUma,GAAY,IAAQnwC,GAAS81B,EAAUvP,EAAGypB,WAAa,SAC9E,GAAIhwC,GAASk2B,GAAUia,GAAY,IAAQnwC,GAASg2B,EAASzP,EAAGypB,WAAa,QAC7E,CAID,IAAII,EAAW7pB,EAAGomB,IAAIsD,EAAUjwC,GAAOhf,QAAQ,KAAM,IAAIR,OACzD+lC,EAAGypB,WAAa/xD,KAAKc,IAAIoxD,EAAUC,GAAY,GAK5C7pB,EAAGypB,WAAa,IAAGzpB,EAAGypB,WAAa,SAEvC,GAAGn1D,EAAUmlB,IAA8B,MAApBA,EAAMjJ,OAAO,GAAY,CAEnD,IAAImC,EAAMqtB,EAAGntB,MAAM/D,IAAIkxB,EAAG8pB,KAAO91C,QAC7B1f,EAAUmlB,KAAQA,EAAQzF,OAAOyF,EAAM7F,OAAO,KAElDosB,EAAGypB,WAAa,EAAI/xD,KAAKgD,MAAMhD,KAAKk0B,IAAInS,GAAS/hB,KAAK44C,KAAO,KAE7D,IAAIyZ,EAASryD,KAAKc,IAAId,KAAK6/B,IAAI5kB,EAAI,IAAKjb,KAAK6/B,IAAI5kB,EAAI,KACjDq3C,EAAWtyD,KAAKgD,MAAMhD,KAAKk0B,IAAIm+B,GAAUryD,KAAK44C,KAAO,KACtD54C,KAAK6/B,IAAIyyB,GAAY,IACjBC,EAAWjqB,EAAGkqB,kBAAoBC,EAASH,GAC1ChqB,EAAGwpB,cAAgB,EAAI9xD,KAAKC,OAAOqyD,EAAW,GAAK,GAChDhqB,EAAGwpB,cAAgBQ,QAI9BhqB,EAAGypB,WAAa,KA4MxB,SAAStC,EAAYnnB,EAAIvqC,EAAG4O,GACxB,IAAIc,EAAK66B,EAAGimB,UAAY,GAExB,MAAO,CACHxwD,EAAGA,EACHqO,GAAI,EACJC,GAAI,EACJM,KAAMA,GAAQ,GACdZ,SAAU0B,EAAG9P,KACbF,KAAMgQ,EAAG/P,OACT8P,UAAWC,EAAG/Q,OAxWtBosD,EAAKgE,UAAY,SAASxkB,EAAIspB,GAC1B,IAAIjvD,EAEJ,SAAS+vD,EAAQ9vD,GACb,OAAO5C,KAAKuO,IAAI3L,EAAG5C,KAAKgD,MAAMhD,KAAKk0B,IAAI09B,GAAc5xD,KAAK44C,OAG9D,GAAe,SAAZtQ,EAAGlkC,KAAiB,CACnBkkC,EAAGtmB,MAAQhlB,EAAI0zB,UAAU4X,EAAGjvB,UAG5B,IAAIs5C,EAAU,EAAIf,EAEfe,EAAUpb,GACTqa,GAAcra,EACd50C,EAAO+vD,EAAQ,IACfpqB,EAAGvmB,MAAQ,IAAO,GAAK4vC,EAAWC,EAAYjvD,EAAMyuD,IAC9CuB,EAAUlb,GAChBma,GAAcna,EACdnP,EAAGvmB,MAAQ,IAAM4vC,EAAWC,EAAY,EAAGP,IACrCsB,EAAUhb,GAChBrP,EAAGvmB,MAAQ4vC,EAAWC,EAAYja,EAAQrP,EAAGsqB,oBAAsB,CAAC,EAAG,EAAG,IAAMrB,GAKhFjpB,EAAGtmB,MAAQhlB,EAAI0zB,UAAU4X,EAAGjvB,UAAU,IAChCs5C,EAAU9a,EAChBvP,EAAGvmB,MAAQ4vC,EAAWC,EAAY/Z,EAASwZ,GACrCsB,EAAU5a,EAChBzP,EAAGvmB,MAAQ4vC,EAAWC,EAAY7Z,EAAQuZ,GACpCqB,EAAU1a,EAChB3P,EAAGvmB,MAAQ4vC,EAAWC,EAAY3Z,EAAQqZ,IAG1C3uD,EAAO+vD,EAAQ,IACfpqB,EAAGvmB,MAAQ4vC,EAAWC,EAAYjvD,EAAMyuD,SAEzC,GAAe,QAAZ9oB,EAAGlkC,KAAgB,CACzBkkC,EAAGtmB,MAAQ,EACX,IAAI/G,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KAErC,GAAGyD,EAAa,GAEZtpB,EAAGvmB,MAAQ/hB,KAAK0sB,KAAKklC,QAClB,GAAG5xD,KAAK6/B,IAAI5kB,EAAI,GAAKA,EAAI,IAAM,EAAG,CAErC,IAAIozC,EAAK,IAAMruD,KAAK6/B,KAAK5kB,EAAI,GAAKA,EAAI,IAAM22C,GAG5CA,EAAa5xD,KAAK6/B,IAAI7/B,KAAKuO,IAAI,GAAI0M,EAAI,IACnCjb,KAAKuO,IAAI,GAAI0M,EAAI,KAAOozC,EAC5B1rD,EAAO+vD,EAAQ,IACfpqB,EAAGvmB,MAAQ,IAAM4vC,EAAWC,EAAYjvD,EAAMyuD,QAK9C9oB,EAAGvmB,MAAS6vC,EAAa,GAAO,KAAO,SAEzB,aAAZtpB,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,MACnCkkC,EAAGtmB,MAAQ,EACXsmB,EAAGvmB,MAAQ/hB,KAAK0sB,KAAK1sB,KAAKc,IAAI8wD,EAAY,KACpCd,GAAUxoB,IAChBA,EAAGtmB,MAAQ,EACXrf,EAAO,EACP2lC,EAAGvmB,MAAQ4vC,EAAWC,EAAYjvD,EAAM+uD,KAGxCppB,EAAGtmB,MAAQ,EACXrf,EAAO+vD,EAAQ,IACfpqB,EAAGvmB,MAAQ4vC,EAAWC,EAAYjvD,EAAMyuD,IAO5C,GAHgB,IAAb9oB,EAAGvmB,QAAaumB,EAAGvmB,MAAQ,IAG1BnlB,EAAU0rC,EAAGvmB,QAA8B,iBAAbumB,EAAGvmB,MAAoB,CACrD,IAAI8wC,EAAWvqB,EAAGvmB,MAElB,MADAumB,EAAGvmB,MAAQ,EACL,mBAAqB9F,OAAO42C,KA2E1C/J,EAAK5Q,cAAgB,SAASn6C,EAAGgkB,EAAOiuC,EAAO32C,GAC3C,IAAIy5C,EAAS9C,GAAS,EAAI,EAG1B,GAAGpzD,EAAUmlB,GAAQ,OAAOhkB,EAAI+0D,EAAS/wC,EAGzC,IAAIgxC,EAAQhxC,EAAMjJ,OAAO,GACrBk6C,EAAWF,EAASx2C,OAAOyF,EAAM7F,OAAO,IAG5C,GAAa,MAAV62C,EAAe,OAAO/1D,EAAIyzB,eAAe1yB,EAAGi1D,EAAU35C,GAGpD,GAAa,MAAV05C,EAAe,OAAO/yD,KAAKk0B,IAAIl0B,KAAKuO,IAAI,GAAIxQ,GAAKi1D,GAAYhzD,KAAK44C,KAIrE,GAAa,MAAVma,EAAe,CACnB,IAAIE,EAAqB,OAAVlxC,EAAkB0vC,EAAYD,EACzCruD,EAAKpF,EAAa,IAAT+0D,EACT1wB,EAAOplC,EAAIo0B,QAAQp0B,EAAI0yB,IAAIvsB,EAAI,GAAI8vD,EAASjD,GAEhD,OAAOhwD,KAAKgD,MAAMG,GACdnD,KAAKk0B,IAAI54B,EAAG2E,MAAMD,KAAKuO,IAAI,GAAI6zB,GAAO,IAAMpiC,KAAK44C,KAClD,KAAM,sBAAwB38B,OAAO8F,IAIhD+mC,EAAKoE,UAAY,SAAS5kB,GACtB,IAAI6lB,EAAM7lB,EAAG6lB,KAAO7xC,OAChBrB,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOgzC,GAC9B6B,EAAQ/0C,EAAI,GAAKA,EAAI,GACrBi4C,EAASlD,EAAQhwD,KAAKgD,MAAQhD,KAAK0sB,KAGnCymC,EAAc,OAATl4C,EAAI,GAAuB,KAATA,EAAI,GAC3B8G,EAAQumB,EAAGvmB,MACXC,EAAQmsC,EAAI7lB,EAAGtmB,OAEnB,GAAGplB,EAAUmlB,GAAQ,CACjB,IAAIqxC,EAAOF,GAAQC,EAAKnxC,GAASD,GAASA,EAAQC,EAMlD,MAHe,aAAZsmB,EAAGlkC,MAAmC,kBAAZkkC,EAAGlkC,OAC5BgvD,EAAOp2D,EAAI85B,UAAUs8B,EAAM,EAAG9qB,EAAGoiB,YAAYnoD,OAAS,IAEnD6wD,EAGX,IAAIL,EAAQhxC,EAAMjJ,OAAO,GACrBu6C,EAAQ/2C,OAAOyF,EAAM7F,OAAO,IAGhC,GAAa,MAAV62C,EAAe,CAOd,IANA,IAEIO,EAAIC,EAAMC,EAFVt9B,EAAM,EACNu9B,EAAKzxC,EAKHkU,EAAM,IAAI,CAEZ,KADAo9B,EAAKxK,EAAK5Q,cAAcub,EAAI1xC,EAAOiuC,EAAO1nB,EAAGjvB,WACpC85C,IAAOM,EAAKN,IAAO,EAExB,OAAGnD,EAAchwD,KAAKi3B,IAAIw8B,EAAIH,GACvBtzD,KAAKc,IAAI2yD,EAAIH,GAExBC,GAAQJ,GAAOM,EAAKH,GAAM,IAAOA,EAAKG,GACtCD,EAAWT,GAAU/yD,KAAK6/B,IAAI7/B,KAAKC,MAAMszD,KAAU,GAAKF,EACxDI,EAAK3K,EAAK5Q,cAAcub,EAAID,EAAUD,EAAO,GAAKvD,EAAQA,EAAO1nB,EAAGjvB,UACpE6c,IAGJ,OADAl5B,EAAIm3B,MAAM,6BAA8BmU,GACjCmrB,EACJ,GAAa,MAAVV,EAGN,OAAO/yD,KAAKk0B,IAAIg/B,GACXlzD,KAAKuO,IAAI,GAAI4kD,GAAMnxC,GAASqxC,GAASA,EAAQrxC,GAAShiB,KAAK44C,KAC7D,GAAa,MAAVma,EAAe,CACrB,IAAIE,EAAqB,OAAVlxC,EAAkB0vC,EAAYD,EACzCpvB,EAAOplC,EAAIo0B,QAAQp0B,EAAI0yB,IAAIyjC,EAAI,GAAIF,EAASjD,GAEhD,OAAOhwD,KAAKgD,MAAMmwD,GACdnzD,KAAKk0B,IAAI54B,EAAG2E,MAAMD,KAAKuO,IAAI,GAAI6zB,GAAO,IAAMpiC,KAAK44C,KAClD,KAAM,sBAAwB38B,OAAO8F,IAShD+mC,EAAK0G,SAAW,SAASlnB,EAAIvqC,EAAG21D,EAAOC,GACnC,IAMIhvD,EANAkE,EAAM4mD,EAAYnnB,EAAIvqC,GACtB61D,EAA4B,UAAhBtrB,EAAG3mB,SACfkyC,EAAiBH,GAASE,EAC1BpyC,EAAS8mB,EAAGlkC,KAEZgrD,EAAuB,aAAX5tC,EAAwB8mB,EAAG+mB,UAAY/mB,EAAGgnB,IAG1D,GAAGsE,GAAalvD,MAAM+D,QAAQ6/B,EAAGwmB,UAAW,CACxC,IAAI7zC,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KACjCvB,GAAW5sD,KAAK6/B,IAAI5kB,EAAI,GAAKA,EAAI,KAAOqtB,EAAGmmB,UAAY,IAAM,IAEjE,IAAI9pD,EAAI,EAAGA,EAAI2jC,EAAGwmB,SAASvsD,UACpBvC,KAAK6/B,IAAI9hC,EAAIqxD,EAAU9mB,EAAGumB,SAASlqD,KAAOioD,GADdjoD,KAGnC,GAAGA,EAAI2jC,EAAGwmB,SAASvsD,OAEf,OADAsG,EAAI8D,KAAOsP,OAAOqsB,EAAGwmB,SAASnqD,IACvBkE,EAIf,SAASu3B,EAAS0zB,GACd,QAAgBptD,IAAbotD,EAAwB,OAAO,EAClC,GAAGJ,EAAO,MAAoB,SAAbI,EAEjB,IAAIC,EAAc,CACdC,MAAO1rB,EAAGunB,MACVe,KAAMtoB,EAAGyoB,OACX+C,GAEF,MAAoB,QAAbA,GAAsB/1D,IAAMg2D,EAGvC,IAAIE,EAAUP,EACV,QACsB,SAAtBprB,EAAGkqB,gBAA6BpyB,EAASkI,EAAG4rB,cAAgB,OAAS,GAiBzE,GAfc,SAAX1yC,EA2EP,SAAoB8mB,EAAIz/B,EAAK6qD,EAAOG,GAChC,IAAIM,EAAK7rB,EAAGypB,WACRjzB,EAAO40B,GAASprB,EAAG8rB,aAAgBtL,EAAKuL,cAAc/rB,GAEvDurB,IAGmBM,EAAfv3D,EAAUu3D,GAAU,EACb,CAACn2D,EAAG,IAAKs2D,EAAG,IAAK14D,EAAG,IAAK24D,EAAG,IAAKC,EAAG,GAAGL,IAGrD,IACIM,EADAxa,EAAUj9C,EAAIwzB,WAAW3nB,EAAI9K,EAAG+gC,EAAKq1B,EAAI7rB,EAAGosB,YAAapsB,EAAGjvB,SAAUivB,EAAGqsB,cAGzEC,EAAa3a,EAAQn3C,QAAQ,OACd,IAAhB8xD,IACCH,EAAUxa,EAAQ/9B,OAAO04C,EAAa,GACtC3a,EAAUA,EAAQ/9B,OAAO,EAAG04C,IAG7Bf,IAQgB,aAAZ5Z,GAAsC,UAAZA,GACzBA,EAAUwa,EACVA,EAAU,IACe,IAAnBxa,EAAQ13C,SAId03C,EAAUA,EAAQl3C,QAAQ,OAAQ,MAIvC0xD,IACIf,EAGW,MAAPS,EAAYla,GAAW,KAAOwa,EAC5Bxa,EAAUwa,GAAWxa,EAAU,KAAOA,EAAU,IAC9C3R,EAAG2oB,cAAiBwD,IAAYnsB,EAAG0oB,gBAC1C/W,GAAW,OAASwa,EACpBnsB,EAAG0oB,cAAgByD,IAI3B5rD,EAAI8D,KAAOstC,EA9HWzpB,CAAW8X,EAAIz/B,EAAK6qD,EAAOG,GAC9B,QAAXryC,EAgIZ,SAAmB8mB,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GAC/C,IAAIlyC,EAAQumB,EAAGvmB,MACXhkB,EAAI8K,EAAI9K,EACR82D,EAAavsB,EAAGusB,WAChBC,EAA2B,iBAAV/yC,GAAsBA,EAAMjJ,OAAO,GAEzC,UAAZm7C,IAOCA,EAAU,IAGXJ,GAA+B,MAAZiB,IAClB/yC,EAAQ,KACR+yC,EAAU,KAGd,GAAGD,GAA2B,MAAZC,EACdjsD,EAAI8D,KAAOooD,EAAU/0D,KAAKuO,IAAI,GAAIxQ,GAAIuqC,EAAI2rB,EAASJ,QAChD,GAAGj3D,EAAUmlB,IAAwB,MAAZ+yC,GAAqB93D,EAAI0yB,IAAI3xB,EAAI,IAAM,GAAK,GAAO,CAC/E,IAAI2O,EAAI1M,KAAKC,MAAMlC,GACfi3D,EAAOh1D,KAAK6/B,IAAInzB,GAChBuoD,EAAiB3sB,EAAGkqB,eACF,UAAnByC,GAA+B1C,EAAW0C,IAAmBxC,EAAS/lD,IACzD7D,EAAI8D,KAAP,IAAND,EAAoB,EACT,IAANA,EAAoB,KACZ,WAAaA,EAAI,EAAI,GAAKs7C,GAAcgN,EAAO,SAE/DnsD,EAAIkD,UAAY,OACU,MAAnBkpD,GAA6C,MAAnBA,IAA2BD,EAAO,EACnEnsD,EAAI8D,KAAO,IAAMsoD,GAAkBvoD,EAAI,EAAI,IAAMs7C,GAAcgN,GAE/DnsD,EAAI8D,KAAOooD,EAAU/0D,KAAKuO,IAAI,GAAIxQ,GAAIuqC,EAAI,GAAI,aACjC,OAAVvmB,GAAuC,MAArBumB,EAAGzwB,IAAIiB,OAAO,KAC/BjQ,EAAIwD,IAAMxD,EAAIkD,SAAW,QAG9B,IAAe,MAAZ+oD,EAGH,KAAM,sBAAwB74C,OAAO8F,GAFxClZ,EAAI8D,KAAOsP,OAAOjc,KAAKC,MAAMD,KAAKuO,IAAI,GAAIvR,EAAI0yB,IAAI3xB,EAAG,MACrD8K,EAAIkD,UAAY,IAIpB,GAAgB,OAAbu8B,EAAGvmB,MAAgB,CAClB,IAAImzC,EAAYj5C,OAAOpT,EAAI8D,MAAMmM,OAAO,GACvB,MAAdo8C,GAAmC,MAAdA,IACI,MAArB5sB,EAAGzwB,IAAIiB,OAAO,GACbjQ,EAAIuD,IAAMvD,EAAIkD,SAAW,GAEzBlD,EAAIwD,IAAMxD,EAAIkD,SAAW,EACzBlD,EAAIuD,KAAOk8B,EAAGntB,MAAM,GAAKmtB,EAAGntB,MAAM,GAAK,GAAK,GACxCtS,EAAIkD,UAAYhO,EAAI,EAAI,GAAM,QAvLpBo3D,CAAU7sB,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GACjD,aAAXzyC,EA4LZ,SAAwB8mB,EAAIz/B,GACxB,IAAIusD,EAAK9sB,EAAGoiB,YAAY1qD,KAAKC,MAAM4I,EAAI9K,SAC7B2I,IAAP0uD,IAAkBA,EAAK,IAC1BvsD,EAAI8D,KAAOsP,OAAOm5C,GA/LaC,CAAe/sB,EAAIz/B,GAC/B,kBAAX2Y,EAiMZ,SAA6B8mB,EAAIz/B,EAAK6qD,GAClC,IAAI9wD,EAAI5C,KAAKC,MAAM4I,EAAI9K,GACnBu3D,EAAOhtB,EAAGoiB,YAAY9nD,IAAM,GAC5BwyD,OAAiB1uD,IAAZ4uD,EAAK,GAAmB,GAAKr5C,OAAOq5C,EAAK,IAC9CC,OAAkB7uD,IAAZ4uD,EAAK,GAAmB,GAAKr5C,OAAOq5C,EAAK,IAEhD5B,EAEC7qD,EAAI8D,KAAO4oD,EAAM,MAAQH,GAGzBvsD,EAAI8D,KAAOyoD,EACXvsD,EAAI2sD,MAAQD,GA7MoBE,CAAoBntB,EAAIz/B,EAAK6qD,GACzD5C,GAAUxoB,GAkOtB,SAAqBA,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GACjD,GAAoB,YAAjB3rB,EAAGotB,WAA4BhC,EA6B9B7qD,EAAI8D,KAAOooD,EAAUlsD,EAAI9K,EAAGuqC,EAAI2rB,EAASJ,OA7BJ,CACrC,IAAI8B,EAAM9sD,EAAI9K,EAAI,IAElB,GAAW,IAAR43D,EACC9sD,EAAI8D,KAAO,QACR,CACH,IAAIy1B,EA6BhB,SAAkBuzB,GACd,SAASC,EAASzyC,EAAGlD,GACjB,OAAOjgB,KAAK6/B,IAAI1c,EAAIlD,IAAM,KAe9B,IAAI41C,EARJ,SAAuB7zD,GAEnB,IADA,IAAIw0C,EAAI,GACDof,EAAS51D,KAAKC,MAAM+B,EAAIw0C,GAAKA,EAAGx0C,IACnCw0C,GAAK,GAET,OAAOA,EAGKsf,CAAcH,GAC1BI,EAASJ,EAAME,EACfG,EAAMh2D,KAAK6/B,IAdf,SAASo2B,EAAQ9yC,EAAGlD,GAChB,OAAO21C,EAAS31C,EAAG,GAAKkD,EAAI8yC,EAAQh2C,EAAGkD,EAAIlD,GAa5Bg2C,CAAQF,EAAQF,IAEnC,MAAO,CAEH71D,KAAKC,MAAM81D,EAASC,GAEpBh2D,KAAKC,MAAM41D,EAAYG,IAtDRE,CAASP,GAEpB,GAAGvzB,EAAK,IAAM,IACVv5B,EAAI8D,KAAOooD,EAAU/3D,EAAIy1B,QAAQ5pB,EAAI9K,GAAIuqC,EAAI2rB,EAASJ,OACnD,CACH,IAAIsC,EAAQttD,EAAI9K,EAAI,EAEL,IAAZqkC,EAAK,GACW,IAAZA,EAAK,GAAUv5B,EAAI8D,KAAO,IACxB9D,EAAI8D,KAAOy1B,EAAK,GAAK,IAE1Bv5B,EAAI8D,KAAO,CACP,QAASy1B,EAAK,GAAI,SAClB,IACA,QAASA,EAAK,GAAI,SAClB,KACFn9B,KAAK,IAGRkxD,IAAOttD,EAAI8D,KAAOq7C,EAAan/C,EAAI8D,SA5P3BypD,CAAY9tB,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GAgNvE,SAAsB3rB,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GACnC,UAAZA,EAOCA,EAAU,GACgB,QAApB3rB,EAAG4rB,cAA0Bl0D,KAAK6/B,IAAIh3B,EAAI9K,EAAIuqC,EAAGvmB,OAAS,OAIhEkyC,EAAU,QAEdprD,EAAI8D,KAAOooD,EAAUlsD,EAAI9K,EAAGuqC,EAAI2rB,EAASJ,GA9NpCwC,CAAa/tB,EAAIz/B,EAAK6qD,EAAOG,EAAgBI,GAG9CN,IACGrrB,EAAGguB,aAAel2B,EAASkI,EAAGiuB,kBAAiB1tD,EAAI8D,KAAO27B,EAAGguB,WAAaztD,EAAI8D,MAC9E27B,EAAGkuB,aAAep2B,EAASkI,EAAGmuB,kBAAiB5tD,EAAI8D,MAAQ27B,EAAGkuB,aAKnD,eAAfluB,EAAGouB,SAA4BpuB,EAAGquB,aAAc,CAC/C,IAAIC,EAAW,SAASh0D,GACpB,IAAI8J,EAAI47B,EAAGuuB,IAAIj0D,GACf,OAAO8J,GAAK,GAAKA,GAAK47B,EAAGhH,QAAU1+B,EAAI,MAG3CiG,EAAIiuD,KAAO,CACPF,EAAS/tD,EAAI9K,EAAI,IACjB64D,EAAS/tD,EAAI9K,EAAIuqC,EAAGvmB,MAAQ,KAIpC,OAAOlZ,GAeXigD,EAAKiO,eAAiB,SAASzuB,EAAIxrB,EAAKk6C,GACpC,GAAGA,IAASloC,GAAUkoC,IAASl6C,EAC3B,OAAOgsC,EAAKiO,eAAezuB,EAAIxrB,GAAO,MAAQgsC,EAAKiO,eAAezuB,EAAI0uB,GAG1E,IAAIC,EAA2B,QAAZ3uB,EAAGlkC,MAAkB0Y,GAAO,EAC3ClP,EAAKk7C,EAAK0G,SAASlnB,EAAIA,EAAG4uB,IAAID,GAAen6C,EAAMA,GAAM,SAASnQ,KAEtE,OAAGsqD,EACgB,IAARn6C,EAAY,IAAMkrC,EAAap6C,EAOnCA,GAiPX,IAAIupD,EAAa,CAAC,IAAK,IAAK,IAAK,IAAK,IAAK,GAAI,IAAK,IAAK,IAAK,KAE9D,SAAS5E,EAAW0C,GAChB,MAA0B,OAAnBA,GAA8C,MAAnBA,EAUtC,SAASxC,EAAS2E,GACd,OAAOA,EAAW,IAAMA,GAAY,GAGxC,SAASrC,EAAUnyD,EAAG0lC,EAAI+uB,EAAa3D,GACnC,IAAIyC,EAAQvzD,EAAI,EAEZ00D,EAAYhvB,EAAGypB,WACfkD,EAAiBoC,GAAe/uB,EAAGkqB,gBAAkB,IACrD4E,EAAW9uB,EAAGwpB,cACd+C,EAAa/L,EAAKuL,cAAc/rB,GAChC5K,EAAoB4K,EAAG5K,kBAI3B,GAAGg2B,EAAO,CAEN,IAAI6D,EAAK,CACL/E,eAAgByC,EAChBlzC,MAA2B,SAApBumB,EAAG4rB,aAA0B5rB,EAAGvmB,MAClCnlB,EAAUgG,IAAK5C,KAAK6/B,IAAIj9B,IAAU,EAGvCuY,MAA2B,SAApBmtB,EAAG4rB,aAA0B5rB,EAAGntB,MAAM/D,IAAIkxB,EAAG8pB,KAAO,CAAC,EAAGxvD,GAAK,IAExE+rD,EAAc4I,GACdD,GAAah7C,OAAOi7C,EAAGxF,aAAe,GAAK,EAC3CqF,EAAWG,EAAGzF,cACXxpB,EAAG8rB,cAAaS,EAAavsB,EAAG8rB,aAGvC,GAAGS,EAAY,OAAOvsB,EAAGkvB,WAAW3C,EAAdvsB,CAA0B1lC,GAAGG,QAAQ,KAAMilD,GAGjE,IA8CQyP,EA9CJjhB,EAAIx2C,KAAKuO,IAAI,IAAK+oD,GAAa,EAgBnC,GALsB,SAAnBrC,IAA2BmC,EAAW,IAIzCx0D,EAAI5C,KAAK6/B,IAAIj9B,IACN4zC,EAEH5zC,EAAI,IACJuzD,GAAQ,MACL,CAQH,GAPAvzD,GAAK4zC,EAEF4gB,IACCx0D,GAAK5C,KAAKuO,IAAI,IAAK6oD,GACnBE,GAAaF,GAGA,IAAdE,EAAiB10D,EAAIqZ,OAAOjc,KAAKgD,MAAMJ,SACrC,GAAG00D,EAAY,EAAG,CAEnB10D,GADAA,EAAIqZ,OAAOjc,KAAKC,MAAM2C,KAChBsZ,OAAO,EAAGtZ,EAAEL,OAAS+0D,GAC3B,IAAI,IAAI3yD,EAAI2yD,EAAW3yD,EAAI,EAAGA,IAAK/B,GAAK,QACrC,CAEH,IAAI80D,GADJ90D,EAAIqZ,OAAOrZ,IACAE,QAAQ,KAAO,EACvB40D,IAAI90D,EAAIA,EAAEsZ,OAAO,EAAGw7C,EAAKJ,GAAWv0D,QAAQ,SAAU,KAG7DH,EAAI5F,EAAIwgC,YAAY56B,EAAG0lC,EAAGqvB,YAAaj6B,GAIxC05B,GAA+B,SAAnBnC,IACR1C,EAAW0C,IAAmBxC,EAAS2E,KAAWnC,EAAiB,SAGrDwC,EAAdL,EAAW,EAAoBpP,GAAcoP,EACrB,UAAnBnC,EAA6C,IAAMmC,EACrCn7C,OAAOm7C,GAEP,MAAnBnC,GAA6C,MAAnBA,EACzBryD,GAAKqyD,EAAiBwC,EACG,UAAnBxC,EACNryD,GAAK,WAAa60D,EAAiB,SACV,MAAnBxC,GAAuC,IAAbmC,EAChCx0D,GAAK,IACC2vD,EAAW0C,KACjBryD,GAAKu0D,EAAWC,EAAW,EAAI,KAOvC,OAAGjB,EAAcnO,EAAaplD,EACvBA,EAslBX,SAASg1D,EAAsBtvB,EAAIyS,GAI/B,IAHA,IAAIlyC,EAAM,GACNiyC,EAAS,GAELn2C,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IAAK,CACjC,IAAI/I,EAAIm/C,EAAKp2C,GACVm2C,EAAOl/C,EAAE45D,OACR1a,EAAOl/C,EAAE45D,OAAOvzD,KAAKrG,EAAEmC,GAEvB+8C,EAAOl/C,EAAE45D,OAAS,CAAC55D,EAAEmC,GAI7B,IAAI,IAAI+D,KAAKg5C,EACTjyC,EAAI5G,KAAKwtD,EAAYnnB,EAAItrC,EAAI80B,OAAOgpB,EAAOh5C,GAAI,IAAMA,IAGzD,OAAO+G,EAyOX,SAASgvD,EAAWj8D,GAChB,MAAO,CAACA,EAAE+Q,KAAM/Q,EAAEmC,EAAGnC,EAAEk8D,OAAQl8D,EAAE6B,KAAM7B,EAAEmQ,SAAUnQ,EAAE4R,WAAWvI,KAAK,KAidzE,SAAS8yD,EAAiBzvB,GACtB,IAAIv8B,EAAWu8B,EAAG6I,MAAM1zC,KAAKE,KACzBq6D,GAAc1vB,EAAG6I,MAAMxkC,KAAKyF,MAAMnV,EAAag7D,aAAe,IAAI11D,OACtE,OAAG+lC,EAAG6I,MAAMn2B,eAAe,YAChBg9C,EACHjsD,GAAY68C,EAAaoP,EAAa76D,GACtC4O,EAAW68C,EAERoP,EACHjsD,GAAYisD,EAAa,GAAK76D,EAC9B4O,EAgHZ,SAASmsD,EAAS5vB,EAAIlhB,GAClB,IAAI1a,EAAI47B,EAAGuuB,IAAIzvC,GACf,OAAQ1a,EAAI,GAAKA,EAAI47B,EAAGhH,QAAU,EA2EtC,SAAS62B,EAAgBC,GACrB,IAAIl8D,EAAIZ,EAAGa,OAAOi8D,GACdC,EAAKn8D,EAAEC,OAAO,oBAClB,OAAOk8D,EAAGjxB,QAAUlrC,EAAEC,OAAO,QAAUk8D,EA4B3C,SAASC,GAAehwB,GAAM,OAAOA,EAAGzwB,IAAM,cAC9C,SAAS0gD,GAAqBjwB,GAAM,OAAOgwB,GAAehwB,GAAM,UAChE,SAASkwB,GAAwBlwB,GAAM,OAAOA,EAAGzwB,IAAM,eAiDvD,SAAS4gD,GAAgBC,EAASC,GAC9B,IAAI,IAAIh0D,EAAI,EAAGA,EAAIg0D,EAAQp2D,OAAQoC,KACK,IAAjC+zD,EAAQ51D,QAAQ61D,EAAQh0D,KAAY+zD,EAAQz2D,KAAK02D,EAAQh0D,IAIpE,SAASi0D,GAAcj5D,EAAIqW,EAAMC,GAC7B,IAGItR,EAAGkQ,EAHHgkD,EAAY,GACZC,EAAY,GACZ73C,EAASthB,EAAGshB,OAGhB,IAAItc,EAAI,EAAGA,EAAIqR,EAAKzT,OAAQoC,IAAKk0D,EAAU52D,KAAK6mD,EAAKtlB,UAAU7jC,EAAIqW,EAAKrR,KACxE,IAAIA,EAAI,EAAGA,EAAIsR,EAAK1T,OAAQoC,IAAKm0D,EAAU72D,KAAK6mD,EAAKtlB,UAAU7jC,EAAIsW,EAAKtR,KAExE,IAAIo0D,EAAYp3D,OAAOC,KAAK8mD,GAExBsQ,EAAc,CACd,SAAU,SAAU,aAAc,WAAY,OAAQ,YAAa,YAEnEC,EAAe,CAAC,SAAU,OAE9B,IAAIt0D,EAAI,EAAGA,EAAIo0D,EAAUx2D,OAAQoC,IAAK,CAClC,IAAIu0D,EAAOH,EAAUp0D,GACjBw0D,EAAON,EAAU,GAAGK,GACpBE,EAAON,EAAU,GAAGI,GACpBG,GAAW,EACXC,GAAgB,EAChBC,GAAgB,EACpB,GAAsB,MAAnBL,EAAKpgD,OAAO,IAA8B,mBAATqgD,IACG,IAA/BH,EAAYl2D,QAAQo2D,GAD5B,CAIA,IAAIrkD,EAAI,EAAGA,EAAIgkD,EAAUt2D,QAAU82D,EAAUxkD,IAAK,CAC9C,IAAI2kD,EAAQX,EAAUhkD,GAAGqkD,GACb,SAATA,IAAmD,IAAhCD,EAAan2D,QAAQq2D,KACF,IAAjCF,EAAan2D,QAAQ02D,IAAiBL,IAASK,EAGnDF,GAAgB,EACVE,IAAUL,IAAME,GAAW,GAEzC,IAAIxkD,EAAI,EAAGA,EAAIikD,EAAUv2D,QAAU82D,EAAUxkD,IAAK,CAC9C,IAAI4kD,EAAQX,EAAUjkD,GAAGqkD,GACb,SAATA,IAAmD,IAAhCD,EAAan2D,QAAQs2D,KACF,IAAjCH,EAAan2D,QAAQ22D,IAAiBL,IAASK,EAGnDF,GAAgB,EACVT,EAAUjkD,GAAGqkD,KAAUE,IAAMC,GAAW,GAEnDA,IACIC,IAAer4C,EAAO43C,EAAU,GAAGlhD,OAAOvT,KAAO,UACjDm1D,IAAet4C,EAAO63C,EAAU,GAAGnhD,OAAOvT,KAAO,UACpDs1D,GAAcz4C,EAAQi4C,EAAML,EAAWC,EAAWn5D,EAAGkF,YAAY80D,cAKzE,IAAIh1D,EAAI,EAAGA,EAAIhF,EAAGkF,YAAY0+B,YAAYhhC,OAAQoC,IAAK,CACnD,IAAIi1D,EAAMj6D,EAAGkF,YAAY0+B,YAAY5+B,IACN,IAA5BqR,EAAKlT,QAAQ82D,EAAIn2B,QACgB,IAA5BxtB,EAAKnT,QAAQ82D,EAAIl2B,OACrB1mC,EAAIm5B,UAAUlV,EAAOsiB,YAAY5+B,GAAI,CAAC,OAKlD,SAAS+0D,GAAcz4C,EAAQ8C,EAAK80C,EAAWC,EAAWe,GAItD,IAGIl1D,EAHAm1D,EAAK98D,EAAIkO,eACTiuD,EAAOW,EAAG74C,EAAO43C,EAAU,GAAGlhD,OAAQoM,GAAK5Y,MAC3CiuD,EAAOU,EAAG74C,EAAO63C,EAAU,GAAGnhD,OAAQoM,GAAK5Y,MAa/C,IAVW,UAAR4Y,IAEIo1C,GAAQA,EAAKxsD,OAASktD,EAAU97D,IAC/Bo7D,EAAKxsD,KAAOktD,EAAU77D,GAEvBo7D,GAAQA,EAAKzsD,OAASktD,EAAU77D,IAC/Bo7D,EAAKzsD,KAAOktD,EAAU97D,IAI1B4G,EAAI,EAAGA,EAAIk0D,EAAUt2D,OAAQoC,IAC7Bm1D,EAAG74C,EAAQ43C,EAAUl0D,GAAGgT,MAAQ,IAAMoM,GAAKxH,IAAI68C,GAEnD,IAAIz0D,EAAI,EAAGA,EAAIm0D,EAAUv2D,OAAQoC,IAC7Bm1D,EAAG74C,EAAQ63C,EAAUn0D,GAAGgT,MAAQ,IAAMoM,GAAKxH,IAAI48C,GAIvD,SAASrI,GAAUxoB,GACf,MAAkB,gBAAXA,EAAGzwB,IAxpDdixC,EAAKuL,cAAgB,SAAS/rB,GAC1B,IAAI3jC,EAyCAo1D,EAAUC,EAhBQj4C,EAAO5G,EACrB8+C,EACAC,EACAC,EA1BR,SAASC,EAAYr4C,GACjB,MAAwB,iBAAVA,EAAqBA,EAAQzF,OAAOyF,EAAMhf,QAAQ,IAAK,KAAO00C,EAGhF,SAAS4iB,EAAgBlqD,EAAMoB,GAC3B,IAAI+oD,EAAW,CAAC,IAAK,KACrB,UAAUnqD,UAAgBoB,EAAO,CAC7B,GAAmB,iBAATpB,EACN,OAAOA,EAAOoB,EAEd,IAAIgpD,EAAeD,EAASx3D,QAAQqN,EAAK2I,OAAO,IAC5C0hD,EAAgBF,EAASx3D,QAAQyO,EAAMuH,OAAO,IAClD,OAAGyhD,IAAiBC,EACTl+C,OAAOnM,EAAKpN,QAAQ,SAAU,KAAOuZ,OAAO/K,EAAMxO,QAAQ,SAAU,KAEpEw3D,EAAeC,EAI9B,MAAuB,iBAATrqD,EAAoB,GAAK,EAY/C,SAASsqD,EAAgB14C,EAAO5G,GAC5B,IAAIu/C,EAA+B,OAAbv/C,EAAM,GACxBw/C,EAAgC,OAAbx/C,EAAM,GACzBy/C,EAAqBP,EAAgBt4C,EAAO5G,EAAM,KAAO,EACzD0/C,EAAsBR,EAAgBt4C,EAAO5G,EAAM,KAAO,EAC9D,OAAQu/C,GAAmBE,KAAwBD,GAAoBE,GAI3E,GAAGvyB,EAAGwyB,iBAAmBxyB,EAAGwyB,gBAAgBv4D,OAAS,EACjD,OAAO+lC,EAAGlkC,MACN,IAAK,OACL,IAAK,SACD,IAAIO,EAAI,EAAGA,EAAI2jC,EAAGwyB,gBAAgBv4D,OAAQoC,IAEtC,IADAq1D,EAAQ1xB,EAAGwyB,gBAAgBn2D,IAClBo2D,UAvBHh5C,EAuB2BumB,EAAGvmB,MAvBvB5G,EAuB8B6+C,EAAMgB,WAtBzDf,SACAC,SACAC,SAFAF,EAsBqEG,GAtB9C,SAASr8D,GAAK,OAAOA,GAC5Cm8D,EAAY/+C,EAAM,GAClBg/C,EAAah/C,EAAM,KACb++C,GAAkC,iBAAdA,GAA2BD,EAAUC,IAAcD,EAAUl4C,OACjFo4C,GAAoC,iBAAfA,GAA4BF,EAAUE,IAAeF,EAAUl4C,KAkBP,CACvEg4C,EAAWC,EACX,MAGR,MAEJ,IAAK,MACD,IAAIr1D,EAAI,EAAGA,EAAI2jC,EAAGwyB,gBAAgBv4D,OAAQoC,IAEtC,IADAq1D,EAAQ1xB,EAAGwyB,gBAAgBn2D,IAClBo2D,SAAWN,EAAgBnyB,EAAGvmB,MAAOi4C,EAAMgB,YAAa,CAC7DjB,EAAWC,EACX,OAQpB,OAAOD,EAAWA,EAASh9B,MAAQuL,EAAGusB,YAU1C/L,EAAKmS,YAAc,SAASt7D,EAAI2oC,GAC5B,IAAI4yB,EAAav7D,EAAGkF,YAAYkR,UAC5BolD,EAAcD,EAAWnW,UAAUzuC,OAAO4kD,EAAWjW,MAAQ,IAE7Dp8C,EAAMy/B,EAAKwgB,EAAKsS,qBAAqBD,EAAa7yB,GAAM6yB,EAU5D,OARAtyD,EAAIwoB,MAAK,SAASlO,EAAGlD,GACjB,IAAIo7C,EAASl4C,EAAEjH,OAAO,GAAG5J,MAAM,KAC3BgpD,EAASr7C,EAAE/D,OAAO,GAAG5J,MAAM,KAE/B,OAAG+oD,EAAO,KAAOC,EAAO,IAAYD,EAAO,IAAMC,EAAO,IAChDD,EAAO,IAAMC,EAAO,MAGzBzyD,GAMXigD,EAAKsS,qBAAuB,SAAStlD,EAAUwyB,GAM3C,IALA,IAAIizB,EAAU,IAAIC,OACQ,MAArBlzB,EAAGzwB,IAAIiB,OAAO,GAAe,IAAMwvB,EAAGzwB,IAAM,IAAQywB,EAAGzwB,IAAM,KAE9D4jD,EAAiB,GAEb92D,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAAK,CACrC,IAAI+2D,EAAK5lD,EAASnR,GACf42D,EAAQ5iD,KAAK+iD,IAAKD,EAAex5D,KAAKy5D,GAG7C,OAAOD,GAIX3S,EAAK6S,cAAgB,SAASh8D,GAC1B,IAAIiF,EAAajF,EAAGkF,YAGpB,IAAGD,EAAW49C,oBAAd,CAEA,IAKI79C,EAAGkQ,EALH+mD,EAAY,CAAC5yB,QAAS,EAAG1H,QAAS18B,EAAWpE,MAAOqX,IAAK,IACzDgkD,EAAa,CAAC7yB,QAAS,EAAG1H,QAAS18B,EAAWwL,OAAQyH,IAAK,IAC3DikD,EAAShT,EAAK7wC,KAAKtY,EAAI,KAAK,GAC5Bo8D,EAASjT,EAAK7wC,KAAKtY,EAAI,KAAK,GAC5Bq8D,EAAW,GAGf,IAAIr3D,EAAI,EAAGA,EAAIm3D,EAAOv5D,OAAQoC,IAE1B,IADAq3D,EAAS/5D,KAAK,CAAClE,EAAG+9D,EAAOn3D,GAAI3G,EAAG69D,IAC5BhnD,EAAI,EAAGA,EAAIknD,EAAOx5D,OAAQsS,IACjB,IAANlQ,GAASq3D,EAAS/5D,KAAK,CAAClE,EAAG69D,EAAW59D,EAAG+9D,EAAOlnD,KACnDmnD,EAAS/5D,KAAK,CAAClE,EAAG+9D,EAAOn3D,GAAI3G,EAAG+9D,EAAOlnD,KAO/C,IAAIonD,EAAUr3D,EAAWs3D,OAAO7/D,UAAU,aACrC4E,KAAK+6D,GAAU,SAASpgE,GAAK,OAAOA,EAAEmC,EAAE8Z,IAAMjc,EAAEoC,EAAE6Z,OAEvDokD,EAAQ52D,QAAQC,OAAO,YAClBsiB,QAAQ,YAAY,GACpB3pB,KAAK,MAAM,SAASrC,GAAK,MAAO,OAASgJ,EAAWG,KAAOnJ,EAAEmC,EAAE8Z,IAAMjc,EAAEoC,EAAE6Z,OAC3EvS,OAAO,QAEV22D,EAAQ92D,OAAOC,SAEf62D,EAAQtgE,MAAK,SAASC,GAClBN,EAAGa,OAAOC,MAAMD,OAAO,QAAQ8B,KAAK,CAChCF,EAAGnC,EAAEmC,EAAEirC,SAAW,EAClBhrC,EAAGpC,EAAEoC,EAAEgrC,SAAW,EAClBxoC,MAAO5E,EAAEmC,EAAEujC,SAAW,EACtBlxB,OAAQxU,EAAEoC,EAAEsjC,SAAW,SA4BnCwnB,EAAKzb,KAAO,SAAS1tC,EAAIq5B,EAAK9X,GAC1B,IAAItc,EAAajF,EAAGkF,YAET,WAARm0B,GACCp0B,EAAWghC,OAAOvpC,UAAU,aAAaV,MAAK,SAASC,GACnD,IAAIihC,EAAKjhC,EAAE,GACPklD,EAAWl8C,EAAWo/C,OAAOnnB,GAC7Br+B,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAElBuhD,EAASyC,WAAWlnD,UAAU,IAAMmC,EAAGqZ,IAAM,QAAQzS,SACrD07C,EAAS0C,WAAWnnD,UAAU,IAAMoC,EAAGoZ,IAAM,QAAQzS,SACrD07C,EAASyC,WAAWlnD,UAAU,IAAMmC,EAAGqZ,IAAM,SAASzS,SACtD07C,EAAS0C,WAAWnnD,UAAU,IAAMoC,EAAGoZ,IAAM,SAASzS,SACtD07C,EAASyC,WAAWlnD,UAAU,IAAMmC,EAAGqZ,IAAM,WAAWzS,SACxD07C,EAAS0C,WAAWnnD,UAAU,IAAMoC,EAAGoZ,IAAM,WAAWzS,SAErD07C,EAASgC,WAAWhC,EAASgC,UAAUzmD,UAAU,QAAQ+I,SACzD07C,EAASiC,eAAejC,EAASiC,cAAc1mD,UAAU,QAAQ+I,SAEpER,EAAWw/B,WAAWjoC,OAAO,MAAQqC,EAAGqZ,IAAM,SAASzS,SACvDR,EAAWw/B,WAAWjoC,OAAO,MAAQsC,EAAGoZ,IAAM,SAASzS,YAI/D,IAAIkmD,EAAWtyB,GAAe,WAARA,EAAuCA,EAAnB8vB,EAAK9C,QAAQrmD,GAEvD,OAAO3C,EAAI87B,YAAYwyB,EAAOl0C,KAAI,SAAST,GACvC,OAAO,WACH,GAAIA,EAAJ,CAEA,IAAI2xB,EAAKwgB,EAAKtlB,UAAU7jC,EAAIgX,GACxBwlD,EAASrT,EAAKzlB,QAAQ1jC,EAAI2oC,EAAIpnB,GAKlC,OAHAonB,EAAG8zB,GAAK9zB,EAAGntB,MAAMC,QACjBktB,EAAG+zB,IAAMr/D,EAAImZ,UAAUmyB,EAAG8zB,GAAI9zB,EAAG6lB,KAE1BgO,SAgCnBrT,EAAKzlB,QAAU,SAAS1jC,EAAI2oC,EAAIpnB,GAG5B,IAAIvc,EAAG+2D,EAAI5a,EAFX5/B,EAAOA,GAAQ,GAIfonB,EAAG11B,WAEH,IAAIhO,EAAajF,EAAGkF,YAChB8R,EAAO2xB,EAAGzwB,IACVjB,EAAWD,EAAKmC,OAAO,GACvB+xC,EAAgB/B,EAAK+B,cAAcl0C,GACnCkwC,EAAejiD,EAAWo/C,OAAO1b,EAAGg0B,cAGxC,GAAIzV,EAAJ,CAEA,IAAI0V,EAAc1V,EAAajwC,EAAW,aACtC4lD,EAAmBl0B,EAAGm0B,kBACtBC,EAAqBp0B,EAAGq0B,oBAExB5hB,EAAOzS,EAAGs0B,MAAQ9T,EAAK8F,UAAUtmB,GAIjCwvB,EAAS,CAACxvB,EAAGu0B,OAAQL,EAAkBE,GAAoBz3D,KAAK,KACpE,IAAIN,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IACxBo2C,EAAKp2C,GAAGmzD,OAASA,EAKrBxvB,EAAGw0B,YAAc,GAGdx0B,EAAGy0B,cAAaz0B,EAAG00B,gBAAkB10B,EAAGy0B,aAC3Cz0B,EAAGy0B,YAAc,GAIjBz0B,EAAG20B,OAAS,KAKZ,IAAIC,EAAW,GAOf,GAAI50B,EAAG5jB,QAAP,CAEA,IACIurC,EAGAkN,EAJAC,EAAUtU,EAAKuU,YAAY/0B,GAM/B,GAAkB,eAAfA,EAAGouB,QAA0B,CAC5B,IAAI4G,EAsQZ,SAAyBh1B,EAAIyS,GACzB,IACIp2C,EADAkE,EAAM,GAKN00D,EAAQ,SAAS3hE,EAAG4hE,GACpB,IAAIC,EAAK7hE,EAAEk7D,KAAK0G,GACN,OAAPC,GACC50D,EAAI5G,KAAKjF,EAAIiM,WAAW,GAAIrN,EAAG,CAACmC,EAAG0/D,MAI3C,GAAG1iB,EAAKx4C,OAAQ,CACZ,IAAIoC,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IACxB44D,EAAMxiB,EAAKp2C,GAAI,GAEnB44D,EAAMxiB,EAAKp2C,EAAI,GAAI,GAGvB,OAAOkE,EA1RgB60D,CAAgBp1B,EAAIyS,GACvCoiB,EAAcrU,EAAKoP,SAAS5vB,EAAIg1B,GAChCrN,EAAwB,WAAb3nB,EAAGq1B,MAAqBR,EAAcG,OAEjDH,EAAcrU,EAAKoP,SAAS5vB,EAAIyS,GAChCkV,EAAwB,WAAb3nB,EAAGq1B,MAAqBR,EAAcpiB,EAGrD,IAAI6iB,EAAWt1B,EAAGu1B,UAAYV,EAC1BW,EAwSR,SAAwBx1B,EAAIyS,GACxB,IACIp2C,EAAGo5D,EADHl1D,EAAM,GAKN00D,EAAQ,SAAS3hE,EAAG4hE,GACpB,IAAIC,EAAK7hE,EAAEk7D,KAAK0G,GACN,OAAPC,GACC50D,EAAI5G,KAAKjF,EAAIiM,WAAW,GAAIrN,EAAG,CAACmC,EAAG0/D,MAI3C,GAAGn1B,EAAGquB,cAAgB5b,EAAKx4C,OAAQ,CAC/B,IAAIoC,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IAAK,CAC7B,IAAI/I,EAAIm/C,EAAKp2C,GACV/I,EAAE45D,QAAUuI,GACXR,EAAM3hE,EAAG,GAEbmiE,EAAUniE,EAAE45D,MAEhB+H,EAAMxiB,EAAKp2C,EAAI,GAAI,GAGvB,OAAOkE,EAhUWm1D,CAAe11B,EAAIyS,GAErC,IAAIn2C,EAAW49C,oBAAqB,CAChC,IAAIiZ,EAAiBnzB,EAAG7wB,cAIpBwmD,EAAgB,GAEpB,IAAIt5D,EAAI,EAAGA,EAAI82D,EAAel5D,OAAQoC,IAAK,CACvC+2D,EAAKD,EAAe92D,GAGpB,IAAIu5D,GAFJpd,EAAWl8C,EAAWo/C,OAAO0X,IAEF7Q,EAAgB,QACvCsT,EAAgBD,EAAYvX,UAAU9uC,IAC1C,IAAGomD,EAAcE,GAAjB,CACAF,EAAcE,GAAiB,EAE/B,IAAIC,EAAwB,MAAbxnD,EACX,MAAQsnD,EAAYl1B,QAAU,IAAMk1B,EAAY58B,QAChD,IAAM48B,EAAYl1B,QAAU,MAAQk1B,EAAY58B,QAEpDwnB,EAAKuV,SAAS1+D,EAAI2oC,EAAI,CAClByS,KAAM6iB,EACNM,YAAaA,EACbthC,MAAOkkB,EAASgC,UAAU3mD,OAAO,IAAMwa,GACvC3H,KAAMovD,EACNhB,QAASA,IAEbtU,EAAKwV,aAAa3+D,EAAI2oC,EAAI,CACtB41B,YAAaA,EACbthC,MAAOkkB,EAASiC,cAChB/zC,KAAMovD,EACNhB,QAASA,MAKrB,IAAImB,EAAYzV,EAAK0V,aAAal2B,GAC9Bm2B,EAAe,GAEnB,GAAGn2B,EAAGq1B,MAAO,CACT,IACIe,EACAC,EASAC,EAXAC,EAAe/V,EAAKgW,aAAax2B,EAAIk0B,EAAkB+B,EAAU,IAYrE,GATGj2B,EAAGy2B,aAAez2B,EAAGu0B,SAAwB,IAAdv0B,EAAGu0B,QACjC6B,EAAiB5V,EAAKgW,aAAax2B,EAAIo0B,EAAoB6B,EAAU,IACrEI,EAAeE,EAAeH,IAE9BA,EAAiB,GACjBC,EAAeE,GAIhBv2B,EAAGquB,cAA6B,YAAbruB,EAAGq1B,OAAsC,eAAfr1B,EAAGouB,QAA0B,CACzE,IAAIsI,EAAgB,GACpB,IAAIr6D,EAAI,EAAGA,EAAIm5D,EAAYv7D,OAAQoC,IAC/Bq6D,EAAclB,EAAYn5D,GAAG5G,GAAK,EAEtC6gE,EAAW,SAAShjE,GAChB,OAAOojE,EAAcpjE,EAAEmC,GAAK2gE,EAAiBC,QAGjDC,EAAWD,EAGf7V,EAAKmW,UAAUt/D,EAAI2oC,EAAI,CACnByS,KAAMkV,EACNrzB,MAAO2/B,EACPvtD,KAAM4vD,EACNxB,QAASA,IAGI,aAAd90B,EAAGu0B,SACF4B,EAAe98D,OAAOC,KAAK0mC,EAAG42B,gBAAkB,KAIxD,IAAIv6D,EAAI,EAAGA,EAAI85D,EAAal8D,OAAQoC,IAAK,CACrC+2D,EAAK+C,EAAa95D,GAClBm8C,EAAWl8C,EAAWo/C,OAAO0X,GAE7B,IAAIyD,EAAgB72B,EAAG42B,eAAexD,IAAO,GACzC0D,EAAatW,EAAKgW,aAAax2B,EAAI62B,EAAc,GAAIZ,EAAU,IAC/DzV,EAAKgW,aAAax2B,EAAI62B,EAAc,GAAIZ,EAAU,IAEtDzV,EAAKmW,UAAUt/D,EAAI2oC,EAAI,CACnByS,KAAMkV,EACNrzB,MAAOkkB,EAASlqC,EAAW,aAC3B5H,KAAMowD,EACNhC,QAASA,IAIjB,IAAIvyD,EAAM,GAcV,GATAA,EAAI5I,MAAK,WACL,OAAO6mD,EAAKuW,WAAW1/D,EAAI2oC,EAAI,CAC3ByS,KAAMA,EACNne,MAAO2/B,EACPa,QAASA,EACTkC,SAAUxW,EAAKyW,aAAaj3B,EAAIk0B,QAIzB,kBAAZl0B,EAAGlkC,KAA0B,CAC5B,IAAI8iB,EAAM,CAACnpB,EAAG,EAAGC,EAAG,IAAI4Y,GAExB/L,EAAI5I,MAAK,WACL,IAAIu9D,EAAU,CAACzhE,EAAG,SAAUC,EAAG,SAAS4Y,GACpCy0B,EAAWo0B,KAAoBD,GAAWt4C,GACzCohB,EAAGy0B,YAAYpmD,EAAO,QAAU2xB,EAAGimB,SAAS5wD,KAAOR,EAAe,GAEvE,OAAO2rD,EAAKuW,WAAW1/D,EAAI2oC,EAAI,CAC3ByS,KAAM6c,EAAsBtvB,EAAIyS,GAChCne,MAAO2/B,EACPmD,IAAK/oD,EAAO,QACZgpD,oBAAoB,EACpBC,WAAW,EACXxC,QAASA,EACTkC,SAAUxW,EAAKyW,aAAaj3B,EAAIk0B,EAAmBnxB,EAAWkzB,EAAU,SAIhF1zD,EAAI5I,MAAK,WAGL,OAFAqmC,EAAG20B,OAASsB,EAAU,IAAMkB,GAAkB,SAASn3B,EAAG+K,MAAQmpB,GA0xB9E,SAAsB78D,EAAI2oC,EAAIpnB,GAC1B,IAAIw+C,EAAMp3B,EAAGzwB,IAAM,UACfkjC,EAAO75B,EAAK65B,KAEZ8kB,EAAW3+C,EAAK0b,MAAMvgC,UAAU,QAAUqjE,GACzCz+D,KAAK85C,EAAM8c,GAEhBgI,EAAS16D,OAAOC,SAEhBy6D,EAASx6D,QAAQ2hC,OAAO,OAAQ,gBAC3Bpf,QAAQ83C,EAAK,GACb93C,QAAQ,QAAS,GACjBprB,KAAKjB,EAAMkB,OAAQ6rC,EAAGw3B,cACtBxjE,MAAM,eAAgBgpB,EAAQ5lB,WAAWC,EAAI2oC,EAAGy3B,aAAc,GAAK,MAExEF,EACK5hE,KAAK,YAAaijB,EAAKk8C,SACvBn/D,KAAK,IAAKijB,EAAKlS,MAzyBLgxD,CAAargE,EAAI2oC,EAAI,CACxByS,KAAM+iB,EACNlhC,MAAO2/B,EACPvtD,KAAM85C,EAAKgW,aAAax2B,EAAIk0B,EAAkB+B,EAAU,GAAIj2B,EAAG20B,QAC/DG,QAASA,YAGX90B,EAAG6I,MAAMn2B,eAAe,aAC9BnQ,EAAI5I,MAAK,WACLqmC,EAAG20B,OAASsB,EAAU,IAAMkB,KAAoBn3B,EAAG+K,MAAQmpB,MAInE,IAAIyD,EAAiBnjE,EAASyX,mBAAmB,cAAe,YAA3CzX,CAAwDwrC,GA2G7E,OAzGAz9B,EAAI5I,MAAK,WACL,IAIIi+D,EAEAj+D,EACAk+D,EACAC,EARAlkE,EAAIosC,EAAG+K,KAAKv6B,OAAO,GACnBunD,EAAUxX,EAAcvgB,EAAG+K,MAAMv6B,OAAO,GACxCzL,EAAMy7C,EAAKwX,cAAc3gE,EAAI2oC,GAC7Bi4B,EAA8B,YAAbj4B,EAAGq1B,MAAsBr1B,EAAGk4B,QAAU,EAkB3D,IAXGl4B,EAAGhvB,YAAc2mD,KACD,kBAAZ33B,EAAGlkC,KACF87D,EAAST,GAAkB,UAE3BS,EAAST,KACO,MAAb7oD,GAA0B,MAAN1a,IACnBosC,EAAG20B,OAASj9D,KAAKc,IAAIo/D,EAAO1/D,MAAQ,EAAI0/D,EAAOv0D,OAAS0B,EAAM,EAAGkzD,MAK1Ej4B,EAAGhvB,WAAY,CACdrX,EAAO,CAAClE,EAAG,EAAGC,EAAG,EAAG0E,EAAG,EAAG0kB,EAAG,EAAGjU,EAAG,EAAG8M,EAAG,GACzC,IAAIwgD,EAAgB,CAAC,EAAG,GAExB,GAAgB,MAAb7pD,GAQC,GAPS,MAAN1a,EACC+F,EAAK/F,GAAKosC,EAAG20B,QAEbh7D,EAAK/F,GAAKosC,EAAG20B,OAASj9D,KAAKc,IAAIo/D,EAAO1/D,MAAQ,EAAI6M,EAAM6yD,EAAOt0D,IAAM,EAAG20D,GACxEE,EAAcxlB,WAGfilB,EAAO1/D,MAAQ,EAAG,CACjB,IAAIkgE,EAASR,EAAO3uD,OAAS+2B,EAAGU,QAAUV,EAAGhH,SAC1Co/B,EAAS,IACRz+D,EAAK0+D,GAAK,EACV1+D,EAAKS,EAAIg+D,GAEb,IAAIE,EAASt4B,EAAGU,QAAUk3B,EAAO/vD,KAC9BywD,EAAS,IACR3+D,EAAK4+D,GAAK,EACV5+D,EAAKmlB,EAAIw5C,SAWjB,GAPS,MAAN1kE,EACC+F,EAAK/F,GAAKosC,EAAG20B,OAASj9D,KAAKc,IAAIo/D,EAAO9vD,OAAS,EAAI/C,EAAM6yD,EAAO/vD,KAAO,EAAGowD,IAE1Et+D,EAAK/F,GAAKosC,EAAG20B,OAASj9D,KAAKc,IAAIo/D,EAAO9vD,OAAS,EAAI8vD,EAAO3uD,MAAQlE,EAAM,EAAGkzD,GAC3EE,EAAcxlB,WAGfilB,EAAO9vD,OAAS,EAAG,CAClB,IAAI0wD,EAASZ,EAAOv0D,QAAU28B,EAAGU,QAAUV,EAAGhH,SAC3Cw/B,EAAS,IACR7+D,EAAK8+D,GAAK,EACV9+D,EAAKge,EAAI6gD,GAEb,IAAIE,EAAS14B,EAAGU,QAAUk3B,EAAOt0D,IAC9Bo1D,EAAS,IACR/+D,EAAKg/D,GAAK,EACVh/D,EAAKkR,EAAI6tD,GAKrB/+D,EAAK4oD,GAA+B,SAAdviB,EAAG/tB,OACrB+tB,EAAGp4B,SACHo4B,EAAGy2B,YAAYmC,OAAOT,EAAc,IAErCn4B,EAAG6I,MAAMxkC,OAAS/H,EAAW+0D,WAAW/iD,KACvC3U,EAAK/F,IAAM67D,EAAiBzvB,IAAOA,EAAG6I,MAAM9F,UAAY,IAGzD/C,EAAGu0B,QAAwB,SAAdv0B,EAAG/tB,UACf4lD,EAAa,CAACpiE,EAAG,EAAGC,EAAG,EAAG0E,EAAG,EAAG0kB,EAAG,EAAGjU,EAAG,EAAG8M,EAAG,IAEpCogD,GAAW/3B,EAAG64B,UACtB74B,EAAGu0B,SAAwB,IAAdv0B,EAAGu0B,SAAiBsD,EAAWE,IAAYE,IAE1C,IAAdj4B,EAAGu0B,QAAiC,UAAdv0B,EAAGu0B,OACxBsD,EAAWtV,GAAiBviB,EAAGy2B,YAAYmC,OAAOT,EAAc,IAC5C,QAAdn4B,EAAGu0B,QAAkC,aAAdv0B,EAAGu0B,SAChCsD,EAAWtV,GAAiB,CAACviB,EAAG84B,kBAAmB94B,EAAG+4B,mBAAmBZ,EAAc,MAKhGR,IACCG,EAAkBtjE,EAASyX,mBAAmB,cAAe,iBAA3CzX,CAA6D6C,EAAI2oC,IAGvFjjB,EAAMiI,WAAW3tB,EAAI24D,GAAehwB,GAAKrmC,GACzCojB,EAAMiI,WAAW3tB,EAAI44D,GAAqBjwB,GAAK63B,GAC/C96C,EAAMiI,WAAW3tB,EAAI64D,GAAwBlwB,GAAK83B,MAGlDl/C,EAAKogD,WACHrB,GAA8B,WAAZ33B,EAAG+K,MAEvBxoC,EAAI5I,MAAK,WAAa,OAwwB9B,SAAmBtC,EAAI2oC,GACnB,IAKIi5B,EALA38D,EAAajF,EAAGkF,YAChB8R,EAAO2xB,EAAGzwB,IACVjB,EAAWD,EAAKmC,OAAO,GACvB/M,EAAWu8B,EAAG6I,MAAM1zC,KAAKE,KAI7B,GAAG2qC,EAAG6I,MAAMn2B,eAAe,YACvBumD,EAAgBj5B,EAAG20B,OAAS30B,EAAG6I,MAAM9F,SAAW0sB,EAAiBzvB,OAC9D,CACH,GAAe,kBAAZA,EAAGlkC,KACFm9D,EAAgBj5B,EAAG20B,WAChB,CAEHsE,EAAgB,GADC,IACIx1D,GAAyBu8B,EAAG64B,UAAY74B,EAAG64B,UAAY,EAAI,GAIhFI,GADY,MAAb3qD,EAC8B,QAAZ0xB,EAAG+K,KAChBtnC,GAAYu8B,EAAGk5B,eAAiB,EAAI,GACpCz1D,GAAYu8B,EAAGk5B,eAAiB,IAAM,IAEb,UAAZl5B,EAAG+K,KAChBtnC,GAAYu8B,EAAGk5B,eAAiB,EAAI,IACpCz1D,GAAYu8B,EAAGk5B,eAAiB,GAAM,GAIlD,IACInwD,EAAWtT,EAAGC,EAWdyjE,EAZAp0D,EAAMy7C,EAAKwX,cAAc3gE,EAAI2oC,GAGjB,MAAb1xB,GACC7Y,EAAIuqC,EAAGU,QAAUV,EAAGhH,QAAU,EAC9BtjC,EAAiB,QAAZsqC,EAAG+K,KAAkBhmC,EAAMk0D,EAAgBl0D,EAAMk0D,IAEtDvjE,EAAIsqC,EAAGU,QAAUV,EAAGhH,QAAU,EAC9BvjC,EAAiB,UAAZuqC,EAAG+K,KAAoBhmC,EAAMk0D,EAAgBl0D,EAAMk0D,EACxDlwD,EAAY,CAAC0vB,OAAQ,MAAOr7B,OAAQ,IAKxC,GAAe,kBAAZ4iC,EAAGlkC,KAA0B,CAC5B,IAAIs9D,EAAap5B,EAAGw0B,YAAYx0B,EAAGzwB,IAAM,QAOzC,GALA4pD,EAAQ,CACJ1uD,UAAW2uD,EACXruB,KAAM/K,EAAG+K,MAGVquB,GAAcA,EAAW/iE,QAAU+iE,EAAW/iE,OAAOoH,WAAY,CAChE,IAAI47D,EAAcr8C,EAAQrT,aAAayvD,EAAW/iE,OAAOoH,YACzD07D,EAAMG,WAAaD,EAAY5jE,EAC/B0jE,EAAMI,UAAYF,EAAY3jE,EAG/BsqC,EAAG6I,MAAMn2B,eAAe,cACvBymD,EAAMv6C,IAAM,GAIpB,OAAOuhC,EAAOpb,KAAK1tC,EAAIgX,EAAO,QAAS,CACnCmrD,cAAex5B,EACfy5B,SAAUz5B,EAAG3wB,MAAQ,cACrBqqD,YAAap9D,EAAW+0D,WAAW/iD,GACnC6qD,MAAOA,EACPpwD,UAAWA,EACX+S,WAAY,CAACrmB,EAAGA,EAAGC,EAAGA,EAAG,cAAe,YA50BXikE,CAAUtiE,EAAI2oC,MAGxCtrC,EAAI87B,YAAYjuB,IAlRvB,SAAS40D,GAAkByC,GACvB,IAAIxC,EAAM/oD,GAAQurD,GAAU,QAE5B,OADIhF,EAASwC,KAAMxC,EAASwC,GAyVpC,SAA4Bp3B,EAAIo3B,GAC5B,IAAI9zD,EAAKD,EACLwE,EAAMoB,EAEP+2B,EAAGw0B,YAAY4C,GAAK/hE,QACnBiO,EAAM8rB,IACN/rB,GAAU+rB,IACVvnB,EAAOunB,IACPnmB,GAASmmB,IACT4Q,EAAGw0B,YAAY4C,GAAK/jE,MAAK,WACrB,IAAIwmE,EAAYhK,EAAgB/7D,MAQ5B2V,EAAKuT,EAAQvU,KAAKoxD,EAAUxjE,OAAOoH,YACvC6F,EAAM5L,KAAKi3B,IAAIrrB,EAAKmG,EAAGnG,KACvBD,EAAS3L,KAAKc,IAAI6K,EAAQoG,EAAGpG,QAC7BwE,EAAOnQ,KAAKi3B,IAAI9mB,EAAM4B,EAAG5B,MACzBoB,EAAQvR,KAAKc,IAAIyQ,EAAOQ,EAAGR,YAG/B3F,EAAM,EACND,EAAS,EACTwE,EAAO,EACPoB,EAAQ,GAGZ,MAAO,CACH3F,IAAKA,EACLD,OAAQA,EACRwE,KAAMA,EACNoB,MAAOA,EACPnB,OAAQzE,EAASC,EACjBpL,MAAO+Q,EAAQpB,GA9XoBiyD,CAAmB95B,EAAIo3B,IACnDxC,EAASwC,KA+YxB5W,EAAK0V,aAAe,SAASl2B,GACzB,IAAI1xB,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzBupD,EAAe,CAACtkE,EAAG,MAAOC,EAAG,SAAS4Y,GACtC0rD,EAAOh6B,EAAG+K,OAASgvB,EAAe,GAAK,EACvCx5D,EAAM,EAAE,EAAG,EAAGy5D,GAAOA,GASzB,MAPiB,WAAbh6B,EAAGq1B,QAAsC,MAAb/mD,KAC5B/N,EAAMA,EAAIuO,KAAI,SAASxU,GAAK,OAAQA,MAGrC0lC,EAAG+K,MACFxqC,EAAI5G,KAAK,CAACmlB,GAAI,EAAGjU,GAAI,EAAGzQ,EAAG,EAAGud,EAAG,GAAGqoB,EAAG+K,KAAKv6B,OAAO,KAEhDjQ,GAYXigD,EAAKuU,YAAc,SAAS/0B,GACxB,IAAI1xB,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzBpT,EAAS4iC,EAAGU,QAChB,MAAoB,MAAbpyB,EACH,SAAShb,GAAK,MAAO,cAAgB8J,EAAS4iC,EAAGuuB,IAAIj7D,EAAEmC,IAAM,OAC7D,SAASnC,GAAK,MAAO,gBAAkB8J,EAAS4iC,EAAGuuB,IAAIj7D,EAAEmC,IAAM,MAevE+qD,EAAKgW,aAAe,SAASx2B,EAAIi6B,EAAOC,EAAKj+D,GACzCA,OAAcmC,IAARnC,EAAoBA,EAAM+jC,EAAGk4B,QAEnC,IAAI5pD,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzBoO,GAAOohB,EAAG64B,WAAa,GAAK,EAEhC,MAAoB,MAAbvqD,EACH,OAAS2rD,EAAQr7C,EAAMs7C,GAAO,IAAOj+D,EAAMi+D,EAC3C,KAAOD,EAAQr7C,EAAMs7C,GAAO,MAASj+D,EAAMi+D,GAwBnD1Z,EAAKyW,aAAe,SAASj3B,EAAIi6B,EAAOE,GACpC,IAAI7rD,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzB4pD,EAAsC,eAAfp6B,EAAGouB,SAAyC,YAAbpuB,EAAGq1B,MAEzDgF,EAAgB,EAChBC,EAAa,EAKjB,GAHGF,IACCC,GAAiBr6B,EAAGk4B,SAErBiC,GAAsB,YAAbn6B,EAAGq1B,MAAqB,CAChC,IAAIkF,EAAM7lE,EAAIy1B,QAAQgwC,GACtBE,EAAgBr6B,EAAGk4B,QAAUxgE,KAAK44B,IAAIiqC,GAAO,EAC7CD,EAAat6B,EAAGk4B,QAAUxgE,KAAK0oC,IAAIm6B,GAEpCv6B,EAAGk5B,iBAAmBkB,GAAwBp6B,EAAGw6B,YAChDH,GAAiB,GAAMr6B,EAAGimB,SAAS5wD,MAIvC,IAKImrB,EAAIC,EAAIg6C,EAAIC,EALZn6D,EAAM,CACN85D,cAHJA,IAAkBr6B,EAAG64B,WAAa,GAAK,EAInCyB,WAAYA,GA8ChB,MAzCgB,MAAbhsD,GACCosD,EAAqB,WAAZ16B,EAAG+K,KAAoB,GAAK,EACrCvqB,EAAK85C,EAAaI,EAClBj6C,EAAKw5C,EAAQI,EAAgBK,EAC7BD,EAAiB,WAAZz6B,EAAG+K,KAAoB,GAAK,GAEjCxqC,EAAIo6D,IAAM,SAASrnE,GAAK,OAAOA,EAAEwQ,GAAK0c,GACtCjgB,EAAIq6D,IAAM,SAAStnE,GAAK,OAAOA,EAAEyQ,GAAK0c,EAAKntB,EAAEmQ,SAAWg3D,GACxDl6D,EAAIs6D,SAAW,SAASvnE,EAAGunB,GACvB,OAAIvmB,EAAUumB,IAAY,IAANA,GAAiB,MAANA,EAGvBA,EAAI6/C,EAAS,EAAK,MAAQ,QAFvB,UAIfn6D,EAAIu6D,SAAW,SAASxnE,EAAGunB,EAAG/kB,GAC1B,OAAQ+kB,GAAK,IAAMA,EAAI,IAAO,GAAM/kB,EACpB,QAAZkqC,EAAG+K,MAAkBj1C,EACrB,IAEW,MAAbwY,IACNosD,EAAqB,UAAZ16B,EAAG+K,KAAmB,GAAK,EACpCvqB,EAAK65C,EACL55C,GAAM65C,EAAaI,EACnBD,EAAgC,KAA3B/iE,KAAK6/B,IAAIyI,EAAG+6B,WAAoB,GAAM,EAE3Cx6D,EAAIo6D,IAAM,SAASrnE,GAAK,OAAOA,EAAEwQ,GAAKm2D,GAASz5C,EAAKltB,EAAEmQ,SAAWg3D,GAAMC,GACvEn6D,EAAIq6D,IAAM,SAAStnE,GAAK,OAAOA,EAAEyQ,GAAK0c,EAAKntB,EAAEmQ,SAAW48C,GACxD9/C,EAAIs6D,SAAW,SAASvnE,EAAGunB,GACvB,OAAGvmB,EAAUumB,IAAsB,KAAhBnjB,KAAK6/B,IAAI1c,GACjB,SAEQ,UAAZmlB,EAAG+K,KAAmB,QAAU,OAE3CxqC,EAAIu6D,SAAW,SAASxnE,EAAGunB,EAAG/kB,GAE1B,OADA+kB,GAAiB,SAAZmlB,EAAG+K,KAAkB,GAAK,IACnB,IAAMj1C,EACd+kB,EAAI,IAAM,GAAM/kB,EAChB,IAILyK,GAuBXigD,EAAKmW,UAAY,SAASt/D,EAAI2oC,EAAIpnB,GAC9BA,EAAOA,GAAQ,GAEf,IAAIw+C,EAAMp3B,EAAGzwB,IAAM,OAEf8lD,EAAQz8C,EAAK0b,MAAMvgC,UAAU,QAAUqjE,GACtCz+D,KAAKqnC,EAAGq1B,MAAQz8C,EAAK65B,KAAO,GAAI8c,GAErC8F,EAAMx4D,OAAOC,SAEbu4D,EAAMt4D,QAAQC,OAAO,QAChBsiB,QAAQ83C,EAAK,GACb93C,QAAQ,QAAS,GACjBA,QAAQ,SAAwB,IAAf1G,EAAKoiD,OACtB9mE,KAAKjB,EAAMkB,OAAQ6rC,EAAGi7B,WACtBjnE,MAAM,eAAgBgpB,EAAQ5lB,WAAWC,EAAI2oC,EAAGk7B,UAAW,GAAK,MAChEvlE,KAAK,IAAKijB,EAAKlS,MAEpB2uD,EAAM1/D,KAAK,YAAaijB,EAAKk8C,UAwBjCtU,EAAKuV,SAAW,SAAS1+D,EAAI2oC,EAAIpnB,GAC7BA,EAAOA,GAAQ,GAEf,IAAIw+C,EAAMp3B,EAAGzwB,IAAM,OACfkjC,EAAO75B,EAAK65B,KACZ0oB,EAAYviD,EAAKg9C,YACrB,IAAmB,IAAhB51B,EAAGo7B,SACF3oB,EAAO,QACJ,GAAG0oB,GAAa3a,EAAK6a,mBAAmBhkE,EAAI2oC,EAAIm7B,GAEnD,IADA,IAAIG,EAA8B,UAAhBt7B,EAAG3mB,SACbhd,EAAI,EAAGA,EAAIo2C,EAAKx4C,OAAQoC,IAAK,CACjC,IAAI+/C,EAAK3J,EAAKp2C,GAAG5G,EACjB,GAAG6lE,GAAelf,EAAM1kD,KAAK6/B,IAAI6kB,GAAMpc,EAAGvmB,MAAQ,IAAM,CAKpD,GAJAg5B,EAAOA,EAAK3/B,MAAM,EAAGzW,GAAG2R,OAAOykC,EAAK3/B,MAAMzW,EAAI,KAI3Ci/D,EACE,MADWj/D,KAM5B,IAAIsV,EAAOiH,EAAK0b,MAAMvgC,UAAU,QAAUqjE,GACrCz+D,KAAK85C,EAAM8c,GAEhB59C,EAAK9U,OAAOC,SAEZ6U,EAAK5U,QAAQC,OAAO,QACfsiB,QAAQ83C,EAAK,GACb93C,QAAQ,SAAwB,IAAf1G,EAAKoiD,OAE3Bh7B,EAAGu7B,IAAMv+C,EAAQ5lB,WAAWC,EAAI2oC,EAAGw7B,UAAW,GAE9C7pD,EAAKhc,KAAK,YAAaijB,EAAKk8C,SACvBn/D,KAAK,IAAKijB,EAAKlS,MACfxS,KAAKjB,EAAMkB,OAAQ6rC,EAAGy7B,WAAa,QACnCznE,MAAM,eAAgBgsC,EAAGu7B,IAAM,MAEZ,mBAAd3iD,EAAKlS,MAAqBiL,EAAKhc,KAAK,IAAKijB,EAAKlS,OAoB5D85C,EAAKwV,aAAe,SAAS3+D,EAAI2oC,EAAIpnB,GACjCA,EAAOA,GAAQA,EAEf,IAAIw+C,EAAMp3B,EAAGzwB,IAAM,KACfmsD,EAAOlb,EAAK6a,mBAAmBhkE,EAAI2oC,EAAIpnB,EAAKg9C,aAE5C+F,EAAK/iD,EAAK0b,MAAMvgC,UAAU,QAAUqjE,GACnCz+D,KAAK+iE,EAAO,CAAC,CAACjmE,EAAG,EAAG8+B,GAAIyL,EAAGzwB,MAAQ,IAExCosD,EAAG9+D,OAAOC,SAEV6+D,EAAG5+D,QAAQC,OAAO,QACbsiB,QAAQ83C,EAAK,GACb93C,QAAQ,KAAM,GACdA,QAAQ,SAAwB,IAAf1G,EAAKoiD,OACtB3nE,MAAK,WAIFulB,EAAK0b,MAAMvgC,UAAU,QAAQg1B,MAAK,SAAS6yC,EAAIC,GAC3C,OAAOhwD,EAAQyvC,OAAOsgB,EAAGrnC,GAAIsnC,EAAGtnC,UAI5ConC,EAAGhmE,KAAK,YAAaijB,EAAKk8C,SACrBn/D,KAAK,IAAKijB,EAAKlS,MACfxS,KAAKjB,EAAMkB,OAAQ6rC,EAAG87B,eAAiB7oE,EAAMyM,aAC7C1L,MAAM,eAAgBgpB,EAAQ5lB,WAAWC,EAAI2oC,EAAG+7B,cAAe/7B,EAAGu7B,KAAO,GAAK,OA2BvF/a,EAAKuW,WAAa,SAAS1/D,EAAI2oC,EAAIpnB,GAC/BA,EAAOA,GAAQ,GAEf,IAAItc,EAAajF,EAAGkF,YAChB8R,EAAO2xB,EAAGzwB,IACVjB,EAAWD,EAAKmC,OAAO,GACvB4mD,EAAMx+C,EAAKw+C,KAAO/oD,EAAO,OACzBokC,EAAO75B,EAAK65B,KACZukB,EAAWp+C,EAAKo+C,SAChBgF,EAAYpjD,EAAK0+C,UAAY,EAAIt3B,EAAG+6B,UACpCkB,GAAaj8B,EAAG00B,iBAAmB,IAAI0C,GAEvCgC,EAAaxgD,EAAK0b,MAAMvgC,UAAU,KAAOqjE,GACxCz+D,KAAKqnC,EAAGk5B,eAAiBzmB,EAAO,GAAI8c,GAErC2M,EAAc,GAyClB,SAASC,EAAevoE,EAAGumE,GACvBvmE,EAAEP,MAAK,SAASC,GACZ,IAAIumE,EAAY7mE,EAAGa,OAAOC,MACtB8qC,EAAei7B,EAAUhmE,OAAO,oBAChCoe,EAAS+kD,EAAS6D,SAASvnE,EAAG6mE,GAE9BpxD,EAAY6P,EAAKk8C,QAAQ5gE,KAAK2lE,EAAUxjE,OAAQ/C,IAC9CgB,EAAU6lE,IAAqB,IAAVA,EACtB,WAAaA,EAAQ,IAAMnD,EAAS2D,IAAIrnE,GAAK,KACzC0jE,EAAS4D,IAAItnE,GAAKA,EAAEmQ,SAAW,GAAK,IACzC,IAGA24D,EAASznE,EAAakP,UAAUg2D,GAChCjxB,EAAa/zC,EAAevB,EAAEmQ,SAC9B44D,EAAerF,EAAS8D,SAASxnE,EAAGgB,EAAU6lE,IAAUA,EAAQ,GAAIiC,EAAS,GAAKxzB,GAMtF,GAJGyzB,IACCtzD,GAAa,iBAAmBszD,EAAe,KAGhDz9B,EAAaE,QACZ+6B,EAAUhmE,OAAO,QAAQ8B,KAAK,CAC1BoT,UAAWA,EACX,cAAekJ,QAEhB,CACH,IACIqqD,EADUt/C,EAAQvU,KAAKm2B,EAAavoC,QAAQ6B,MACxB,CAACiL,KAAM,GAAKD,MAAO,IAAK+O,GAChD2sB,EAAajpC,KAAK,YAAaoT,GAAauzD,EAAU,aAAeA,EAAU,MAAQ,SApEnGlD,EAAWr8D,QAAQC,OAAO,KACrBsiB,QAAQ83C,EAAK,GACbp6D,OAAO,QAGHrH,KAAK,cAAe,UACpBtC,MAAK,SAASC,GACX,IAAIumE,EAAY7mE,EAAGa,OAAOC,MACtByoE,EAAallE,EAAGmlE,UAAUviE,OAE9B4/D,EACK3lE,KAAKS,EAAayU,aAAc4tD,EAAS2D,IAAIrnE,GAAI0jE,EAAS4D,IAAItnE,IAC9DY,KAAK8oB,EAAQ7nB,KAAM7B,EAAE6B,KAAM7B,EAAEmQ,SAAUnQ,EAAE4R,WACzCb,KAAK/Q,EAAE+Q,MACPnQ,KAAKS,EAAayQ,gBAAiB/N,GAErCA,EAAGmlE,UAAUD,GAKZL,EAAYviE,KAAKtC,EAAGmlE,UAAUznD,MAAMgc,MAAK,WACrCorC,EAAetC,EAAWmC,OAI9BG,EAAetC,EAAWmC,MAI1C5C,EAAWv8D,OAAOC,SAEf8b,EAAKy+C,oBACJ+B,EAAW/lE,MAAK,SAASC,GACrBN,EAAGa,OAAOC,MAAMD,OAAO,QAClBK,KAAKS,EAAayU,aAAc4tD,EAAS2D,IAAIrnE,GAAI0jE,EAAS4D,IAAItnE,OA2C3E6oE,EAAe/C,EAAa6C,EAAY,EAAKA,EAAYD,GAMzD,IAAIS,EAAY,KAyEbz8B,EAAGw0B,cACFx0B,EAAGw0B,YAAY4C,GAAOgC,GAG1B,IAAI72D,EAAM,CAjFV,WACI,OAAO25D,EAAYjiE,QAAUkgC,QAAQuiC,IAAIR,KAqF1Cl8B,EAAGhvB,YAAc1U,EAAWqgE,4BAA4C,KAAdV,GACzDQ,EAAY,GACZl6D,EAAI5I,MAAK,WACLwiE,EAAe/C,EAAY6C,OAG/B15D,EAAI5I,MAtFR,WAMI,GALAwiE,EAAe/C,EAAY4C,GAKxBvpB,EAAKx4C,QAAuB,MAAbqU,IAAqBha,EAAU0nE,KAChC,QAAZh8B,EAAGlkC,MAAiD,MAA/B6X,OAAOqsB,EAAGvmB,OAAOjJ,OAAO,IAChD,CACEisD,EAAY,EAEZ,IAEIpgE,EAFAugE,EAAc,EACdC,EAAW,GAsBf,GAnBAzD,EAAW/lE,MAAK,SAASC,GACrBspE,EAAcllE,KAAKc,IAAIokE,EAAatpE,EAAEmQ,UAEtC,IAAIhO,EAAIuqC,EAAGuuB,IAAIj7D,EAAEmC,GACbokE,EAAYhK,EAAgB/7D,MAC5B2V,EAAKuT,EAAQvU,KAAKoxD,EAAUxjE,QAEhCwmE,EAASljE,KAAK,CAEV2J,IAAK,EACLD,OAAQ,GACRyE,OAAQ,GACRD,KAAMpS,EAAIgU,EAAGvR,MAAQ,EAErB+Q,MAAOxT,EAAIgU,EAAGvR,MAAQ,EAAI,EAC1BA,MAAOuR,EAAGvR,MAAQ,OAIP,eAAf8nC,EAAGouB,UAA4BpuB,EAAGquB,cAAkBz1C,EAAK0+C,UAiBtD,CACH,IAAIwF,EAAOrqB,EAAKx4C,OAEZ8iE,EADcrlE,KAAK6/B,KAAKkb,EAAKqqB,EAAO,GAAGrnE,EAAIg9C,EAAK,GAAGh9C,GAAKuqC,EAAGg9B,KAAOF,EAAO,GACjC,IAAdF,GAAkC,kBAAZ58B,EAAGlkC,KAGvD,IAAIO,EAAI,EAAGA,EAAIwgE,EAAS5iE,OAAS,EAAGoC,IAChC,GAAG3H,EAAIk6B,cAAciuC,EAASxgE,GAAIwgE,EAASxgE,EAAI,IAAK,CAChDogE,EAAYM,EAAW,GAAK,GAC5B,WA1B4D,CACpE,IAAIE,EAAM,EAKV,IAJGj9B,EAAGq1B,QAAO4H,GAAOj9B,EAAGk7B,UAAY,GAI/B7+D,EAAI,EAAGA,EAAIwgE,EAAS5iE,OAAQoC,IAAK,CACjC,IAAImyD,EAAO/b,EAAKp2C,GAAGmyD,KACf0O,EAAML,EAASxgE,GACnB,GACiB,OAAZmyD,EAAK,IAAgB0O,EAAIr1D,KAAOm4B,EAAGuuB,IAAIC,EAAK,IAAOyO,GACvC,OAAZzO,EAAK,IAAgBxuB,EAAGuuB,IAAIC,EAAK,IAAM0O,EAAIj0D,MAASg0D,EACvD,CACER,EAAY,GACZ,QAiBTA,GACCN,EAAe/C,EAAYqD,OAwBpCz8B,EAAGy0B,aACFlyD,EAAI5I,MAAK,WACLqmC,EAAGy0B,YAAY2C,GAAqB,OAAdqF,EACjBnoE,EAAU0nE,GAAaA,EAAY,EACpCS,KAIZ,IAAIrwC,EAAO13B,EAAI87B,YAAYjuB,GAE3B,OADG6pB,GAAQA,EAAK2E,MAAM15B,EAAGmlE,UAAU7iE,KAAKyyB,GACjCA,GAoDXo0B,EAAKwX,cAAgB,SAAS3gE,EAAI2oC,GAC9B,IAGIm9B,EAHA3hC,EAAKnkC,EAAGkF,YAAYkoB,MACpBnW,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzBu6B,EAAO/K,EAAG+K,KAiBd,MAdiB,SAAd/K,EAAG/tB,OACFkrD,EAAan9B,EAAGy2B,YACG,MAAbnoD,EACN6uD,EAAa,CACTz8B,QAASlF,EAAG3wB,GAAK,GAAKm1B,EAAGp4B,UAAY,IAAM4zB,EAAG1lC,EAC9CkjC,QAAS,GAEM,MAAb1qB,IACN6uD,EAAa,CACTz8B,QAASlF,EAAG1c,GAAKkhB,EAAGp4B,UAAY,GAAK4zB,EAAG3lC,EACxCmjC,QAAS,IAIL,QAAT+R,GAA2B,SAATA,EACVoyB,EAAWz8B,QACH,WAATqK,GAA8B,UAATA,EACpBoyB,EAAWz8B,QAAUy8B,EAAWnkC,aADpC,GAqHXwnB,EAAK6a,mBAAqB,SAAShkE,EAAI2oC,EAAI41B,GACvC,IAAIjjD,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KACrC,OACKlzC,EAAI,GAAKA,EAAI,IAAM,GACpBqtB,EAAGo9B,WACU,WAAZp9B,EAAGlkC,MAAiC,MAAZkkC,EAAGlkC,SAC1BkkC,EAAGonB,aAAepnB,EAAGqnB,WAAW,KAAO7gC,KAErCopC,EAAS5vB,EAAI,KAgBzB,SAAgC3oC,EAAI2oC,EAAI41B,EAAajjD,GACjD,IAAI0qD,EAAkBzH,EAAYvX,UAClC,IAAIgf,EAAiB,OAErB,IAAI/gE,EAAajF,EAAGkF,YAChB+R,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GACzB+xC,EAAgB/B,EAAK+B,cAAcviB,EAAGzwB,KAEtC+tD,EAAet9B,EAAGU,SAChBhpC,KAAK6/B,IAAI5kB,EAAI,IAAMjb,KAAK6/B,IAAI5kB,EAAI,MAAuB,MAAbrE,GAC5C,EAAI0xB,EAAGhH,SAGX,SAASukC,EAAaC,GAClB,IAAIA,EAAIhD,WAAagD,EAAI3E,UAAW,OAAO,EAC3C,IAAI4E,EAAY/lE,KAAKc,KAAKglE,EAAI3E,UAAY74B,EAAG+7B,eAAiB,EAAG,GAEjE,SAAS2B,EAAYC,GACjB,MAAuB,iBAATA,GAAqBjmE,KAAK6/B,IAAIomC,EAAOL,GAAgBG,EAGvE,GAAGC,EAAYF,EAAIrJ,oBAAsBuJ,EAAYF,EAAInJ,qBACrD,OAAO,EAEX,IAAIuJ,EAAgBJ,EAAI5G,gBAAkB,GAC1C,IAAI,IAAIp9D,KAAKokE,EACT,GAAGF,EAAYE,EAAcpkE,GAAG,KAAOkkE,EAAYE,EAAcpkE,GAAG,IAChE,OAAO,EAKnB,IAAIg/C,EAAWl8C,EAAWo/C,OAAOka,EAAY5B,cAC7C,KAAKxb,EAAS4B,cAAgB5B,GAAUmD,SAAS1hD,OAC7C,OAAOsjE,EAAa3H,GAIxB,IADA,IAAIiI,EAAoBrd,EAAK7wC,KAAKtY,EAAIkrD,GAC9BlmD,EAAI,EAAGA,EAAIwhE,EAAkB5jE,OAAQoC,IAAK,CAC9C,IAAIyhE,EAAeD,EAAkBxhE,GACrC,GACIyhE,EAAazf,YAAcgf,GAC3BE,EAAaO,GAEb,OAAO,GA3DNC,CAAuB1mE,EAAI2oC,EAAI41B,EAAajjD,IAgEzD,SAAuBtb,EAAI2oC,GAKvB,IAJA,IAAI1zB,EAAWjV,EAAG8uC,UACdrvC,EAAUkpC,EAAGg0B,aACb1lD,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GAErBnU,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK,CACrC,IAAI9I,EAAQ+Y,EAASjQ,GAErB,IAAqB,IAAlB9I,EAAM6oB,SAAqB7oB,EAAMyD,MAAQzD,EAAM0D,QAAWH,EAAS,CAClE,GACItC,EAAS2C,QAAQ5D,EAAO,aACxBA,EAAM+Z,cAAgB,CAAC7X,EAAG,IAAKC,EAAG,KAAK4Y,GACzC,OAAO,EAET,GACI/a,EAAMgC,MACNhC,EAAMgC,KAAKib,OAAOjd,EAAMgC,KAAK0E,OAAS,KAAOqU,EAC/C,OAAO,GAGjB,OAAO,EAnFC0vD,CAAc3mE,EAAI2oC,KAK9BwgB,EAAKoP,SAAW,SAAS5vB,EAAIyS,GACzB,OAAOA,EAAK5D,QAAO,SAASv7C,GAAK,OAAOs8D,EAAS5vB,EAAI1sC,EAAEmC,OA+F3D+qD,EAAKyd,gBAAkB,SAAS5mE,GAE5B,IADA,IAAI2rD,EAASxC,EAAK7wC,KAAKtY,EAAI,IAAI,GACvBgF,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CACnC,IAAI2jC,EAAKgjB,EAAO3mD,GACb2jC,EAAGhvB,aACF+L,EAAMkhD,gBAAgB5mE,EAAI24D,GAAehwB,IACtCA,EAAGu0B,QACFx3C,EAAMkhD,gBAAgB5mE,EAAI44D,GAAqBjwB,KAGpDxrC,EAASyX,mBAAmB,cAAe,YAA3CzX,CAAwDwrC,IACvDjjB,EAAMkhD,gBAAgB5mE,EAAI64D,GAAwBlwB,MAU9DwgB,EAAK0d,KAAO,SAAS7mE,EAAIjE,GAGrB,IAFA,IAAI+qE,EAOR,SAAwB9mE,EAAIjE,GACxB,IACIiJ,EAAGkQ,EADH49B,EAAS,GAGb,IAAI9tC,EAAI,EAAGA,EAAIjJ,EAAO6G,OAAQoC,IAAK,CAC/B,IAAI+hE,EAAU,GACVhiB,EAAK/kD,EAAG8uC,UAAU/yC,EAAOiJ,IAAIrF,MAC7BqlD,EAAKhlD,EAAG8uC,UAAU/yC,EAAOiJ,IAAIpF,MACjC,GAAImlD,GAAOC,EAAX,CAEA,IAAI9vC,EAAI,EAAGA,EAAI49B,EAAOlwC,OAAQsS,KACM,IAA7B49B,EAAO59B,GAAG9W,EAAE+E,QAAQ4hD,KAA2C,IAA7BjS,EAAO59B,GAAG7W,EAAE8E,QAAQ6hD,IACrD+hB,EAAQzkE,KAAK4S,GAIrB,GAAI6xD,EAAQnkE,OAAZ,CAKA,IACIokE,EADAC,EAASn0B,EAAOi0B,EAAQ,IAG5B,GAAGA,EAAQnkE,OAAS,EAChB,IAAIsS,EAAI,EAAGA,EAAI6xD,EAAQnkE,OAAQsS,IAC3B8xD,EAASl0B,EAAOi0B,EAAQ7xD,IACxB4jD,GAAgBmO,EAAO7oE,EAAG4oE,EAAO5oE,GACjC06D,GAAgBmO,EAAO5oE,EAAG2oE,EAAO3oE,GAGzCy6D,GAAgBmO,EAAO7oE,EAAG,CAAC2mD,IAC3B+T,GAAgBmO,EAAO5oE,EAAG,CAAC2mD,SAfvBlS,EAAOxwC,KAAK,CAAClE,EAAG,CAAC2mD,GAAK1mD,EAAG,CAAC2mD,MAkBlC,OAAOlS,EA1CQo0B,CAAelnE,EAAIjE,GAE1BiJ,EAAI,EAAGA,EAAI8hE,EAASlkE,OAAQoC,IAChCi0D,GAAcj5D,EAAI8mE,EAAS9hE,GAAG5G,EAAG0oE,EAAS9hE,GAAG3G,K,8CCl8FrD,IAAIwnB,EAAY,EAAQ,YAExBhqB,EAAOC,QAAU,CACbqrE,WAAY,YACZ3oD,KAAMqH,EAAUrH,KAEhBrK,iBAAkB,EAAQ,YAC1BywC,qBAAsB,EAAQ,YAE9BlX,KAAM,EAAQ,c,8CCTlB,IAAI9xC,EAAQ,EAAQ,YAChB++B,EAAa,EAAQ,YAAaA,WAEtC9+B,EAAOC,QAAU,SAAkBS,EAAG4O,EAAIjP,GACtC,IAAIyE,EAAOzE,EAAM0K,OAAOjG,KACpB+G,EAAYizB,EAAWh6B,EAAK5D,MAAOoO,EAAGiE,MAAQxT,EAAMyM,YACpDpI,EAAY06B,EAAWh6B,EAAKE,MAAOsK,EAAGiE,MAAQ,EAElD7S,EAAEI,MAAM,eAAgBsD,GACnBpD,KAAKjB,EAAMsC,KAAMiN,EAAGpO,OACpBF,KAAKjB,EAAMkB,OAAQ4K,K,8CCV5B,IAAIvK,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YAElBxB,EAAOC,QAAU,CACbqrE,WAAY,YACZ3oD,KAAM,gBAEN4oD,OAAQ,CACJjxD,SAAU,CACNkxD,MAAO,CAACzjC,YAAa,EAAQ,eAIrCzvB,iBAAkB,EAAQ,YAC1BmzD,eAAgB,EAAQ,YACxBC,gBAMJ,SAAqBxyD,EAAUC,GAC3B,IAAIwyD,EAAOrqE,EAASsqE,iBAAiBC,KACrC,IAAIF,EAAM,OAKV,IAHA,IAAI7iB,EAAY6iB,EAAK7iB,UAEjB1iD,EAAOD,OAAOC,KAAK8S,GACf/P,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAAK,CACjC,IAAI7C,EAAIF,EAAK+C,GACV2/C,EAAU3rC,KAAK7W,KAAO4S,EAAS5S,GAAGyhC,aAAe,IAAIhhC,SACpDvF,EAAI44B,WAAWjhB,EAAU2yD,iBAAkBH,GAC3CnqE,EAAI44B,WAAWjhB,EAAUoB,UAAUsxD,KAAMvlE,MAfjDylE,QAAS,EAAQ,YACjBl6B,KAAM,EAAQ,c,8CCPlB5xC,QAAQ23B,aAAe,SAAsBlS,GACzC,MACmB,SAAjBA,EAAK8L,SACa,SAAjB9L,EAAK8L,SAAsB9L,EAAKnjB,GAAK,EAAI,GAIhDtC,QAAQyxB,eAAiB,SAAwBhM,GAC7C,MACqB,WAAjBA,EAAK8L,SACa,SAAjB9L,EAAK8L,SAAsB9L,EAAKnjB,EAAI,EAAI,GAAKmjB,EAAKnjB,EAAI,EAAI,GAInEtC,QAAQwxB,cAAgB,SAAuB/L,GAC3C,MACmB,UAAjBA,EAAK8L,SACa,SAAjB9L,EAAK8L,SAAsB9L,EAAKnjB,GAAK,EAAI,GAIhDtC,QAAQ43B,YAAc,SAAqBnS,GACvC,MACqB,QAAjBA,EAAKiM,SACa,SAAjBjM,EAAKiM,SAAsBjM,EAAKljB,GAAK,EAAI,GAIlDvC,QAAQ4xB,eAAiB,SAAwBnM,GAC7C,MACqB,WAAjBA,EAAKiM,SACa,SAAjBjM,EAAKiM,SAAsBjM,EAAKljB,EAAI,EAAI,GAAKkjB,EAAKljB,EAAI,EAAI,GAInEvC,QAAQ2xB,eAAiB,SAAwBlM,GAC7C,MACmB,WAAjBA,EAAKiM,SACa,SAAjBjM,EAAKiM,SAAsBjM,EAAKljB,GAAK,EAAI,I,8CCjDhD,IAAI1C,EAAK,EAAQ,YACb0B,EAAM,EAAQ,YAgElB,SAASwqE,EAAUC,GACf,MAAO,IAAMA,EAAY,eAG7BjsE,EAAOC,QAAU,CACbisE,kBAnCJ,SACID,EACAp2D,EACAzM,GAEA,GAAGA,EAAWs8B,YAAYymC,KAAM,CAC5B,IAAIC,EAASJ,EAAUC,GACnB5a,EAAUjoD,EAAWs8B,YAAYC,QACjCxjC,EAAO0T,EAAU6B,MAAQ7B,EAAUtF,SAEvCsF,EAAUw2D,KAAOlqE,EAAOkvD,EAExBjoD,EAAWgjE,GAAUhjE,EAAWgjE,IAAWlwC,IACvCrmB,EAAUw2D,OACVjjE,EAAWgjE,GAAU5nE,KAAKi3B,IACtBryB,EAAWgjE,GACX5nE,KAAKc,IAAInD,EAAMkvD,OAoB3Bib,iBAdJ,SACIL,EACA7iE,GAGAA,EADa4iE,EAAUC,SACF/gE,GAUrBqhE,WArEJ,SAAoBpoE,EAAIqoE,EAAQP,GAC5B,IAAI7iE,EAAajF,EAAGkF,YAChBgoD,EAAUjoD,EAAW,IAAM6iE,EAAY,gBAC3C,GAAG5a,EAAS,CACR,IAEIrtD,EAFAyoE,EAA6C,SAAhCrjE,EAAWs8B,YAAYymC,KAGxC,OAAOF,GACH,IAAK,aACL,IAAK,MACL,IAAK,WACDjoE,EAAW,UACX,MACJ,IAAK,UACDA,EAAW,qBACX,MACJ,QACIA,EAAW,qBAGnBwoE,EAAO3rE,UAAUmD,GAAU7D,MAAK,SAASC,GACrC,IAAIyV,EAAYzV,EAAEyV,UACfA,IACCA,EAAU6B,MAAS+0D,GAAc52D,EAAUw2D,KAAQ,EAAIhb,EAAUx7C,EAAUtF,SAElEzQ,EAAGa,OAAOC,MAAMD,OAAO,QAC7B8B,KAAK,YAAajB,EAAIujC,iBAAiBlvB,Y,8CC5B1D,IAAIrU,EAAM,EAAQ,YACd4W,EAAW,EAAQ,YAEnBs0D,EAA0B,EAAQ,YAClCC,EAAyB,EAAQ,YACjCC,EAA0B,EAAQ,YAElChkD,EAAa,EAAQ,YAEzB5oB,EAAOC,QAAU,SAA0B6lB,EAAaC,EAAcN,GAClE,IAAIonD,EAAcz0D,EAASmF,aAAawI,EAAc,YAClD+mD,EAAahnD,EAAYinD,UAAY,GAEzC,SAAS9xD,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO6xD,EAAYD,EAAajkD,EAAYnmB,EAAM4B,GAGjE,IAAI2oE,EAAgB/xD,EAAO,iBAC3BA,EAAO,YAAgC,aAAlB+xD,EACjB,IAAMvnD,EAAOzgB,MAAQygB,EAAOi0B,OAAO9tB,EAAInG,EAAOi0B,OAAOxyC,GACrD,IAGJ,IAAI+lE,EAAUhyD,EAAO,WACrBA,EAAO,MAAoB,aAAZgyD,EACX,EACAxnD,EAAO7Q,OAAS6Q,EAAOi0B,OAAO/hC,EAAI8N,EAAOi0B,OAAOj1B,GAGpDxJ,EAAO,KACPA,EAAO,WACPA,EAAO,QACPA,EAAO,KACPA,EAAO,WACPA,EAAO,QACPzZ,EAAIy8B,UAAU6uC,EAAYD,EAAa,CAAC,IAAK,MAE7C5xD,EAAO,gBACPA,EAAO,gBACPA,EAAO,eACPA,EAAO,eACPA,EAAO,WAEPyxD,EAAwBI,EAAYD,EAAa5xD,EAAQ,UAEzD,IAAIyK,EAAO,CAAC5L,YAAY,EAAO7X,KAAMwjB,EAAOxjB,MAC5C2qE,EAAwBE,EAAYD,EAAa5xD,EAAQ,SAAUyK,GACnEinD,EAAuBG,EAAYD,EAAa5xD,EAAQ,SAAUyK,GAElEzK,EAAO,aAAcwK,EAAO04C,WAAW4O,UACvCvrE,EAAImkB,WAAW1K,EAAQ,aAAcwK,EAAOxjB,MAC5CgZ,EAAO,gB,8CCpDX,IAAInb,EAAK,EAAQ,YACbotE,EAAU,EAAQ,YAoCtB,SAASvzC,EAAc5vB,GACnB,IAAIojE,EAAWpjE,GAAMA,EAAGQ,WACrB4iE,GAAUA,EAAS72D,YAAYvM,GAgBtC,SAAS8vB,EAAoBzsB,EAAKpJ,EAAUopE,GACxC,IAAI/rC,EAAK,mBAAqBj0B,EAC1BtM,EAAQokB,SAASmoD,eAAehsC,GAChCvgC,KACAA,EAAQokB,SAAS6hB,cAAc,UACzBnvB,aAAa,KAAMypB,GAEzBvgC,EAAMmV,YAAYiP,SAASooD,eAAe,KAC1CpoD,SAASwoB,KAAKz3B,YAAYnV,IAE9B,IAAIysE,EAAazsE,EAAM0sE,MAEpBD,EAAWE,WACVF,EAAWE,WAAWzpE,EAAW,IAAMopE,EAAc,IAAK,GACpDG,EAAWG,QACjBH,EAAWG,QAAQ1pE,EAAUopE,EAAa,GACvCF,EAAQltD,KAAK,uBAYxBhgB,EAAOC,QAAU,CACbw5B,YAzEJ,SAAqBt1B,GACjB,IAAIwpE,EAEJ,GAAiB,iBAAPxpE,EAAiB,CAGvB,GAAiB,QAFjBwpE,EAAYzoD,SAASmoD,eAAelpE,IAGhC,MAAM,IAAIg+B,MAAM,2BAA8Bh+B,EAAK,yBAGvD,OAAOwpE,EACJ,GAAGxpE,QACN,MAAM,IAAIg+B,MAAM,6CAIpB,OAAOh+B,GA0DPu1B,UAvDJ,SAAmB3vB,GACf,IAAI6jE,EAAM9tE,EAAGa,OAAOoJ,GACpB,OAAO6jE,EAAIzqE,iBAAkB0qE,aACzBD,EAAIzrE,QACJyrE,EAAIxhD,QAAQ,mBAoDhBuN,cAAeA,EACfC,aAxCJ,SAAsB51B,EAAUopE,GAC5BvzC,EAAoB,SAAU71B,EAAUopE,IAwCxCvzC,oBAAqBA,EACrBC,uBAZJ,SAAgC1sB,GAC5B,IAAIi0B,EAAK,mBAAqBj0B,EAC1BtM,EAAQokB,SAASmoD,eAAehsC,GACjCvgC,GAAO64B,EAAc74B,M,8CChF5B,IAAIizB,EAAe,EAAQ,YAAaA,aASxC/zB,EAAOC,QAAU,SAAqB8oB,GAClC,IAOI+kD,EACA3kE,EACAkQ,EACA00D,EACA78D,EACA88D,EACAC,EACAC,EAdAC,EAAU,GACVC,EAAe,GACfC,EAAiB,GACjBC,EAAUvlD,EAAE,GACZwlD,EAAM,GACNC,EAAQ,CAAC,EAAG,EAAG,GACfC,EAAY16C,EAAahL,GAU7B,IAAI5f,EAAI,EAAGA,EAAI4f,EAAEhiB,OAAQoC,IAIrB,IAHA2kE,EAAUS,EACVA,EAAMD,EACNA,EAAUvlD,EAAE5f,EAAI,IAAM,GAClBkQ,EAAI,EAAGA,EAAIo1D,EAAWp1D,SACRnO,IAAXqjE,EAAIl1D,MACH20D,QAAgC9iE,IAAfqjE,EAAIl1D,EAAI,GAAmB,EAAI,SAC5BnO,IAAfqjE,EAAIl1D,EAAI,GAAmB,EAAI,SAChBnO,IAAf4iE,EAAQz0D,GAAmB,EAAI,SAChBnO,IAAfojE,EAAQj1D,GAAmB,EAAI,KAKvB,IAANlQ,GAAS6kE,IACH,IAAN30D,GAAS20D,IACT7kE,IAAM4f,EAAEhiB,OAAS,GAAGinE,IACpB30D,IAAMk1D,EAAIxnE,OAAS,GAAGinE,IAItBA,EAAgB,IACfI,EAAa,CAACjlE,EAAGkQ,IAAM,CAAClQ,EAAGkQ,EAAG20D,IAGlCG,EAAQ1nE,KAAK,CAAC0C,EAAGkQ,EAAG20D,KACjBK,EAAe5nE,KAAK,CAAC0C,EAAGkQ,KAK3C,KAAMg1D,EAAetnE,QAAQ,CAKzB,IAJAknE,EAAkB,GAClBC,GAAoB,EAGhBh9D,EAAIm9D,EAAetnE,OAAS,EAAGmK,GAAK,EAAGA,KAKvC88D,IAAkBI,EAAa,EAH/BjlE,GADA4kE,EAASM,EAAen9D,IACb,IAGyB,EAFpCmI,EAAI00D,EAAO,MAEmCS,GAAO,IAChDJ,EAAa,CAACjlE,EAAI,EAAGkQ,KAAOm1D,GAAO,IACnCJ,EAAa,CAACjlE,EAAGkQ,EAAI,KAAOm1D,GAAO,IACnCJ,EAAa,CAACjlE,EAAGkQ,EAAI,KAAOm1D,GAAO,IAAM,MAG1CP,EAAgBF,GAAU,CAAC5kE,EAAGkQ,EAAG20D,GACjCK,EAAepuD,OAAO/O,EAAG,GACzBg9D,GAAoB,GAI5B,IAAIA,EACA,KAAM,6CAIV,IAAIH,KAAUE,EACVG,EAAaL,GAAUE,EAAgBF,GACvCI,EAAQ1nE,KAAKwnE,EAAgBF,IAKrC,OAAOI,EAAQt4C,MAAK,SAASlO,EAAGlD,GAAK,OAAOA,EAAE,GAAKkD,EAAE,Q,8CCxFzD,IAAI+mD,EAAe,EAAQ,YAAUA,aAEjC38B,EAAS,CAET9B,KAAM,SAAS0+B,GAKX,GAAGA,EAAQC,eAAeF,EAAc,OAAOC,EAE/C,IAAIE,EAAK,IAAIH,EACTI,EAAa,IAAIJ,EAyDrB,OAlDAC,EAAQC,IAAMC,EAUdF,EAAQI,YAAcD,EAWtBH,EAAQliD,GAAKoiD,EAAGpiD,GAAGuiD,KAAKH,GACxBF,EAAQM,KAAOJ,EAAGI,KAAKD,KAAKH,GAC5BF,EAAQO,eAAiBL,EAAGK,eAAeF,KAAKH,GAChDF,EAAQQ,mBAAqBN,EAAGM,mBAAmBH,KAAKH,GAMxDF,EAAQS,YAAcN,EAAWriD,GAAGuiD,KAAKF,GACzCH,EAAQU,cAAgBP,EAAWG,KAAKD,KAAKF,GAC7CH,EAAQW,wBAA0BR,EAAWI,eAAeF,KAAKF,GACjEH,EAAQY,4BAA8BT,EAAWK,mBAAmBH,KAAKF,GAQzEH,EAAQpgD,KAAO,SAASP,EAAOvoB,GACN,oBAAX+pE,QACNA,OAAOb,GAASc,QAAQzhD,EAAOvoB,GAGnCopE,EAAGtgD,KAAKP,EAAOvoB,GACfqpE,EAAWvgD,KAAKP,EAAOvoB,IAGpBkpE,GASXx7B,eAAgB,SAASw7B,EAAS3gD,EAAOvoB,GACrC,IAAIiqE,EACAC,EAMiB,oBAAXH,SACNE,EAAqBF,OAAOb,GAASx7B,eAAenlB,EAAOvoB,IAM/D,IAAIopE,EAAKF,EAAQC,IACjB,IAAIC,EAAI,OAAOa,EAEf,IAwBIvmE,EAxBAymE,EAAWf,EAAGgB,QAAQ7hD,GAC1B,IAAI4hD,EAAU,OAAOF,EAGrB,SAASzsC,EAAM6sC,GAMX,OAAGA,EAAQC,UACPlB,EAAGK,eAAelhD,EAAO8hD,EAAQC,UAC7BD,EAAQE,WAAZ,GACIF,EAAQE,OAAQ,EACTF,EAAQC,SAAS9sC,MAAM4rC,EAAI,CAACppE,MAGhCqqE,EAAQ7sC,MAAM4rC,EAAI,CAACppE,IAQlC,IAHAmqE,EAAW1mE,MAAM+D,QAAQ2iE,GAAYA,EAAW,CAACA,GAG7CzmE,EAAI,EAAGA,EAAIymE,EAAS7oE,OAAS,EAAGoC,IAChC85B,EAAM2sC,EAASzmE,IAUnB,OAPAwmE,EAAwB1sC,EAAM2sC,EAASzmE,SAOT+B,IAAvBwkE,EACHA,EACAC,GAGRM,MAAO,SAAStB,GAeZ,cAdOA,EAAQC,WACRD,EAAQliD,UACRkiD,EAAQM,YACRN,EAAQO,sBACRP,EAAQQ,0BACRR,EAAQpgD,YAERogD,EAAQC,WACRD,EAAQI,mBACRJ,EAAQS,mBACRT,EAAQU,qBACRV,EAAQW,+BACRX,EAAQY,4BAERZ,IAKf3uE,EAAOC,QAAU8xC,G,8CChKjB,IAAIvwC,EAAM,EAAQ,YACd8G,EAAQ,EAAQ,YAChB4nE,EAAe,EAAQ,YACvBrpC,EAAU,EAAQ,YAEtB7mC,EAAOC,QAAU,CACbqrE,WAAY,YACZ3oD,KAAM,cAEN4oD,OAAQ,CACJjxD,SAAU,CACNxW,MAAO,CACHqsE,YAAa3uE,EAAIiM,WAAW,GAAInF,EAAO,CACnCvE,MAAOmsE,OAMvB53D,iBAAkB,EAAQ,YAC1BmzD,eAAgB,EAAQ,YACxB2E,cAAe,EAAQ,YACvBv+B,KAAM,EAAQ,YACd+P,UAAW/a,EAAQ+a,UACnByuB,SAAUxpC,EAAQwpC,SAClBC,eAAgBzpC,EAAQypC,iB,8CCzB5B,IAAI9uE,EAAM,EAAQ,YACdoX,EAAU,EAAQ,YAAcA,QAChC23D,EAAY,EAAQ,YACpBC,EAAY,EAAQ,YAAeA,UACnCC,EAAiB,EAAQ,YAAeA,eAExCnkB,EAAe,EAAQ,YAA6BA,aACpDokB,EAAU,EAAQ,YAA6BA,QAsFnD,SAASC,EAAkB15B,EAAQ25B,EAAQ/zD,EAAY1D,EAAWmiB,GAC9D,IAEInyB,EAAGkQ,EAAGw3D,EAAKC,EAFXC,EAAsC,UAAdz1C,EACxB01C,EAAW73D,EAAUP,EAAQg4D,IAAShoE,KAGtCqoE,EAAe,GACnB,IAAI53D,EAAI,EAAGA,EAAIwD,EAAW9V,OAAQsS,IAE9B,IADAw3D,EAAMh0D,EAAWxD,MACNu3D,IAEXE,EAAM33D,EAAUP,EAAQi4D,KACjBjoE,OAASooE,EACZ,GAAIF,EAAII,YAED,GAAGH,GAAyBD,EAAI/xD,OAAQ,CAG1B5F,EAAUP,EAAQk4D,EAAI/xD,SACzBmyD,YACVD,EAAaxqE,KAAKoqE,SANtBI,EAAaxqE,KAAKoqE,GAY9B,IAAI1nE,EAAI,EAAGA,EAAI8tC,EAAOlwC,OAAQoC,IAC1B,GAAG8tC,EAAO9tC,GAAGynE,GAAS,CAClB,IAAIO,EAAYl6B,EAAO9tC,GAEnBioE,EAAsB,GAC1B,IAAI/3D,EAAI,EAAGA,EAAI43D,EAAalqE,OAAQsS,IAE5B83D,EADJN,EAAMI,EAAa53D,KACC+3D,EAAoB3qE,KAAKoqE,GAEjD,MAAO,CAACI,aAAcG,EAAqBD,UAAWA,GAI9D,MAAO,CAACF,aAAcA,EAAcE,UAAW,MAiBnD,SAASE,EAAuBryD,EAAkBmyD,EAAWP,EAAQU,EAAaC,GAC9E,IAAIpoE,EAAGkQ,EAAGm4D,EAAQC,EAAMC,EAEP,OAAdP,IACCA,EAAY,IACFP,GAAU,EACpBc,EAAiB1yD,EAAiBjY,OAClCiY,EAAiBvY,KAAK0qE,IAEtBO,EAAiB1yD,EAAiB1X,QAAQ6pE,GAG9C,IAAIQ,EAAgBxrE,OAAOC,KAAK+qE,GAIhC,IAAIhoE,EAAI,EAAGA,EAAI6V,EAAiBjY,OAAQoC,IAEpC,GADAqoE,EAASxyD,EAAiB7V,GACvBA,IAAMuoE,GAAkBF,EAAOF,GAAc,CAC5C,IAAIM,EAAYJ,EAAOF,GACvB,IAAIj4D,EAAI,EAAGA,EAAIs4D,EAAc5qE,OAAQsS,IAEjCm4D,EADAC,EAAOE,EAAct4D,IACNu4D,EAAYL,EAAaJ,EAAUM,GAGtD,YADAzyD,EAAiBiB,OAAOyxD,EAAgB,GAOhD,GAAkB,IAAfH,EACC,IAAIl4D,EAAI,EAAGA,EAAIs4D,EAAc5qE,OAAQsS,IACjC83D,EAAUQ,EAAct4D,KAAOk4D,EAGvCJ,EAAUG,GAAe,EAmL7B,SAASO,EAAa/kC,EAAIglC,GACtB,IAAIC,EAAcjlC,EAAGklC,aACjBC,EAAiBvB,EAAQ5jC,EAAGolC,iBAC5BlgD,EAAS+/C,EAAY,IAAMA,EAAY,GAAKA,EAAY,IAAME,EAElEnlC,EAAG44B,OAAS54B,EAAGpuB,OAAOgnD,OAAS,CAC3B1zC,GAAU+/C,EAAY,GAAK//C,GAAU8/C,EACrC9/C,GAAU+/C,EAAY,GAAK//C,GAAU8/C,GAEzChlC,EAAG11B,WA3WPnX,QAAQwY,yBAA2B,SAASqN,EAAaC,EAAc9K,EAAQyK,GAC3E,IAuBIxI,EAASi1D,EAcTb,EAAac,EArCbv1D,EAAa6I,EAAK7I,WAClB1D,EAAYuM,EAAKvM,UACjBmG,EAAkBoG,EAAKpG,gBACvBC,EAAgBmG,EAAKnG,cACrBP,EAAmB7F,EAAU8F,sBAC7BC,EAAc/F,EAAUgG,iBACxBhE,EAAO4K,EAAa1J,IACpBjB,EAAWD,EAAKmC,OAAO,GACvBS,IAAe5E,EAAU6E,YAAc,IAAI5C,IAAa,IAAID,IAAS,GACrEy1D,EAAS7qD,EAAa1J,IACtBsB,EAASizD,EAAOtzD,OAAO,GAIvBge,EAAYrgB,EAAO,YAAasE,GA+CpC,GA9CA/d,EAAIyZ,OAAO6K,EAAaC,EAAc,CAClCmsD,gBAAiB,CACbnyB,QAAS,aACTG,OAAmB,MAAXviC,EAAiB,CAAC,OAAQ,SAAU,SAAW,CAAC,SAAU,SAAU,OAC5EtZ,KAAiB,MAAXsZ,EAAiB,SAAW,WAEvC,oBAICmI,EAAY5I,UAAWa,EAAWb,SAAa6I,EAAamrD,aAC5DiB,EAAYxB,EAAkBzxD,EAAa0xD,EAAQ/zD,EAAY1D,GAC/D+D,EAAU1b,EAAIyZ,OAAO6K,EAAaC,EAAc,CAC5C7I,QAAS,CACL6iC,QAAS,aACTG,OAAQiyB,EAAUlB,cAAgB,GAClC5sE,KAAM0Z,EAAWb,UAEtB,YAMHA,GACC6I,EAAamrD,YAA4B,WAAd51C,IAC5BxV,EAAYwrD,cAAehyD,IAE3B8yD,EAAYzB,EAAkB3xD,EAAkB4xD,EAAQ/zD,EAAY1D,EAAWmiB,GAC/Eg2C,EAAc9vE,EAAIyZ,OAAO6K,EAAaC,EAAc,CAChDurD,YAAa,CACTvxB,QAAS,aACTG,OAAQkyB,EAAUnB,cAAgB,KAEvC,cAAe3xD,IAGnBpC,UACQ6I,EAAauV,UACpB+1C,EAAuBnyD,EAAaizD,EAAUhB,UAAWP,EAAQ1zD,EAAS,KACvB,IAA7CL,EAAWvV,QAAQwe,EAAY5I,UACrC1b,EAAIwe,KAAK,WAAa+F,EAAa5J,MAAQ,cACvC2J,EAAY5I,QAAU,kFAI3Bo0D,EAAa,CACZ,IAAIC,EAAat2D,EAAO,cAOpBs2D,IAAYA,EAAaxrD,EAAawrD,WAAa,GAEvDF,EAAuBryD,EAAkBozD,EAAUjB,UAAWP,EAAQU,EAAaC,QAC5B,IAAjD10D,EAAWvV,QAAQwe,EAAYwrD,cACrC9vE,EAAIwe,KAAK,WAAa+F,EAAa5J,MAAQ,kBACvC2J,EAAYwrD,YAAc,uKAuGtCrxE,QAAQoyE,QAAU,SAAiBluE,GAC/B,IAGIgF,EAAGkQ,EAAGi5D,EAAQxlC,EAAIylC,EAAWpG,EAAM2F,EAHnC1oE,EAAajF,EAAGkF,YAChB2V,EAAmB5V,EAAW6V,uBAAyB,GAI3D,IAAI9V,EAAI,EAAGA,EAAI6V,EAAiBjY,OAAQoC,IAAK,CACzC,IAAIsH,EAAQuO,EAAiB7V,GACzBqpE,EAAUrsE,OAAOC,KAAKqK,GAEtBgiE,EAAWv2C,IACXw2C,EAAW,EAMXC,EAAaz2C,IACb02C,EAAa,GACbtlB,EAAO,GACPulB,GAAyB,EAG7B,IAAIx5D,EAAI,EAAGA,EAAIm5D,EAAQzrE,OAAQsS,IAE3Bi0C,EADAglB,EAASE,EAAQn5D,IACFyzB,EAAK1jC,EAAWwP,EAAQ05D,IAEpCxlC,EAAGklC,aAAcllC,EAAG44B,OAAS54B,EAAGklC,aAAapyD,QAC3CktB,EAAGklC,aAAellC,EAAG44B,OAAO9lD,QAE7BktB,EAAGgmC,cAAahmC,EAAGgmC,YAAchmC,EAAGntB,MAAMC,SAI9CktB,EAAG11B,WAGHw7D,EAAWN,GAAUC,EAAY/tE,KAAK6/B,IAAIyI,EAAGg9B,IAAMr5D,EAAM6hE,GACzDG,EAAWjuE,KAAKi3B,IAAIg3C,EAAUF,GACV,WAAjBzlC,EAAGxR,WAA2BwR,EAAGimC,wBAChCJ,EAAanuE,KAAKi3B,IAAIk3C,EAAYJ,WAI/BzlC,EAAGimC,sBACVL,EAAWluE,KAAKc,IAAIotE,EAAUH,GAEV,WAAjBzlC,EAAGxR,YAAwBu3C,GAAyB,GAI3D,KAAGJ,EAAWnmB,EAAeomB,IAAaG,EAG1C,IAAIx5D,EAAI,EAAGA,EAAIm5D,EAAQzrE,OAAQsS,IAQ3B,GANAk5D,EAAYK,EADZN,EAASE,EAAQn5D,IAGjB8yD,GADAr/B,EAAKwgB,EAAKglB,IACAh3C,UAIPi3C,IAAcI,GAAuB,WAATxG,EAG3B,GAFA2F,EAASS,EAAYI,EAET,UAATxG,EACCoE,EAAUzjC,EAAIglC,OACX,CAGH,IAAIC,EAAcjlC,EAAGklC,aACjBgB,GAAgBlmC,EAAG44B,OAAO,GAAK54B,EAAG44B,OAAO,KACxCqM,EAAY,GAAKA,EAAY,IAC9BkB,GAAenmC,EAAG6lB,IAAI7lB,EAAGntB,MAAM,IAAMmtB,EAAG6lB,IAAI7lB,EAAGntB,MAAM,MACpDmtB,EAAG6lB,IAAI7lB,EAAGgmC,YAAY,IAAMhmC,EAAG6lB,IAAI7lB,EAAGgmC,YAAY,KAIvD,IAFAhB,GAAUkB,GAEEC,EAAc,EAAG,CAGzBnmC,EAAG44B,OAAS54B,EAAGpuB,OAAOgnD,OAASqM,EAAYnyD,QAC3C2wD,EAAUzjC,EAAIglC,GACd,SAUJ,GAPGmB,EAAc,IAGbnmC,EAAGntB,MAAQmtB,EAAGpuB,OAAOiB,MAAQmtB,EAAGgmC,YAAYlzD,QAC5CkyD,GAAUmB,GAGXnmC,EAAGptB,UAAW,CAab,IAAIwzD,EAAMpmC,EAAG6lB,IAAI7lB,EAAGntB,MAAM,IACtBwzD,EAAMrmC,EAAG6lB,IAAI7lB,EAAGntB,MAAM,IACtByzD,GAAeF,EAAMC,GAAO,EAC5BE,EAAWD,EACXE,EAAWF,EACXG,EAAY/uE,KAAK6/B,IAAI8uC,EAAMC,GAG3BI,EAAWJ,EAAcG,EAAYzB,EAAS,OAC9C2B,EAAWL,EAAcG,EAAYzB,EAAS,OAC9C4B,EAASlD,EAAU1jC,GAEvB+kC,EAAa/kC,EAAIglC,GACjB,IAII6B,EACArtE,EALAwyD,EAAIt0D,KAAK6/B,IAAIyI,EAAGg9B,IAChB8J,EAAWnD,EAAetsE,EAAI2oC,GAC9B+mC,EAAWD,EAASn4C,IACpBq4C,EAAWF,EAAStuE,IAIxB,IAAIgB,EAAI,EAAGA,EAAIutE,EAAS9sE,OAAQT,KAC5BqtE,EAASE,EAASvtE,GAAGgb,IAAMoyD,EAAOG,EAASvtE,IAAMwyD,GACrC0a,GAAYG,EAASN,IAC7BA,EAAWM,GAInB,IAAIrtE,EAAI,EAAGA,EAAIwtE,EAAS/sE,OAAQT,KAC5BqtE,EAASG,EAASxtE,GAAGgb,IAAMoyD,EAAOI,EAASxtE,IAAMwyD,GACrC2a,GAAYE,EAASL,IAC7BA,EAAWK,GAKnB7B,IADoBwB,EAAWD,IAAa,EAAIE,GAGhDF,EAAWvmC,EAAGomB,IAAImgB,GAClBC,EAAWxmC,EAAGomB,IAAIogB,GAClBxmC,EAAGntB,MAAQmtB,EAAGpuB,OAAOiB,MAASuzD,EAAMC,EAChC,CAACE,EAAUC,GAAY,CAACA,EAAUD,GAG1CxB,EAAa/kC,EAAIglC,MASrC7xE,QAAQ+iB,MAAQ,SAAe7e,EAAI2oC,GAC/B,GAAGA,EAAGklC,aAAc,CAIhB,IAHA,IAAI+B,GAAgB,EAChB54D,EAAO2xB,EAAGzwB,IACV2C,EAAmB7a,EAAGkF,YAAY4V,sBAC9B5F,EAAI,EAAGA,EAAI2F,EAAiBjY,OAAQsS,IACxC,GAAG2F,EAAiB3F,GAAG8B,GAAO,CAC1B44D,GAAgB,EAChB,MAGJA,GAAkC,WAAjBjnC,EAAGxR,YACpBwR,EAAGpuB,OAAOgnD,OAAS54B,EAAG44B,OAAS54B,EAAGklC,oBAC3BllC,EAAGklC,iB,8CCpWtB,IAAIlyE,EAAK,EAAQ,YACb0B,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAEhBi0E,EAAa,EAAQ,YACrBC,EAAc,EAAQ,YACtB17C,EAAgB/2B,EAAI+2B,cAEpB27C,EAAUl0E,EAAOC,QAAU,GAE/Bi0E,EAAQC,UAAY,SAASC,GACzB,IAAIphC,EAAQqhC,EAAqBzxD,EAAM0xD,EAAgB/zD,EACnDg0D,EAAc,IAAIN,EAEtB,SAASh0E,QAAQu0E,EAAcC,GAc3B,OAbGA,IAAYl0D,EAAYk0D,GAC3B30E,EAAGa,OAAOb,EAAGa,OAAO4f,GAAWpd,OAAOoH,YAAY1J,UAAU,qCAAqC+I,SAEjGopC,EAAWA,EAEPza,EAAcya,EAAQwhC,GADtBA,EAGA5xD,IAAMA,EAAOoxD,EAAWU,QAC5BJ,EAAiBN,EAAWW,QAAQC,SAAS7I,QAAQ/4B,GACrDpwB,EAAKowB,OAAOshC,GAAgBO,OAAOt0D,GACnC6zD,EAAI3uE,KAAOutC,EAAOvtC,KAClB2uE,EAAI3uD,OAASutB,EAAOvtB,OACpByuD,EAAQY,WAAWV,GACZphC,EA0BX,OAxBA/yC,QAAQ80E,SAAU,EAClB90E,QAAQyjB,IAAM,WAAa,OAAOd,EAAKc,OACvCzjB,QAAQ+0E,UAAY,WAAa,OAAOhiC,GACxC/yC,QAAQg1E,cAAgB,WACpB,OAAOjB,EAAWW,QAAQC,SAAS7I,QAAQnpD,EAAKqyD,iBAAiB,IAErEh1E,QAAQi1E,cAAgB,WAAa,MAAO,CAACv9D,EAAGiL,EAAKuyD,eAAgBjuE,EAAG0b,EAAKwyD,gBAC7En1E,QAAQo1E,aAAe,WACnB,IAEUC,EAAcC,EAFpBC,EAAO50E,KACP60E,EAAczB,EAAW0B,KAAKC,UAAU3iC,GAClCsiC,EASPG,EATqBF,EASRlB,EARZE,EAAYqB,IAAI,CACZC,KAAM,WACCN,GAAsBC,EAAKD,IAElCO,KAAM,WACFN,EAAKF,MAIjBjB,EAAsBL,EAAW0B,KAAKC,UAAUF,IAEpDx1E,QAAQ41E,KAAO,WAAatB,EAAYsB,QACxC51E,QAAQ61E,KAAO,WAAavB,EAAYuB,QACjC71E,SAGXi0E,EAAQY,WAAa,SAASV,GAC1B,IAAI7zD,EAAYzgB,EAAGa,OAAOyzE,GAAKvzE,UAAU,mBACrCk1E,EAAWx1D,EAAU1f,UAAU,kBAC/Bm1E,EAAQ5B,EAAID,WAAaC,EAAID,UAAUzwD,KAAO0wD,EAAID,UAAUzwD,MAC5DuyD,EAAQ,CACRjxE,MAAO,IACP4P,OAAQ,IACR6G,cAAe1b,EAAMib,WACrBy5D,WAAYl0D,EACZ21D,UAAWH,EACX3rC,OAAQ4rC,GAGZ5B,EAAI/qE,YAAckvB,EAAc09C,EAAO7B,EAAI3uD,U,8CCxE/C,IAAIjkB,EAAM,EAAQ,YACdgmC,EAAO,EAAQ,YACf2uC,EAA+B,EAAQ,YAEvCvtD,EAAa,EAAQ,YAazB,SAASwtD,EAAcC,EAASC,EAAUltE,GACtC,SAAS6R,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOo7D,EAASC,EAAU1tD,EAAYnmB,EAAM4B,GAG3D,IAAIkyE,EAASt7D,EAAO,UAGpB,IAFcA,EAAO,YAAas7D,GAErB,OAAOD,EAEpBr7D,EAAO,SACPA,EAAO,WACPA,EAAO,WACPA,EAAO,SACPA,EAAO,SACPA,EAAO,UACPA,EAAO,WAKP,IAHA,IAAIu7D,EAAS,CAAEntE,YAAaD,GACxBqtE,EAAY,CAAC,IAAK,KAEdttE,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAEvB,IAAIiS,EAAWq7D,EAAUttE,GACrByjC,EAAQpF,EAAKqmB,UAAUwoB,EAASC,EAAUE,EAAQp7D,EAAU,SAEhE,GAAa,UAAVwxB,EACUpF,EAAKQ,UAAUwuC,EAAQ5pC,GAC7B5wB,YAAYvV,KAAK6vE,EAASlsD,QAGjCod,EAAK0mB,eAAeooB,EAAUE,EAAQv7D,EAAQ2xB,EAAOxxB,EAAU,GAGnE,OAAOk7D,EA5CXt2E,EAAOC,QAAU,SAA8BiZ,EAAUC,GAMrDg9D,EAA6Bj9D,EAAUC,EAL5B,CACPwJ,KAJG,SAKH+zD,mBAAoBN,M,8CCV5B,IAAIt2E,EAAK,EAAQ,YACbuB,EAAY,EAAQ,YACpBs1E,EAAkB,EAAQ,YAE1Br1E,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdC,EAAe,EAAQ,YACvB1B,EAAQ,EAAQ,YAChB+pB,EAAU,EAAQ,YAClB2d,EAAK,EAAQ,YACbD,EAAO,EAAQ,YACfE,EAAY,EAAQ,YACpBC,EAAc,EAAQ,YACtBuK,EAAU,EAAQ,YAA6BA,QAC/C0kC,EAAkB,EAAQ,YAC1BC,EAAmB,EAAQ,YAA8BA,iBAEzDhtD,EAAQ,EAAQ,YAEhBme,EAAY,EAAQ,YAAcA,UAClC8uC,EAAa,EAAQ,YAAYA,WACjCC,EAAc,EAAQ,YAAYA,YAClCC,EAAgB,EAAQ,YAAYA,cACpCzG,EAAY,EAAQ,YAEpBvmD,EAAY,EAAQ,YACpBitD,EAAUjtD,EAAUitD,QACpBC,EAAUltD,EAAUktD,QAGpBC,GAAiB,EAm4BrB,SAASC,EAAY9xB,EAAUliD,EAAUi0E,EAAW5rC,GAChD,IAAI6rC,EAAW91E,EAAIkJ,aAAa46C,EAASmG,UAAWroD,EAAUi0E,GAAW,SAAS32E,GAC9EA,EAAE0rB,QAAQ,QAAQ,GACbtrB,MAAM,CAACuB,KAAM,cAAe,eAAgB,IAC5CI,KAAK,eAAgB6iD,EAASjkB,OAKvC,OAFAi2C,EAASt2E,KAAK0mC,EAAW+D,GAElB6rC,EAASn0E,OAGpB,SAASo0E,EAAgBjyB,EAAU+xB,EAAW5rC,EAAQlpC,EAAGC,EAAGG,EAAGC,GAC3D,IAAI40E,EAAUJ,EAAY9xB,EAAU,OAAQ+xB,EAAW5rC,GAEvD,OADA3rC,EAAGa,OAAO62E,GAASx2E,KAAK8oB,EAAQjnB,QAASN,EAAGC,EAAGG,EAAGC,GAC3C40E,EAGX,SAASC,EAAkB3nB,EAAQ4nB,GAC/B,IAAI,IAAIvuE,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAC9B,IAAI2mD,EAAO3mD,GAAG+nE,WAAY,OAAOwG,EAErC,MAAO,GAsBX,SAASC,EAAa7nB,EAAQ8nB,EAAYC,EAAYC,EAASC,GAC3D,IAAI,IAAI5uE,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CACnC,IAAI6uE,EAAMloB,EAAO3mD,GACjB,IAAG6uE,EAAI9G,WAEP,GAAG8G,EAAI9jB,YAAa,CAChB,IAAI+jB,EAA4B,MAAtBD,EAAI37D,IAAIiB,OAAO,GACrB46D,EAAMD,EAAO,EAAIL,EAAcA,EAC/BO,EAAMF,EAAO,EAAIJ,EAAcA,EAEnCC,EAAQE,EAAI77D,MAAQ,aAAe67D,EAAI9kB,IAAI8kB,EAAII,IAAIF,EAAMF,EAAIlyC,UAC7DgyC,EAAQE,EAAI77D,MAAQ,aAAe67D,EAAI9kB,IAAI8kB,EAAII,IAAID,EAAMH,EAAIlyC,cAC1D,CACH,IAAIuyC,EAAiBL,EAAInX,IAAI,GACzByX,EAAoBN,EAAInX,IAAI,GAAKwX,EACrCP,EAAQE,EAAI77D,MAAQ,aAAe67D,EAAI9kB,IAAImlB,EAAiBC,EAAoBV,GAChFE,EAAQE,EAAI77D,MAAQ,aAAe67D,EAAI9kB,IAAImlB,EAAiBC,EAAoBT,IAKxF,GAAGE,GAAcA,EAAWhxE,OAAQ,CAChC,IAAIwxE,GAAoBX,GAAc,EAAIC,IAAe,EACzDF,EAAaI,EAAYQ,EAAkB,EAAIA,EAAkBT,EAAS,KAIlF,SAASU,EAAW1oB,EAAQ2oB,GACxB,IAAI,IAAItvE,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CACnC,IAAI6uE,EAAMloB,EAAO3mD,GACjB,IAAI6uE,EAAI9G,WACJ,GAAG8G,EAAI9jB,YAAa,CAChB,IACIngD,EAAKikE,EAAIlyC,QAGT4yC,GAFKV,EAAII,IAFJ,EAEaK,GAAOT,EAAII,IAFxB,IAGAJ,EAAII,IAAIrkE,EAAK0kE,GAAOT,EAAII,IAAIrkE,KACb,EAExBikE,EAAIr4D,MAAQ,CACRq4D,EAAI9kB,IAAI8kB,EAAInX,IAAI,GAAK6X,GACrBV,EAAI9kB,IAAI8kB,EAAInX,IAAI,GAAK6X,SAGzBV,EAAIr4D,MAAQ,CACRq4D,EAAI9kB,IAAI8kB,EAAInX,IAAI,GAAK4X,EAAMT,EAAIlO,IAC/BkO,EAAI9kB,IAAI8kB,EAAInX,IAAI,GAAK4X,EAAMT,EAAIlO,MAYnD,SAAS6O,EAAMv4E,GACX,OAAO,GAAMA,GAAK,EAAKoE,KAAKi3B,IAAIr7B,EAAG,IAC/B,GAAK,EAAIoE,KAAKc,IAAIlF,GAAI,IAAO,QAerC,SAASw4E,EAAYC,EAAWC,EAAKC,EAAIC,EAAIC,GACzC,OAAOJ,EAAU/uE,OAAO,QACnBrH,KAAK,QAAS,WACd3B,MAAM,CACH,KAAQg4E,EAAM,GAAM,gBAAkB,sBACtC,eAAgB,IAEnBr2E,KAAK,YAAa,aAAes2E,EAAK,KAAOC,EAAK,KAClDv2E,KAAK,IAAKw2E,EAAQ,KAG3B,SAASC,EAAYL,EAAWE,EAAIC,GAChC,OAAOH,EAAU/uE,OAAO,QACnBrH,KAAK,QAAS,mBACd3B,MAAM,CACHuB,KAAMtC,EAAMib,WACZ/Z,OAAQlB,EAAMyM,YACd,eAAgB,EAChBpB,QAAS,IAEZ3I,KAAK,YAAa,aAAes2E,EAAK,KAAOC,EAAK,KAClDv2E,KAAK,IAAK,SAGnB,SAAS02E,EAAcC,EAAIC,EAASC,EAAKL,EAAOM,EAAQT,GACpDM,EAAG32E,KAAK,IACJw2E,EAAQ,IAAOK,EAAK,EAAI,IAAOA,EAAK,EAAI,IAAOA,EAAK,EACpD,IAAOA,EAAK,EAAI,KAAQA,EAAK,EAAI,KAAQA,EAAK,EAAI,KACtDE,EAAkBJ,EAAIC,EAASE,EAAQT,GAG3C,SAASU,EAAkBJ,EAAIC,EAASE,EAAQT,GACxCS,IACAH,EAAG/rD,aACEvsB,MAAM,OAAQg4E,EAAM,GAAM,kBACvB,yBACHz9C,SAAS,KACdg+C,EAAQhsD,aACHvsB,MAAM,UAAW,GACjBu6B,SAAS,MAItB,SAASo+C,EAAct1E,GACnBrE,EAAGa,OAAOwD,GACLtD,UAAU,mEACV+I,SAGT,SAAS8vE,EAAwBv1E,GAC1BgzE,GAAkBhzE,EAAGsB,MAAQtB,EAAGG,SAASq1E,WACxCn4E,EAAI04B,SAAS14B,EAAIy4B,EAAE91B,EAAI,iCAAkC,QACzDgzE,GAAiB,GAIzB,SAASyC,EAAgBC,GACrB,MAAoB,UAAbA,GAAqC,WAAbA,EAmBnC,SAASC,EAAUR,GACf,IAAIS,EAAOv1E,KAAKgD,MAAMhD,KAAKi3B,IAAI69C,EAAI70D,EAAI60D,EAAI3hE,EAAG2hE,EAAIpyE,EAAIoyE,EAAI1tD,EAAGsrD,GAAW,GACxE,MAAO,KACFoC,EAAI1tD,EAAI,KAAO,KAAO0tD,EAAI3hE,EAAI,GAAMoiE,GAAQ,OAAUA,EACnD,IAAMA,EAAO,SAAWA,EAAO,GAAK,MACvCT,EAAIpyE,EAAI,KAAO,KAAOoyE,EAAI3hE,EAAI,GAAMoiE,GAAQ,QAAWA,EACpD,KAAQA,EAAQ,QAAUA,EAAO,GAAK,MACzCT,EAAIpyE,EAAI,KAAO,KAAOoyE,EAAI70D,EAAI,GAAMs1D,GAAQ,OAASA,EAClD,KAAQA,EAAQ,OAASA,EAAO,GAAK,MACxCT,EAAI1tD,EAAI,KAAO,KAAO0tD,EAAI70D,EAAI,GAAMs1D,GAAQ,MAAQA,EACjD,IAAMA,EAAO,QAAUA,EAAO,GAAK,IAG/C,SAASC,EAAU71E,EAAI8yC,EAAQgjC,EAAQC,GAMnC,IALA,IAGIC,EAAKC,EAAKC,EAASC,EAHnBC,GAAuB,EACvBC,EAAS,GACTC,EAAS,GAGLtxE,EAAI,EAAGA,EAAI8tC,EAAOlwC,OAAQoC,IAAK,CACnC,IAAIsH,EAAQwmC,EAAO9tC,GAEnB,IAAIgxE,KAAOF,EACP,GAAGxpE,EAAM0pE,GAAM,CAIX,IAAIE,KAAW5pE,GACgB,MAAtB4pE,EAAQ/8D,OAAO,GAAa28D,EAASC,GAAQG,KAC9CG,EAAOH,GAAWF,GAK1B,IAAIC,KAAOF,EACJzpE,EAAM2pE,KAAMG,GAAuB,GAOlD,IAAIH,KAAOF,EACP,GAAGzpE,EAAM2pE,GACL,IAAIE,KAAW7pE,GACgB,MAAtB6pE,EAAQh9D,OAAO,GAAa28D,EAASC,GAAQI,KAC9CG,EAAOH,GAAWF,GAOnCG,IAIC/4E,EAAIiM,WAAW+sE,EAAQC,GACvBA,EAAS,IAGb,IAAIC,EAAe,GACfC,EAAc,GAClB,IAAIN,KAAWG,EAAQ,CACnB,IAAIx3E,EAAKglC,EAAU7jC,EAAIk2E,GACvBM,EAAYl0E,KAAKzD,GACjB03E,EAAa13E,EAAGqZ,KAAOrZ,EAG3B,IAAI43E,EAAe,GACfC,EAAc,GAClB,IAAIP,KAAWG,EAAQ,CACnB,IAAIx3E,EAAK+kC,EAAU7jC,EAAIm2E,GACvBO,EAAYp0E,KAAKxD,GACjB23E,EAAa33E,EAAGoZ,KAAOpZ,EAG3B,MAAO,CACHg3E,OAAQS,EACRR,OAAQU,EACR1gE,MAAOygE,EACPxgE,MAAO0gE,EACPL,OAAQA,EACRC,OAAQA,EACRF,qBAAsBA,GAK9B,SAASO,EAAwBpkE,EAASo5D,GACtC,GAAI6G,EAGG,CACH,IAAIoE,OAAqC7vE,IAApBwL,EAAQskE,QAAwB,QAAU,aAE5DtkE,EAAQukE,UACPvkE,EAAQgQ,oBAAoBq0D,EAAgBrkE,EAAQukE,UAExDvkE,EAAQukE,SAAWnL,EAEnBp5D,EAAQwkE,iBAAiBH,EAAgBjL,EAAS,CAACqL,SAAS,cAVrCjwE,IAApBwL,EAAQskE,QAAuBtkE,EAAQskE,QAAUlL,OACnB5kE,IAAzBwL,EAAQ0kE,eAA4B1kE,EAAQ0kE,aAAetL,GAa3E,SAASuL,EAAW5lE,GAChB,IAAIpI,EAAM,GACV,IAAI,IAAI/G,KAAKmP,EAAMpI,EAAI5G,KAAKgP,EAAKnP,IACjC,OAAO+G,EAGXrN,EAAOC,QAAU,CACbq7E,YA1qCJ,SAAqBn3E,EAAImhD,EAAU/iD,EAAGC,EAAGG,EAAGC,EAAG24E,EAAIC,GAO/C,IAKIC,EAAKC,EAELzB,EAAQC,EAERhgE,EAAOC,EAEP4+D,EAAIC,EAEJ2C,EAAIC,GAIJC,GAEA3+D,GAEA4+D,GAASC,GAETC,GAEAC,GAAOC,GAEPC,GAAcC,GAAUC,GAExBvE,GA7BAe,GAAY10E,EAAGkF,YAAYizE,WAC3BC,GAAchB,EAAKC,IAAO,OAC1BgB,GAAiC,KAApBjB,EAAKC,GAAIz0E,OA6B1B,SAAS01E,KAcL,GAbAhB,EAAMn2B,EAASxhD,MACf43E,EAAMp2B,EAASvhD,MACf43E,EAAKF,EAAI31C,QACT81C,GAAKF,EAAI51C,QACTizC,EAAK0C,EAAIjuC,QACTwrC,EAAK0C,EAAIluC,SAETysC,EAAS,IACFwB,EAAIp/D,KAAOo/D,GAClBvB,EAAS,IACFwB,EAAIr/D,KAAOq/D,EAGfH,GAAMC,EAEL,IADA,IAAI/yB,EAAWnD,EAASmD,SAChBt/C,EAAI,EAAGA,EAAIs/C,EAAS1hD,OAAQoC,IAAK,CACrC,IAAInG,EAAKylD,EAASt/C,GAAGrF,MACrBm2E,EAAOj3E,EAAGqZ,KAAOrZ,EACjB,IAAIC,EAAKwlD,EAASt/C,GAAGpF,MACrBm2E,EAAOj3E,EAAGoZ,KAAOpZ,EAIzBiX,EAAQmhE,EAAWpB,GACnB9/D,EAAQkhE,EAAWnB,GACnB4B,GAAUrE,EAAkBv9D,EAAOshE,GACnCO,GAAUtE,EAAkBt9D,EAAOohE,GACnCS,IAAkBD,KAAYD,GAE9BD,GAAQ7B,EAAU71E,EAAIA,EAAGkF,YAAY4V,sBAAuBg7D,EAAQC,GACpEh9D,GAAU88D,EAAU71E,EAAIA,EAAGkF,YAAY8V,iBAAkB86D,EAAQC,GACjE+B,GAAQT,GAAMK,GAAMtB,sBAAwBr9D,GAAQq9D,qBACpD2B,GAAQX,GAAMM,GAAMtB,sBAAwBr9D,GAAQq9D,qBAEpD,IAAInxE,EAAajF,EAAGkF,YACpB8yE,GAAe/yE,EAAWma,KAAK,aAC/B64D,GAAWhzE,EAAWma,KAAK,SAC3B84D,GAASjzE,EAAWma,KAAK,OAG7Bk5D,KAEA,IAAIhxC,GAi5BR,SAAuBixC,EAAM7C,EAAU0C,GACnC,IAAIG,EAAM,MAAO,UACjB,GAAY,SAATA,EAGC,OAAGH,EAAmB,GACN,QAAb1C,EAA2B,OACvB,YAEX,OAAO6C,EAAKC,cAAgB,UA15BfC,CAAcb,GAAUD,GAAS33E,EAAGkF,YAAYwwE,SAAU0C,IACnE/E,GAAUD,EAAgBjyB,EAAUi2B,EAAKC,EAAK,OAAQ/vC,GAAQlpC,EAAGC,EAAGG,EAAGC,GAK3E,GAAGo5E,KAAmBO,GAGlB,OAFA/E,GAAQqF,YAAc,KACtBrF,GAAQ12E,MAAMg8E,cAAgB,OACvBtF,GAGX,IAwJIlqD,GAAIC,GAEJ+rD,GAEAR,GAEAG,GAEAM,GAEAwD,GAEA3D,GAEAC,GAEA2D,GAxKAC,GAAc,CACdvmE,QAAS8gE,GACTrzE,GAAIA,EACJmhD,SAAUA,GAwFd,SAAS43B,KAELD,GAAY33B,SAAS/tC,WAAY,EAEjCw/D,EAAY5yE,GAGhB,SAASytC,GAAQY,EAAWC,GACxB,IAAIia,EAAYvoD,EAAGkF,YAAYqjD,UAM/B,GAJA+sB,EAAct1E,GAEG,IAAdquC,GAAoBgqC,IAgc3B,WACI,GAAGr4E,EAAGg5E,2BAA4B,OAElC,IAAIC,EAAoBj5E,EAAGG,SAAS+4E,YAEhCvtB,EAAS,GACVgsB,KAAShsB,EAASA,EAAOh1C,OAAOZ,IAChC6hE,KAASjsB,EAASA,EAAOh1C,OAAOX,IAChC+C,GAAQhD,QAAO41C,EAASA,EAAOh1C,OAAOoC,GAAQhD,QAC9CgD,GAAQ/C,QAAO21C,EAASA,EAAOh1C,OAAOoC,GAAQ/C,QAEjD,IACI2yB,EAAI3jC,EAAGm0E,EADPh1E,EAAQ,GAQZ,GAAyB,mBAAtB80E,EAGC,IAFAA,EAAoB,WAEhBj0E,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAE1B,IADA2jC,EAAKgjB,EAAO3mD,IACL8mD,gBACCnjB,EAAGntB,MAAM,KAAOmtB,EAAGmjB,cAAc,IACjCnjB,EAAGntB,MAAM,KAAOmtB,EAAGmjB,cAAc,MAEnCnjB,EAAGmjB,gBAAkBnjB,EAAGptB,UAC5B,CACE09D,EAAoB,QACpB,MAKZ,GAAyB,aAAtBA,EAGC,IAAIj0E,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,KAC1B2jC,EAAKgjB,EAAO3mD,IACL+nE,aAAY5oE,EAAMwkC,EAAG3wB,MAAQ,eAAgB,QAErD,GAAyB,UAAtBihE,EAWN,KARGtB,IAAWD,GAAMtB,wBAAsBzqB,EAASA,EAAOh1C,OAAO+gE,GAAM3hE,QACpE6hE,KAAYF,GAAMtB,uBAAsBzqB,EAASA,EAAOh1C,OAAO+gE,GAAM1hE,QAErE0hE,GAAMtB,uBACDuB,GACKC,KAASjsB,EAASA,EAAOh1C,OAAOX,IAD5B21C,EAASA,EAAOh1C,OAAOZ,IAIpC/Q,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,KAC1B2jC,EAAKgjB,EAAO3mD,IAEL+nE,aACCpkC,EAAGmjB,eAGHqtB,EAAexwC,EAAGmjB,cAClB3nD,EAAMwkC,EAAG3wB,MAAQ,aAAemhE,EAAa,GAC7Ch1E,EAAMwkC,EAAG3wB,MAAQ,aAAemhE,EAAa,IAJ7Ch1E,EAAMwkC,EAAG3wB,MAAQ,eAAgB,GAUjDhY,EAAGoqB,KAAK,qBAAsB,MAC9BjtB,EAASN,KAAK,eAAgBmD,EAAImE,GAtgBA+0E,GAE/Bd,GACI7vB,EAAUplD,QAAQ,WAAa,GAC9B0vE,EAAcvkC,EAAKtuC,EAAI+V,EAAOC,EAAOmrC,EAASjkB,GAAI47C,IAGnDvwB,EAAUplD,QAAQ,UAAY,GAC7BmgC,EAAGF,MAAMpjC,EAAIsuC,EAAK6S,EAASjkB,SAE5B,GAAiB,IAAdmR,GAAmBgqC,GAAW,CACpC,IAAI1vC,EAAKyuC,EAAKG,EAAMD,EAChBxrE,EAAc,MAAPsrE,GAAqB,MAAPC,EAAc,EAAI,EACvC+B,EAAUzwC,EAAG3wB,MAAQ,UAAYlM,EAAM,IACvCutE,EA+rBhB,SAAoB1wC,EAAI78B,GACpB,IAEIwtE,EAFAC,EAAa5wC,EAAGntB,MAAM1P,GACtB0tE,EAAOn5E,KAAK6/B,IAAIq5C,EAAa5wC,EAAGntB,MAAM,EAAI1P,IAK9C,MAAe,SAAZ68B,EAAGlkC,KACK80E,EACW,QAAZ5wC,EAAGlkC,MACT60E,EAAMj5E,KAAK0sB,KAAK1sB,KAAKc,IAAI,GAAId,KAAKk0B,IAAIilD,GAAQn5E,KAAK44C,OAAS,EACrDt9C,EAAGkI,OAAO,IAAMy1E,EAAM,IAAtB39E,CAA2B0E,KAAKuO,IAAI,GAAI2qE,MAE/CD,EAAMj5E,KAAKgD,MAAMhD,KAAKk0B,IAAIl0B,KAAK6/B,IAAIq5C,IAAel5E,KAAK44C,MACnD54C,KAAKgD,MAAMhD,KAAKk0B,IAAIilD,GAAQn5E,KAAK44C,MAAQ,EACtCt9C,EAAGkI,OAAO,IAAMyY,OAAOg9D,GAAO,IAA9B39E,CAAmC49E,IA9sBpBE,CAAW9wC,EAAI78B,GAC7B4tE,EAAS,OACTC,EAAS,SAEb,GAAGhxC,EAAGokC,WAAY,OAEfqK,GACCuC,EAAiB,MAAPvC,EAAc,MAAQ,SACjB,UAAZzuC,EAAG+K,OAAkBgmC,EAAS,UACpB,MAAPrC,IAAYqC,EAAS,SAE5B15E,EAAGG,SAASy5E,yBACXj+E,EAAGa,OAAO62E,IACLx2E,KAAKS,EAAaopC,aAAc,CAC7B1mC,GAAIA,EACJ65E,WAAW,EACXhjE,WAAY7W,EAAGkF,YAAYoS,cAC3BtK,KAAMsP,OAAO+8D,GACbn7E,KAAMyqC,EAAGimB,SAAWjmB,EAAGimB,SAAS7xD,MAAQ,OACxC+8E,gBAAiBJ,EACjBK,cAAeJ,IAElBrxD,GAAG,QAAQ,SAAStb,GACjB,IAAI/J,EAAI0lC,EAAGqxC,IAAIhtE,QACNjG,IAAN9D,GACC9F,EAASN,KAAK,eAAgBmD,EAAIo5E,EAASn2E,OA4CnE,SAASg3E,GAASC,EAAKC,GACnB,GAAGn6E,EAAGg5E,2BACF,OAAO,EAGX,IAAIz1E,EAAKlD,KAAKc,IAAI,EAAGd,KAAKi3B,IAAIkgD,EAAI0C,EAAM/wD,KACpC1lB,EAAKpD,KAAKc,IAAI,EAAGd,KAAKi3B,IAAImgD,GAAI0C,EAAM/wD,KACpC3c,EAAKpM,KAAK6/B,IAAI38B,EAAK4lB,IACnBzc,EAAKrM,KAAK6/B,IAAIz8B,EAAK2lB,IAOvB,SAASgxD,IACLxB,GAAW,GACXzD,GAAIpyE,EAAIoyE,GAAI1tD,EACZ0tD,GAAI3hE,EAAI2hE,GAAI70D,EACZ40D,GAAQ52E,KAAK,IAAK,SAGtB,GAZA62E,GAAI1tD,EAAIpnB,KAAKi3B,IAAInO,GAAI5lB,GACrB4xE,GAAIpyE,EAAI1C,KAAKc,IAAIgoB,GAAI5lB,GACrB4xE,GAAI3hE,EAAInT,KAAKi3B,IAAIlO,GAAI3lB,GACrB0xE,GAAI70D,EAAIjgB,KAAKc,IAAIioB,GAAI3lB,GASlBi0E,GAAMtB,qBACF3pE,EAAKsmE,GAAWrmE,EAAKqmE,GACpB6F,GAAW,KACRnsE,EAAK+qE,EAAK9qE,EAAK+qE,IACd/qE,EAAKD,EAAKgrE,GAAKD,EACZpuD,GAAK3lB,EAAI0xE,GAAI3hE,EAAI4V,GAAK1c,EACpByoE,GAAI70D,EAAI8I,GAAK1c,IAElBD,EAAKC,EAAK8qE,EAAKC,GACZtuD,GAAK5lB,EAAI4xE,GAAI1tD,EAAI0B,GAAK1c,EACpB0oE,GAAIpyE,EAAIomB,GAAK1c,GAEtByoE,GAAQ52E,KAAK,IAAKq3E,EAAUR,MAE5BiF,SAED,GAAGrhE,GAAQq9D,qBACd,GAAG3pE,EAAKsmE,GAAWrmE,EAAKqmE,EAAS,CAC7B6F,GAAW,KAEX,IAAIplB,EAAKnzD,KAAKi3B,IAAI69C,GAAI1tD,EAAI+vD,GAAKC,GAAKtC,GAAI70D,GAAKm3D,IACzC4C,EAAKh6E,KAAKc,IAAIg0E,GAAIpyE,EAAIy0E,GAAKC,GAAKtC,GAAI3hE,GAAKikE,IAE7CtC,GAAI1tD,EAAI+rC,EAAKgkB,EACbrC,GAAIpyE,EAAIs3E,EAAK7C,EACbrC,GAAI70D,GAAK,EAAIkzC,GAAMikB,GACnBtC,GAAI3hE,GAAK,EAAI6mE,GAAM5C,GACnBvC,GAAQ52E,KAAK,IAAKq3E,EAAUR,UAE5BiF,SAEGxC,IAAWlrE,EAAKrM,KAAKi3B,IAAIj3B,KAAKc,IAAS,GAALsL,EAAUqmE,GAAUC,GAI1DtmE,EAAKqmE,IAAY6E,GAChByC,KAEAjF,GAAI3hE,EAAI,EACR2hE,GAAI70D,EAAIm3D,GACRmB,GAAW,IACX1D,GAAQ52E,KAAK,IAotB7B,SAAkB62E,EAAK/rD,GACnB,MAAO,KACF+rD,EAAI1tD,EAAI,IAAO,KAAO2B,EAAK2pD,EAAU,IACtC,QAAU,EAAIA,EAAU,GAAK,QAC5BoC,EAAIpyE,EAAI,IAAO,KAAOqmB,EAAK2pD,EAAU,IACtC,OAAS,EAAIA,EAAU,GAAK,OAztBFuH,CAASnF,GAAK/rD,OAE7BuuD,IAAWlrE,EAAKpM,KAAKi3B,IAAS,GAAL5qB,EAAUqmE,IAC1CoC,GAAI1tD,EAAI,EACR0tD,GAAIpyE,EAAIy0E,EACRoB,GAAW,IACX1D,GAAQ52E,KAAK,IAstBzB,SAAkB62E,EAAKhsD,GACnB,MAAO,KACFA,EAAK4pD,EAAU,IAAO,KAAOoC,EAAI3hE,EAAI,IACtC,QAAU,EAAIu/D,EAAU,GAAK,QAC5B5pD,EAAK4pD,EAAU,IAAO,KAAOoC,EAAI70D,EAAI,IACtC,OAAS,EAAIyyD,EAAU,GAAK,OA3tBNwH,CAASpF,GAAKhsD,OAEhCyvD,GAAW,KACX1D,GAAQ52E,KAAK,IAAKq3E,EAAUR,MAEhCA,GAAI32E,EAAI22E,GAAIpyE,EAAIoyE,GAAI1tD,EACpB0tD,GAAI12E,EAAI02E,GAAI70D,EAAI60D,GAAI3hE,EAEjBolE,KAAUC,IAAc,GAC3B74E,EAAGkxC,SAAW2nC,GAEd7D,EAAcC,GAAIC,GAASC,GAAKL,GAAOM,GAAQT,IAC/C6F,KACAx6E,EAAGoqB,KAAK,qBAAsBupD,IAC9ByB,IAAS,EAGb,SAASoF,KACL7G,GAAU,GAGM,OAAbiF,IAAkC,MAAbA,KACpBpF,EAAaz9D,EAAOo/D,GAAI1tD,EAAI+vD,EAAIrC,GAAIpyE,EAAIy0E,EAAI7D,GAAS+D,GAAM3hE,OAC3D0kE,GAAqB,IAAK9G,KAEd,OAAbiF,IAAkC,MAAbA,KACpBpF,EAAax9D,GAAQyhE,GAAKtC,GAAI70D,GAAKm3D,IAAKA,GAAKtC,GAAI3hE,GAAKikE,GAAI9D,GAAS+D,GAAM1hE,OACzEykE,GAAqB,IAAK9G,KAIlC,SAAS+G,KACLF,KACAlF,EAAct1E,GACd26E,KACApF,EAAwBv1E,GA5R5B84E,GAAY/sC,OAAS,SAAS8K,EAAG+jC,EAAQC,GACrC,IAAIC,EAAehC,GAAYpD,SAC3BqF,EAAc/6E,EAAGkF,YAAYwwE,SAC9BqF,IAAgBD,IACfhC,GAAYpD,SAAWqF,GAG3BzC,KAEIT,KACGO,GAGIvhC,EAAEmkC,SACkB,QAAhBD,EAAuBA,EAAc,OAC/BtF,EAAgBsF,KAAcA,EAAc,OAC/ClkC,EAAEI,UACR8jC,EAAc,OAIlBA,EAAc,OAIMjC,GAAYmC,QAArB,UAAhBF,EAA+C,OACvBh0E,EAExB0uE,EAAgBsF,IACfjC,GAAY/iE,MAAQA,EACpB+iE,GAAY9iE,MAAQA,EAEpB28D,EAAW97B,EAAG+jC,EAAQC,EAAQ/B,GAAaiC,KAE3CjC,GAAYrrC,QAAUA,GACnBgoC,EAAgBqF,IAWf/B,KAGAlB,KACmB,SAAhBkD,GACCjC,GAAY9sC,OAASiuC,GACrBnB,GAAYtsC,OAASkuC,GAKrB5B,GAAYmC,QAAU,EA2GtC,SAAkBpkC,EAAG+jC,EAAQC,GACzB,IAAIK,EAAW7H,GAAQphE,wBACvBkX,GAAKyxD,EAASM,EAAS1qE,KACvB4Y,GAAKyxD,EAASK,EAASjvE,IACvBkpE,GAAM,CAAC1tD,EAAG0B,GAAIpmB,EAAGomB,GAAI3qB,EAAG,EAAGgV,EAAG4V,GAAI9I,EAAG8I,GAAI3qB,EAAG,GAC5Ck2E,GAAM30E,EAAGm7E,YACJn7E,EAAGo7E,YAAcp7E,EAAGm7E,YACrBj+E,EAAU8C,EAAGkF,YAAYm2E,cAAcC,eAE3ClG,IAAS,EACTwD,GAAW,KACXC,IAAc,EACd5D,GAAKR,EAAYC,GAAWC,GAAKC,EAAIC,EAJrCC,GAAQ,QAAU0C,EAAK,IAAMC,GAAK,QAKlCvC,GAAUH,EAAYL,GAAWE,EAAIC,GAtHzB0G,CAAS1kC,EAAG+jC,EAAQC,IACE,QAAhBE,IACNjC,GAAY9sC,OAASwvC,GACrB1C,GAAYtsC,OAASmuC,MAKjC36E,EAAGkF,YAAYu2E,QAAU,WACrB,IAAIC,EAAc17E,EAAG27E,UAElBD,GAAeA,EAAYnpE,UAAY8gE,KAGlCoC,EAFcz1E,EAAGkF,YAAYwwE,YAG7B4C,KACAsD,GAAe,CAAC,EAAG,EAAGpE,EAAIC,KAC1BqB,GAAY9sC,OAAO0vC,EAAYjvE,GAAIivE,EAAYhvE,QAmE/D82B,EAAYsI,KAAKgtC,IAiJjB,IAAI+C,GAAgB,CAAC,EAAG,EAAGrE,EAAIC,IAE3BqE,GAAc,KACdC,GAAcl2D,EAAUk2D,YACxBj5B,GAAW3B,EAAS2B,SAAW9iD,EAAGkF,YAAYm/C,OAAOlD,EAAS2B,UAAY3B,EA6F9E,SAASq6B,GAAS/uE,EAAIC,GAElB,IAAG1M,EAAGg5E,2BAAN,CAOA,GAFAh5E,EAAGkF,YAAY82E,aAAc,EAEd,OAAZrE,IAAgC,OAAZC,GAYnB,OAXGD,KACCtD,EAAWt+D,EAAOtJ,GAClBguE,GAAqB,MAEtB7C,KACCvD,EAAWr+D,EAAOtJ,GAClB+tE,GAAqB,MAEzBmB,GAAe,CAACjE,IAAWlrE,EAAK,EAAGmrE,IAAWlrE,EAAK,EAAG8qE,EAAIC,KAC1DwE,UACAj8E,EAAGoqB,KAAK,qBAAsBupD,IA6BlC,GAAG+D,GAAMtB,sBAAwBuB,IAAWC,GAAS,CAGjD,IAAIsE,EAAwB,MAAZvE,KAAkC,MAAZC,IAAoB,GAAK,EAC3DuE,GAAe1vE,EAAK+qE,EAAK0E,EAAUxvE,EAAK+qE,IAAM,EAClDhrE,EAAK0vE,EAAc3E,EACnB9qE,EAAKwvE,EAAUC,EAAc1E,GAGlB,MAAZE,GAAiBlrE,EAAK2vE,EAAGrmE,EAAO,EAAGtJ,GAClB,MAAZkrE,GAAiBlrE,EAAK2vE,EAAGrmE,EAAO,GAAItJ,GACnCkrE,KAASlrE,EAAK,GAER,MAAZmrE,GAAiBlrE,EAAK0vE,EAAGpmE,EAAO,EAAGtJ,GAClB,MAAZkrE,GAAiBlrE,EAAK0vE,EAAGpmE,EAAO,GAAItJ,GACnCkrE,KAASlrE,EAAK,GAEvB,IAAI2vE,EAAsB,MAAZ1E,GAAmBlrE,EAAK,EAClC6vE,EAAsB,MAAZ1E,GAAmBlrE,EAAK,EAEtC,GAAGgrE,GAAMtB,qBAAsB,CAC3B,IAAIpxE,EACJ,IAAI2yE,IAA8B,IAAnBC,GAAQh1E,OAAc,CAGjC,IAAIoC,EAAI,EAAGA,EAAI+Q,EAAMnT,OAAQoC,IACzB+Q,EAAM/Q,GAAGwW,MAAQzF,EAAM/Q,GAAGy3D,GAAGhhD,QAC7B2wD,EAAUr2D,EAAM/Q,GAAI,EAAI0H,EAAK+qE,IAGjC4E,GADA5vE,EAAKC,EAAK8qE,EAAKC,IACD,EAElB,IAAIG,IAA8B,IAAnBD,GAAQ/0E,OAAc,CACjC,IAAIoC,EAAI,EAAGA,EAAIgR,EAAMpT,OAAQoC,IACzBgR,EAAMhR,GAAGwW,MAAQxF,EAAMhR,GAAGy3D,GAAGhhD,QAC7B2wD,EAAUp2D,EAAMhR,GAAI,EAAIyH,EAAK+qE,GAGjC8E,GADA5vE,EAAKD,EAAKgrE,GAAKD,GACD,GAItBiD,GAAqB,KACrBA,GAAqB,KACrBmB,GAAe,CAACS,EAAQC,EAAQ9E,EAAK/qE,EAAIgrE,GAAK/qE,IAC9CuvE,KACAj8E,EAAGoqB,KAAK,qBAAsBupD,IAlE9B,SAASyI,EAAGG,EAASzwE,EAAK7P,GAItB,IAHA,IACIugF,EACAC,EAFAC,EAAW,EAAI5wE,EAGX9G,EAAI,EAAGA,EAAIu3E,EAAQ35E,OAAQoC,IAAK,CACpC,IAAI6uE,EAAM0I,EAAQv3E,GAClB,IAAG6uE,EAAI9G,WAAP,CACAyP,EAAU3I,EACV4I,EAAmB5I,EAAInX,IAAIggB,IACtB7I,EAAInX,IAAI5wD,GAAO+nE,EAAInX,IAAIggB,IAAalI,EAAMv4E,EAAI43E,EAAIlyC,SACvD,IAAIg7C,EAAS9I,EAAI9kB,IAAI0tB,IAIP,IAAXE,QAA+B51E,IAAX41E,IAAsB9I,EAAIr4D,MAAM1P,GAAO6wE,IAElE,OAAOH,EAAQ76C,SAAW66C,EAAQ9f,IAAI5wD,GAAO2wE,IACxCD,EAAQ9f,IAAI5wD,GAAO0wE,EAAQ9f,IAAIggB,KAoD5C,SAASjC,GAAqBxjE,EAAU/N,GASpC,IARA,IAAI0zE,EAAc7jE,GAAQq9D,qBACtB,CAACh4E,EAAG4X,EAAO3X,EAAG0X,GAAOkB,GACrB8B,GAAQ9B,EAAW,QAEnB4lE,EAAkB9jE,GAAQq9D,qBAC1B,CAACh4E,EAAG2X,EAAO1X,EAAG2X,GAAOiB,GACrB,GAEIjS,EAAI,EAAGA,EAAI43E,EAAYh6E,OAAQoC,IAAK,CACxC,IAAI2jC,EAAKi0C,EAAY53E,GACjBgS,EAAO2xB,EAAGzwB,IACV0D,EAAQ7C,GAAQs9D,OAAOr/D,IAAS+B,GAAQu9D,OAAOt/D,GAC/CmvD,EAAM0W,EAAgB,IAAM/G,EAAOl6D,IAAUm6D,EAAOn6D,GAErDuqD,IACIj9D,GAECA,EAAIy/B,EAAG3wB,MAAQ,aAAe9O,EAAIi9D,EAAInuD,MAAQ,aAC9C9O,EAAIy/B,EAAG3wB,MAAQ,aAAe9O,EAAIi9D,EAAInuD,MAAQ,cAE9C2wB,EAAGntB,MAAQ2qD,EAAI3qD,MAAMC,UAQrC,SAASwgE,KACL,IACIj3E,EADA83E,EAAc,GAGlB,SAASC,EAAgBpxB,GACrB,IAAI3mD,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IACtB2mD,EAAO3mD,GAAG+nE,YAAY+P,EAAYx6E,KAAKqpD,EAAO3mD,GAAGkT,KAgB7D,IAZG4/D,KACCiF,EAAgBhnE,GAChBgnE,EAAgBrF,GAAM3hE,OACtBgnE,EAAgBhkE,GAAQhD,QAEzBgiE,KACCgF,EAAgB/mE,GAChB+mE,EAAgBrF,GAAM1hE,OACtB+mE,EAAgBhkE,GAAQ/C,QAG5B29D,GAAU,GACN3uE,EAAI,EAAGA,EAAI83E,EAAYl6E,OAAQoC,IAAK,CACpC,IAAIgS,EAAO8lE,EAAY93E,GACnB2jC,EAAK9E,EAAU7jC,EAAIgX,GACvBqsB,EAAKK,QAAQ1jC,EAAI2oC,EAAI,CAACg5B,WAAW,IACjCgS,GAAQhrC,EAAG3wB,MAAQ,aAAe2wB,EAAGntB,MAAM,GAC3Cm4D,GAAQhrC,EAAG3wB,MAAQ,aAAe2wB,EAAGntB,MAAM,GAG/C6nB,EAAK8mB,iBAAiBnqD,EAAI88E,GA6E9B,SAASnC,KAILiB,GAAe,CAAC,EAAG,EAAGpE,EAAIC,KAI1Bp6E,EAAI87B,YAAY,CACZzT,EAAMioB,iBACN,WACI3tC,EAAGkF,YAAY82E,aAAc,EAC7B7+E,EAASN,KAAK,eAAgBmD,EAAI2zE,MAEvC3zE,GAOP,SAAS47E,GAAeoB,GACpB,IAGIh4E,EAAG+2D,EAAIl9D,EAAIC,EAHXmG,EAAajF,EAAGkF,YAChB+3E,EAAYh4E,EAAWo/C,OACvBluC,EAAWlR,EAAWmR,UAAUgvC,UAOpC,GAJG6yB,IACC96E,EAASsqE,iBAAiByV,MAAMtmC,KAAK52C,GAGtCg4E,GACC,IAAIhzE,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAK5B,GAHAnG,GADAk9D,EAAKkhB,EAAU9mE,EAASnR,KAChBrF,MACRb,EAAKi9D,EAAGn8D,MAELm8D,EAAG7V,OAAQ,CACV,IAAIi3B,EAAO9/E,EAAImZ,UAAU3X,EAAG2c,MAAO3c,EAAG2vD,KAClC4uB,EAAO//E,EAAImZ,UAAU1X,EAAG0c,MAAO1c,EAAG0vD,KACtCuN,EAAG7V,OAAO7V,OAAO,CAAC70B,MAAO,CAAC2hE,EAAK,GAAIC,EAAK,GAAID,EAAK,GAAIC,EAAK,MAUtE,IALGnF,IAAYD,MACXvF,EAAgBzyE,GAChB0yE,EAAiB1yE,IAGlBk4E,GAAQ,CACP,IAAImF,EAAeL,EAAQ,GAAK1F,EAAI31C,QAChC27C,EAAeN,EAAQ,GAAKzF,EAAI51C,QAEpC,IAAI38B,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAAK,CAEjCnG,GADAk9D,EAAKkhB,EAAU9mE,EAASnR,KAChBrF,MACRb,EAAKi9D,EAAGn8D,MAER,IAGI29E,EAAeC,EACfC,EAAQC,EAJRC,EAAS7F,KAAUj5E,EAAGkuE,YAAc+I,EAAOj3E,EAAGqZ,KAC9C0lE,EAAS7F,KAAUj5E,EAAGiuE,YAAcgJ,EAAOj3E,EAAGoZ,KAsClD,GAjCGylE,GACCJ,EAAgBF,EAChBI,EAASpG,EAAK2F,EAAQ,GAAKa,GAASh/E,EAAI0+E,IAClCxkE,GAAQ+8D,OAAOj3E,EAAGqZ,MACxBqlE,EAAgBF,EAChBI,EAAST,EAAQ,GAAKn+E,EAAG8iC,QAAU21C,EAAI31C,SACjC5oB,GAAQg9D,OAAOl3E,EAAGqZ,MACxBqlE,EAAgBD,EAChBG,EAAqB,OAAZ7F,IACJoF,EAAQ,GAAKn+E,EAAG8iC,QAAU41C,EAAI51C,QAC/Bk8C,GAASh/E,EAAI0+E,EAAe,CAACl7E,EAAG,MAAO9F,EAAG,UAAUq7E,MAGxD6F,EAASK,GAAiBj/E,EAD1B0+E,EAAgBQ,GAAqBl/E,EAAIw+E,EAAcC,IAIxDM,GACCJ,EAAgBF,EAChBI,EAAStG,EAAK4F,EAAQ,GAAKa,GAAS/+E,EAAI0+E,IAClCzkE,GAAQg9D,OAAOj3E,EAAGoZ,MACxBslE,EAAgBF,EAChBI,EAASV,EAAQ,GAAKl+E,EAAG6iC,QAAU41C,EAAI51C,SACjC5oB,GAAQ+8D,OAAOh3E,EAAGoZ,MACxBslE,EAAgBH,EAChBK,EAAqB,OAAZ/F,IACJqF,EAAQ,GAAKl+E,EAAG6iC,QAAU21C,EAAI31C,QAC/Bk8C,GAAS/+E,EAAI0+E,EAAe,CAAC3mC,EAAG,QAASr4C,EAAG,QAAQm5E,MAGxD+F,EAASI,GAAiBh/E,EAD1B0+E,EAAgBO,GAAqBj/E,EAAIu+E,EAAcC,IAKvDC,GAAkBC,EAAtB,CAKID,IAAeA,EAAgB,GAC/BC,IAAeA,EAAgB,GAEnC,IAAIQ,EAASn/E,EAAGwqC,QAAUo0C,EAASF,EAC/BU,EAASn/E,EAAGuqC,QAAUq0C,EAASF,EAMnCzhB,EAAGmiB,SACErhF,KAAK8oB,EAAQ/S,aAAc6qE,EAAQC,GACnC7gF,KAAK8oB,EAAQ1S,SAAUsqE,EAAeC,GAE3CzhB,EAAGt9C,KACE5hB,KAAK8oB,EAAQ/S,aAAcorE,EAAQC,GACnCphF,KAAK8oB,EAAQ1S,SAAU,EAAIsqE,EAAe,EAAIC,GAMhDD,IAAkBxhB,EAAGshB,cAAgBG,IAAkBzhB,EAAGuhB,eACzD33D,EAAQxS,mBAAmB4oD,EAAG1Z,aAAck7B,EAAeC,GAC3D73D,EAAQhS,mBAAmBooD,EAAGzZ,aAAci7B,EAAeC,IAG/D73D,EAAQpmB,uBAAuBw8D,EAAG3Z,sBAAuB2Z,GAGzDA,EAAGshB,aAAeE,EAClBxhB,EAAGuhB,aAAeE,KAQ9B,SAASO,GAAqBp1C,EAAI00C,EAAcC,GAC5C,OAAG30C,EAAGokC,WAAmB,EAEtB+K,IAASJ,GAAM5B,OAAOntC,EAAGzwB,KACjBmlE,EAERtF,KAAUL,GAAMtB,qBAAuBsB,GAAM5B,OAAS4B,GAAM3B,QAAQptC,EAAGzwB,KAC/DolE,EAEJ,EAGX,SAASQ,GAAiBn1C,EAAIw1C,GAC1B,OAAGA,GACCx1C,EAAGntB,MAAQmtB,EAAG8zB,GAAGhhD,QACjB2wD,EAAUzjC,EAAIw1C,GACPN,GAASl1C,EAAIw1C,IAEjB,EAGX,SAASN,GAASl1C,EAAIw1C,EAAaC,GAC/B,OAAOz1C,EAAGhH,SAAW,EAAIw8C,GAAepwC,EAAQqwC,GAAQz1C,EAAGolC,iBAAmB,UAGlF,OAtZGqJ,EAAGx0E,OAASy0E,EAAGz0E,QAAW,GACzB+zE,EAAwBtD,IAvF5B,SAAmBx8B,GAIf,GAAI72C,EAAGG,SAASk+E,YAAYj5B,WAAcplD,EAAGkF,YAAYo5E,kBAAzD,CAOA,GAHAvF,KAGG/4E,EAAGg5E,2BAGF,OAFAniC,EAAEJ,sBACFI,EAAE0nC,kBAINjG,KAEAlpC,aAAa0sC,IAEb,IAAI0C,GAAc3nC,EAAEL,OAEpB,GADI/b,SAAS+jD,KAAaA,EAAa3nC,EAAE2nC,WAAa,IAClD/jD,SAAS+jD,GAAb,CAKA,IAIIx5E,EAJAy5E,EAAOp+E,KAAKq+E,KAAKr+E,KAAKi3B,IAAIj3B,KAAKc,IAAIq9E,GAAa,IAAK,IAAM,KAC3DG,EAAM77B,GAASwE,UAAU9qD,OAAO,aAAawC,OAAOiT,wBACpD2sE,GAAS/nC,EAAEa,QAAUinC,EAAInuE,MAAQmuE,EAAI99E,MACrCg+E,GAASF,EAAI3yE,OAAS6qC,EAAEG,SAAW2nC,EAAIluE,OAY3C,GAAGqnE,GAAO,CAKN,IAFIT,IAAIuH,EAAQ,IAEZ55E,EAAI,EAAGA,EAAI+Q,EAAMnT,OAAQoC,IACzB85E,EAAiB/oE,EAAM/Q,GAAI45E,EAAOH,GAEtChE,GAAqB,KAErBoB,GAAc,IAAM4C,EACpB5C,GAAc,IAAMA,GAAc,GAAK+C,GAAS,EAAIH,EAAO,GAE/D,GAAG1G,GAAO,CAGN,IAFIX,IAAIyH,EAAQ,IAEZ75E,EAAI,EAAGA,EAAIgR,EAAMpT,OAAQoC,IACzB85E,EAAiB9oE,EAAMhR,GAAI65E,EAAOJ,GAEtChE,GAAqB,KAErBoB,GAAc,IAAM4C,EACpB5C,GAAc,IAAMA,GAAc,IAAM,EAAIgD,IAAU,EAAIJ,EAAO,GAIrE7C,GAAeC,IACfI,KAEAj8E,EAAGoqB,KAAK,qBAAsBupD,IAI9BmI,GAAc5sC,YAAW,WACrB2sC,GAAgB,CAAC,EAAG,EAAGrE,EAAIC,IAC3BkD,OACDoB,IAEHllC,EAAEJ,sBAzDEp5C,EAAIk3B,IAAI,yCAA0CsiB,GAUtD,SAASioC,EAAiBn2C,EAAImlC,EAAgB2Q,GAC1C,IAAG91C,EAAGokC,WAAN,CAEA,IAAIgS,EAAU1hF,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KACrCp3B,EAAK2nD,EAAQ,IAAMA,EAAQ,GAAKA,EAAQ,IAAMjR,EAElDnlC,EAAGntB,MAAQujE,EAAQtnE,KADnB,SAAgBxU,GAAK,OAAO0lC,EAAGomB,IAAI33B,GAAMn0B,EAAIm0B,GAAMqnD,WAqcpDpL,KAuTPJ,YAAaA,EACbG,gBAAiBA,EACjBqB,YAAaA,EACbM,YAAaA,EAEbC,cAAeA,EACfW,UAAWA,EACXN,kBAAmBA,EACnBC,cAAeA,EACfC,wBAAyBA,EAEzBoB,wBAAyBA,I,8CC7tC7B,IAAIh7E,EAAK,EAAQ,YAEb0B,EAAM,EAAQ,YACdE,EAAkB,EAAQ,YAC1BC,EAAe,EAAQ,YAA0BA,aAIrD,SAASwhF,EAAQC,EAAYC,GACzB,OAAOD,EAAWjgF,OAAOiT,wBAAwBitE,GAGrD,IAAIC,EAAW,gCAEfrjF,QAAQiS,gBAAkB,SAAS5N,EAAUH,EAAIo/E,GAC7C,IAAIvlD,EAAM15B,EAAS6M,OAIfqyE,GAAQl/E,EAAS7B,KAAK,eACF,oBAAZsjC,SACR/H,EAAIpnB,MAAM0sE,GAEVtiD,EAASlhC,EAAGa,OAAO2D,EAASnB,OAAOoH,YACvC,IAAGy2B,EAAO4K,QAAV,CACA,IAAI63C,EAAYn/E,EAAS7B,KAAK,SAAY6B,EAAS7B,KAAK,SAASqU,MAAM,KAAK,GAAK,OA6GjF,OA5GA2sE,GAAY,QACZziD,EAAOngC,UAAU,OAAS4iF,GAAU75E,SACpCo3B,EAAOngC,UAAU,KAAO4iF,EAAW,UAAU75E,SAC7CtF,EAASxD,MAAM,UAAW,MACrB2B,KAAK,CAKF,mBAAoBu7B,EACpB,YAAa,MA0BlBwlD,GACGr/E,GAAMA,EAAGmlE,WAAc,IAAI7iE,KAAK,IAAIwgC,SAAQ,SAASC,GACnD5iC,EAASxD,MAAM,UAAW,QAC1B,IAAIyP,EAAW+rB,SAASh4B,EAASnB,OAAOrC,MAAMyP,SAAU,IACpDyiC,EAAS,CAACziC,SAAUA,IAkFpC,SAAkBmzE,EAAYC,EAASJ,GACnC,IAAIK,EACAC,EACAC,EACAC,EAEJh+C,QAAQG,IAAI89C,OACZ,WASI,OARAH,EAAiBriF,EAAI+2B,cAAc,GAAIwN,QAAQG,IAAI8M,QAEnD8wC,EAA8B/9C,QAAQG,IAAI+9C,yBACH/4E,IAApC66B,QAAQG,IAAI+9C,sBAEXl+C,QAAQG,IAAI+9C,oBAAsB,GAG/Bl+C,QAAQG,IAAIC,OAAO,CACtBC,aAAc,OACdG,QAAS,CACLC,WAAY,CAAC,CAAC,IAAK,KAAM,CAAC,MAAO,SAErCF,aAAc,YAGtB,WAGI,GAAwB,SADxBs9C,EAAmB79C,QAAQG,IAAI8M,OAAOkxC,aAAaC,UAE/C,OAAOp+C,QAAQG,IAAIk+C,YAAY,UAGvC,WACI,IAAIC,EAAW,eAAiB7iF,EAAIo6B,QAAQ,GAAI,IAOhD,OANAmoD,EAASjkF,EAAGa,OAAO,QAAQmJ,OAAO,OAC7BrH,KAAK,CAAC4+B,GAAIgjD,IACVvjF,MAAM,CAACwjF,WAAY,SAAU5vE,SAAU,aACvC5T,MAAM,CAAC,YAAa6iF,EAAQpzE,SAAW,OACvCY,KAAwBuyE,EAzCxBn8E,QAAQg9E,EAAU,SACtBh9E,QAAQi9E,EAAU,UA0CZz+C,QAAQG,IAAIu+C,QAAQV,EAAO5gF,WAEtC,WACI,IAAIuhF,EAAY5kF,EAAGa,OAAO,QAAQA,OAAO,uBAEzC,GAAGojF,EAAOpjF,OAAO,gBAAgBirC,UAAYm4C,EAAOpjF,OAAO,OAAOwC,OAC9D3B,EAAIk3B,IAAI,wCAAyCgrD,GACjDH,QACG,CACH,IAAIoB,EAAUZ,EAAOpjF,OAAO,OAAOwC,OAAOiT,wBAC1CmtE,EAAUQ,EAAOpjF,OAAO,gBAAiB+jF,EAAWC,GAKxD,GAFAZ,EAAOn6E,SAEiB,QAArBg6E,EACC,OAAO79C,QAAQG,IAAIk+C,YAAYR,MAGvC,WAII,YAHmC14E,IAAhC44E,IACC/9C,QAAQG,IAAI+9C,oBAAsBH,GAE/B/9C,QAAQG,IAAIC,OAAO09C,MA9ItBe,CAASpB,EAAI,GAAIxwC,GAAQ,SAAS6xC,EAAQC,EAAYC,GAClD/jD,EAAOngC,UAAU,OAAS4iF,GAAU75E,SACpCo3B,EAAOngC,UAAU,KAAO4iF,EAAW,UAAU75E,SAE7C,IAAIo7E,EAASH,GAAUA,EAAOlkF,OAAO,OACrC,IAAIqkF,IAAWA,EAAO7hF,OAGlB,OAFAmhD,SACApd,IAIJ,IAAIwE,EAAe1K,EAAOl3B,OAAO,KAC5BsiB,QAAQq3D,EAAW,UAAU,GAC7BhhF,KAAK,CACF,iBAAkB,OAClB,mBAAoBu7B,EACpB,YAAa,MAGrB0N,EAAavoC,OAAO8S,YAAY+uE,EAAO7hF,QAGpC2hF,GAAcA,EAAW3hF,QACxB6hF,EAAO7hF,OAAO8hF,aAAaH,EAAW3hF,OAAO6S,WAAU,GAC5BgvE,EAAO7hF,OAAO+hF,YAG7CF,EAAOviF,KAAK,CACR,MAASghF,EACT7uE,OAAQmwE,EAASnwE,OACjBs3C,oBAAqB,kBAExBprD,MAAM,CAACqkF,SAAU,UAAW,iBAAkB,SAE/C,IAAI9iF,EAAOiC,EAASnB,OAAOrC,MAAMuB,MAAQ,QACrC+kB,EAAI49D,EAAOrkF,OAAO,KACtBymB,EAAE3kB,KAAK,CAACJ,KAAMA,EAAMpB,OAAQoB,IAE5B,IAAI+iF,EAAUjC,EAAQ/7D,EAAG,SACrBi+D,EAAUlC,EAAQ/7D,EAAG,UACrBo0B,GAAQl3C,EAAS7B,KAAK,KAAO2iF,EAC7B,CAACp1E,MAAO,EAAGE,OAAQ,GAAKD,IAAK,GAAG3L,EAAS7B,KAAK,gBAAkB,SAGhEoO,IADaN,GAAY4yE,EAAQ7+E,EAAU,WACxB,EAEJ,MAAhBm/E,EAAS,IACR/3C,EAAajpC,KAAK,CACdoT,UAAW,UAAY,EAAE,IAAKvR,EAAS7B,KAAK,MAAO6B,EAAS7B,KAAK,MACjE,eAAiB,EAAE2iF,EAAU,EAAGv0E,EAAKw0E,EAAU,GAAK,MAExDL,EAAOviF,KAAK,CAACF,GAAI+B,EAAS7B,KAAK,KAAMD,GAAI8B,EAAS7B,KAAK,QACjC,MAAhBghF,EAAS,GACfuB,EAAOviF,KAAK,CAACF,EAAG+B,EAAS7B,KAAK,KAAMD,EAAGqO,EAAMw0E,EAAU,IACjC,MAAhB5B,EAAS,IAA6C,IAA/BA,EAASn8E,QAAQ,UAC9C09E,EAAOviF,KAAK,CAACF,EAAG,EAAGC,EAAGqO,IAEtBm0E,EAAOviF,KAAK,CAACF,EAAGi5C,EAAMh5C,GAAK8B,EAAS7B,KAAK,KAAOoO,EAAKw0E,EAAU,IAGhE9B,GAAWA,EAAUviF,KAAKsD,EAAUonC,GACvCxE,EAAQwE,UAGb4Y,IAEAhgD,EA/FP,SAASggD,IACDtjB,EAAO4K,UACP63C,EAAWn/E,EAAS7B,KAAK,SAAW,QACpCu+B,EAAOrgC,OAAO,OAAS8iF,GAAU75E,UAErCtF,EAAS6M,KAAK,IACTrQ,MAAM,cAAe,OAsYlC,SAAsBwkF,EAAetnD,GAQjCA,EAAMA,EAAIz2B,QAAQg+E,EAAU,KAE5B,IAMIC,EANAC,GAAU,EAKVC,EAAY,GAEZC,GAAe,EAEnB,SAASC,IACLD,IAEA,IAAIE,EAAW3gE,SAAS4gE,gBAAgBpkF,EAAgBgiB,IAAK,SAC7D5jB,EAAGa,OAAOklF,GAAUpjF,KAAK,CACrBsjF,MAAO,OACPl1E,GAAK80E,EAAchkF,EAAgB,OAEvC2jF,EAAcrvE,YAAY4vE,GAE1BL,EAAcK,EAEd,IAAIG,EAAeN,EAGnB,GAFAA,EAAY,CAAC,CAACviF,KAAM0iF,IAEjBG,EAAaj/E,OAAS,EACrB,IAAI,IAAIoC,EAAI,EAAGA,EAAI68E,EAAaj/E,OAAQoC,IACpC88E,EAAUD,EAAa78E,IAKnC,SAAS88E,EAAUC,GACf,IAEIjlD,EAFAr4B,EAAOs9E,EAASt9E,KAChBu9E,EAAY,GAGhB,GAAY,MAATv9E,EAAc,CACbq4B,EAAW,IACX,IAAIpB,EAASqmD,EAASrmD,OAClBza,EAAO8gE,EAAS9gE,KAChBghE,EAAQF,EAASE,MAClBhhE,IACC+gE,EAAY,CACR,mBAAgC,WAAXtmD,GAA4C,MAArBA,EAAOviB,OAAO,GAAc,MAAQ,UAChFuiB,OAAQA,EACR,mBAAoBza,GAErBghE,IAGCD,EAAUE,QAAU,sDAChBD,EAAQ,0BAGjBnlD,EAAW,QAEfilD,EAASplF,QAAOqlF,EAAUrlF,MAAQolF,EAASplF,OAE9C,IAAIwlF,EAAUphE,SAAS4gE,gBAAgBpkF,EAAgBgiB,IAAKud,GAE5D,GAAY,QAATr4B,GAA2B,QAATA,EAAgB,CACjC29E,EAAYf,EA5QD,KA6QXA,EAAYvvE,YAAYqwE,GAExB,IAAIE,EAAWthE,SAAS4gE,gBAAgBpkF,EAAgBgiB,IAAK,SAC7D6iE,EAAYC,EAhRD,KAiRX1mF,EAAGa,OAAO6lF,GAAU/jF,KAAK,KAAMgkF,EAAS79E,IACxCu9E,EAAUt1E,GAAK61E,EAAS99E,GAExB48E,EAAYvvE,YAAYqwE,GACxBd,EAAYvvE,YAAYuwE,QAExBhB,EAAYvvE,YAAYqwE,GAG5BxmF,EAAGa,OAAO2lF,GAAS7jF,KAAK0jF,GAExBX,EAAcU,EAAS/iF,KAAOmjF,EAC9BZ,EAAUj/E,KAAKy/E,GAGnB,SAASK,EAAYpjF,EAAMgO,GACvBhO,EAAK8S,YAAYiP,SAASooD,eAAen8D,IAG7C,SAASw1E,EAAS/9E,GAGd,GAAwB,IAArB88E,EAAU3+E,OAAb,CAKA,IAAI6O,EAAY8vE,EAAU7jE,MAEvBjZ,IAASgN,EAAUhN,MAClBpH,EAAIk3B,IAAI,cAAgB9iB,EAAUhN,KAAO,2BACrCA,EAAO,8BAA+Bo1B,GAE9CwnD,EAAcE,EAAUA,EAAU3+E,OAAS,GAAG5D,UAV1C3B,EAAIk3B,IAAI,iCAAmC9vB,EAAO,KAAMo1B,GAajD4oD,EAAOzpE,KAAK6gB,GAEd4nD,KAETJ,EAAcF,EACdI,EAAY,CAAC,CAACviF,KAAMmiF,KAIxB,IADA,IAAInlE,EAAQ6d,EAAIlnB,MAAM+vE,GACd19E,EAAI,EAAGA,EAAIgX,EAAMpZ,OAAQoC,IAAK,CAClC,IAAIq0C,EAAQr9B,EAAMhX,GACdyN,EAAQ4mC,EAAM5mC,MAAMkwE,GACpBC,EAAUnwE,GAASA,EAAM,GAAG+lE,cAC5BqK,EAAWC,EAAWF,GAE1B,GAAe,OAAZA,EACCnB,SACG,QAAgB16E,IAAb87E,EACNT,EAAYf,EAAa0B,EAAgB1pC,SAGzC,GAAG5mC,EAAM,GACL+vE,EAASI,OACN,CACH,IAAII,EAAQvwE,EAAM,GAEdsvE,EAAW,CAACt9E,KAAMm+E,GAKlBK,EAAMC,EAAeF,EAAOG,GAQhC,GAPGF,GACCA,EAAMA,EAAI7/E,QAAQggF,EAAY,YAC3BP,IAAUI,GAAO,IAAMJ,IACpBA,IAAUI,EAAMJ,GAEvBI,IAAKlB,EAASplF,MAAQsmF,GAEV,MAAZL,EAAiB,CAChBtB,GAAU,EAEV,IAAIrgE,EAAOiiE,EAAeF,EAAOK,GAEjC,GAAGpiE,EAAM,CAEL,IAAIqiE,EAAcviE,SAAS6hB,cAAc,KACzC0gD,EAAYriE,KAAOA,GAC6B,IAA7CsiE,EAAUpgF,QAAQmgF,EAAYE,YAI7BzB,EAAS9gE,KAAOwiE,UAAUC,UAAUziE,IACpC8gE,EAASrmD,OAASwnD,EAAeF,EAAOW,IAAgB,SACxD5B,EAASE,MAAQiB,EAAeF,EAAOY,KAKnD9B,EAAUC,IAKtB,OAAOT,EApjBWuC,CAAa1jF,EAASnB,OAAQ66B,IAOxC15B,EAASxD,MAAM,iBAAkB,OAGrCb,QAAQiW,aAAa5R,GAElBi/E,GAAWA,EAAUviF,KAAKsD,KAiFrC,IAAIigF,EAAW,kBACXC,EAAW,kBAyEf,IAAIyC,EAAa,CAIbgB,IAAK,gBACLC,IAAK,gBACLzjE,EAAG,mBACHtb,EAAG,oBACHwe,EAAG,iBACHwgE,KAAM,GACNC,GAAI,sCAIJ1B,EAAW,CACXwB,IAAK,QACLD,IAAK,UAILxB,EAAW,CACXyB,IAAK,UACLD,IAAK,UAULP,EAAY,CAAC,QAAS,SAAU,UAAW,QAAIx8E,EAAW,KAE1Dq6E,EAAWtlF,QAAQslF,SAAW,cAE9BsB,EAAa,aAEbC,EAAU,6BAEVF,EAAS,gBACb3mF,QAAQw8D,WAAa,iBA2BrB,IAAI6qB,EAAa,mDACbE,EAAY,8CACZM,EAAc,oDACdC,EAAa,mDAIjB,SAASV,EAAegB,EAAMC,GAC1B,IAAID,EAAM,OAAO,KACjB,IAAIzxE,EAAQyxE,EAAKzxE,MAAM0xE,GACnBC,EAAS3xE,IAAUA,EAAM,IAAMA,EAAM,IACzC,OAAO2xE,GAAUrB,EAAgBqB,GAGrC,IAAIhB,EAAa,iBAWjBtnF,QAAQuoF,UAAY,SAASH,EAAM3iE,GAc/B,IAXA,IAAI3c,OAAoBmC,KAFxBwa,EAAOA,GAAQ,IAEC3c,MAAmC,IAAd2c,EAAK3c,IAAc2c,EAAK3c,IAAMmzB,IAC/DusD,OAAmCv9E,IAArBwa,EAAK+iE,YAA4B/iE,EAAK+iE,YAAc,CAAC,MAGnEC,EADW,MACK3hF,OAEhB4hF,EAAWN,EAAKvxE,MAAM+vE,GACtB+B,EAAW,GACXC,EAAU,GACVj9D,EAAI,EAEAziB,EAAI,EAAGA,EAAIw/E,EAAS5hF,OAAQoC,IAAK,CACrC,IAAI+H,EAAIy3E,EAASx/E,GACbyN,EAAQ1F,EAAE0F,MAAMkwE,GAChBC,EAAUnwE,GAASA,EAAM,GAAG+lE,cAEhC,GAAGoK,GAEsC,IAAlC0B,EAAYnhF,QAAQy/E,KACnB6B,EAASniF,KAAKyK,GACd23E,EAAU9B,OAEX,CACH,IAAI+B,EAAO53E,EAAEnK,OAEb,GAAI6kB,EAAIk9D,EAAQ//E,EACZ6/E,EAASniF,KAAKyK,GACd0a,GAAKk9D,OACF,GAAGl9D,EAAI7iB,EAAK,CACf,IAAIggF,EAAQhgF,EAAM6iB,EAEfi9D,IAAwB,OAAZA,GAAoBE,GAASL,GAAQI,GAAQJ,IACxDE,EAAS/mE,MAGV9Y,EAAM2/E,EACLE,EAASniF,KAAKyK,EAAEwP,OAAO,EAAGqoE,EAAQL,GAjCnC,OAmCCE,EAASniF,KAAKyK,EAAEwP,OAAO,EAAGqoE,IAE9B,MAGJF,EAAU,IAIlB,OAAOD,EAASn/E,KAAK,KAkBzB,IAAIu/E,EAAkB,CAClBC,GAAI,IACJC,IAAK,IACLC,GAAI,IACJC,GAAI,IACJC,KAAM,IACNC,MAAO,IACPC,OAAQ,IACRC,IAAK,KAKLC,EAAe,iCACnB,SAASvC,EAAgBmB,GACrB,OAAOA,EAAK9gF,QAAQkiF,GAAc,SAASC,EAAWC,GAalD,OAX4B,MAAzBA,EAAWrsE,OAAO,GAgB7B,SAAuBssE,GAGnB,GAAGA,EAAO,QAAU,OACpB,IAAIC,EAAsBppE,OAAOqpE,cACjC,GAAGD,EAAqB,OAAOA,EAAoBD,GAInD,IAAIG,EAAqBtpE,OAAOupE,aAChC,OAAGJ,GAAQ,MAAeG,EAAmBH,GACtCG,EACY,OAAdH,GAAQ,IACRA,EAAO,KAAS,OA3BHE,CACmB,MAAzBH,EAAWrsE,OAAO,GACdgf,SAASqtD,EAAWjpE,OAAO,GAAI,IAC/B4b,SAASqtD,EAAWjpE,OAAO,GAAI,KAE1BsoE,EAAgBW,KAIfD,KA+O1B,SAASO,EAAcC,EAAO3pE,EAAWunB,GACrC,IAIIqiD,EACAC,EACAC,EANAC,EAASxiD,EAAQm2C,gBACjBsM,EAASziD,EAAQo2C,eAAiB,MAClCsM,EAAQN,EAAM/mF,OAAOiT,wBACrBq0E,EAAQlqE,EAAUpd,OAAOiT,wBAqB7B,OAfIg0E,EADU,WAAXG,EACU,WAAa,OAAOC,EAAMr6E,OAASg6E,EAASv1E,QACpC,WAAX21E,EACG,WAAa,OAAOC,EAAMp6E,KAAOo6E,EAAM51E,OAASu1E,EAASv1E,QAAU,GAEnE,WAAa,OAAO41E,EAAMp6E,KAInCi6E,EADU,UAAXC,EACW,WAAa,OAAOE,EAAMz0E,MAAQo0E,EAASnlF,OACpC,WAAXslF,EACI,WAAa,OAAOE,EAAM71E,MAAQ61E,EAAMxlF,MAAQmlF,EAASnlF,OAAS,GAElE,WAAa,OAAOwlF,EAAM71E,MAGjC,WAOH,OANAw1E,EAAWvpF,KAAKuC,OAAOiT,wBACvBxV,KAAKE,MAAM,CACPsP,IAAMg6E,IAAWK,EAAMr6E,IAAO,KAC9BuE,KAAO01E,IAAYI,EAAM91E,KAAQ,KACjC,UAAW,MAER/T,MA5QfX,QAAQinF,gBAAkBA,EAgN1BjnF,QAAQ0Q,UAAY,SAAmBjQ,GACnC,OAAOA,EAAEG,UAAU,cAAcsB,QAAU,GAG/ClC,QAAQiW,aAAe,SAAsBxV,EAAG6B,EAAGC,GAC/C,OAAO9B,EAAEP,MAAK,WACV,IAAIgR,EAAOrR,EAAGa,OAAOC,MAErB,SAAS8pF,EAASjoF,EAAM6e,GAQpB,YAPWpW,IAARoW,EAEY,QADXA,EAAMnQ,EAAK1O,KAAKA,MAEZ0O,EAAK1O,KAAKA,EAAM,GAChB6e,EAAM,GAEPnQ,EAAK1O,KAAKA,EAAM6e,GAChBA,EAGX,IAAIqpE,EAAQD,EAAS,IAAKnoF,GACtBqoF,EAAQF,EAAS,IAAKloF,GAEL,SAAlB5B,KAAKwC,UACJ+N,EAAKtQ,UAAU,cAAc4B,KAAK,CAACF,EAAGooF,EAAOnoF,EAAGooF,QAwD5D3qF,QAAQ4qC,aAAe,SAASz1B,EAAS0yB,GACrC,IAAI3jC,EAAK2jC,EAAQ3jC,GACb0mF,EAAY/iD,EAAQgD,SACpBggD,EAAWhrF,EAAGgrF,SAAS,OAAQ,QAAS,UACxCC,EAAiBF,GAAaz1E,EAIlC,GAFAA,EAAQtU,MAAM,CAAC,iBAAkB+pF,EAAY,OAAS,QAEhC,IAAnBz1E,EAAQjT,OAAc,MAAM,IAAIggC,MAAM,OAEzC,SAAS6P,KAuBT,WACI,IACIzxB,EADUzgB,EAAGa,OAAOwD,GACAxD,OAAO,kBAC3BqqF,EAAMzqE,EAAUzW,OAAO,OACvBmhF,EAAS71E,EAAQjS,OAAOrC,MACxByP,EAAWyH,WAAWizE,EAAO16E,UAAY,IAEzCitE,EAAc11C,EAAQ32B,UACPjG,IAAhBsyE,IAA2BA,EAAcpoE,EAAQ3S,KAAK,qBAEzDuoF,EAAI5+D,QAAQ,4BAA4B,GACnCtrB,MAAM,CACH4T,SAAU,WACV,cAAeu2E,EAAOhhD,YAAc,QACpC,YAAa15B,EACbrP,MAAO4mC,EAAQzlC,MAAQ4oF,EAAO5oF,MAAQ,QACtC+I,QAAS,EACT,mBAAoB08B,EAAQ9sB,YAAc,cAC1CkwE,QAAS,sBACTxxC,OAAQ,EAAEnpC,EAAW,EAAI,EAAG,EAAG,GAAI,GAAG9G,KAAK,OAAS,KACpD0hF,QAAS,IACT,aAAc,eAEjB1oF,KAAK,CAAC2oF,iBAAiB,IACvBj6E,KAAKqsE,GACLx8E,KAAKipF,EAAc70E,EAASmL,EAAWunB,IACvCrb,GAAG,QAAQ,WACRtoB,EAAGmxC,UAAW,EACdlgC,EAAQjE,KAAKvQ,KAAKyqF,aACbvqF,MAAM,CAACsK,QAAS,IACrB,IACIkgF,EADA7H,EAAW3jF,EAAGa,OAAOC,MAAM6B,KAAK,UAEvB6oF,EAAV7H,EAAyB,IAAMA,EAAS3sE,MAAM,KAAK,GAAK,cACvC,yBAEhBhX,EAAGa,OAAOyU,EAAQjS,OAAOoH,YAAY5J,OAAO2qF,GAAcxqF,MAAM,CAACsK,QAAS,IAE9E,IAAI+F,EAAOvQ,KAAKyqF,YAChBvrF,EAAGa,OAAOC,MAAMysB,aAAagO,SAAS,GAAGzxB,SACzC9J,EAAGa,OAAOukB,UAAUuH,GAAG,UAAW,MAClCq+D,EAASS,KAAKvqF,KAAKoU,EAASjE,MAE/Bsb,GAAG,SAAS,WACT,IAAI++D,EAAU5qF,KACduD,EAAGmxC,UAAW,EACdx1C,EAAGa,OAAOukB,UAAUuH,GAAG,WAAW,WAC9B,GAAG3sB,EAAGkuB,MAAM6R,SAAW2rD,EAAS,OAAO,EACpCtmE,SAASumE,gBAAkBT,EAAI7nF,QAAQ6nF,EAAI7nF,OAAOuoF,aAG5Dj/D,GAAG,SAAS,WACa,KAAnB3sB,EAAGkuB,MAAM29D,OACRxnF,EAAGmxC,UAAW,EACdlgC,EAAQtU,MAAM,CAACsK,QAAS,IACxBtL,EAAGa,OAAOC,MACLE,MAAM,CAACsK,QAAS,IAChBqhB,GAAG,QAAQ,WAAa,OAAO,KAC/BY,aAAazjB,SAClBkhF,EAASc,OAAO5qF,KAAKoU,EAASxU,KAAKyqF,eAEnCP,EAASe,MAAM7qF,KAAKoU,EAASxU,KAAKyqF,aAClCvrF,EAAGa,OAAOC,MAAMI,KAAKipF,EAAc70E,EAASmL,EAAWunB,QAG9Drb,GAAG,WAAW,WACW,KAAnB3sB,EAAGkuB,MAAM29D,OAAc/qF,KAAK8qF,UAElC1qF,KAAK8qF,GAzFVC,GACA32E,EAAQtU,MAAM,CAACsK,QAAS,IAExB,IACIkgF,EADA7H,EAAWsH,EAAetoF,KAAK,UAEtB6oF,EAAV7H,EAAyB,IAAMA,EAAS3sE,MAAM,KAAK,GAAK,cACvC,yBAEhBhX,EAAGa,OAAOyU,EAAQjS,OAAOoH,YAAY5J,OAAO2qF,GAAcxqF,MAAM,CAACsK,QAAS,IAIlF,SAAS0gF,EAAsBE,GAC3B,IAAIjiF,EAAKiiF,EAAI7oF,OACTwc,EAAQuF,SAAS+mE,cACrBtsE,EAAMusE,mBAAmBniF,GACzB,IAAIhH,EAAMghB,OAAOooE,eACjBppF,EAAIqpF,kBACJrpF,EAAIspF,SAAS1sE,GACb5V,EAAGuiF,QA4EP,OAHGxkD,EAAQk2C,UAAWhsC,IACjB+4C,EAAet+D,GAAG,QAASulB,GAEzBlyC,EAAGysF,OAAOn3E,EAAS01E,EAAU,Q,+CC5yBxC,YAEA,IACI0B,EADAC,EAAY,EAAQ,YAIvBD,EADgC,mBAAtBE,EAAOC,YACLD,EAAOC,WAAW,iBAAiBzvE,QAGpCuvE,EAGZzsF,EAAOC,QAAUusF,I,wECFjB,IAAI1sF,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YAEpBE,EAAW,EAAQ,YACnBsrF,EAAa,EAAQ,YACrBx0E,EAAW,EAAQ,YACnB5W,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAChBuzB,EAAS,EAAQ,YAA0BA,OAE3Ck/C,EAAU,EAAQ,YAElBqa,EAAiB,EAAQ,YACzBC,EAAa,EAAQ,YAErB3nC,EAAoB,EAAQ,YAAqBA,kBAEjDxxB,EAAoBnyB,EAAImyB,kBACxBsG,EAAIz4B,EAAIy4B,EAERvX,EAAQ1iB,EAAOC,QAAU,GAG7BuB,EAAIiM,WAAWiV,EAAOphB,GAEtBohB,EAAMkG,WAAa,EAAQ,YAC3BlG,EAAMkG,WAAWhgB,KAAKs3C,OAASx9B,EAAMqqE,SACrCrqE,EAAMg9B,UAAY,EAAQ,YAC1Bh9B,EAAMpK,iBAAmB,EAAQ,YAGjCoK,EAAMsqE,WAAa,SAEnB,IAAIC,EAAqBvqE,EAAMuqE,mBAE3BC,EAAgB,EAAQ,YAC5BxqE,EAAM0L,kBAAoB8+D,EAAc9+D,kBACxC1L,EAAMyqE,0BAA4BD,EAAcC,0BAChDzqE,EAAMyQ,sBAAwB+5D,EAAc/5D,sBAC5CzQ,EAAM0qE,4BAA8BF,EAAcE,4BAKlD1qE,EAAM2qE,WAAa,SAASlpF,GAGxB,IAAIiF,GAFJjF,EAAK3C,EAAIi4B,YAAYt1B,IAEDkF,aAAe,GAKnC,OAJeD,EAAWma,MAAQna,EAAWma,KAAK,WAChBpf,EAAGsB,MAAQtB,EAAGsB,KAAK,IAAMtB,EAAGsB,KAAK,GAAGyB,GAKtE,OAAO,IAAI+/B,SAAQ,SAASC,GACxBmM,YAAW,WACP/xC,EAASyX,mBAAmB,cAAe,OAA3CzX,CAAmD6C,GACnD7C,EAASyX,mBAAmB,SAAU,OAAtCzX,CAA8C6C,GAC9C7C,EAASyX,mBAAmB,WAAY,OAAxCzX,CAAgD6C,GAChD+iC,EAAQxkB,EAAMovB,iBAAiB3tC,MAChC,SAKXue,EAAM4qE,OAAS,SAASnpF,GAGpB,IAAIopF,EAFJppF,EAAK3C,EAAIi4B,YAAYt1B,GAGrB,IAAI+M,EAAI,IAAI+1B,SAAQ,SAASC,EAASC,GAC9BhjC,IAAM3C,EAAIojC,SAASzgC,IACnBgjC,EAAO,IAAIhF,MAAM,wDAGlBh+B,EAAGqpF,cAAcj6C,aAAapvC,EAAGqpF,cACjCrpF,EAAGspF,iBAAgBF,EAAoBppF,EAAGspF,gBAC7CtpF,EAAGspF,eAAiBvmD,EAEpB/iC,EAAGqpF,aAAen6C,YAAW,WAEzB,IAAIlvC,EAAGshB,QAAWthB,EAAGshB,OAAOzgB,OAASb,EAAGshB,OAAO7Q,QAAWpT,EAAIojC,SAASzgC,GACnE+iC,EAAQ/iC,OADZ,QAKOA,EAAGshB,OAAOzgB,aACVb,EAAGshB,OAAO7Q,OAGjB,IAAI84E,EAAavpF,EAAGwpF,QAGpBxpF,EAAGypF,UAAW,EAEdtsF,EAASN,KAAK,WAAYmD,EAAI,CAAC0pF,UAAU,IAAOhwD,MAAK,WACjD15B,EAAGwpF,QAAUD,EAEVvpF,EAAGspF,iBAAmBvmD,WACd/iC,EAAGspF,eACVvmD,EAAQ/iC,UAGjB,QAIP,OADGopF,GAAmBA,EAAkBr8E,GACjCA,GAMXwR,EAAMovB,iBAAmB,SAAS3tC,GAC9B,IAAIA,EAAGmlE,WAAa,IAAIviE,OACpB,OAAOkgC,QAAQuiC,IAAIrlE,EAAGmlE,WACjBzrC,MAAK,WAAa15B,EAAGmlE,UAAY,OAU9C5mD,EAAMorE,SAAW,SAAS3pF,GAEtB,GAAIA,EAAGG,SAASypF,UAAa5pF,EAAGG,SAAS0pF,YAAzC,CAEA,IAAI5kF,EAAajF,EAAGkF,YAEhB4kF,EAAgBzsF,EAAIkJ,aAAatB,EAAWghC,OAAQ,OAAQ,0BAA0B,SAAS1pC,GAC/FA,EAAEI,MAAM,CACJ,cAAe,iCACf,YAAa,OACb,KAAQf,EAAMyM,YACd,iBAAkB,QAErBrM,MAAK,WACF,IAAI07E,EAAQ/7E,EAAGa,OAAOC,MACtBi7E,EAAM/xE,OAAO,SAASsiB,QAAQ,mBAAmB,GACjDyvD,EAAM/xE,OAAO,SAASsiB,QAAQ,kBAAkB,GAChDyvD,EAAM/xE,OAAO,SAASsiB,QAAQ,kBAAkB,SAKpDjb,EAAO88E,EAAc9qF,OACrBmF,EAAQ,CAAC9F,EAAG4G,EAAWghC,OAAO3nC,KAAK,UAAY,GAOhDyiB,SAASoiB,KAAK4mD,SAAS/8E,IAASA,EAAKg9E,yBAA4B/kF,EAAWpE,MAAQ,IAEnFsD,EAAM,eAAiB,QACvBA,EAAM/F,EAAI,IAGV+F,EAAM,eAAiB,MACvBA,EAAM/F,EAAI6G,EAAWghC,OAAO3nC,KAAK,SAAW,GAGhDwrF,EAAcxrF,KAAK6F,GAEnB,IAAI8lF,EAAWH,EAActtF,OAAO,oBAChC0tF,EAAYJ,EAActtF,OAAO,mBACjC2tF,EAAaL,EAActtF,OAAO,mBAEnCwD,EAAGG,SAAS0pF,aAAa7pF,EAAGG,SAAS0pF,YAAY7pF,GAGjDA,EAAGG,SAASypF,UAQnB,SAA8B5pF,EAAIoc,GAC9BA,EAAUpP,KAAK,IACf,IAAIo9E,EAAOhuE,EAAUzW,OAAO,KACvBrH,KAAK,CACF,mBAAoB,IACpB,MAAS,6BACT,cAAe,SAElB0O,KAAKhN,EAAGG,SAASkqF,SAAW,IAAM/tE,OAAOupE,aAAa,MAE3D,GAAG7lF,EAAGG,SAASmqF,SACXF,EAAK9hE,GAAG,SAAS,WACb/J,EAAMgsE,gBAAgBvqF,UAEvB,CACH,IAAIqP,EAAOuQ,OAAOoB,SAASwpE,SAAS73E,MAAM,KACtC83E,EAAQ7qE,OAAOoB,SAAS0pE,OAC5BN,EAAK9rF,KAAK,CACN,mBAAoB,MACpB,mBAAoB,IAAM+Q,EAAK,GAAGsD,MAAM,KAAK,GAAK,IAAMtD,EAAK,GAAKo7E,KA3BjDE,CAAqB3qF,EAAIiqF,GAGlDC,EAAUl9E,KAAMi9E,EAASj9E,QAAUm9E,EAAWn9E,OAAU,MAAQ,MA6BpEuR,EAAMgsE,gBAAkB,SAASvqF,GAC7B,IAAI4qF,GAAWhrE,OAAOirE,WAAa,IAAIC,UAAY9qF,EAAGG,SAAS4qF,gBAC/D,GAAIH,EAAJ,CAEA5qF,EAAGoqB,KAAK,uBAER,IAAI4gE,EAAgBrvF,EAAGa,OAAOwD,GACzB2F,OAAO,OACPrH,KAAK,KAAM,cACX3B,MAAM,UAAW,QAElBsuF,EAAaD,EACZrlF,OAAO,QACPrH,KAAK,CACF4sF,OAAQN,EAAU,YAClB1gE,OAAQ,OACRwR,OAAQ,WAehB,OAZsBuvD,EACjBtlF,OAAO,SACPrH,KAAK,CACFmG,KAAM,OACN+Z,KAAM,SAGExf,OAAOo+B,MAAQ7e,EAAM4sE,UAAUnrF,GAAI,EAAO,YAC1DirF,EAAWjsF,OAAOosF,SAClBJ,EAAcvlF,SAEdzF,EAAGoqB,KAAK,uBACD,IAGX,IAAIihE,EAAe,CACf,OAAQ,YAAa,SAAU,cAAe,UAC9C,WAAY,OAAQ,OACpB,UAAW,YAAa,WAAY,YAGpCC,EAAkB,CAClB,OAAQ,QAAS,WAAY,gBAwYjC,SAASC,EAAavrF,EAAIwrF,GACtB,IAAIC,EAASzrF,EAAGG,SAASsrF,OAGrBC,GAAa,EACbC,EAAY,GAEhB,SAASC,EAAcC,GAEnB,IADA,IAAIC,GAAiB,EACb9mF,EAAI,EAAGA,EAAIwmF,EAAW5oF,OAAQoC,IAAK,CACvC,IAAI+mF,EAAYP,EAAWxmF,GACvB2mF,EAAUI,KACPF,EAAUE,GACTJ,EAAUI,GAAaF,EAAUE,GAC9BD,GAAiB,GAG7BA,IAAgBJ,GAAa,GAIpC,IAAI,IAAI1mF,EAAI,EAAGA,EAAI,EAAGA,IAAK,CAEvB,IADA,IAAIgnF,EAAUhsF,EAAGG,SAAS6rF,QAClB92E,EAAI,EAAGA,EAAI,EAAGA,IAAK,CACvB,IAAI+2E,GAAWD,EAAQP,IAAW,IAAI5nF,OACtC,GAAGooF,IACCL,EAAcK,GACXP,GAAY,MAEnBM,EAAU7uF,EAAS+uF,eAGvB,IAAIC,EAAaV,EAAO94E,MAAM,KAAK,GACnC,GAAG+4E,GAAcS,IAAeV,EAAQ,MACxCA,EAASU,EAMb,OAFIT,GAAYE,EAAczuF,EAAS+uF,eAAeE,GAAGvoF,QAElD8nF,EA6QX,SAASU,EAAgB1jD,EAAI1jC,GACzB,IAAIqnF,EAAS,CAACpnF,YAAaD,GAEvBsnF,EAA2B,MAArB5jD,EAAGzwB,IAAIiB,OAAO,GACpBqzE,EAAW7jD,EAAGqe,UAAUoY,YACxBqtB,EAAgB,GAChBC,EAAwB,GACxBC,EAAW,GAUf,GAPGH,IACCG,EAAWH,EAASxlC,UAAU9uC,IAC9Bu0E,EAAgBF,EAAO5jD,EAAGzwB,IAAMy0E,EAAaA,EAAWhkD,EAAGzwB,MAK3Du0E,IAAkBxnF,EAAWo/C,OAAOooC,GAAgB,CACpDA,EAAgB,GAGhB,IADA,IAAIG,EAAajkD,EAAG5wB,aACZ7C,EAAI,EAAGA,EAAI03E,EAAWhqF,OAAQsS,IAAK,CACvC,IAAI23E,EAAcD,EAAW13E,GACzBgoB,EAAKqvD,EAAO5jD,EAAGzwB,IAAM20E,EAAgBA,EAAclkD,EAAGzwB,IACtDw0E,IAAuBA,EAAwBxvD,GACnD,IAAI4mC,EAAYuK,EAAQxqC,UAAUyoD,EAAQO,GAC1C,GAAGF,GAAY7oB,EAAUtrD,aAAem0E,EAAU,CAC9CF,EAAgBvvD,EAChB,QAKZ,OAAOuvD,GAAiBC,EA+W5B,SAASI,EAAsB5wF,GAC3B,IAAI0X,EAAa1X,EAAM0X,WACvB,GAAG7O,MAAM+D,QAAQ8K,IAAeA,EAAWhR,OACvC,IAAI,IAAIoC,EAAI,EAAGA,EAAI4O,EAAWhR,OAAQoC,IAAK,CACvC,IAAI+nF,EAAKn5E,EAAW5O,GAChBmI,EAAU4/E,EAAG5/E,SAAW27E,EAAmBiE,EAAGtoF,MAClD,GAAG0I,GAAWA,EAAQ6/E,UAAW,OAAO,EAGhD,OAAO,EAuDX,SAASC,EAAgBC,EAAWj4E,EAAUqM,EAAQrc,GAIlD,IAHA,IAAImX,EAAY8wE,EAAUt5E,WACtBu5E,EAAU,CAACD,GAEPloF,EAAI,EAAGA,EAAIoX,EAAUxZ,OAAQoC,IAAK,CACtC,IAAI0M,EAAY0K,EAAUpX,GACtBmI,EAAU27E,EAAmBp3E,EAAUjN,MAExC0I,GAAWA,EAAQuE,YAClBy7E,EAAUhgF,EAAQuE,UAAUy7E,EAAS,CACjCz7E,UAAWA,EACXw7E,UAAWA,EACXj4E,SAAUA,EACVqM,OAAQA,EACRrc,WAAYA,EACZmoF,eAAgBpoF,KAK5B,OAAOmoF,EAmXX,SAASE,EAAYpoF,GACjB,IAAIswC,EAAStwC,EAAWswC,OAExB,IAAItwC,EAAWmoB,MAAO,CAClB,IAAI+W,EAAKl/B,EAAWmoB,MAAQ,CACxB3F,EAAGpnB,KAAKC,MAAMi1C,EAAO9tB,GACrB1kB,EAAG1C,KAAKC,MAAMi1C,EAAOxyC,GACrByQ,EAAGnT,KAAKC,MAAMi1C,EAAO/hC,GACrB8M,EAAGjgB,KAAKC,MAAMi1C,EAAOj1B,GACrBvT,EAAG1M,KAAKC,MAAMi1C,EAAOhuB,MAEzB4c,EAAG3lC,EAAI6B,KAAKC,MAAM2E,EAAWpE,OAASsjC,EAAG1c,EAAI0c,EAAGphC,EAChDohC,EAAG1lC,EAAI4B,KAAKC,MAAM2E,EAAWwL,QAAU0zB,EAAG3wB,EAAI2wB,EAAG7jB,EAEjDrb,EAAWqoF,cAAaroF,EAAWqoF,YAAc,IACjDroF,EAAWsoF,iBAAgBtoF,EAAWsoF,eAAiB,IAhgD/DhvE,EAAMivE,eAAiB,SAASxtF,EAAIuhB,GAChC,IAAIksE,EAAiBlsE,GAAQA,EAAKksE,eAC9BxuE,EAAgBjf,EAAGkF,aAAe,GAEtC,GAAG+Z,EAAcyuE,qBACNzuE,EAAcyuE,kBADzB,CAKA,IAWI1oF,EAXA+Z,EAAgB/e,EAAGkF,YAAc,GACjCyoF,EAAY3tF,EAAGshB,QAAU,GAEzBtC,EAAchf,EAAG8uC,WAAa,GAC9BhwB,EAAc9e,EAAG8uC,UAAY,GAC7B8+C,EAAU5tF,EAAGsB,MAAQ,GAErBusF,EAAc7tF,EAAGoyC,UAAY,GAE7BnhC,EAAUjR,EAAGG,UAAY,GAKzBH,EAAG2uC,iBAAiBpwB,EAAMuvE,qBAAqB9tF,GAanD+e,EAAci7C,WAAa,CACvBv7C,KAAMqX,EAAE91B,EAAI,6BACZ5B,EAAG03B,EAAE91B,EAAI,+BACT3B,EAAGy3B,EAAE91B,EAAI,+BACT4oE,SAAU9yC,EAAE91B,EAAI,mCAChBgnC,WAAYlR,EAAE91B,EAAI,aAEtB+e,EAAcgvE,WAAaj4D,EAAE91B,EAAI,SAEjC,IAAI2rF,EAAYJ,EAAavrF,EAAIqrF,GAOjC,GAJAtsE,EAAcivE,mBAAqB/8E,EAAQg9E,kBAIxChvE,EAAcivE,uBAAwB,CAErC,IAAIC,EAAWlvE,EAAcpe,MACzButF,EAAYnvE,EAAcxO,OAE9B8N,EAAM8vE,2BAA2BV,EAAW5uE,EAAe4sE,GAEvDgC,EAAU9sF,QAAOke,EAAcle,MAAQstF,GACvCR,EAAUl9E,SAAQsO,EAActO,OAAS29E,GAC7C7vE,EAAM+vE,gBAAgBvvE,OACnB,CAEHR,EAAM8vE,2BAA2BV,EAAW5uE,EAAe4sE,GAE3D,IAAI4C,GAAyBZ,EAAU9sF,QAAU8sF,EAAUl9E,OACvDi5E,EAAW3qE,EAAc2qE,SACzB8E,EAAcv9E,EAAQu9E,YACJD,IAAyB7E,GAAY8E,GAEvCjwE,EAAMkwE,aAAazuF,EAAI2tF,EAAW5uE,GAC9CwvE,GAAsBhwE,EAAM+vE,gBAAgBvvE,IAGhD2qE,GAAY6E,IACZZ,EAAU9sF,MAAQke,EAAcle,MAChC8sF,EAAUl9E,OAASsO,EAActO,QAIzCsO,EAActR,UA2UlB,SAAsBk+E,EAAW7tD,GAI7B,OAHA6tD,EAAU+C,QAAU5wD,EAAW3kB,OAAO,GACtCwyE,EAAUgD,UAAY7wD,EAAW3kB,OAAO,GAEjCxd,EAAG8vF,OAAOE,GA/USiD,CAAajD,EAAW5sE,EAAc+e,YAChE/e,EAAci2C,aAAeu2B,EAAavrF,EAAIsrF,GAE9CvsE,EAAcmvE,wBAAyB,EAGvCnvE,EAAc8vE,YAAcjB,EAAQhrF,OAGpCmc,EAAc0iC,SAAW,GACzB1iC,EAAc+vE,gBAAkB,GAChC/vE,EAAc4oD,iBAAmB,GACjC,IAAIxxD,EAAW4I,EAAc3I,UA2NjC,WACI,IAEIpR,EAAGkQ,EAFH65E,EAA0B5xF,EAAS4xF,wBACnC7lF,EAAM,GAGV,IAAI6lF,EAAyB,CACzBA,EAA0B,GAE1B,IAAItnB,EAAmBtqE,EAASsqE,iBAEhC,IAAI,IAAIunB,KAAevnB,EAAkB,CACrC,IACIwnB,EADgBxnB,EAAiBunB,GACL1wF,KAEhC,GAAG2wF,IACCF,EAAwBzsF,KAAK0sF,GAI1BjqF,MAAM+D,QAAQmmF,IACb,IAAI/5E,EAAI,EAAGA,EAAI+5E,EAAYrsF,OAAQsS,IAC/B7X,EAAI44B,WAAW84D,EAAyBE,EAAY/5E,KAOxE,IAAIlQ,EAAI,EAAGA,EAAI+pF,EAAwBnsF,OAAQoC,IAC3CkE,EAAI6lF,EAAwB/pF,IAAM,GAEtC,OAAOkE,EA1PkCgmF,GAGrCC,EAAYpwE,EAAclF,WAAa,CAACzb,EAAG,GAAIC,EAAG,IAClD+wF,EAAgBrwE,EAAcswE,eAAiB,GAEnDtwE,EAAcuwE,eAAiB,GAG/BvwE,EAAc2pC,kBAAoB,GAElC3pC,EAAcwwE,cAAgB,GAE9BxwE,EAAcywE,eAAiB,GAE/BzwE,EAAc0wE,WAAa,GAI3B1wE,EAAc2wE,oBAAsB,GAGpC3wE,EAAc4wE,WAwJlB,SAAsB3wE,EAAa4uE,GAC/B,IAEI5oF,EAAG4qF,EAFHhrF,EAAMgpF,EAAQhrF,OACditF,EAAe,GAEnB,IAAI7qF,EAAI,EAAGA,EAAIga,EAAYpc,OAAQoC,IAAK,CACpC,IAAI8qF,EAAgB9wE,EAAYha,GAAGorC,WAChC0/C,IAAkBF,GAAeC,EAAavtF,KAAKwtF,GACtDF,EAAgBE,EAEpB,IAAIC,EAASF,EAAajtF,OACtBsG,EAAM,IAAInE,MAAMH,GAChBorF,EAAW,GAEf,SAASC,EAAOhnF,EAAKjE,GACjBkE,EAAIlE,GAAKiE,EACT+mF,EAAS/mF,GAAO,EAGpB,SAASinF,EAAOjnF,EAAKjE,GACjB,GAAGiE,GAAsB,iBAARA,IAAqB+mF,EAAS/mF,GAE3C,OADAgnF,EAAOhnF,EAAKjE,IACL,EAIf,IAAIA,EAAI,EAAGA,EAAIJ,EAAKI,IAAK,CACrB,IAAImrF,EAASvC,EAAQ5oF,GAAGiE,IACH,iBAAXknF,IAAqBA,EAAS7zE,OAAO6zE,IAE5CD,EAAOC,EAAQnrF,KACfA,EAAI+qF,GAAUG,EAAOL,EAAa7qF,GAAGiE,IAAKjE,IAC7CirF,EAAO5yF,EAAIo6B,QAAQu4D,GAAWhrF,IAGlC,OAAOkE,EA1LoBknF,CAAapxE,EAAa4uE,GAGrD7uE,EAAcsxE,mBAAqBrwF,EAAGG,UAAY,IAAImwF,iBACtD/xE,EAAMgyE,mBAAmB3C,EAAS9uE,EAAa6uE,EAAW5uE,GAI1D,IAAIyxE,EAAUxuF,OAAOC,KAAKktF,EAAU/wF,GAChCqyF,EAAUzuF,OAAOC,KAAKktF,EAAU9wF,GACpC,GAAGmyF,EAAQ5tF,OAAS,GAAK6tF,EAAQ7tF,OAAS,EAAG,CAGzC,IAFAzF,EAASyX,mBAAmB,OAAQ,eAApCzX,CAAoDwwF,EAAW5uE,GAE3D/Z,EAAI,EAAGA,EAAIwrF,EAAQ5tF,OAAQoC,IAC3B3H,EAAI44B,WAAW9f,EAASxW,MAAO6wF,EAAQxrF,IAE3C,IAAIA,EAAI,EAAGA,EAAIyrF,EAAQ7tF,OAAQoC,IAC3B3H,EAAI44B,WAAW9f,EAASvW,MAAO6wF,EAAQzrF,IAE3C,IAAI,IAAI7C,KAAKitF,EACT/xF,EAAI44B,WAAW9f,EAASivC,UAAWjjD,GAO3C,GAFA4c,EAAcK,KAAOb,EAAMmyE,aAAa7lB,KAAK9rD,GAE1CC,EAAYpc,SAAWkc,EAAYlc,OAClC,IAAIoC,EAAI,EAAGA,EAAI8Z,EAAYlc,OAAQoC,IAC/BwqB,EAAkB1Q,EAAY9Z,GAAIga,EAAYha,IAKtDuZ,EAAMoyE,2BAA2BhD,EAAW5uE,EAAeD,EAAa9e,EAAG2uC,iBAK3E,IAAI8S,EAAW1iC,EAAc+vE,gBACzB8B,EAA0B,GAC9B,IAAI5rF,EAAI,EAAGA,EAAIy8C,EAAS7+C,OAAQoC,IAAK,CACjC,IAAI6rF,EAAQpvC,EAASz8C,GAAG8rF,mBAErBD,GAAOxzF,EAAI44B,WAAW26D,EAAyBC,GAEtD,IAAI7rF,EAAI,EAAGA,EAAI4rF,EAAwBhuF,OAAQoC,IAC3C4rF,EAAwB5rF,GAAG8Z,EAAaC,GAK5CA,EAAc8jC,oBACgC,IAA1C9jC,EAAc4oD,iBAAiB/kE,QACY,UAA3Cmc,EAAc4oD,iBAAiB,GAAGnpD,MAClCgyE,EAAQ5tF,OAAS,IACjB6tF,EAAQ7tF,OAAS,IACe,IAAhCmc,EAAcgyE,OAAOnuF,QACW,IAAhCmc,EAAciyE,OAAOpuF,OAKzBmc,EAAckyE,cAAgBlyE,EAAcK,KAAK,aACjDL,EAAcmyE,QAAUnyE,EAAcK,KAAK,OAC3CL,EAAcoyE,SAAWpyE,EAAcK,KAAK,QAC5CL,EAAcqyE,SAAWryE,EAAcK,KAAK,QAC5CL,EAAcsyE,YAActyE,EAAcK,KAAK,WAC/CL,EAAcuyE,QAAUvyE,EAAcK,KAAK,OAG3Cb,EAAMgzE,aAAazyE,EAAaC,EAAeC,EAAaC,GAG5DV,EAAMizE,UAAU1yE,EAAaC,EAAeC,EAAaC,GAOtDA,EAAck5D,aAAen4E,EAAGqlC,WAC/BpmB,EAAck5D,WAAWz7E,UAAU,mBAAmB+I,SA8N9D,SAA6BqZ,EAAaC,GACtC,IAAIxR,EACAkkF,EAAY,GAEb1yE,EAAczR,OACbC,EAAQwR,EAAcxR,MAAQ,CAC1BD,KAAMyR,EAAczR,KACpBgU,OAAQ,CAAChU,KAAMyR,EAAczR,QAIrC,IAAI,IAAItI,EAAI,EAAGA,EAAI8Z,EAAYlc,OAAQoC,IAAK,CACxC,IAAI9I,EAAQ4iB,EAAY9Z,GAErB9I,EAAMoR,KACLmkF,EAAUv1F,EAAMopB,OAASppB,EAAMqR,MAAQ,CAACD,KAAMpR,EAAMoR,MAC9CyR,EAAczR,OACpBpR,EAAMqR,MAAQ,CAACD,KAAMyR,EAAczR,OAEpCyR,EAAczR,OACbpR,EAAMqR,MAAM+T,OAAS,CAAChU,KAAMyR,EAAczR,OAI/CmkF,EAAU7uF,SACL2K,IACAA,EAAQwR,EAAcxR,MAAQ,IAElCA,EAAMjM,KAAOmwF,GArPjBC,CAAoB5yE,EAAaC,GAGjCyQ,EAAkBzQ,EAAeE,GAGjC9hB,EAASyX,mBAAmB,aAAc,qBAA1CzX,CAAgE2hB,EAAaC,GAIzEA,EAAc4yE,UAAS5yE,EAAc4yE,QAAU,IAE/C5yE,EAAc6yE,eAAc7yE,EAAc6yE,aAAe,IAC7D,IAEI3oF,EAFA4oF,EAAc9yE,EAAc6yE,aAC5BE,EAAO,GAEX,IAAI7oF,KAAO4oF,EAAaC,EAAK7oF,GAAO,MACpC,IAAIjE,EAAI,EAAGA,EAAI8Z,EAAYlc,OAAQoC,IAE3B8sF,EADJ7oF,EAAM6V,EAAY9Z,GAAGorC,WAAWnnC,OACjB4oF,EAAY5oF,GAAO,IAClC6oF,EAAK7oF,GAAO,MAEhB,IAAIA,KAAO6oF,EACU,QAAdA,EAAK7oF,WAAuB4oF,EAAY5oF,GAI/CokF,EAAYtuE,GAGZ5hB,EAASyX,mBAAmB,cAAe,WAA3CzX,CAAuD4hB,GAGnD0uE,GAAkBI,EAAYjrF,SAAWkc,EAAYlc,QACrD2b,EAAMwzE,yBAAyBlE,EAAa/uE,KAIpDP,EAAMwzE,yBAA2B,SAASlE,EAAa/uE,GACnD,IAAI,IAAI9Z,EAAI,EAAGA,EAAI8Z,EAAYlc,OAAQoC,IAAK,CACxC,IAAIgtF,EAAWlzE,EAAY9Z,GACvBitF,GAAOpE,EAAY7oF,IAAM,IAAI,GACjC,GAAGitF,GAAOA,EAAI/1F,MAAO,CACjB,IAAIg2F,EAAWD,EAAI/1F,MACnB,GAAGg2F,EAASC,kBAAmB,CAC3B,IACIj9E,EAAG2H,EAAMu1E,EADTC,EAAaH,EAASI,YAG1B,IAAIp9E,EAAI,EAAGA,EAAIm9E,EAAWzvF,OAAQsS,IAC9B2H,EAAOw1E,EAAWn9E,GAClBk9E,EAAc/0F,EAAIkO,eAAe2mF,EAAUr1E,GAAMrR,MAAMiQ,QACvDpe,EAAIkO,eAAeymF,EAAUn1E,GAAMD,IAAIw1E,GAG/CH,EAAI/1F,MAAQ81F,KAoMxBzzE,EAAMuvE,qBAAuB,SAAS9tF,GAE9BA,EAAG2uC,kBACH3uC,EAAG2uC,gBAAkB,IAGrB3uC,EAAG2uC,gBAAgBC,UACnB5uC,EAAG2uC,gBAAgBC,QAAU,IAG7B5uC,EAAG2uC,gBAAgB4jD,aACnBvyF,EAAG2uC,gBAAgB4jD,WAAa,IAGhCvyF,EAAG2uC,gBAAgB6jD,WACnBxyF,EAAG2uC,gBAAgB6jD,SAAW,GAG9BxyF,EAAG2uC,gBAAgB8jD,sBACnBzyF,EAAG2uC,gBAAgB8jD,oBAAsB,KAOjDl0E,EAAMmyE,aAAe,SAASgC,GAC1B,IAAI1tF,EAGA2tF,EAAkBl2F,KAAKkrE,kBAAoB,GAC/C,IAAI3iE,EAAI,EAAGA,EAAI2tF,EAAgB/vF,OAAQoC,IACnC,GAAG2tF,EAAgB3tF,GAAGwZ,OAASk0E,EAAU,OAAO,EAIpD,IAAIlxC,EAAU/kD,KAAKglD,UAAY,GAC/B,IAAIz8C,EAAI,EAAGA,EAAIw8C,EAAQ5+C,OAAQoC,IAAK,CAChC,IAAIwZ,EAAOgjC,EAAQx8C,GAAGwZ,KACtB,GAAGA,IAASk0E,EAAU,OAAO,EAE7B,IAAIvlF,EAAUhQ,EAASqkD,QAAQhjC,GAC/B,GAAGrR,GAAWA,EAAQy0C,WAAW8wC,GAAW,OAAO,EAGvD,OAAO,GAGXn0E,EAAMizE,UAAY,SAAS1yE,EAAaC,EAAeC,EAAaC,GAChE,IAAIja,EAAGkQ,EAEHy9E,EAAkB1zE,EAAc0oD,kBAAoB,GACxD,IAAI3iE,EAAI,EAAGA,EAAI2tF,EAAgB/vF,OAAQoC,IAAK,CACxC,IAAImI,EAAUwlF,EAAgB3tF,GAE3BmI,EAAQ0R,OACP1R,EAAQ0R,MAAMC,EAAaC,EAAeC,EAAaC,GAI/D,IAAI+mC,EAAQ/mC,EAAcG,MAAQH,EAAcG,KAAK,MACjD6mC,EAAQlnC,EAAcK,MAAQL,EAAcK,KAAK,MAElD4mC,IAAUC,QACyBl/C,IAA/BkY,EAAc2zE,eACb3zE,EAAc2zE,aAAal2F,UAAU,cAAc+I,SACnDwZ,EAAc2zE,aAAal2F,UAAU,aAAa+I,SAClDwZ,EAAc4zE,UAAY,MAIlC,IAAIC,IAAiB7zE,EAAcwlB,WAEnCsuD,EACA,IAAI/tF,EAAI,EAAGA,EAAIga,EAAYpc,OAAQoC,IAAK,CACpC,IACIguF,EADWh0E,EAAYha,GACLiE,IAEtB,IAAIiM,EAAI,EAAGA,EAAI4J,EAAYlc,OAAQsS,IAAK,CAGpC,GAAG89E,IAFYl0E,EAAY5J,GAEJjM,IAAK,SAAS8pF,EAItCD,GACC7zE,EAAcwlB,WAAWjoC,OAAO,MAAQw2F,GAAQvtF,WAK5D8Y,EAAMgzE,aAAe,SAASzyE,EAAaC,EAAeC,EAAaC,GACnE,IAAIja,EAAGkQ,EAEH+9E,EAAch0E,EAAcolC,QAAU,GACtC6uC,EAAcn0E,EAAcslC,OAAS,GACrC8uC,EAAiBp0E,EAAc3I,UAE/Bk2E,EAAS,CACTx9C,UAAWhwB,EACX5Z,YAAa6Z,GAGb8nC,EAAMssC,EAAe/tC,UAAUzuC,OAAOw8E,EAAe7tC,MAAQ,IAEjE,IAAItgD,EAAI,EAAGA,EAAI6hD,EAAIjkD,OAAQoC,IAAK,CAC5B,IAIIm8C,EAJAjkB,EAAK2pB,EAAI7hD,GACTouF,EAAaH,EAAY/1D,GACzBv9B,EAAQ0uE,EAAQxqC,UAAUyoD,EAAQpvD,EAAI,KACtCt9B,EAAQyuE,EAAQxqC,UAAUyoD,EAAQpvD,EAAI,KA2B1C,IAvBGk2D,EACCjyC,EAAW+xC,EAAYh2D,GAAMk2D,GAE7BjyC,EAAW+xC,EAAYh2D,GAAM,IACpBA,GAAKA,EAIlBv9B,EAAMoY,aAAazV,KAAK1C,EAAMsY,KAC9BtY,EAAMmY,aAAazV,KAAK3C,EAAMuY,KAC9BvY,EAAMmY,cAAcxV,KAAK46B,GACzBt9B,EAAMkY,cAAcxV,KAAK46B,GAGzBikB,EAASxhD,MAAQA,EACjBwhD,EAASvhD,MAAQA,EAMjBuhD,EAASzhD,qBAAsB,EAE3BwV,EAAI,EAAGA,EAAI4J,EAAYlc,OAAQsS,IAAK,CACpC,IAAIhZ,EAAQ4iB,EAAY5J,GAExB,GACIhZ,EAAMyD,QAAUwhD,EAASxhD,MAAMuY,KAC/Bhc,EAAM0D,QAAUuhD,EAASvhD,MAAMsY,MACV,IAArBhc,EAAMm3F,WACR,CACElyC,EAASzhD,qBAAsB,EAC/B,QAOZ,IACIipC,EADAgjB,EAAS0iB,EAAQ/1D,KAAKg0E,EAAQ,MAAM,GAExC,IAAItnF,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CAE/B,IAAIsuF,EAAS,MADb3qD,EAAKgjB,EAAO3mD,IAGNwT,aACF86E,EAASjlB,EAAQxqC,UAAUyoD,EAAQ3jD,EAAGnwB,cAGzB86E,EAAO96E,aAChBmwB,EAAGnwB,YAAa,EAChB86E,EAAS,MAGjB3qD,EAAGqe,UAAYssC,GAAU3qD,EAUtB2qD,IAAQ3qD,EAAG44B,OAAS+xB,EAAO/xB,OAAO9lD,SAErCktB,EAAGy2B,YAA4B,SAAdz2B,EAAG/tB,OAChB,KACAyzD,EAAQxqC,UAAUyoD,EAAQ3jD,EAAG/tB,QAKrC,IAAI5V,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAQ1B,IAPA2jC,EAAKgjB,EAAO3mD,IACT+S,aAAa2Z,KAAK28C,EAAQpqB,QAC7Btb,EAAG7wB,cAAc4Z,KAAKr0B,EAAIkiC,aAC1BoJ,EAAGg0B,aAAe0vB,EAAgB1jD,EAAI5pB,GAInC4pB,EAAG5wB,aAAanV,SACd+lC,EAAGxuB,YAAiD,IAApCwuB,EAAGxuB,UAAUhX,QAAQ,WACrCwlC,EAAGhvB,YAAcgvB,EAAGu0B,QAAwB,SAAdv0B,EAAG/tB,QAClCzd,EAASyX,mBAAmB,cAAe,YAA3CzX,CAAwDwrC,IACzD,CACC,IAAIrR,EAAM,EACNn2B,EAAM,EACV,IAAI+T,EAAI,EAAGA,EAAIyzB,EAAG5wB,aAAanV,OAAQsS,IAAK,CACxC,IAAIixD,EAAMkI,EAAQxqC,UAAUyoD,EAAQ3jD,EAAG5wB,aAAa7C,IACpDoiB,EAAMj3B,KAAKi3B,IAAIA,EAAK6uC,EAAI5E,OAAO,IAC/BpgE,EAAMd,KAAKc,IAAIA,EAAKglE,EAAI5E,OAAO,IAEhCjqC,EAAMn2B,IACLwnC,EAAG84B,kBAAoBnqC,EACvBqR,EAAG+4B,kBAAoBvgE,KAkDvCod,EAAMg1E,gCAAkC,SAASr3F,GAC7C,IAAIsmB,EAAYnT,EAAMrK,EA0BtB,IAdAqK,EAAO,IAGPmT,EAAatmB,EAAMiR,QAAQqmF,eAIvBt3F,EAAMiR,QAAQqmF,YAAchxE,EAAa,GACzCimE,EAAWgL,MACPv3F,EAAMiR,QAAQsX,YAjBtB,SAA0BnmB,EAAMo1F,EAAUvvF,EAAOwvF,GAC7CtkF,EAAKskF,GAASD,EACdrkF,EAAKzM,OAAS+wF,EAAQ,EACF,UAAjBr1F,EAAKs9C,cAAqC70C,IAAdzI,EAAK4B,MAChCsiB,EAAWlgB,KAAK+M,EAAK/J,KAAK,UAkB9BN,EAAI,EAAGA,EAAIwd,EAAW5f,OAAQoC,IAAK,CACpB3H,EAAIkO,eAAerP,EAAO,UAAYsmB,EAAWxd,IAEnDwG,OACTnO,EAAIkO,eAAerP,EAAOsmB,EAAWxd,IAAI4X,IAAI,QAMzD2B,EAAMgyE,mBAAqB,SAASqD,EAAQzG,EAAS7rE,EAAQrc,GACzD,IAMID,EAAGkoF,EAAWhxF,EANdslD,EAAUv8C,EAAWw8C,SACrBoyC,EAAiB5uF,EAAW6pF,gBAC5B6D,EAAkB1tF,EAAW0iE,iBAC7BpxC,EAAM,EACNu9D,EAAW,EAMf,SAASC,EAAW7G,GAChBC,EAAQ7qF,KAAK4qF,GAEb,IAAI//E,EAAU+/E,EAAU//E,QACpBA,IAEJ9P,EAAI44B,WAAWurB,EAASr0C,IACC,IAAtB+/E,EAAUnoE,SAAkB1nB,EAAI44B,WAAW49D,EAAgB1mF,GAC9D9P,EAAI44B,WAAW08D,EAAiBzF,EAAU//E,QAAQ6mF,gBAClDz9D,KASgC,IAA7B22D,EAAU3yE,OAAOwK,SAAmB+uE,KApB3C7uF,EAAWgvF,kBAAoB,GAuB/B,IAAIC,EAAc,GACdC,EAAmB,GACnBC,GAAgB9yE,EAAO+yE,UAAY,IAAI/yF,MAAQ,GAC/CgzF,EAAYrgF,EAASsgF,eAAeH,GAExC,IAAIpvF,EAAI,EAAGA,EAAI4uF,EAAOhxF,OAAQoC,IAAK,CAa/B,GAZA9I,EAAQ03F,EAAO5uF,IAIfkoF,EAAYoH,EAAUtC,SAAS91F,IACrB+M,IAAMhE,EAAW0qF,WAAW3qF,GACtCuZ,EAAMi2E,oBAAoBt4F,EAAOgxF,EAAW4G,EAAU7uF,EAAYD,GAElEkoF,EAAU5nE,MAAQtgB,EAClBkoF,EAAU3yE,OAASre,EACnBgxF,EAAUx1E,eAAiB6e,EAExB22D,EAAUt5E,YAAcs5E,EAAUt5E,WAAWhR,OAK5C,IAJA,IAAI6xF,GAAgC,IAAlBv4F,EAAM6oB,UAA2C,IAAtBmoE,EAAUnoE,QAEnD2vE,EAAiBzH,EAAgBC,EAAWC,EAAS7rE,EAAQrc,GAEzDiQ,EAAI,EAAGA,EAAIw/E,EAAe9xF,OAAQsS,IAAK,CAC3C,IAAIy/E,EAAgBD,EAAex/E,GAG/B0/E,EAAoB,CACpB7yE,UAAWmrE,EAAUnrE,UACrBtd,KAAMyoF,EAAUzoF,KAGhBwE,IAAKikF,EAAUjkF,IAAMiM,GAStBu/E,IAAyC,IAA1BE,EAAc5vE,gBACrB4vE,EAAc5vE,QAGzBxG,EAAMi2E,oBAAoBG,EAAeC,EAAmBr+D,EAAKtxB,EAAYD,GAI7EwqB,EAAkBolE,EAAmBD,GAGrCC,EAAkBtvE,MAAQtgB,EAC1B4vF,EAAkBr6E,OAASre,EAC3B04F,EAAkBxkD,WAAa88C,EAG/B0H,EAAkBl9E,eAAiB6e,EACnCq+D,EAAkBC,eAAiBF,EAEnCZ,EAAWa,QAIf1H,EAAU98C,WAAa88C,EACvBA,EAAU2H,eAAiB3H,EAE3B6G,EAAW7G,GAGZ/vF,EAAS2C,QAAQotF,EAAW,gBAC3BgH,EAAYhH,EAAUtnC,QAAUsnC,GAGjC/vF,EAAS2C,QAAQotF,EAAW,oBAC3BiH,EAAiB7xF,KAAK0C,GAI9B,IAAIA,EAAI,EAAGA,EAAImvF,EAAiBvxF,OAAQoC,IAGpC,IAFAkoF,EAAYC,EAAQgH,EAAiBnvF,KAEvB+f,QAAd,CAEA,IAAI+vE,EAAaZ,EAAYhH,EAAUtnC,QACvCsnC,EAAU6H,QAAUD,EAEhBA,GAAeA,EAAW/vE,SAK9BmoE,EAAUvtF,MAAQm1F,EAAWn1F,MAC7ButF,EAAUttF,MAAQk1F,EAAWl1F,OALzBstF,EAAUnoE,SAAU,IAShCxG,EAAMy2E,wBAA0B,SAASzzE,GAErC,IAAIvc,EADJuc,EAAOA,GAAQ,GAEf,IAAI0zE,EAAU,GAEd,SAASn+E,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOyK,GAAQ,GAAI0zE,EAASvM,EAAgBpqF,EAAM4B,GAOjE,GAJA4W,EAAO,QACPA,EAAO,aACPA,EAAO,eAEJ/R,MAAM+D,QAAQyY,EAAK2zE,OAElB,IADAD,EAAQC,MAAQ,GACZlwF,EAAI,EAAGA,EAAIuc,EAAK2zE,MAAMtyF,OAAQoC,IAC9BiwF,EAAQC,MAAMlwF,GAAKuZ,EAAM42E,6BAA6B5zE,EAAK2zE,MAAMlwF,IAAM,SAG3EiwF,EAAQC,MAAQ32E,EAAM42E,6BAA6B5zE,EAAK2zE,OAAS,IAGrE,GAAGnwF,MAAM+D,QAAQyY,EAAK2H,YAElB,IADA+rE,EAAQ/rE,WAAa,GACjBlkB,EAAI,EAAGA,EAAIuc,EAAK2H,WAAWtmB,OAAQoC,IACnCiwF,EAAQ/rE,WAAWlkB,GAAKuZ,EAAM62E,kCAAkC7zE,EAAK2H,WAAWlkB,IAAM,SAG1FiwF,EAAQ/rE,WAAa3K,EAAM62E,kCAAkC7zE,EAAK2H,YAAc,IAGpF,OAAO+rE,GAGX12E,EAAM42E,6BAA+B,SAAS5zE,GAC1C,IAAI0zE,EAAU,GAEd,SAASn+E,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOyK,GAAQ,GAAI0zE,EAASvM,EAAewM,MAAO52F,EAAM4B,GAMvE,OAHA4W,EAAO,YACPA,EAAO,UAEAm+E,GAGX12E,EAAM62E,kCAAoC,SAAS7zE,GAC/C,IAAI0zE,EAAU,GAEd,SAASn+E,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOyK,GAAQ,GAAI0zE,EAASvM,EAAex/D,WAAY5qB,EAAM4B,GAM5E,OAHA4W,EAAO,YACPA,EAAO,UAEAm+E,GAGX12E,EAAM82E,oBAAsB,SAASC,GACjC,IAAIC,EAAW,GAEf,SAASz+E,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOw+E,EAASC,EAAU5M,EAAYrqF,EAAM4B,GAU3D,OAPA4W,EAAO,SACPA,EAAO,QACPA,EAAO,UACPA,EAAO,aACPA,EAAO,QACPA,EAAO,UAEAy+E,GAGXh3E,EAAMi2E,oBAAsB,SAASpzE,EAASC,EAAUm0E,EAAYl0E,EAAQm0E,GACxE,IAGIzwF,EAHA0wF,EAAWp0E,EAAOo0E,UAAY95F,EAAM6mB,SACpCiC,EAAegxE,EAASF,EAAaE,EAAS9yF,QAIlD,SAASkU,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOsK,EAASC,EAAU9C,EAAMkG,WAAYnmB,EAAM4B,GAGjE,IAAI6kB,EAAUjO,EAAO,WAErBA,EAAO,QACPA,EAAO,OAAQwK,EAAOysE,WAAa,IAAM0H,GAEzC3+E,EAAO,aAAcwK,EAAOxH,YAI5B,IAAI3M,EAAUoR,EAAM4jC,UAAU9gC,GAG9B,GADAA,EAASlU,QAAUA,EAChBA,EAAS,CACR,IAAI6mF,EAAiB7mF,EAAQ6mF,eACzB/E,EAAc+E,EAAe11F,KAC7Bq3F,EAAe3B,EAAevvE,WAClC,GAAGwqE,GAAe0G,EAAc,CAC5B,IAAIx/E,EAAWmL,EAAOlL,UAClB6tB,EAAY,GAEhB,GACIlf,GACwB,SAAxBivE,EAAex1E,KAIjB,CACE,GAAGzZ,MAAM+D,QAAQmmF,GACb,IAAIjqF,EAAI,EAAGA,EAAIiqF,EAAYrsF,OAAQoC,IAAK,CACpC,IAAI4wF,EAAQ3G,EAAYjqF,GACpB4qD,EAAOvyD,EAAIyZ,OAAOsK,EAASC,EAAUs0E,EAAcC,GAEpDz/E,EAASy/E,IAAQv4F,EAAI44B,WAAW9f,EAASy/E,GAAQhmC,GACpD3rB,GAAa2rB,OAGjB3rB,EAAY5mC,EAAIyZ,OAAOsK,EAASC,EAAUs0E,EAAc1G,GAGzD94E,EAAS69E,EAAex1E,OACvBnhB,EAAI44B,WAAW9f,EAAS69E,EAAex1E,MAAOylB,KAsD9D,OAhDGlf,IACCjO,EAAO,cACPA,EAAO,OACPA,EAAO,QAEJ3Z,EAAS2C,QAAQuhB,EAAU,eAC1BhkB,EAAIyZ,OAAOsK,EAASC,EAChBlU,EAAQsX,WAAW2sB,WAAajkC,EAAQsX,WAAalG,EAAMkG,WAC3D,cAGJ3N,EAAO,eAEPuK,EAASw0E,iBAAkB,GAE3Bx0E,EAASw0E,iBAAkB,EAG5B1oF,GACCA,EAAQqgF,eAAepsE,EAASC,EAAUqD,EAAcpD,GAGxDnkB,EAAS2C,QAAQuhB,EAAU,cAC3BvK,EAAO,WAGR3Z,EAAS2C,QAAQuhB,EAAU,yBAG1BA,EAAS0D,UAAY1D,EAAS0D,SAG9B5nB,EAAS2C,QAAQuhB,EAAU,aACvBA,EAASy0E,eAAez4F,EAAI8yB,gBAAgB/O,EAASC,EAAUC,GAG9C,YAAlBD,EAAS5c,MACRtH,EAASyX,mBAAmB,KAAM,iBAAlCzX,CAAoDikB,EAASC,EAAUqD,EAAcpD,IAI1FnU,GAAWA,EAAQ4oF,cAClBj/E,EAAO,kBAGXyH,EAAMy3E,wBAAwB50E,EAASC,EAAUC,IAG9CD,GAqBX9C,EAAMuuE,sBAAwBA,EAE9BvuE,EAAMy3E,wBAA0B,SAAS50E,EAASC,EAAUC,GAKxD,GAAKD,EAASsgB,SAAWmrD,EAAsB1rE,GAA/C,CAEA,IAAIkvE,EAAmBhvE,EAAO+uE,mBAAqB,GAC/C4F,EAAmB30E,EAAO2yE,mBAAqB,GAEnD,GAAIlvF,MAAM+D,QAAQsY,EAAQxN,aAA2C,IAA5B08E,EAAiB1tF,OAM1D,IAJA,IAAI+e,EAAcP,EAAQxN,YAAc,GACpCsiF,EAAgB5F,EAAiB35E,OAAOgL,GACxCC,EAAeP,EAASzN,WAAa,GAEjC5O,EAAI,EAAGA,EAAIkxF,EAActzF,OAAQoC,IAAK,CAC1C,IAGImxF,EAHAC,EAAcF,EAAclxF,GAC5BP,EAAO2xF,EAAY3xF,KACnB0I,EAAU27E,EAAmBrkF,GAY7B4xF,IAAiBD,EAAYjpF,SAAWipF,EAAYjpF,UAAYA,GAChEmpF,EAAgBnpF,GAAwC,mBAAtBA,EAAQuE,UAE1CvE,GAAS9P,EAAIwe,KAAK,+BAAiCpX,EAAO,KAE3D0I,GAAWA,EAAQqgF,iBAAmB6I,GAAgBC,KACrDH,EAAehpF,EAAQqgF,eAAe4I,EAAa/0E,EAAUC,EAAQF,IACxD3c,KAAOA,EACpB0xF,EAAahpF,QAAUA,EAEvB9P,EAAI44B,WAAWggE,EAAkB9oF,IAEjCgpF,EAAe94F,EAAIiM,WAAW,GAAI8sF,GAGtCx0E,EAAatf,KAAK6zF,MA2B1B53E,EAAM8vE,2BAA6B,SAASt5E,EAAUC,EAAW22E,GAC7D,SAAS70E,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO/B,EAAUC,EAAWuJ,EAAMpK,iBAAkB7V,EAAM4B,GAGzE,IAAIm0F,EAAWt/E,EAASs/E,SACrBh3F,EAAIY,cAAco2F,KACjBr/E,EAAUq/E,SAAWA,EACrBr/E,EAAU+M,UAAYsyE,EAAS/yE,OAC/BtM,EAAUuhF,cAAgBlC,EAAS/yF,MAGvC,IAAIk1F,EAAan5F,EAAImkB,WAAW1K,EAAQ,QAExCA,EAAO,aAAc9B,EAAUglD,WAAWv7C,MAE1CphB,EAAImkB,WAAW1K,EAAQ,aAAc,CACjC/Y,OAAQy4F,EAAWz4F,OACnBC,KAAMqC,KAAKC,MAAwB,IAAlBk2F,EAAWx4F,MAC5BjB,MAAOy5F,EAAWz5F,QAGtB+Z,EAAO,cACPA,EAAO,cACPA,EAAO,WACPA,EAAO,WACPA,EAAO,iBACPA,EAAO,iBACPA,EAAO,eACPA,EAAO,eACPA,EAAO,eACPA,EAAO,eAEeA,EAAO,qBAEzBA,EAAO,uBAYXA,EAAO,aAAc/B,EAASlU,OAASkU,EAAStE,SAEhDqG,EAAO,SACPA,EAAO,UACPA,EAAO,YACPA,EAAO,YACPA,EAAO,YACPA,EAAO,YACPA,EAAO,cACPA,EAAO,qBAEJ/B,EAASlU,OAASkU,EAAStE,QAAQ8N,EAAM+vE,gBAAgBt5E,GAE5D7X,EAASyX,mBAAmB,OAAQ,eAApCzX,CAAoD4X,EAAUC,GAE9D8B,EAAO,iBAEPA,EAAO,aAAc60E,EAAU+C,QAAU/C,EAAUgD,WACnD73E,EAAO,eAEPA,EAAO,YAEPA,EAAO,gBACP,IAAIgD,EAAahD,EAAO,cACxBA,EAAO,eAAgBgD,GACvBhD,EAAO,oBAAqBgD,GAE5BhD,EAAO,uBACPA,EAAO,kBAAmBlb,EAAMoP,WAAWgK,EAAUsC,cAAe,KACpE,IAAIm/E,EAAsB76F,EAAMioB,SAASjoB,EAAMsnB,IAAIlO,EAAU0hF,QAAQhrE,UACrE5U,EAAO,gBAAiBlb,EAAMoP,WAAWyrF,EAAqB,KAC9D3/E,EAAO,sBAAuBlb,EAAMoP,WAAWyrF,EAAqB,KACpE3/E,EAAO,qBAAsBgD,GAE7BhD,EAAO,QAGJzZ,EAAIY,cAAc8W,EAASmU,cAC1BpS,EAAO,uBACPA,EAAO,qBACPA,EAAO,wBAGX3Z,EAASyX,mBACL,YACA,iBAFJzX,CAGE4X,EAAUC,EAAW,YAEvB7X,EAASyX,mBACL,KACA,6BAFJzX,CAGE4X,EAAUC,EAAW8B,IAG3ByH,EAAMkwE,aAAe,SAAsBzuF,EAAIshB,EAAQrc,GACnD,IAEI0xF,EACAC,EAHA3lF,EAAUjR,EAAGG,UAAY,GACzB02F,EAAe5lF,EAAQ4lF,aAIvBthE,EAAYl4B,EAAIk4B,UAAUv1B,GAM9B,GAJGu1B,GAAWv1B,EAAGoqB,KAAK,mBAInBnZ,EAAQ6lF,UACPH,EAAW/2E,OAAOm3E,WAClBH,EAAYh3E,OAAOo3E,YAInBj2E,SAASoiB,KAAKxmC,MAAMqkF,SAAW,aAC5B,CAKH,IAAIiW,EAAgB1hE,EAAY3V,OAAO+gB,iBAAiB3gC,GAAM,GAK9D,GAHA22F,EAAW9iF,WAAWojF,EAAcp2F,QAAUgT,WAAWojF,EAAcC,WAAajyF,EAAWpE,MAC/F+1F,EAAY/iF,WAAWojF,EAAcxmF,SAAWoD,WAAWojF,EAAcE,YAAclyF,EAAWwL,OAE/FxT,EAAU45F,IAAiBA,EAAe,EAAG,CAC5C,IAAIlpB,EAAS,EAAI,EAAIkpB,EACrBF,EAAWt2F,KAAKC,MAAMqtE,EAASgpB,GAC/BC,EAAYv2F,KAAKC,MAAMqtE,EAASipB,IAIxC,IAAIlqE,EAAWnO,EAAMpK,iBAAiBtT,MAAMy2B,IACxCxK,EAAYvO,EAAMpK,iBAAiB1D,OAAO6mB,IAC3Cq/D,EAAWjqE,IAAUiqE,EAAWjqE,GAChCkqE,EAAY9pE,IAAW8pE,EAAY9pE,GAEtC,IAAIsqE,GAAmB91E,EAAOzgB,OACzBR,KAAK6/B,IAAIj7B,EAAWpE,MAAQ81F,GAAY,EACzCU,GAAoB/1E,EAAO7Q,QAC1BpQ,KAAK6/B,IAAIj7B,EAAWwL,OAASmmF,GAAa,GAE5CS,GAAoBD,KAChBA,IAAiBnyF,EAAWpE,MAAQ81F,GACpCU,IAAkBpyF,EAAWwL,OAASmmF,IAKzC52F,EAAGs3F,mBACHt3F,EAAGs3F,iBAAmB,CAAEz2F,MAAO81F,EAAUlmF,OAAQmmF,IAGrDr4E,EAAM+vE,gBAAgBrpF,IAG1BsZ,EAAMoyE,2BAA6B,SAAS57E,EAAUC,EAAWC,EAAUsiF,GACvE,IAEIC,EAAWxyF,EAAGmI,EAFdsqF,EAAqBt6F,EAASs6F,mBAC9B9E,EAAkB39E,EAAU2yD,iBAG5B+vB,EAAYv6F,EAASsqE,iBAAiBriB,UAI1C,IAAIoyC,KAAaC,GACbtqF,EAAUsqF,EAAmBD,IAElBjwB,iBACPp6D,EAAQo6D,gBAAgBxyD,EAAUC,GAgB1C,IAAI,IAAIg6E,KAXJ2D,EAAgB/vF,QAChB+vF,EAAgBrwF,KAAKo1F,GAItB1iF,EAAUoK,KAAK,eACdjiB,EAASyX,mBAAmB,OAAQ,kBAApCzX,CAAuD4X,EAAUC,GACjE0iF,EAAU5yC,iBAAiB/vC,EAAUC,IAIlBA,EAAUoB,UAC7BpB,EAAUoB,UAAU44E,GAAat9D,KAAKr0B,EAAIkiC,aAI9C,IAAIv6B,EAAI,EAAGA,EAAI2tF,EAAgB/vF,OAAQoC,KACnCmI,EAAUwlF,EAAgB3tF,IAGf4/C,sBACPz3C,EAAQy3C,qBAAqB7vC,EAAUC,EAAWC,GAQ1D,IAAIusC,EAAUxsC,EAAUysC,SACxB,IAAIz8C,EAAI,EAAGA,EAAIw8C,EAAQ5+C,OAAQoC,KAC3BmI,EAAUq0C,EAAQx8C,IAEP4/C,sBACPz3C,EAAQy3C,qBAAqB7vC,EAAUC,EAAWC,GAK1D,IAAIghF,EAAmBjhF,EAAUi/E,kBACjC,IAAIjvF,EAAI,EAAGA,EAAIixF,EAAiBrzF,OAAQoC,KACpCmI,EAAU8oF,EAAiBjxF,IAEhB4/C,sBACPz3C,EAAQy3C,qBAAqB7vC,EAAUC,EAAWC,EAAUsiF,GAIpE,IAAIC,KAAaC,GACbtqF,EAAUsqF,EAAmBD,IAElB5yC,sBACPz3C,EAAQy3C,qBAAqB7vC,EAAUC,EAAWC,IAO9DsJ,EAAMutD,MAAQ,SAAS9rE,GAInB,IAAIiF,EAAajF,EAAGkF,aAAe,QACJ6B,IAA5B9B,EAAW2tF,eACV3tF,EAAW2tF,aAAal2F,UAAU,cAAc+I,SAChDR,EAAW2tF,aAAantF,SACxBR,EAAW4tF,UAAY,MAIxB5tF,EAAW0yF,UAAU1yF,EAAW0yF,SAASxxC,UAEzCnmD,EAAG2uC,kBAGC3uC,EAAG2uC,gBAAgB8jD,sBAClBzyF,EAAG2uC,gBAAgB8jD,oBAAoB7vF,OAAS,GAGjD5C,EAAG2uC,gBAAgBipD,eAClBh4E,OAAOi4E,qBAAqB73F,EAAG2uC,gBAAgBipD,gBAKvDv6F,EAAI23B,gBAGJ33B,EAAIu4B,gBAAgB51B,UAGbA,EAAGsB,YACHtB,EAAGshB,cACHthB,EAAG8uC,iBACH9uC,EAAGkF,mBACHlF,EAAGoyC,gBACHpyC,EAAGgwE,iBACHhwE,EAAGynC,aAEHznC,EAAG83F,WAEH93F,EAAG+3F,iBACH/3F,EAAGg4F,eACHh4F,EAAGypF,gBACHzpF,EAAGwpF,eAIHxpF,EAAGmlE,iBACHnlE,EAAGqpF,oBACHrpF,EAAGo7E,mBACHp7E,EAAGm7E,mBACHn7E,EAAG2uC,uBACH3uC,EAAGi4F,sBACHj4F,EAAGs3F,wBACHt3F,EAAGg5E,kCAIHh5E,EAAGqlC,iBACHrlC,EAAGkxC,gBACHlxC,EAAG27E,iBACH37E,EAAGk4F,kBACHl4F,EAAGm4F,2BACHn4F,EAAGmxC,gBACHnxC,EAAGo4F,sBACHp4F,EAAGqvC,qBAGPrvC,EAAGgrE,oBAAoBhrE,EAAGgrE,sBAGjCzsD,EAAM5hB,MAAQ,SAASqD,GACnB,IAEIgF,EAFAy8C,EAAWzhD,EAAGkF,YAAY4pF,gBAC1BuJ,EAAe,GAMnB,IAAIrzF,EAAI,EAAGA,EAAIy8C,EAAS7+C,OAAQoC,IAAK,CACjC,IAAImI,EAAUs0C,EAASz8C,GACpBmI,EAAQxQ,OACPU,EAAI44B,WAAWoiE,EAAclrF,EAAQxQ,OAI7C,IAAIqI,EAAI,EAAGA,EAAIqzF,EAAaz1F,OAAQoC,IAChCqzF,EAAarzF,GAAGhF,IAIxBue,EAAM+vE,gBAAkB,SAASrpF,GAE7B,GAAIA,GAAeA,EAAWswC,OAA9B,CAEA,IAKI+iD,EALAz3F,EAAQoE,EAAWpE,MACnB4P,EAASxL,EAAWwL,OACpB8kC,EAAStwC,EAAWswC,OACpBgjD,EAAY13F,GAAS00C,EAAO9tB,EAAI8tB,EAAOxyC,GACvCy1F,EAAa/nF,GAAU8kC,EAAO/hC,EAAI+hC,EAAOj1B,GAO1Ci4E,EAAY,IACXD,GAAcz3F,EAAQ,IAAM00C,EAAO9tB,EAAI8tB,EAAOxyC,GAC9CwyC,EAAO9tB,EAAIpnB,KAAKgD,MAAMi1F,EAAa/iD,EAAO9tB,GAC1C8tB,EAAOxyC,EAAI1C,KAAKgD,MAAMi1F,EAAa/iD,EAAOxyC,IAG3Cy1F,EAAa,IACZF,GAAc7nF,EAAS,IAAM8kC,EAAO/hC,EAAI+hC,EAAOj1B,GAC/Ci1B,EAAO/hC,EAAInT,KAAKgD,MAAMi1F,EAAa/iD,EAAO/hC,GAC1C+hC,EAAOj1B,EAAIjgB,KAAKgD,MAAMi1F,EAAa/iD,EAAOj1B,MAIlD/B,EAAMk6E,mBAAqB,SAASz4F,GAChCA,EAAGkF,YAAYqoF,eAAiB,IAGpChvE,EAAMqoD,gBAAkB,SAAS5mE,EAAIk9B,GACjCl9B,EAAGkF,YAAYqoF,eAAerwD,GAAM,GAoCxC3e,EAAMoP,WAAa,SAAS3tB,EAAIk9B,EAAIw7D,GAChC,IAAIzzF,EAAajF,EAAGkF,YAEhByzF,EAAa1zF,EAAWqoF,YACxBsL,EAAgB3zF,EAAWsoF,eAE/B,IAAoC,IAAjCtoF,EAAWswC,OAAOC,WAAsB,CACvC,GAAIkjD,EAGG,CACH,IAAInxE,EAAMmxE,EAAEnxE,IACZ,QAAWxgB,IAARwgB,EAAmB,CAClB,IAAIguB,EAAStwC,EAAWswC,OAGxBhuB,EAAMlnB,KAAKi3B,IAAI,GAAIie,EAAO9tB,EAAG8tB,EAAOxyC,EAAGwyC,EAAO/hC,EAAG+hC,EAAOj1B,GAKzDo4E,EAAEjxE,EAAIixE,EAAE31F,EAAuB,GAAnBkC,EAAWpE,QACtBxD,EAAIk3B,IAAI,cAAe2I,EAAI,6BAC3Bw7D,EAAEjxE,EAAIixE,EAAE31F,EAAI,GAEb21F,EAAEp4E,EAAIo4E,EAAEllF,EAAwB,GAApBvO,EAAWwL,SACtBpT,EAAIk3B,IAAI,cAAe2I,EAAI,6BAC3Bw7D,EAAEp4E,EAAIo4E,EAAEllF,EAAI,GAGhB,IAAI0tD,OAAcn6D,IAAT2xF,EAAEx3B,GAAmBw3B,EAAEx3B,GAAKw3B,EAAEt6F,EACnC4iE,OAAcj6D,IAAT2xF,EAAE13B,GAAmB03B,EAAE13B,GAAK03B,EAAEt6F,EACnCkjE,OAAcv6D,IAAT2xF,EAAEp3B,GAAmBo3B,EAAEp3B,GAAKo3B,EAAEr6F,EACnC+iE,OAAcr6D,IAAT2xF,EAAEt3B,GAAmBs3B,EAAEt3B,GAAKs3B,EAAEr6F,EAEvCs6F,EAAWz7D,GAAM,CACbzV,EAAG,CAACtK,IAAK+jD,EAAIljE,KAAM06F,EAAEjxE,EAAIF,GACzBxkB,EAAG,CAACoa,IAAK6jD,EAAIhjE,KAAM06F,EAAE31F,EAAIwkB,GACzBjH,EAAG,CAACnD,IAAKikD,EAAIpjE,KAAM06F,EAAEp4E,EAAIiH,GACzB/T,EAAG,CAAC2J,IAAKmkD,EAAItjE,KAAM06F,EAAEllF,EAAI+T,IAE7BqxE,EAAc17D,GAAM,cAjCby7D,EAAWz7D,UACX07D,EAAc17D,GAmCzB,IAAIj4B,EAAW+2E,YACX,OAAOz9D,EAAMs6E,aAAa74F,KAKtCue,EAAMs6E,aAAe,SAAS74F,GAC1B,IAAIiF,EAAajF,EAAGkF,YAChBD,EAAWmoB,QAAOnoB,EAAWmoB,MAAQ,IACzCigE,EAAYpoF,GAEZ,IAAIk/B,EAAKl/B,EAAWmoB,MAChBmoB,EAAStwC,EAAWswC,OACpBujD,EAAaz7F,EAAIiM,WAAW,GAAI66B,GAKhC40D,EAAKxjD,EAAO9tB,EACZuxE,EAAKzjD,EAAOxyC,EACZk2F,EAAK1jD,EAAO/hC,EACZ0lF,EAAK3jD,EAAOj1B,EACZzf,EAAQoE,EAAWpE,MACnB4P,EAASxL,EAAWwL,OACpBkoF,EAAa1zF,EAAWqoF,YACxBsL,EAAgB3zF,EAAWsoF,eAE/B,IAAoC,IAAjCtoF,EAAWswC,OAAOC,WAAsB,CACvC,IAAI,IAAIrzC,KAAKw2F,EACLC,EAAcz2F,WAAWw2F,EAAWx2F,GAc5C,IAAI,IAAIg3F,KAVRR,EAAW31F,KAAO,CACdykB,EAAG,CAACtK,IAAK,EAAGnf,KAAM+6F,GAClBh2F,EAAG,CAACoa,IAAK,EAAGnf,KAAMg7F,GAClBxlF,EAAG,CAAC2J,IAAK,EAAGnf,KAAMi7F,GAClB34E,EAAG,CAACnD,IAAK,EAAGnf,KAAMk7F,IAMRP,EAAY,CACtB,IAAIS,EAAWT,EAAWQ,GAAI1xE,GAAK,GAC/B4xE,EAAaV,EAAWQ,GAAI74E,GAAK,GACjCg5E,EAAKF,EAASj8E,IACdo8E,EAAKH,EAASp7F,KACdw7F,EAAKH,EAAWl8E,IAChBs8E,EAAKJ,EAAWr7F,KAEpB,IAAI,IAAI07F,KAAMf,EAAY,CACtB,GAAG17F,EAAUs8F,IAAOZ,EAAWe,GAAI32F,EAAG,CAClC,IAAI42F,EAAKhB,EAAWe,GAAI32F,EAAEoa,IACtBy8E,EAAKjB,EAAWe,GAAI32F,EAAE/E,KAE1B,GAAG27F,EAAKL,EAAI,CACR,IAAIO,GAAQN,EAAKI,GAAMC,EAAK/4F,GAASy4F,IAAOK,EAAKL,GAC7CQ,GAAQF,GAAM,EAAIN,IAAOC,EAAK14F,IAAU,EAAI84F,KAAQA,EAAKL,GAC1DO,GAAQ,GAAKC,GAAQ,GAAKj5F,GAASg5F,EAAOC,GAAQ,GAAKD,EAAOC,EAAOf,EAAKC,IACzED,EAAKc,EACLb,EAAKc,IAKjB,GAAG78F,EAAUw8F,IAAOd,EAAWe,GAAIlmF,EAAG,CAClC,IAAIumF,EAAKpB,EAAWe,GAAIlmF,EAAE2J,IACtBhS,EAAKwtF,EAAWe,GAAIlmF,EAAExV,KAE1B,GAAG+7F,EAAKP,EAAI,CACR,IAAIQ,GAAQP,EAAKM,GAAM5uF,EAAKsF,GAAU+oF,IAAOO,EAAKP,GAC9CS,GAAQ9uF,GAAM,EAAIquF,IAAOC,EAAKhpF,IAAW,EAAIspF,KAAQA,EAAKP,GAC3DQ,GAAQ,GAAKC,GAAQ,GAAKxpF,GAAUwpF,EAAOD,GAAQ,GAAKA,EAAOC,EAAOf,EAAKD,IAC1EC,EAAKc,EACLf,EAAKgB,OAiB7B,GATA91D,EAAG1c,EAAIpnB,KAAKC,MAAMy4F,GAClB50D,EAAGphC,EAAI1C,KAAKC,MAAM04F,GAClB70D,EAAG3wB,EAAInT,KAAKC,MAAM24F,GAClB90D,EAAG7jB,EAAIjgB,KAAKC,MAAM44F,GAClB/0D,EAAGp3B,EAAI1M,KAAKC,MAAMi1C,EAAOhuB,KACzB4c,EAAG3lC,EAAI6B,KAAKC,MAAMO,GAASsjC,EAAG1c,EAAI0c,EAAGphC,EACrCohC,EAAG1lC,EAAI4B,KAAKC,MAAMmQ,GAAU0zB,EAAG3wB,EAAI2wB,EAAG7jB,GAGlCrb,EAAW+2E,aAAez9D,EAAM27E,gBAAgBpB,EAAY30D,GAAK,CAC9D,+BAAgCl/B,EAC/BA,EAAWqgE,6BAEXrgE,EAAWqgE,2BAA6B,EAQ5C,IAAI60B,EAAqB,GAAK,EAAIn4F,OAAOC,KAAK22F,GAAeh2F,QAE7D,GAAGqC,EAAWqgE,2BAA6B60B,EACvC,OAAOh9F,EAASN,KAAK,OAAQmD,GAE7B3C,EAAIwe,KAAK,mCAKrB,IAAIu+E,EAAa,CAAC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,KAgqBhD,SAASC,EAAYr6F,EAAI0e,EAAgB6C,GACrC,IAAI+4E,GAAU,EA2Gd,IAAIpvF,EAAM,CACNqT,EAAMovB,iBAdV,WAEI,GAAI3tC,EAAG2uC,gBAQP,OAFA3uC,EAAGi4F,gBAAiB,EApGxB,SAA0B3/E,GACtB,IAAIvL,EAAI+1B,QAAQC,UAChB,IAAIzqB,EAAM,OAAOvL,EACjB,KAAMuL,EAAK1V,QACPmK,EAAIA,EAAE2sB,KAAMphB,EAAKsqD,SAErB,OAAO71D,EAgGAwtF,CAAiBv6F,EAAG2uC,gBAAgB8jD,sBAM3ClxE,EAAKi5E,UACLj8E,EAAMk8E,QA7FV,WAGI,OAFAz6F,EAAGoqB,KAAK,uBAAwB,IAEzB,IAAI0Y,SAAQ,SAASC,GAExB/iC,EAAGi4F,gBAAiB,EAKjBv5E,EAAewY,SAAW,IACzBl3B,EAAGg5E,4BAA6B,GAMpCh5E,EAAG2uC,gBAAgB8jD,oBAAoBnwF,MAAK,WACxCg4F,GAAU,KAGX/4E,EAAKorB,QACJ3sC,EAAG2uC,gBAAgB8jD,oBAAoBnwF,MAAK,WACxC,OAAOnF,EAASN,KAAK,SAAUmD,MAKvCA,EAAG2uC,gBAAgB8jD,oBAAoBnwF,MAAK,WACxCtC,EAAGoqB,KAAK,+BAAgC,OAK5C,IAAIswE,EAAe,EACfC,EAAe,EACnB,SAASC,IAEL,OADAF,IACO,WACHC,IAEIL,GAAWK,IAAiBD,GAahD,SAA4BG,GAIxB,IAAI76F,EAAG2uC,gBAAiB,QAjE5B,SAAwBr2B,GACpB,GAAIA,EACJ,KAAMA,EAAK1V,QACP0V,EAAKsqD,SAgETk4B,CAAe96F,EAAG2uC,gBAAgB8jD,qBAE3B3vD,QAAQC,UAAUrJ,MAAK,WAC1B,GAAGnY,EAAKorB,OACJ,OAAOxvC,EAASN,KAAK,SAAUmD,MAEpC05B,MAAK,WAGJ15B,EAAGi4F,gBAAiB,EACpBj4F,EAAGg5E,4BAA6B,EAEhCh5E,EAAGoqB,KAAK,sBAAuB,OAChCsP,KAAKmhE,GA/BQE,CAAmBh4D,IAK/BxhB,EAAKy5E,MAAMJ,GAGX1rD,WAAW0rD,UA+CfK,EAAqB59F,EAAI87B,YAAYjuB,EAAKlL,GAM9C,OAJIi7F,GAAuBA,EAAmBvhE,OAC1CuhE,EAAqBn4D,QAAQC,WAG1Bk4D,EAAmBvhE,MAAK,WAAa,OAAO15B,KAxxBvDue,EAAM27E,gBAAkB,SAASgB,EAASC,GACtC,IAAI,IAAIn2F,EAAI,EAAGA,EAAIo1F,EAAWx3F,OAAQoC,IAAK,CACvC,IAAI7C,EAAIi4F,EAAWp1F,GACfo2F,EAAKF,EAAQ/4F,GACbk5F,EAAKF,EAAQh5F,GAGjB,IAAIlF,EAAUm+F,IAAO/6F,KAAK6/B,IAAIm7D,EAAKD,GAAM,EACrC,OAAO,EAGf,OAAO,GA0BX78E,EAAM4sE,UAAY,SAASnrF,EAAIs7F,EAAUtzB,EAAMuzB,EAAQC,EAAaC,IAE5DD,GAAeF,IAAat7F,EAAG8uC,WAC1B0sD,IAAgBF,IAAat7F,EAAGkF,cACrCqZ,EAAMivE,eAAextF,GAGzB,IAAIsB,EAAO,EAAgBtB,EAAG8uC,UAAY9uC,EAAGsB,KACzCggB,EAAS,EAAgBthB,EAAGkF,YAAclF,EAAGshB,OAC7CotB,GAAU1uC,EAAG2uC,iBAAmB,IAAIC,QAExC,SAAS8sD,EAASz/F,EAAG0/F,GACjB,GAAgB,mBAAN1/F,EACN,OAAO0/F,EAAe,aAAe,KAEzC,GAAGt+F,EAAIY,cAAchC,GAAI,CACrB,IACI2/F,EADAlD,EAAI,GAyCR,OAvCA12F,OAAOC,KAAKhG,GAAGy1B,OAAOxvB,SAAQ,SAASe,GAGnC,IAAwC,IAArC,CAAC,IAAK,KAAKE,QAAQF,EAAEkW,OAAO,IAG/B,GAAmB,mBAATld,EAAEgH,GAAZ,CAMA,GAAY,aAAT+kE,GAEC,GAA8B,QAA3B/kE,EAAEsZ,OAAOtZ,EAAEL,OAAS,GACnB,YAED,GAAY,eAATolE,GAKN,GAAkB,iBADlB4zB,EAAM3/F,EAAEgH,EAAI,SACkB24F,EAAIz4F,QAAQ,KAAO,IACzC9F,EAAIY,cAAchC,EAAE4/F,QACpB,YAGL,GAAY,YAAT7zB,GAIY,iBADlB4zB,EAAM3/F,EAAEgH,EAAI,SACkB24F,EAAIz4F,QAAQ,KAAO,EAC7C,OAKRu1F,EAAEz1F,GAAKy4F,EAASz/F,EAAEgH,GAAI04F,QA9BfA,IAAcjD,EAAEz1F,GAAK,gBAgCzBy1F,EAGX,OAAG3zF,MAAM+D,QAAQ7M,GACNA,EAAEwb,KAAI,SAASrZ,GAAI,OAAOs9F,EAASt9F,EAAGu9F,MAG9Ct+F,EAAIqyB,aAAazzB,GACToB,EAAImZ,UAAUva,EAAGoB,EAAIkI,UAK7BlI,EAAIuzB,SAAS30B,GAAWoB,EAAIqzB,kBAAkBz0B,GAE1CA,EAGX,IAAI6gB,EAAM,CACNxb,MAAOA,GAAQ,IAAImW,KAAI,SAASxU,GAC5B,IAAIhH,EAAIy/F,EAASz4F,GAIjB,OADGq4F,UAAmBr/F,EAAE6/F,IACjB7/F,MAWf,OARIq/F,IAAYx+E,EAAIwE,OAASo6E,EAASp6E,IAEnCthB,EAAGgwE,WAAahwE,EAAGgwE,UAAUY,UAAS9zD,EAAM9c,EAAGgwE,UAAUa,aAEzDniC,IAAQ5xB,EAAI4xB,OAASgtD,EAAShtD,IAE9B+sD,IAAe3+E,EAAI+xB,OAAS6sD,EAAS17F,EAAGG,UAAU,IAElC,WAAXo7F,EAAuBz+E,EAAMi/E,KAAKC,UAAUl/E,IASxDyB,EAAM09E,aAAe,SAASj8F,EAAIk8F,GAC9B,IAAIl3F,EAAGoe,EAAI8xE,EACPtmD,EAAU5uC,EAAG2uC,gBAAgBC,QAC7B2jD,EAAavyF,EAAG2uC,gBAAgB4jD,WAEpC,IAAIvtF,EAAI,EAAGA,EAAIk3F,EAAWt5F,OAAQoC,IAG9B,QAFAoe,EAAK84E,EAAWl3F,IAENP,MAQN,IAAK,UACDywF,EAAQ9xE,EAAGga,MACX,IAAI++D,GAAWvtD,EAAQxrB,EAAGkC,QAAU,IAAI9G,KACpC0xB,EAAUglD,EAAM12E,KACpBowB,EAAQxrB,EAAGkC,OAASitE,EAAWriD,GAAWglD,EAEvChlD,IAAYisD,WAGJ5J,EAAW4J,GAClB5J,EAAWriD,GAAWglD,GAG1B,MACJ,IAAK,SAED3C,GADA2C,EAAQ9xE,EAAGga,OACM5e,MAAQ02E,EACzBtmD,EAAQ9yB,OAAOsH,EAAGkC,MAAO,EAAG4vE,GAC5B,MACJ,IAAK,gBAEM3C,GADP2C,EAAQtmD,EAAQxrB,EAAGkC,QACK9G,MACxBowB,EAAQ9yB,OAAOsH,EAAGkC,MAAO,GAKrC,OAAOwd,QAAQC,WAcnBxkB,EAAM69E,aAAe,SAASp8F,EAAIq8F,GAC9B,IACIr3F,EAAGs3F,EAAc9sD,EAAY+sD,EAD7BC,EAAcx8F,EAAG2uC,gBAAgB4jD,WASrC,IAAI8J,EACA,MAAM,IAAIr+D,MAAM,kDAGpB,IAAIy+D,EAAWD,EAAYH,EAAUl4E,YAGrC,IAAIs4E,EACA,OAAO,EAOX,IAJA,IAAIC,EAAa,CAACD,GACdE,EAAiB,CAACF,EAASj+E,MAGzBi+E,EAASG,YAAcH,EAAWD,EAAYC,EAASG,UAAUz4E,eAErB,IAA3Cw4E,EAAex5F,QAAQs5F,EAASj+E,OAEnCk+E,EAAWp6F,KAAKm6F,GAChBE,EAAer6F,KAAKm6F,EAASj+E,MAOjC,IAHA,IAAI4lE,EAAS,GAGNqY,EAAWC,EAAWh/E,OAKzB,GAJG++E,EAASn7E,SACR8iE,EAAO9iE,OAAS/C,EAAMs+E,aAAazY,EAAO9iE,OAAQm7E,EAASn7E,SAG5Dm7E,EAASn7F,KAAM,CAMd,GALI8iF,EAAO9iF,OACP8iF,EAAO9iF,KAAO,MAElBg7F,EAAeG,EAAS1gG,QAKpB,IADAugG,EAAe,GACXt3F,EAAI,EAAGA,EAAIy3F,EAASn7F,KAAKsB,OAAQoC,IACjCs3F,EAAat3F,GAAKA,EAQ1B,IAJIo/E,EAAOroF,SACPqoF,EAAOroF,OAAS,IAGhBiJ,EAAI,EAAGA,EAAIy3F,EAASn7F,KAAKsB,OAAQoC,IAI9BwqC,OADHA,EAAa8sD,EAAat3F,OAMR,KADlBu3F,EAAYnY,EAAOroF,OAAOoH,QAAQqsC,MAE9B+sD,EAAYnY,EAAO9iF,KAAKsB,OACxBwhF,EAAOroF,OAAOwgG,GAAa/sD,GAG/B40C,EAAO9iF,KAAKi7F,GAAah+E,EAAMu+E,YAAY1Y,EAAO9iF,KAAKi7F,GAAYE,EAASn7F,KAAK0D,KAK7F,OAAOo/E,GASX7lE,EAAMw+E,mBAAqB,SAAS/8F,GAGhC,IAFA,IAAIsR,EAAOtR,EAAG2uC,gBAAgB4jD,WAAa,GACvC7jD,EAAS1uC,EAAG2uC,gBAAgBC,QACxB5pC,EAAI,EAAGA,EAAI0pC,EAAO9rC,OAAQoC,IAAK,CACnC,IAAIkwF,EAAQxmD,EAAO1pC,GAChBkwF,GAASA,EAAM12E,OACdlN,EAAK4jF,EAAM12E,MAAQ02E,KAe/B32E,EAAMy+E,2BAA6B,SAASr/D,EAAMi+D,EAAKqB,GACnD,IAAIC,EAAeC,EAAcn4F,EAAGkQ,EAAYkoF,EAAUC,EAAcC,EACpEC,EAAOlgG,EAAIg3B,mBAAmB,GAAIunE,GAAO,IACzC4B,EAAcngG,EAAImgC,kBAAkB+/D,GACpCE,EAAe,GAKnB,GAAGR,GAAkBA,EAAer6F,OAChC,IAAIoC,EAAI,EAAGA,EAAIi4F,EAAer6F,OAAQoC,SAId+B,KAFpBo2F,GADAD,EAAgB7/F,EAAIkO,eAAeiyF,EAAaP,EAAej4F,KAClCwG,OAGzBnO,EAAIkO,eAAekyF,EAAcR,EAAej4F,IAAI4X,IAAI,OAExDsgF,EAActgF,IAAI,MAClBvf,EAAIkO,eAAekyF,EAAcR,EAAej4F,IAAI4X,IAAIugF,IAOpE,GAFAx/D,EAAOtgC,EAAIg3B,mBAAmBsJ,GAAQ,GAAI6/D,GAEvCP,GAAkBA,EAAer6F,OAChC,IAAIoC,EAAI,EAAGA,EAAIi4F,EAAer6F,OAAQoC,IAIlC,GAFAq4F,EADUhgG,EAAIkO,eAAekyF,EAAcR,EAAej4F,IACnCwG,MAEvB,CAUA,IAPA8xF,GADAF,EAAW//F,EAAIkO,eAAeoyB,EAAMs/D,EAAej4F,KAC1BwG,MAErBzG,MAAM+D,QAAQw0F,KACdA,EAAgB,GAChBF,EAASxgF,IAAI0gF,IAGbpoF,EAAI,EAAGA,EAAImoF,EAAaz6F,OAAQsS,IAAK,CACrC,IAAIwoF,EAASL,EAAanoF,GAENooF,EAAcpoF,GAApB,OAAXwoF,EAAoC,KAEhBn/E,EAAMy+E,2BAA2BM,EAAcpoF,GAAIwoF,GAI9EN,EAASxgF,IAAI0gF,GAIrB,OAAO3/D,GAGXpf,EAAMo/E,oBAAsB,CAAC,aAAc,cAC3Cp/E,EAAM2G,sBAAwB/nB,EAAS+nB,sBAUvC3G,EAAMu+E,YAAc,SAASc,EAAWC,GACpC,OAAOt/E,EAAMy+E,2BAA2BY,EAAWC,EAAUt/E,EAAMo/E,sBAYvEp/E,EAAMs+E,aAAe,SAASiB,EAAYC,GACtC,OAAOx/E,EAAMy+E,2BAA2Bc,EAAYC,EAAWx/E,EAAM2G,wBAkBzE3G,EAAM2K,WAAa,SAASlpB,EAAIsB,EAAMggB,EAAQvlB,EAAQiiG,EAAWt/E,GAC7D,IAAI6C,EAAO,CAACorB,OAAQqxD,EAAUrxD,QAC1BsxD,EAAqB,GACrBC,EAAU,GA4Id,OA1IA38E,EAAKi5E,UAAY,WAIb,IAHA,IAAI2D,EAAap5F,MAAM+D,QAAQxH,GAAQA,EAAKsB,OAAS,EACjD05F,EAAevgG,EAAO0f,MAAM,EAAG0iF,GAE3Bn5F,EAAI,EAAGA,EAAIs3F,EAAa15F,OAAQoC,IAAK,CACzC,IAAIo5F,EAAW9B,EAAat3F,GAExBmI,EADQnN,EAAG8uC,UAAUsvD,GACLjxF,QAGpB,GAAIA,EAAJ,CAKA,GAAGA,EAAQkxF,WAAY,CACnB,IAAIh8F,EAAI8K,EAAQ6mF,eAAex1E,KAC3By/E,EAAmB57F,KAAI47F,EAAmB57F,GAAK,IACnD47F,EAAmB57F,GAAGC,KAAK87F,GAG/Bp+F,EAAGsB,KAAKg7F,EAAat3F,IAAMuZ,EAAMu+E,YAAY98F,EAAGsB,KAAKg7F,EAAat3F,IAAK1D,EAAK0D,KAKhF,IAAIs5F,EAAejhG,EAAImgC,kBAAkBngC,EAAIg3B,mBAAmB,GAAI/S,IAMhEi9E,EAAa,mBACjB,IAAI,IAAIjgG,KAAQggG,EACRC,EAAWvlF,KAAK1a,WACbggG,EAAahgG,GAAMkd,MAG9B+C,EAAMs+E,aAAa78F,EAAGshB,OAAQg9E,UASvBt+F,EAAGoyC,SAEV7zB,EAAMivE,eAAextF,GACrBue,EAAMigF,WAAWx+F,GAEjB,IAAI2tF,EAAYtwF,EAAImgC,kBAAkBlc,GAEtC,GAAGqsE,EAAW,CACV,IAAIx3E,EAAWnW,EAAGkF,YAAYm/C,OAE9B,IAAI,IAAIliD,KAAKgU,EAAU,CACnB,IAAIgrC,EAAWhrC,EAAShU,GACpBtD,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MACd6+F,EAAM5/F,EAAG2c,MAAMC,QACfijF,EAAM5/F,EAAG0c,MAAMC,QAEfkjF,EAAM,KACNC,EAAM,KACN9mB,EAAQ,KACRC,EAAQ,KAEThzE,MAAM+D,QAAQ6kF,EAAU9uF,EAAGmZ,MAAQ,WAClC2mF,EAAMhR,EAAU9uF,EAAGmZ,MAAQ,UAAUyD,QAC/B1W,MAAM+D,SAAS6kF,EAAU9uF,EAAGmZ,QAAU,IAAIwD,SAChDmjF,EAAMhR,EAAU9uF,EAAGmZ,OAAOwD,MAAMC,SAEjC1W,MAAM+D,QAAQ6kF,EAAU7uF,EAAGkZ,MAAQ,WAClC4mF,EAAMjR,EAAU7uF,EAAGkZ,MAAQ,UAAUyD,QAC/B1W,MAAM+D,SAAS6kF,EAAU7uF,EAAGkZ,QAAU,IAAIwD,SAChDojF,EAAMjR,EAAU7uF,EAAGkZ,OAAOwD,MAAMC,SAGjCgjF,GAAOE,IACL9/F,EAAG2vD,IAAIiwC,EAAI,MAAQ5/F,EAAG2vD,IAAImwC,EAAI,KAAO9/F,EAAG2vD,IAAIiwC,EAAI,MAAQ5/F,EAAG2vD,IAAImwC,EAAI,OAEpE7mB,EAAQ,CAAC2mB,IAAKA,EAAKE,IAAKA,IAEzBD,GAAOE,IACL9/F,EAAG0vD,IAAIkwC,EAAI,MAAQ5/F,EAAG0vD,IAAIowC,EAAI,KAAO9/F,EAAG0vD,IAAIkwC,EAAI,MAAQ5/F,EAAG0vD,IAAIowC,EAAI,OAEpE7mB,EAAQ,CAAC2mB,IAAKA,EAAKE,IAAKA,KAGzB9mB,GAASC,IACRmmB,EAAQ57F,KAAKjF,EAAIiM,WAAW,CAAC63C,SAAUA,GAAW22B,EAAOC,KAKrE,OAAOj1C,QAAQC,WAGnBxhB,EAAKy5E,MAAQ,SAASJ,GAClB,IAAIiE,EAGA75F,EAFA2tF,EAAkB3yF,EAAGkF,YAAYyiE,iBACjCm3B,EAAoBZ,EAAQt7F,OAGhC,GAAG0e,EACC,IAAItc,EAAI,EAAGA,EAAI2tF,EAAgB/vF,OAAQoC,IAChC2tF,EAAgB3tF,GAAG6/C,gBAClB8tC,EAAgB3tF,GAAG6/C,eAAe7kD,EAAIk+F,EAASx/E,EAAgBk8E,GAsB3E,IAAI,IAAIv4F,KAdLy8F,IACCD,EAAsBxhG,EAAIiM,WAAW,GAAIoV,IACrBwY,SAAW,SAGxB+mE,EAAmB74C,WAE1By5C,EAAsBngF,EAObu/E,EAAoB,CAC7B,IAAI3B,EAAe2B,EAAmB57F,GACxBrC,EAAG8uC,UAAUwtD,EAAa,IAAInvF,QACpC6mF,eAAev1E,KAAKze,EAAIs8F,EAAcuC,EAAqBjE,KAIpEP,EAAYr6F,EAAI0e,EAAgB6C,IAa3ChD,EAAMwgF,oBAAsB,SAAS/+F,EAAIg/F,EAAcC,EAAehgF,GAClE,IAAIha,EAAajF,EAAGkF,YAChBwZ,EAAiBzZ,EAAWikB,WAC5B3H,EAAO,GACP28E,EAAU,GA6Fd,OA3FA38E,EAAKi5E,UAAY,WACb,IAAIrkF,EAAWlR,EAAWo/C,OAQ1B,IAAI,IAAIliD,KAJRof,EAAKorB,QAAS,EACW,SAAtBqyD,EAAaE,OAAiB39E,EAAKorB,QAAS,GACrB,SAAvBsyD,EAAcC,OAAiB39E,EAAKorB,QAAS,GAEnCx2B,EAAU,CACnB,IAAIgrC,EAAWhrC,EAAShU,GACpBtD,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MACd6+F,EAAMx/E,EAAcpgB,EAAGmZ,OAAOwD,MAAMC,QACpCijF,EAAMz/E,EAAcngB,EAAGkZ,OAAOwD,MAAMC,QACpCkjF,EAAM9/F,EAAG2c,MAAMC,QACfmjF,EAAM9/F,EAAG0c,MAAMC,QAEnB5c,EAAGoU,WACHnU,EAAGmU,WAEH,IAAI6kE,EAAQ,KACRC,EAAQ,KAETl5E,EAAG2vD,IAAIiwC,EAAI,MAAQ5/F,EAAG2vD,IAAImwC,EAAI,KAAO9/F,EAAG2vD,IAAIiwC,EAAI,MAAQ5/F,EAAG2vD,IAAImwC,EAAI,MAClE7mB,EAAQ,CAAC2mB,IAAKA,EAAKE,IAAKA,IAEzB7/F,EAAG0vD,IAAIkwC,EAAI,MAAQ5/F,EAAG0vD,IAAIowC,EAAI,KAAO9/F,EAAG0vD,IAAIkwC,EAAI,MAAQ5/F,EAAG0vD,IAAIowC,EAAI,MAClE7mB,EAAQ,CAAC2mB,IAAKA,EAAKE,IAAKA,KAGzB9mB,GAASC,IACRmmB,EAAQ57F,KAAKjF,EAAIiM,WAAW,CAAC63C,SAAUA,GAAW22B,EAAOC,IAIjE,OAAOj1C,QAAQC,WAGnBxhB,EAAKy5E,MAAQ,SAASJ,GAUlB,IATA,IAIIuE,EACAN,EACAZ,EANAhpF,EAAWjV,EAAG8uC,UAEd6jD,EADa3yF,EAAGkF,YACayiE,iBAM7By3B,EAAkB,GACdp6F,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAChCo6F,EAAgB98F,KAAK0C,GAGzB,SAAS6/C,IACL,IAAI,IAAI3vC,EAAI,EAAGA,EAAIy9E,EAAgB/vF,OAAQsS,IACpCy9E,EAAgBz9E,GAAG2vC,gBAClB8tC,EAAgBz9E,GAAG2vC,eAAe7kD,EAAIk+F,EAASiB,EAAoBvE,GAK/E,SAASyE,IACL,IAAI,IAAInqF,EAAI,EAAGA,EAAIy9E,EAAgB/vF,OAAQsS,IACvCy9E,EAAgBz9E,GAAGuJ,KAAKze,EAAIi+F,EAAoBY,EAAqBjE,GAI1EsD,EAAQt7F,QAAUo8F,EAAaE,KACC,iBAA5BxgF,EAAe4gF,UACdH,EAAqB9hG,EAAIiM,WAAW,GAAIoV,EAAgB,CAACwY,SAAU,IACnE+mE,EAAqBmB,EACrBP,EAAsBngF,EACtBwwB,WAAW2V,EAAgBnmC,EAAewY,UAC1CmoE,MAEAF,EAAqBzgF,EACrBu/E,EAAqB,KACrBY,EAAsBxhG,EAAIiM,WAAW,GAAIoV,EAAgB,CAACwY,SAAU,IACpEgY,WAAWmwD,EAAkBF,EAAmBjoE,UAChD2tB,KAEEq5C,EAAQt7F,QACdu8F,EAAqBzgF,EACrBmmC,KACMm6C,EAAaE,OACnBjB,EAAqBmB,EACrBP,EAAsBngF,EACtB2gF,MAIDhF,EAAYr6F,EAAI0e,EAAgB6C,IA2I3ChD,EAAMigF,WAAa,SAASx+F,EAAIjE,GAC5B,IAIIG,EAAOiR,EAASnI,EAAGkQ,EAJnBy2C,EAAS0iB,EAAQ/1D,KAAKtY,GACtBiV,EAAWjV,EAAG8uC,UACd7pC,EAAajF,EAAGkF,YAMhBktC,EAAW,IAAIrtC,MAAMkQ,EAASrS,QAC9BirF,GAAe7tF,EAAGoyC,UAAY,IAAI32B,QAwBtC,IAvBAzb,EAAGoyC,SAAWA,EAKdntC,EAAWs6F,UAAY,EACvBt6F,EAAWu6F,YAAc,EAGzBv6F,EAAWw6F,uBAAyB,GAGpCz/F,EAAGm7E,YAAc,EACjBn7E,EAAGo7E,YAAc,EAGjBn2E,EAAWy6F,aAAe,GAC1Bz6F,EAAW06F,kBAAoB,GAC/B16F,EAAW26F,iBAAmB,GAC9B36F,EAAW46F,oBAAsB,GAI7B76F,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IACzBD,MAAM+D,QAAQ/M,KAAkC,IAAvBA,EAAOoH,QAAQ6B,KACvCotC,EAASptC,GAAK6oF,EAAY7oF,IAKlC,IAAIA,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,KAC5B9I,EAAQ+Y,EAASjQ,IAEXstF,YAAc7J,EAAWqX,oBAAoB5jG,GAGnDA,EAAM6jG,UAAY,GAItB,IAAIC,EAAW/6F,EAAWmR,UAAU6pF,OAAS,GAC7C,IAAIj7F,EAAI,EAAGA,EAAIg7F,EAASp9F,OAAQoC,IAC5B2mD,EAAOrpD,KACH2C,EAAW+6F,EAASh7F,IAAIk7F,WACxBj7F,EAAW+6F,EAASh7F,IAAIm7F,aAKhC,IAAI,IAAIh+F,KAAK8C,EAAWwqF,WAAY,CAChC,IAAIpxC,EAAQp5C,EAAW9C,IACJ,IAAhBk8C,EAAM+hD,eACE/hD,EAAMgiD,YACNhiD,EAAMiiD,MAIrB,IAAIC,GAAmB,EAEvB,SAASC,EAAex7F,GAIpB,GAHA9I,EAAQ+Y,EAASjQ,GACjBmI,EAAUjR,EAAMiR,SAEK,IAAlBjR,EAAM6oB,SAAoB7oB,EAAM0X,WAAY,CAI3C,GAAGzG,GAAWA,EAAQszF,KAAM,CACxB,IAAIC,EAAMvzF,EAAQszF,KAAKzgG,EAAI9D,GAIxBwkG,EAAI,IAAMA,EAAI,GAAGltF,GAAKktF,EAAI,GAAGltF,EAAE0yC,eACvBw6C,EAAI,GAAGltF,EAAE0yC,OAAOy6C,MAI/B,IAAIzrF,EAAI,EAAGA,EAAIhZ,EAAM0X,WAAWhR,OAAQsS,IAAK,CACzC,IAAIxD,EAAYxV,EAAM0X,WAAWsB,IAEjC/H,EAAU27E,EAAmBp3E,EAAUjN,QACzB0I,EAAQyzF,gBAClB1kG,EAAMi2F,mBAAoB,EAC1BoO,GAAmB,EACnBpzF,EAAQyzF,cAAc5gG,EAAI9D,EAAOwV,MAMjD,SAASmvF,EAAM77F,EAAG87F,GAId,GAHA5kG,EAAQ+Y,EAASjQ,MACjBmI,EAAUjR,EAAMiR,SAEH2zF,cAAgBA,EAA7B,CAEA,IAAI3mE,EAAK,GAET,IAAqB,IAAlBj+B,EAAM6oB,SAAsC,IAAlB7oB,EAAMylC,QAAe,QAEvCzlC,EAAMk/B,eAIb,IAAIxnB,EAAa1X,EAAM0X,YAAc,GACrC,IAAIsB,EAAItB,EAAWhR,OAAS,EAAGsS,GAAK,EAAGA,IACnC,GAAGtB,EAAWsB,GAAGkmD,QAAS,CACtBl/D,EAAMk/B,eAAiBxnB,EAAWsB,GAAGkmB,eACrC,MAILjuB,GAAWA,EAAQszF,OAClBtmE,EAAKhtB,EAAQszF,KAAKzgG,EAAI9D,IAQ1B6I,MAAM+D,QAAQqxB,IAAQA,EAAG,KACzBA,EAAK,CAAC,CAAC/7B,EAAG+wB,EAAQ9wB,EAAG8wB,KAMrBgL,EAAG,GAAG3mB,IAAG2mB,EAAG,GAAG3mB,EAAI,IACvB2mB,EAAG,GAAGj+B,MAAQA,EAEdk2C,EAASptC,GAAKm1B,GAOlB,IAJA4mE,EAAoBp1C,EAAQ12C,EAAUhQ,GAIlCD,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK67F,EAAM77F,GAAG,GAC9C,IAAIA,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAKw7F,EAAex7F,GAOpD,IAJGu7F,GAAkBQ,EAAoBp1C,EAAQ12C,EAAUhQ,GAIvDD,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK67F,EAAM77F,GAAG,GAC9C,IAAIA,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK67F,EAAM77F,GAAG,GAE9Cg8F,EAAiBhhG,GAGjB,IAAIihG,EAiBR,SAAmCt1C,EAAQ3rD,GACvC,IACIgF,EAAGkQ,EAAG/S,EAAGslB,EAAGixE,EADZwI,EAAiB,GAGrB,SAASC,EAAa18F,EAAMkkC,EAAIvL,GAC5B,IAAInmB,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GAC7B,GAAY,uBAAT1U,EAA+B,CAC9B,IAAI28F,EAAkBz4D,EAAG5wB,aAAa,GAClC+rD,EAAYuK,EAAQxqC,UAAU7jC,EAAIohG,GAElCC,EAA4B,MAAbpqF,GAAyC,MAApBmqF,GAA8C,aAAnBt9B,EAAUr/D,KACzE68F,EAA4B,MAAbrqF,GAAyC,MAApBmqF,GAA8C,aAAnBt9B,EAAUr/D,KAE7E,OAAO,SAASi0F,EAAGjxE,GACf,OAAS,IAANixE,GAAiB,IAANjxE,GACX45E,GAAgB3I,IAAMt7D,EAAM3V,GAAG7kB,OAAS,GACxC0+F,GAAgB75E,IAAM2V,EAAMx6B,OAAS,GAFT,GAIV,MAAbqU,EAAmBwQ,EAAIixE,GAAK,GAGxC,OAAO,SAASA,EAAGjxE,GACf,MAAoB,MAAbxQ,EAAmBwQ,EAAIixE,GAK1C,IAAI6I,EAAQ,CACR,IAAO,SAASxlD,GAAS,OAAO1+C,EAAIw0B,QAAQxxB,KAAKi3B,IAAK,KAAMykB,IAC5D,IAAO,SAASA,GAAS,OAAO1+C,EAAIw0B,QAAQxxB,KAAKc,IAAK,KAAM46C,IAC5D,IAAO,SAASA,GAAS,OAAO1+C,EAAIw0B,SAAQ,SAASrO,EAAGlD,GAAK,OAAOkD,EAAIlD,IAAK,KAAMy7B,IACnF,MAAS,SAASA,GAAS,OAAO1+C,EAAIw0B,SAAQ,SAASrO,EAAGlD,GAAK,OAAOkD,EAAIlD,IAAK,KAAMy7B,IACrF,KAAQ,SAASA,GAAS,OAAO1+C,EAAIy0B,KAAKiqB,IAC1C,OAAU,SAASA,GAAS,OAAO1+C,EAAI00B,OAAOgqB,KAGlD,IAAI/2C,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAAK,CAC/B,IAAI2jC,EAAKgjB,EAAO3mD,GAChB,GAAe,aAAZ2jC,EAAGlkC,KAAN,CAGA,IAAIgO,EAAQk2B,EAAGoS,cAActoC,MAAM+uF,GACnC,GAAG/uF,EAAO,CACN,IAAIgvF,EAAahvF,EAAM,GACnBqoC,EAAQroC,EAAM,GAGdivF,EAAkB,GACtB,IAAIxsF,EAAI,EAAGA,EAAIyzB,EAAGoiB,YAAYnoD,OAAQsS,IAClCwsF,EAAgBp/F,KAAK,CAACqmC,EAAGoiB,YAAY71C,GAAI,KAI7C,IAAIA,EAAI,EAAGA,EAAIyzB,EAAGnxB,cAAc5U,OAAQsS,IAAK,CACzC,IAAIs6B,EAAa7G,EAAGnxB,cAActC,GAC9Bg4E,EAAYltF,EAAG8uC,UAAUU,GACzBv4B,EAAW0xB,EAAGzwB,IAAIiB,OAAO,GAG7B,IAAyB,IAAtB+zE,EAAUnoE,QAAb,CAEA,IAAItgB,EAAOyoF,EAAUzoF,KAClBtH,EAAS2C,QAAQotF,EAAW,sBACpBA,EAAUyU,yBACVzU,EAAU0U,mBAGrB,IAAIznE,EAAKn6B,EAAGoyC,SAAS5C,GACrB,IAAIrtC,EAAI,EAAGA,EAAIg4B,EAAGv3B,OAAQT,IAAK,CAC3B,IACI0/F,EAAKC,EAAU1kE,EADfsjE,EAAMvmE,EAAGh4B,GAGb,GAAY,UAATsC,EAAkB,CAGjB,IAAIs9F,EAAwB7U,EAAU8U,SAASr5D,EAAGzwB,KAGlD,GAAgB,MAAbjB,EAAkB,CACjB,IAAIgrF,EAAoB/U,EAAUgV,MAAMH,GAAuB,GAC5DE,IAAmBt5D,EAAK3oC,EAAGkF,YAAYmpE,EAAQ55D,QAAQwtF,KAG9D,IAAIrgD,EAAa8+C,EAAIxkG,MAAMimG,WAAWJ,GAAuBhmD,OAC7D,IAAIt0B,EAAI,EAAGA,EAAIm6B,EAAWh/C,OAAQ6kB,IAK9B,IAJAo6E,EAAMjgD,EAAWn6B,GACjBq6E,EAAWn5D,EAAGy5D,eAAeP,GAGzBnJ,EAAI,EAAGA,EAAIgI,EAAIxkG,MAAMimG,WAAWv/F,OAAQ81F,IACxC,GAAGA,IAAMqJ,EAAT,CACA,IAAIM,EAAY3B,EAAIxkG,MAAMimG,WAAWzJ,GACrCgJ,EAAgBI,GAAU,GAAGx/F,KAAK+/F,EAAUtmD,OAAOt0B,UAGxD,GAAY,cAAThjB,EAAsB,CAE5B,IAAIgjB,EAAI,EAAGA,EAAIi5E,EAAIltF,EAAEpV,EAAEwE,OAAQ6kB,IACX,MAAbxQ,IACC4qF,EAAMnB,EAAIltF,EAAEpV,EAAEqpB,GACdq6E,EAAWD,EACXzkE,EAAQsjE,EAAIltF,EAAEnV,EAAEopB,IAGJ,MAAbxQ,IACC4qF,EAAMnB,EAAIltF,EAAEnV,EAAEopB,GACdq6E,EAAWD,EACXzkE,EAAQsjE,EAAIltF,EAAEpV,EAAEqpB,IAEpBi6E,EAAgBI,GAAU,GAAGx/F,KAAK86B,GAInCsjE,EAAIltF,GAAKktF,EAAIltF,EAAE0yC,eACPw6C,EAAIltF,EAAE0yC,OAAOy6C,WAErB,GAAGD,EAAIrlF,eAAe,KAAM,CAE/B+hB,EAAQsjE,EAAI97E,EACZ,IAAI09E,EAAUnB,EAAajU,EAAUzoF,KAAMkkC,EAAIvL,GAE/C,IAAI3V,EAAI,EAAGA,EAAI2V,EAAMx6B,OAAQ6kB,IACzB,IAAIixE,EAAI,EAAGA,EAAIt7D,EAAM3V,GAAG7kB,OAAQ81F,KAC5BoJ,EAAWQ,EAAQ5J,EAAGjxE,IACR,GAAGi6E,EAAgBI,GAAU,GAAGx/F,KAAK86B,EAAM3V,GAAGixE,SAapE,IARgB,MAAbzhF,GACC4qF,EAAMnB,EAAI3zF,EAAI,EAAI2zF,EAAI3zF,EAAI2zF,EAAItiG,EAC9Bg/B,EAAQsjE,EAAInkG,GAAKmkG,EAAIz9F,GAAKy9F,EAAIriG,GACX,MAAb4Y,IACN4qF,EAAMnB,EAAI3zF,EAAI,EAAI2zF,EAAI3zF,EAAI2zF,EAAIriG,EAC9B++B,EAAQsjE,EAAInkG,GAAKmkG,EAAIz9F,GAAKy9F,EAAItiG,GAE9B2G,MAAM+D,QAAQs0B,KAAQA,EAAQ,CAACA,IAC/B3V,EAAI,EAAGA,EAAI2V,EAAMx6B,OAAQ6kB,IACzBi6E,EAAgBG,GAAK,GAAGv/F,KAAK86B,EAAM3V,MAMnDkhB,EAAG45D,iBAAmBb,EAEtB,IAAIc,EAA4B,GAChC,IAAIttF,EAAI,EAAGA,EAAIwsF,EAAgB9+F,OAAQsS,IACnCstF,EAA0BlgG,KAAK,CAC3Bo/F,EAAgBxsF,GAAG,GACnBqsF,EAAME,GAAYC,EAAgBxsF,GAAG,MAK7CstF,EAA0B9wE,MAAK,SAASlO,EAAGlD,GACvC,OAAOkD,EAAE,GAAKlD,EAAE,MAGpBqoB,EAAG85D,2BAA6BD,EAGhC75D,EAAGqS,mBAAqBwnD,EAA0B/qF,KAAI,SAASsL,GAC3D,OAAOA,EAAE,MAIA,eAAV+3B,GACCnS,EAAGqS,mBAAmBM,UAI1B4lD,EAAiBA,EAAevqF,OAAOgyB,EAAG+5D,6BAGlD,OAAOxB,EAhMMyB,CAA0Bh3C,EAAQ3rD,GAC/C,GAAGihG,EAAOr+F,OAAQ,CAKd,IAHAqC,EAAWs6F,UAAY,EACvBt6F,EAAWu6F,YAAc,EAErBx6F,EAAI,EAAGA,EAAIi8F,EAAOr+F,OAAQoC,IAAK67F,EAAMI,EAAOj8F,IAAI,GACpD,IAAIA,EAAI,EAAGA,EAAIi8F,EAAOr+F,OAAQoC,IAAK67F,EAAMI,EAAOj8F,IAAI,GACpDg8F,EAAiBhhG,GAGrB7C,EAASyX,mBAAmB,KAAM,OAAlCzX,CAA0C6C,GAC1C7C,EAASyX,mBAAmB,YAAa,OAAzCzX,CAAiD6C,IAGrD,IAAIwhG,EAAiC,yDAoLrC,SAAST,EAAoBp1C,EAAQ12C,EAAUhQ,GAC3C,IACID,EAAG2jC,EAAI3xB,EADP4rF,EAAW,GAGf,IAAI59F,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAE1BgS,GADA2xB,EAAKgjB,EAAO3mD,IACFkT,IAEVywB,EAAGk6D,YACY,kBAAZl6D,EAAGlkC,MACFkkC,EAAGm6D,mBAAmB7tF,GAG1B2tF,EAASj6D,EAAGzwB,KAAO,EAIvB,IAAI6C,EAAc9V,EAAW+V,kBAAoB,GACjD,IAAIhW,EAAI,EAAGA,EAAI+V,EAAYnY,OAAQoC,IAC/B,IAAIgS,KAAQ+D,EAAY/V,GAChB49F,EAAS5rF,KACT2xB,EAAK1jC,EAAWopE,EAAQ55D,QAAQuC,KAC7B6rF,YAMnB,SAAS7B,EAAiBhhG,GACtB,IAGIgF,EAAGkQ,EAAG/S,EAHN8C,EAAajF,EAAGkF,YAChBs8C,EAAUv8C,EAAW6pF,gBACrBx9E,EAAO,GAOX,IAAI4D,EAAI,EAAGA,EAAIssC,EAAQ5+C,OAAQsS,IAAK,CAChC,IAAI/H,EAAUq0C,EAAQtsC,GAClBmlB,EAAKltB,EAAQ41F,eACjB,GAAG1oE,EAAI,CACH,IAAI2oE,EAAS71F,EAAQ6mF,eAAex1E,KACjClN,EAAK0xF,GACJ3lG,EAAI44B,WAAW3kB,EAAK0xF,GAAS3oE,GAE7B/oB,EAAK0xF,GAAU,CAAC3oE,IAK5B,IAAIl4B,KAAKmP,EAAM,CACX,IAAI2xF,EAAU3xF,EAAKnP,GACfgU,EAAWlR,EAAWmR,UAAUjU,GAEpC,GAAG4C,MAAM+D,QAAQqN,GACb,IAAInR,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAAK,CACjC,IAAI+2D,EAAK5lD,EAASnR,GACdk+F,EAAe,cAAN/gG,EACT8C,EAAWo/C,OAAO0X,GAClB92D,EAAW82D,GAEf,IAAI7mD,EAAI,EAAGA,EAAI+tF,EAAQrgG,OAAQsS,IAC3B+tF,EAAQ/tF,GAAGlV,EAAIkjG,EAAQnnC,QAI/B,IAAI7mD,EAAI,EAAGA,EAAI+tF,EAAQrgG,OAAQsS,IAC3B+tF,EAAQ/tF,GAAGlV,IAM3Bue,EAAMk8E,QAAU,SAASz6F,GAClBA,EAAGkF,YAAYi+F,UACdnjG,EAAGkF,YAAYi+F,YAIvB5kF,EAAM6kF,OAAS,SAASpjG,GACjBA,EAAGkF,YAAYu2E,SACdz7E,EAAGkF,YAAYu2E,WAIvBl9D,EAAM8kF,4BAA8B,SAASrjG,EAAIP,EAAS6jG,EAAiBC,GACvE,IAEIv+F,EAFAw+F,EAAe/jG,EAAQgkG,UACvBA,EAAY,GAIhB,IAAIz+F,EAAI,EAAGA,EAAIs+F,EAAgB1gG,OAAQoC,IAAK,CACxC,IAAI0+F,EAAaJ,EAAgBt+F,GAC7B9I,EAAQwnG,EAAW,GAAGxnG,MAIvBA,EAAM6oB,UACL0+E,EAAUvnG,EAAMuI,MAAQg/F,EAAUvnG,EAAMuI,OAAS,GACjDg/F,EAAUvnG,EAAMuI,MAAMnC,KAAKohG,IAOnC,IAAI,IAAIC,KAAiBH,EACrB,IAAIC,EAAUE,GAAgB,CAC1B,IAAIC,EAAgBJ,EAAaG,GAAe,GAChCC,EAAc,GAAG1nG,MAEvB6oB,SAAU,EACpB0+E,EAAUE,GAAiB,CAACC,GAKpC,IAAI,IAAIt5C,KAAcm5C,EAAW,CAC7B,IAAII,EAAiBJ,EAAUn5C,GACjBu5C,EAAe,GAAG,GAAG3nG,MAAMiR,QAEjCsR,KAAKze,EAAIP,EAASpC,EAAI4rB,cAAc46E,GAAiBN,GAIjE9jG,EAAQgkG,UAAYA,GAGxBllF,EAAMK,aAAe,SAAS4+B,EAAax9C,EAAIjE,EAAQ2iB,EAAgBC,GACnE,IAAIxR,EAAUhQ,EAASglD,UAAU3E,GAC7BsmD,EAAW9iD,EAAkBhhD,EAAGoyC,SAAUjlC,GAAS,GACvDA,EAAQsR,KAAKze,EAAI8jG,EAAUplF,EAAgBC,IAG/CJ,EAAMW,cAAgB,SAASs+B,EAAa1+B,EAAaC,EAAeC,EAAaC,GACjF,IAAI8kF,EAAO9kF,EAAcG,MAAQH,EAAcG,KAAKo+B,GAChDwmD,EAAOjlF,EAAcK,MAAQL,EAAcK,KAAKo+B,GAEjDumD,IAAQC,GACP/kF,EAAc,IAAMu+B,EAAc,SAAS9gD,UAAU,WAAW+I,W,8CCvtGxE5J,EAAOC,QAAU,SAAekC,EAAMimG,GAGlC,IAFA,IAAIC,EAAOlmG,EAAK4E,OACZuhG,EAAQ,EACJn/F,EAAI,EAAGA,EAAIk/F,EAAMl/F,IAClBi/F,EAAOj/F,IACNhH,EAAKgH,IAAMi/F,EAAOj/F,GAClBm/F,GAASnmG,EAAKgH,IACXhH,EAAKgH,GAAK,KAErB,OAAOm/F,I,8CCXXtoG,EAAOC,QAAU,CACb2oB,WAAY,EAAQ,YACpB+oE,eAAgB,EAAQ,YACxBiT,KAAM,EAAQ,YACdhiF,KAAM,EAAQ,YACdmqD,SAAU,EAAQ,YAClBjsE,MAAO,EAAQ,YACfynG,YAAa,EAAQ,YAErBj9B,WAAY,QACZ3oD,KAAM,UACNw1E,eAAgB,EAAQ,YACxBpyC,WAAY,CAAC,YAAa,MAAO,QAAS,cAC1Ct0C,KAAM,CACFwuC,YAAa,CACT,6DACA,iBACA,mEACA,2BAEA,yCACA,yCACA,uEACA,gDACA,wDACA,gDACA,gEACA,sDACA,qDACA,yEACA,iEACA,gDACA,oEACA,iBAEA,yEACA,+DACFx2C,KAAK,Q,8CCpCfzJ,EAAOC,QAAU,SAA6BslB,EAASC,EAAUvK,IAE9C,IADDA,EAAO,aAGjBA,EAAO,QACPA,EAAO,SAGXA,EAAO,kB,8CCTX,IAAIutF,EAAa,GAqFjB,SAASC,EAAcC,GAChBA,GAAyB,OAAhBA,EAAMC,QACdp1D,aAAam1D,EAAMC,OACnBD,EAAMC,MAAQ,MAxEtB1oG,QAAQ+4B,SAAW,SAAkBqI,EAAIunE,EAAa5J,GAClD,IAAI0J,EAAQF,EAAWnnE,GACnBwnE,EAAM1zD,KAAK0zD,MAEf,IAAIH,EAAO,CAMP,IAAI,IAAII,KAAON,EACRA,EAAWM,GAAK/3F,GAAK83F,EAAM,YACnBL,EAAWM,GAG1BJ,EAAQF,EAAWnnE,GAAM,CAACtwB,GAAI,EAAG43F,MAAO,MAK5C,SAASI,IACL/J,IACA0J,EAAM33F,GAAKokC,KAAK0zD,MACbH,EAAMM,SACLN,EAAMM,SACNN,EAAMM,OAAS,MAPvBP,EAAcC,GAWXG,EAAMH,EAAM33F,GAAK63F,EAChBG,IAIJL,EAAMC,MAAQt1D,YAAW,WACrB01D,IACAL,EAAMC,MAAQ,OACfC,IAGP3oG,QAAQi5B,KAAO,SAASmI,GACpB,IAAIqnE,EAAQF,EAAWnnE,GACvB,OAAIqnE,GAAUA,EAAMC,MAEb,IAAI1hE,SAAQ,SAASC,GACxB,IAAI+hE,EAAiBP,EAAMM,OAC3BN,EAAMM,OAAS,WACRC,GAAgBA,IACnB/hE,IACAwhE,EAAMM,OAAS,SAPW/hE,QAAQC,WAkB9CjnC,QAAQm5B,MAAQ,SAASiI,GACrB,GAAGA,EACConE,EAAcD,EAAWnnE,WAClBmnE,EAAWnnE,QAElB,IAAI,IAAIynE,KAAON,EAAYvoG,QAAQm5B,MAAM0vE,K,8CCjFjD,IAAIhpG,EAAK,EAAQ,YACb0B,EAAM,EAAQ,YACdmmC,EAAc,EAAQ,YACtBd,EAAU,EAAQ,YAClBvuB,EAAmB,EAAQ,YAC3B4wF,EAAc,EAAQ,YAE1BlpG,EAAOC,QAAU,CACbqrE,WAAY,YACZ3oD,KAAM,KAENqH,UAAW,EAAQ,YACnBuhD,OAAQ,CACJ9lD,OAAQnN,GAGZsQ,WAAY,EAAQ,YACpBtQ,iBAAkBA,EAElBk6E,2BAA4B,EAAQ,YACpCb,eAAgB,EAAQ,YACxB5oC,qBAAsB,EAAQ,YAE9B67C,KAAM,EAAQ,YAEduE,oBAAqBtiE,EAAQsiE,oBAC7BC,WAAYviE,EAAQuiE,WACpBC,MAAOxiE,EAAQwiE,MACfC,WAAYziE,EAAQyiE,WACpBvnG,sBAAuB8kC,EAAQ9kC,sBAE/BwnG,gBAyBJ,SAAyBlpG,EAAO0+B,EAAUt8B,GACtC,OAAOjB,EAAIs9B,WAAWz+B,EAAO0+B,EAAU,cAAgBt8B,IAzBvD+mG,cA4BJ,SAAuBnpG,EAAO+I,EAAY21B,GAKtC,OAAOv9B,EAAIs9B,WAAWz+B,EAAO0+B,EAAU,aAJvC,SAAiBzd,GACb,OAAO9f,EAAI8yB,gBAAgB,CAACm1E,UAAWnoF,GAAM,CAAChQ,QAASjR,EAAMiR,SAAUlI,OA5B3E8uD,MAAOgxC,EAAYhxC,MACnBwxC,QAAS/hE,EAAY+hE,QAErB3/D,UAAWm/D,EAAYn/D,UACvBM,YAKJ,SAAqBs/D,GAGjB,IAAIpyF,EAAY/V,EAAIu/B,cAAc4oE,GAC1BA,EACA7pG,EAAGa,OAAOgpG,GAElBpyF,EAAU1W,UAAU,eAAe+I,SACnC2N,EAAU1W,UAAU,cAAc+I,UAXlC29B,MAAO,EAAQ,c,+CCxCPvnC,EAAOC,QAAU,EAAQ,aAE/Bi0E,QAAU,EAAQ,a,8CCFxB,IAAI1yE,EAAM,EAAQ,YACd20E,EAA+B,EAAQ,YAEvCvtD,EAAa,EAAQ,YAGrBjG,EAFY,EAAQ,YAEHA,KACjBinF,EAAYhhF,EAAWxU,MAU3B,SAASy1F,EAAeC,EAAUC,EAAW5wF,GACzC,SAAS8B,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO6uF,EAAUC,EAAWnhF,EAAYnmB,EAAM4B,GAS7D,IANA,IAAI+P,EAAQ+hE,EAA6B2zB,EAAUC,EAAW,CAC1DpnF,KAAM,QACN+zD,mBAAoBszB,IAGpBC,EAAY,EACR9gG,EAAI,EAAGA,EAAIiL,EAAMrN,OAAQoC,IAC1BiL,EAAMjL,GAAG+f,SAAS+gF,IAOzB,GAFGA,EAAY,EAAaF,EAAU7gF,SAAU,EACjCjO,EAAO,WACtB,CAEA8uF,EAAUG,WAAaD,EACvB,IAAIE,EAAWJ,EAAUK,cAAgB5oG,EAAI4rB,cAAchZ,IAGtDA,EADQ6G,EAAO,YACE,IAAIiO,UAAS6gF,EAAUj/E,OAASq/E,EAAS,GAAG//E,QAElEnP,EAAO,KACPA,EAAO,KACPzZ,EAAIy8B,UAAU6rE,EAAUC,EAAW,CAAC,IAAK,MAEzC9uF,EAAO,WACPA,EAAO,WAEPA,EAAO,OACPA,EAAO,WAEPA,EAAO,SACPA,EAAO,SACPA,EAAO,SACPA,EAAO,SAEPzZ,EAAImkB,WAAW1K,EAAQ,OAAQ9B,EAAUlX,MAEbgZ,EAAO,0BAG/BA,EAAO,wBACPA,EAAO,uBACPA,EAAO,uBACPA,EAAO,uBAEPzZ,EAAImkB,WAAW1K,EAAQ,oBAAqB8uF,EAAU9nG,OAG1DgZ,EAAO,uBACPA,EAAO,qBAEPA,EAAO,WACPA,EAAO,iBACPA,EAAO,eACPA,EAAO,eACPA,EAAO,WACPA,EAAO,aACPA,EAAO,aACPA,EAAO,iBAGX,SAAS+uF,EAAaK,EAASC,GAC3B,SAASrvF,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOovF,EAASC,EAAUV,EAAWnnG,EAAM4B,GAQ1D,GAJsB,SAAnBgmG,EAAQh8E,QAAsBnlB,MAAM+D,QAAQo9F,EAAQ/7E,MAEtCrT,EAAO,WADVqvF,EAASphF,SAAU,EAGrB,CACRjO,EAAO,UACPA,EAAO,QACP,IAAI8U,EAAQ9U,EAAO,QAAS,QAAUqvF,EAASlgF,QAC/CnP,EAAO,QAAS8U,GAChB9U,EAAO,YA1Ffjb,EAAOC,QAAU,SAAyBiZ,EAAUC,GAChDg9D,EAA6Bj9D,EAAUC,EAAW,CAC9CwJ,KAAMA,EACN+zD,mBAAoBmzB,M,4CCZ5B,IAAIlxF,EAAU,EAAQ,YAClB4xF,EAAkB,EAAQ,YAC1BjpG,EAAW,EAAQ,YACnB4W,EAAiB,EAAQ,YAAiBA,eAE1CsyF,EAAgB,EAAQ,YACxBC,EAAiB,EAAQ,YAU7BzqG,EAAOC,QAAU,SAAuBkE,GACpC,IAAIiF,EAAajF,EAAGkF,YAChB+L,EAAUjR,EAAGG,SACbomG,EAAUthG,EAAW0yF,SAEzB,GAAI1mF,EAAQu1F,gBAAmBv1F,EAAQw1F,UAAvC,CAQA,IAAI1hG,MAAM+D,QAAQmI,EAAQy1F,wBACtB,MAAM,IAAI1oE,MAAM,CACZ,iDACA,qBACF14B,KAAK,MAGX,IAAIP,MAAM+D,QAAQmI,EAAQ01F,qBACtB,MAAM,IAAI3oE,MAAM,CACZ,8CACA,qBACF14B,KAAK,MAGX,IACIshG,EADAC,EAAgB51F,EAAQq1F,eAIxBM,EADD7hG,MAAM+D,QAAQ+9F,IAAkBA,EAAcjkG,OA2LrD,SAA0BikG,GACtB,IAAI,IAAI7hG,EAAI,EAAGA,EAAI6hG,EAAcjkG,OAAQoC,IAGrC,IAFA,IAAI8hG,EAAcD,EAAc7hG,GAExBkQ,EAAI,EAAGA,EAAI4xF,EAAYlkG,OAAQsS,IAAK,CACxC,IAAI0U,EAASk9E,EAAY5xF,GAEzB,GAAqB,iBAAX0U,EAAqB,CAC3B,QAA8B7iB,IAA3Bu/F,EAAe18E,GAGd,MAAM,IAAIoU,MAAM,CACZ,yCACA,uBACF14B,KAAK,MALPuhG,EAAc7hG,GAAGkQ,GAAKoxF,EAAe18E,IAWrD,OAAOi9E,EA9MYE,CAAiBF,IACzB51F,EAAQu1F,gBAAkBv1F,EAAQw1F,UAC1B,GAUvB,SAAyBzmG,GACrB,IAAIiF,EAAajF,EAAGkF,YAChB+P,EAAWjV,EAAG8uC,UACd79B,EAAUjR,EAAGG,SACb6mG,EAAkB/1F,EAAQy1F,uBAC1BO,EAAeh2F,EAAQ01F,oBAEvBngD,EAAevhD,EAAWma,KAAK,aAC/B8nF,EAAUjiG,EAAWma,KAAK,QAC1B+nF,EAASliG,EAAWma,KAAK,OACzBgoF,EAASniG,EAAWma,KAAK,OACzBioF,EAAgBpiG,EAAWma,KAAK,cAChCkoF,EAAUriG,EAAWma,KAAK,QAC1BmoF,EAAatiG,EAAWma,KAAK,WAC7BooF,EAAYviG,EAAWma,KAAK,UAC5BqoF,EAAWxiG,EAAWma,KAAK,SAC3BsoF,EAAYziG,EAAWma,KAAK,UAC5BuoF,EA4FR,SAAyB1iG,GAGrB,IAFA,IAAI0mD,EAASn3C,EAAQ8D,KAAK,CAACpT,YAAaD,GAAa,MAAM,GAEnDD,EAAI,EAAGA,EAAI2mD,EAAO/oD,OAAQoC,IAC9B,IAAI2mD,EAAO3mD,GAAG+nE,WACV,OAAO,EAIf,OAAO,EArGY66B,CAAgB3iG,GAC/B4iG,EAAuB9zF,EAAe9O,EAAWgU,WAEjD65B,EAAS,GAEb,SAASg1D,EAASC,GACd,GAAIA,EAASnlG,OAAb,CAIA,IAFA,IAAIsG,EAAM,GAEFlE,EAAI,EAAGA,EAAI+iG,EAASnlG,OAAQoC,IAAK,CACrC,IAAI4kB,EAASm+E,EAAS/iG,IACkB,IAArCgiG,EAAgB7jG,QAAQymB,IAC3B1gB,EAAI5G,KAAKgkG,EAAe18E,IAG5BkpB,EAAOxwC,KAAK4G,IAIhB,IAAI8+F,EAAc,CAAC,WAChB/2F,EAAQg3F,sBAAuBD,EAAY1lG,KAAK,qBAC3C2O,EAAQi3F,iBAAiBF,EAAY1lG,KAAK,mBAClDwlG,EAASE,GAET,IAAIG,EAAY,GACZC,EAAa,GACbC,EAAa,GACbC,EAAgB,IAEhB9hD,GAAgB8gD,GAAWF,GAAUC,GAAiBE,GAAcJ,EAASD,EAAUM,EAAYC,EAAW,GAG9GW,EAAa,CAAC,eACdC,EAAa,CAAC,eACRlB,GACNgB,EAAY,CAAC,YAAa,cAC1BC,EAAa,CAAC,mBACdC,EAAa,CAAC,aACRnB,GACNkB,EAAa,CAAC,kBACdC,EAAa,CAAC,uBAAwB,0BAChCb,GACNW,EAAY,CAAC,eAAgB,iBAC7BC,EAAa,CAAC,eACdC,EAAa,CAAC,oBACRf,EACNc,EAAa,CAAC,oBACRhB,EACNgB,EAAa,CAAC,mBACRV,GACNU,EAAa,CAAC,wBAAyB,yBACvCC,EAAa,CAAC,oBAGdD,EAAa,CAAC,eAKf5hD,IACC4hD,EAAa,CAAC,mBAAoB,wBAAyB,2BA4EnE,SAAoBnzF,GAChB,IAAI,IAAIjQ,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAChC,IAAI7H,EAAS2C,QAAQmV,EAASjQ,GAAI,WAAY,OAAO,EAEzD,OAAO,EA9EJujG,CAAWtzF,IAAa4yF,KACvBO,EAAa,KAGb5hD,IAAgB8gD,GAAaK,IAC7BQ,EAAY,CAAC,WAAY,YAAa,eACjB,eAAlBE,EAAW,KAAqBA,EAAa,CAAC,kBAGlDnB,EACCoB,EAAgB,CAAC,SAAU,QAAS,gBAAiB,kBAC7C9hD,GAAgB8gD,KAAaK,GAAiBJ,EACtDe,EAAgB,CAAC,SAAU,SACrBd,GAAaL,EACnBmB,EAAgB,CAAC,SACXb,IACNa,EAAgB,CAAC,YA2BzB,SAAsBrzF,GAGlB,IAFA,IAAIuzF,GAAa,EAETxjG,EAAI,EAAGA,EAAIiQ,EAASrS,SACrB4lG,EAD6BxjG,IAAK,CAGrC,IAAI9I,EAAQ+Y,EAASjQ,GAEjB9I,EAAMiR,SAAYjR,EAAMiR,QAAQ4oF,eAEjC54F,EAAS2C,QAAQ5D,EAAO,iBACpBkqG,EAAgBxmD,WAAW1jD,IAAUkqG,EAAgBvmD,QAAQ3jD,MAC5DssG,GAAa,GAEXrrG,EAAS2C,QAAQ5D,EAAO,eACP,QAApBA,EAAM0iD,WAAwC,QAAjB1iD,EAAM2iD,SAQtC2pD,GAAa,IAIrB,OAAOA,GApDJC,CAAaxzF,IACZqzF,EAAchmG,KAAK,WAAY,WAOnC,OAJAwlG,EAASQ,GACTR,EAASK,EAAUxxF,OAAO0xF,IAC1BP,EAASM,GAyDb,SAA+Bt1D,EAAQ1rB,GACnC,GAAGA,EAAQxkB,OACP,GAAGmC,MAAM+D,QAAQse,EAAQ,IACrB,IAAI,IAAIpiB,EAAI,EAAGA,EAAIoiB,EAAQxkB,OAAQoC,IAC/B8tC,EAAOxwC,KAAK8kB,EAAQpiB,SAErB8tC,EAAOxwC,KAAK8kB,GAGvB,OAAO0rB,EAhEA41D,CAAsB51D,EAAQm0D,GAlHlB0B,CAAgB3oG,GAGhCumG,EAASA,EAAQl2D,OAAOrwC,EAAI4mG,GAC1B3hG,EAAW0yF,SAAW0O,EAAcrmG,EAAI4mG,QAjCtCL,IACCA,EAAQpgD,iBACDlhD,EAAW0yF,Y,4CCxB9B,IAAIt6F,EAAM,EAAQ,YACdurG,EAAiB,EAAQ,YAIzBC,EAAgB,CAChBrqF,KAAM,CACFo9B,QAAS,SACTC,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,wEACA,iEACA,qEACA,oDACA,8DACA,gCACA,wCACFx2C,KAAK,OA+Mf,SAASwjG,EAActqF,GACnB,OAAOA,GAAwB,iBAATA,EAG1B,SAASuqF,EAAgBvqF,GACrB,IAAIwqF,EAAWxqF,EAAK5b,OAAS,EAI7B,MAH6B,MAA1B4b,EAAKrF,OAAO6vF,IACX3rG,EAAIwe,KAAK,oCAAsC2C,GAE5CA,EAAKjC,OAAO,EAAGiC,EAAK5b,OAAS,GAAK,WArN7CimG,EAA8B,iBAAI,CAC9BjtD,QAAS,SACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,qEACA,uEACA,qEACA,uEACA,+DACA,iEACA,8DACFx2C,KAAK,MAeXxJ,QAAQ4/C,eAAiB,SAASl9B,EAAMra,GAIpC,OAHAA,EAAM8kG,iBAAmBzqF,EACzBra,EAAMqa,KAAOqqF,EAAcrqF,KAC3Bra,EAAsB,iBAAI0kG,EAA8B,iBACjD1kG,GAeXrI,QAAQy4F,eAAiB,SAASH,GAC9B,IACItsB,EAAWohC,EADXC,EAAc,GAGlB,IAAIrhC,KAAassB,EACb8U,EAAgB9U,EAAatsB,GAC1B/iE,MAAM+D,QAAQogG,IAAkBA,EAActmG,SAC7CumG,EAAYrhC,GAAa,GA2BjC,MAAO,CACHkqB,SAxBJ,SAAkB5wE,GAEd,IAAIC,EAAW,CAAC5c,KADhBqjE,EAAYzqE,EAAIyZ,OAAOsK,EAAS,GAAIwnF,EAAgB,QACnB7mF,UAAW,MAC5C,GAAG+lD,KAAaqhC,EAAa,CACzBD,EAAgB9U,EAAatsB,GAE7B,IAAIshC,EAAQD,EAAYrhC,GAAaohC,EAActmG,OACnDumG,EAAYrhC,KACZzmD,EAASU,UAAYmnF,EAAcE,GAYvC,OAAO/nF,KAuBfvlB,QAAQsd,aAAe,SAASgD,EAAWoC,EAAM6qF,GAC7C,IAAIhV,EAAWj4E,EAAU2F,UACrB1D,EAAOg2E,IAAaA,EAAS71E,IAAU6qF,GAAYhV,EAASgV,IAIhE,OAHIhsG,EAAIY,cAAcogB,KAAOA,EAAO,MAE1BjC,EAAUoC,GAAQ,CAACuD,UAAW1D,IAuB5CviB,QAAQwtG,eAAiB,SAASltF,EAAWoC,EAAM+qF,GAC/C,IAAIlV,EAAWj4E,EAAU2F,UACrBynF,EAAmBnV,GAAYA,EAAS0U,EAAgBvqF,IACxDirF,EAAgBpV,GAAYA,EAAS71E,GACrCzZ,MAAM+D,QAAQ2gG,IAAmBA,EAAc7mG,SAC/C6mG,EAAgB,IAGpB,IAAIC,EAAY,GA8DhB,MAAO,CACHC,QA7DJ,SAAiBC,GAMb,IAAI1gG,EAAM,CAACsV,KAAMorF,EAAOprF,KAAMjE,OAAQqvF,GAClCC,EAAmB3gG,EAAoB,iBAAI0gG,EAAuB,iBAGtE,IAAId,EAAce,GAEd,OADA3gG,EAAI6Y,UAAYynF,EACTtgG,EAKX,IAAI,IAAIlE,EAAI,EAAGA,EAAIykG,EAAc7mG,OAAQoC,IAAK,CAC1C,IAAI8kG,EAAeL,EAAczkG,GACjC,GAAG8kG,EAAatrF,OAASqrF,EAMrB,OAFAH,EAAUG,GAAoB,EAC9B3gG,EAAI6Y,UAAY+nF,EACT5gG,EAWf,OAHAA,EAAIqgG,GAAiBK,EAAOL,KAAkB,EAE9CrgG,EAAI6Y,WAAY,EACT7Y,GA0BP6gG,aAvBJ,WAEI,IADA,IAAI7gG,EAAM,GACFlE,EAAI,EAAGA,EAAIykG,EAAc7mG,OAAQoC,IAAK,CAC1C,IAAI8kG,EAAeL,EAAczkG,GAC7BwZ,EAAOsrF,EAAatrF,KAGxB,GAAGsqF,EAActqF,KAAUkrF,EAAUlrF,GAAO,CACxC,IAAIwrF,EAAO,CACPjoF,UAAW+nF,EACXtrF,KAAMA,EACNjE,OAAQ,CAAC0vF,kBAAmBzrF,IAEhCwrF,EAAqB,iBAAIF,EAA6B,iBACtD5gG,EAAI5G,KAAK0nG,GACTN,EAAUlrF,GAAQ,GAG1B,OAAOtV,KAoBfpN,QAAQitG,gBAAkBA,EAwB1BjtG,QAAQ8pB,YAAc,SAASskF,EAAUhmE,EAAcimE,GACnD,IAAIC,GAAY/sG,EAAIkO,eAAe2+F,EAAUhmE,GAAc14B,OAAS,IAAI5I,OACpE0iB,EAAQ6kF,EAAQlkF,OAIhB4jF,EAAoBvkF,GAAS8kF,IAAcD,EAAQ5vF,QAAU,IAAI0vF,kBAClEJ,IAAkBvkF,EAAQ8kF,GAC7B,IAEI/5D,EAFAg6D,EAAUnmE,EAAe,IAAM5e,EAAQ,IAG3C,SAASglF,IACLj6D,EAAS,GACNw5D,IACCx5D,EAAOg6D,GAAW,GAClBh6D,EAAOg6D,GAAyB,iBAAIR,GAS5C,SAAStlE,EAAWjmC,EAAM8+B,GACnBysE,EAECxsG,EAAIkO,eAAe8kC,EAAOg6D,GAAU/rG,GAAMse,IAAIwgB,GAG9CiT,EAAOg6D,EAAU,IAAM/rG,GAAQ8+B,EAIvC,SAASoH,IACL,IAAI+lE,EAAYl6D,EAEhB,OADAi6D,IACOC,EAWX,OA9BAD,IA8BO,CACHhmE,WA7BJ,SAAoBhmC,EAAM8+B,GACtBiT,EAAO/xC,GAAQ8+B,GA6BfmH,WAAYA,EACZC,aAAcA,EACd5d,YAZJ,SAAqBtoB,EAAM8+B,GACpB9+B,GAAMimC,EAAWjmC,EAAM8+B,GAC1B,IAAIotE,EAAgBhmE,IACpB,IAAI,IAAIpgB,KAAOomF,EACXntG,EAAIkO,eAAe2+F,EAAU9lF,GAAKxH,IAAI4tF,EAAcpmF,Q,4CCjThE,IAAI/mB,EAAM,EAAQ,YACdonB,EAAa,EAAQ,YACrBgmF,EAA2B,EAAQ,YAEvC5uG,EAAOC,QAAU,SAAwBslB,EAASC,EAAUqD,EAAcpD,GAKtE,IAAIC,EAAOlkB,EAAIiM,WAAW,GAAIgY,EAAOmkB,YAClCpkB,EAASy0E,gBAAev0E,EAAKmpF,YAAc,GAE9CD,EAAyBrpF,EAASC,GAPlC,SAAgB/iB,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOsK,EAASC,EAAUoD,EAAYnmB,EAAM4B,KAMPqhB,K,4CCZxD,IAAIlkB,EAAM,EAAQ,YAElBxB,EAAOC,QAAU,SAAuBq+B,EAAIj+B,GACrCmB,EAAI+K,oBAAoBlM,EAAMmN,iBAC7BhM,EAAI49B,YAAYd,EAAIj+B,K,8CCJ5B,IAAIe,EAAY,EAAQ,YAEpBE,EAAW,EAAQ,YACnBkmC,EAAO,EAAQ,YACfhmC,EAAM,EAAQ,YAEdstG,EAAmB,EAAQ,YAkB/B,SAASC,EAAY1vE,EAAWh/B,EAAO2uG,EAAMC,GACzC,IAAIvpF,EAAOrlB,EAAM,SAAW4uG,IAAU,GAElC1vD,EAAO,GAEX,GAHiB75B,EAAKwD,UAAqD,IAA1C,CAAC,SAAU,OAAO5hB,QAAQ0nG,EAAKpmG,MAGhE,CAIA,IAFA,IAAIsmG,EAAeJ,EAAiBppF,GAE5Bvc,EAAI,EAAGA,EAAIk2B,EAAUt4B,OAAQoC,IAAK,CACtC,IAAI61B,EAASK,EAAUl2B,GAEnBgmG,EAAMnwE,EAAO71B,EAGjB,QAAW+B,IAARikG,EAAmBA,EAAMhmG,OAWvB,GAAW,OAARgmG,EAAc,SAEtB,IAAIC,EAAYpwE,EAAOiwE,GAEvB,GAAI7tG,EAAU4tG,EAAKtzC,IAAI0zC,IAAvB,CAEA,IAAIC,EAASH,EAAaE,EAAWD,GACrC,GAAG/tG,EAAUiuG,EAAO,KAAOjuG,EAAUiuG,EAAO,IAAK,CAC7C,IAAIC,EAAOtwE,EAAOiwE,EAAQ,KAAOG,EAAYC,EAAO,GAChDE,EAAMvwE,EAAOiwE,EAAQ,KAAOG,EAAYC,EAAO,GACnD9vD,EAAK94C,KAAK6oG,EAAMC,KAIxB,IAAIp0F,EAAO6zF,EAAK3yF,IACZmzF,EAAenvG,EAAM6jG,UAAU/oF,GAC/By4D,EAAWpsC,EAAKomB,aAChBohD,EACAzvD,EACA/9C,EAAIiM,WAAW,CAACgiG,OAAQD,EAAa9pF,KAAK+pF,QAAS,CAACC,QAAQ,KAEhEF,EAAa/zE,IAAM+zE,EAAa/zE,IAAI3gB,OAAO84D,EAASn4C,KACpD+zE,EAAalqG,IAAMkqG,EAAalqG,IAAIwV,OAAO84D,EAAStuE,MAhExDtF,EAAOC,QAAU,SAAckE,GAG3B,IAFA,IAAIoyC,EAAWpyC,EAAGoyC,SAEVptC,EAAI,EAAGA,EAAIotC,EAASxvC,OAAQoC,IAAK,CACrC,IAAIk2B,EAAYkX,EAASptC,GACrB9I,EAAQg/B,EAAU,GAAGh/B,MAEzB,IAAqB,IAAlBA,EAAM6oB,SAAoB5nB,EAAS2C,QAAQ5D,EAAO,eAAgB,CACjE,IAAI2C,EAAKwkC,EAAKQ,UAAU7jC,EAAI9D,EAAMyD,OAC9Bb,EAAKukC,EAAKQ,UAAU7jC,EAAI9D,EAAM0D,OAClCgrG,EAAY1vE,EAAWh/B,EAAO2C,EAAI,KAClC+rG,EAAY1vE,EAAWh/B,EAAO4C,EAAI,S,4CClB9C,IAAInD,EAAK,EAAQ,YAEjBE,EAAOC,QAAU,SAAekE,GAC5BrE,EAAGa,OAAOwD,GAAItD,UAAU,aACnBC,MAAM,WAAW,SAASV,GACvB,OAAOA,EAAEC,MAAM+K,a,4CCN3B,IAAIukG,EAAkB,EAAQ,YAE9B3vG,EAAOC,QAAU,CACb4vB,QAAS,CACLkwB,QAAS,QACT17C,KAAMsrG,EAAgB30F,WACtBglC,KAAM,QACNM,SAAU,OACVL,YAAa,kDAEjBrwB,YAAa,CACTmwB,QAAS,QACT17C,KAAMsrG,EAAgBnjG,YACtBwzC,KAAM,QACNM,SAAU,OACVL,YAAa,8CAEjBnyB,YAAa,CACTiyB,QAAS,UACT17C,KAAM,EACNo3B,IAAK,EACLukB,KAAM,QACNM,SAAU,OACVL,YAAa,8CAEjBvgC,UAAW,CACPqgC,QAAS,UACT17C,MAAM,EACN27C,KAAM,QACNM,SAAU,OACVsvD,aAAc,CAAC,gBAAY1kG,EAAW,gBAAYA,GAClD+0C,YAAa,CACT,sDACA,0CACA,+DACFx2C,KAAK,MAEXkW,MAAO,CACHogC,QAAS,aACTC,KAAM,OACNI,MAAO,CACH,CAACL,QAAS,MAAOO,SAAU,OAAQsvD,aAAc,CAAC,cAAc,IAChE,CAAC7vD,QAAS,MAAOO,SAAU,OAAQsvD,aAAc,CAAC,cAAc,KAEpEtvD,SAAU,OACVsvD,aAAc,CAAC,WAAa,GAC5B3vD,YAAa,CACT,sCACA,gDACA,sDACA,6BACA,2DACA,4DACA,6CACA,0DACA,2DACA,6CACFx2C,KAAK,MAEX1I,UAAW,CACPg/C,QAAS,SACT17C,KAAM,IACNo3B,IAAK,EACLn2B,IAAK,EACL06C,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,sDACA,2BACFx2C,KAAK,MAEXyf,QAAS,CACL62B,QAAS,UACT17C,MAAM,EACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8DACA,8DACFx2C,KAAK,MAEX62C,SAAU,S,4CChFd,IAAI9+C,EAAM,EAAQ,YACdgmC,EAAO,EAAQ,YAEfqK,EAAO,EAAQ,YAAUA,KAY7B,SAASg+D,EAAa1rG,GAClB,IAAIiF,EAAajF,EAAGkF,YAMpB7H,EAAI4rB,cAAchkB,EAAW2+B,aAAa1hC,SAAQ,SAAS+3D,GACvD,IAAIp7D,EAAKwkC,EAAKQ,UAAU7jC,EAAIi6D,EAAIn2B,MAC5BhlC,EAAKukC,EAAKQ,UAAU7jC,EAAIi6D,EAAIl2B,MAEhCk2B,EAAI8lC,UAAY,GACblhG,GAAI8sG,EAAkB1xC,EAAKp7D,GAC3BC,GAAI6sG,EAAkB1xC,EAAKn7D,MAItC,SAAS6sG,EAAkB1xC,EAAKtxB,GAC5B,IAeI8mC,EAfAz4D,EAAO2xB,EAAGzwB,IACVsB,EAASxC,EAAKmC,OAAO,GACrBzL,EAAMusD,EAAIzgD,GACVoyF,EAAO3xC,EAAI,IAAMzgD,GACjBqyF,EAAM5xC,EAAIzgD,EAAS,OACnBsyF,EAAO7xC,EAAI,IAAMzgD,EAAS,OAC1BuyF,EAAU9xC,EAAI,IAAMzgD,EAAS,WAC7BwyF,EAAW/xC,EAAI,IAAMzgD,EAAS,YAC9BopD,EAAQ,CAACxkE,EAAG,EAAGC,GAAI,GAAGmb,GAAUygD,EAAIzgD,EAAS,SAC7CyyF,EAAW,EAAIhyC,EAAIiyC,UAAYjyC,EAAIjvB,YAAc,EACjDmhE,EAAWF,EAAWrpC,EACtBwpC,EAAYH,EAAWrpC,EACvBypC,EAAgB,EAAIpyC,EAAIqyC,eAAiBryC,EAAIjvB,YAAc,EAC3DuhE,EAAgBF,EAAgBzpC,EAChC4pC,EAAiBH,EAAgBzpC,EAGrC,GAAGkpC,IAASD,EAAK,CAEb,IAAIY,EAAmBppE,EAAKomB,aAAa9gB,EAAI,CAACA,EAAG+jE,IAAIh/F,IAAO,CACxDi/F,SAAUR,EACVS,UAAWR,IAGXS,EAAcxpE,EAAKomB,aAAa9gB,EAAI,CAACA,EAAG+jE,IAAId,IAAQ,CACpDe,SAAUtsG,KAAKc,IAAI4qG,EAASQ,GAC5BK,UAAWvsG,KAAKc,IAAI6qG,EAAUQ,KAElC/8B,EAAW,CACPn4C,IAAK,CAACm1E,EAAiBn1E,IAAI,GAAIu1E,EAAYv1E,IAAI,IAC/Cn2B,IAAK,CAACsrG,EAAiBtrG,IAAI,GAAI0rG,EAAY1rG,IAAI,UAGnDorG,EAAgBX,EAAOW,EAAgBX,EAAOW,EAC9CC,EAAiBZ,EAAOY,EAAiBZ,EAAOY,EAChD/8B,EAAWpsC,EAAKomB,aAAa9gB,EAAI,CAACA,EAAG+jE,IAAIh/F,IAAO,CAC5Ci/F,SAAUtsG,KAAKc,IAAI4qG,EAASI,EAAUI,GACtCK,UAAWvsG,KAAKc,IAAI6qG,EAAUI,EAAWI,KAIjDvyC,EAAI8lC,UAAU/oF,GAAQy4D,EApE1B5zE,EAAOC,QAAU,SAAuBkE,GACpC,IAAIiF,EAAajF,EAAGkF,YAGpB,GAFqB7H,EAAI4rB,cAAchkB,EAAW2+B,aAEhChhC,QAAU5C,EAAG8uC,UAAUlsC,OACrC,OAAOvF,EAAI87B,YAAY,CAACuU,EAAMg+D,GAAe1rG,K,4CCZrD,IAAIu7C,EAAY,EAAQ,YACpBuxD,EAAkB,EAAQ,YAAuBrnE,WACjDn8B,EAAa,EAAQ,YAAoBA,WAE7CzN,EAAOC,QAAU,CACb2pC,WAAY,CACR/Z,QAASpiB,EAAW,GAAIwjG,EAAgBphF,QAAS,CAC7CqhF,SAAS,EACTjxD,YAAa,iEAEjBrwB,YAAaniB,EAAW,GAAIwjG,EAAgBrhF,YAAa,CACrDshF,SAAS,EACTjxD,YAAa,8DAEjBh+C,KAAMy9C,EAAU,CACZwxD,SAAS,EACT5wD,SAAU,OACVL,YAAa,wCAEjB5U,MAAO59B,EAAW,GAAIwjG,EAAgB5lE,MAAO,CAAC6lE,SAAS,IACvDrC,WAAYphG,EAAW,GAAIwjG,EAAgBpC,WAAY,CAACqC,SAAS,IACjE5wD,SAAU,U,iCCvBlB,IAAIxgD,EAAK,EAAQ,YAEby4B,EADM,EAAQ,YACMA,cACpB40B,EAAY,EAAQ,YAAgCA,UAEpDgkD,EAAInxG,EAAOC,QAAU,CAAEmxG,QAAS,SAEpCD,EAAEz8B,KAAO,WACL,IAIIhxD,EAAKnD,EAA4C60D,EAAaD,EAJ9DniC,EAAS,CACTvtC,KAAM,GACNggB,OAAQ,IACT4rF,EAAc,GAAIC,EAAa,GACdxmB,EAAWhrF,EAAGgrF,SAAS,SACvC7qF,QAAU,GAsfd,OAhCAA,QAAQ40E,OAAS,SAASJ,GAEtB,OAvdJ,SAAgBA,GACZl0D,EAAYk0D,GAAcl0D,EAC1B,IAAI9a,EAAOutC,EAAOvtC,KACd8rG,EAAav+D,EAAOvtB,QACA,iBAAblF,GAAyBA,EAAUnd,YAAUmd,EAAYzgB,EAAGa,OAAO4f,IAC9EA,EAAUqhB,MAAMn8B,GAAMtF,MAAK,SAASqxG,EAAOpnF,GACvC,IAAIqnF,EAAeD,EAAM5xF,QACzB0xF,EAAa,CACT7rG,KAAM0rG,EAAEz7B,KAAKC,UAAU87B,GACvBhsF,OAAQ0rF,EAAEz7B,KAAKC,UAAU47B,IAE7B,IAAI5X,EAAa,EACjB8X,EAAaprG,SAAQ,SAASjG,EAAG+I,GACxB/I,EAAEc,QACHd,EAAEc,MAAQqwG,EAAWG,kBAAkB/X,GACvCA,GAAcA,EAAa,GAAK4X,EAAWG,kBAAkB3qG,QAE5D3G,EAAEuxG,cACHvxG,EAAEuxG,YAA6B,aAAfvxG,EAAEwxG,SAA0BxxG,EAAEc,MAAQpB,EAAGunB,IAAIjnB,EAAEc,OAAO2wG,SAASvpF,YAEnFgpF,EAAW7rG,KAAK0D,GAAGjI,MAAQd,EAAEc,MAC7BowG,EAAW7rG,KAAK0D,GAAGwoG,YAAcvxG,EAAEuxG,YACnCL,EAAW7rG,KAAK0D,GAAG2oG,WAAa1xG,EAAE0xG,WAClCR,EAAW7rG,KAAK0D,GAAG4oG,WAAa3xG,EAAE2xG,cAEtC,IAAItsG,EAAOgsG,EAAa91D,QAAO,SAASv7C,EAAG+I,GACvC,IAAI+f,EAAU9oB,EAAE8oB,QAChB,YAA0B,IAAZA,IAAuC,IAAZA,KAEzC8oF,GAAY,EACZC,EAAkBxsG,EAAKmW,KAAI,SAASxb,EAAG+I,GAEvC,OADA6oG,EAAYA,QAAkC,IAAd5xG,EAAE8xG,QAC3B9xG,KAEX,GAAI4xG,EAAW,CACX,IAAIG,EAAUryG,EAAGsyG,OAAO7pF,KAAI,SAASnoB,EAAG+I,GACpC,YAA2B,IAAb/I,EAAE8xG,QAAyB9xG,EAAE8xG,QAAU,eACtDj+D,QAAQg+D,GACPI,EAAa,GACbC,EAAUH,EAAQv2F,KAAI,SAASxb,EAAG+I,GAClC,GAAc,cAAV/I,EAAEmoB,IAAqB,OAAOnoB,EAAE8/C,OAChC,IAAIqyD,EAAYnyG,EAAE8/C,OAAO,GAAGh5C,EAAE0U,KAAI,SAASxb,EAAG+I,GAC1C,OAAO,KAOX,OALA/I,EAAE8/C,OAAO75C,SAAQ,SAASjG,EAAG+I,EAAGwe,GAC5BvnB,EAAEoyG,OAAS,CAAED,GACbF,EAAW5rG,KAAK8rG,GAChBA,EAAYpB,EAAEz7B,KAAK+8B,UAAUryG,EAAE8G,EAAGqrG,MAE/BnyG,EAAE8/C,UAGjBz6C,EAAO3F,EAAG4yG,MAAMJ,GAEpB7sG,EAAKY,SAAQ,SAASjG,EAAG+I,GACrB/I,EAAEuX,EAAIzO,MAAM+D,QAAQ7M,EAAEuX,EAAE,IAAMvX,EAAEuX,EAAI,CAAEvX,EAAEuX,GACxCvX,EAAE8G,EAAIgC,MAAM+D,QAAQ7M,EAAE8G,EAAE,IAAM9G,EAAE8G,EAAI,CAAE9G,EAAE8G,MAE5C,IAAIyrG,EAASnuG,KAAKi3B,IAAI81E,EAAWvsG,MAAQusG,EAAW73D,OAAO/kC,KAAO48F,EAAW73D,OAAO3jC,MAAOw7F,EAAW38F,OAAS28F,EAAW73D,OAAOtpC,IAAMmhG,EAAW73D,OAAOvpC,QAAU,EACnKwiG,EAASnuG,KAAKc,IAAI,GAAIqtG,GACtB,IACIC,EADAC,EAAc,CAAEtB,EAAW73D,OAAO/kC,KAAOg+F,EAAQpB,EAAW73D,OAAOtpC,IAAMuiG,GAEzEX,EAEAY,EAAS,CAAE,EADe9yG,EAAGwF,IAAI6rG,EAAEz7B,KAAK+8B,UAAUtB,EAAEz7B,KAAKo9B,UAAUrtG,GAAMyB,EAAE,GAAIiqG,EAAEz7B,KAAKo9B,UAAUT,MAE7FO,EAAS9yG,EAAG8yG,OAAOzB,EAAEz7B,KAAKq9B,aAAattG,EAAKmW,KAAI,SAASxb,EAAG+I,GAC/D,OAAO/I,EAAE8G,OAETqqG,EAAWyB,WAAWttC,QAAUyrC,EAAE8B,aAAYL,EAAO,GAAK,GAC9Dx9B,EAAct1E,EAAG4X,MAAMw7F,SAASxtC,OAAO6rC,EAAWyB,WAAWttC,QAAUyrC,EAAE8B,YAAc1B,EAAWyB,WAAWttC,OAAS6rC,EAAWyB,WAAWttC,OAASktC,GAAQjzF,MAAM,CAAE,EAAGgzF,IACxKrB,EAAW7rF,OAAOutF,WAAWttC,OAAS0P,EAAY1P,SAClD,IAIIvD,EAJAgxC,EAAoBhC,EAAEz7B,KAAKq9B,aAAattG,EAAKmW,KAAI,SAASxb,EAAG+I,GAC7D,OAAO/I,EAAEuX,MAETy7F,EAA4C,iBAAzBD,EAAkB,GAErCC,IACAD,EAAoBhC,EAAEz7B,KAAK29B,YAAYF,GACvChxC,EAAQgxC,EAAkBvzF,QAC1BuzF,EAAoBrzG,EAAG6f,MAAMwzF,EAAkBpsG,QAC/CtB,EAAOA,EAAKmW,KAAI,SAASxb,EAAG+I,GACxB,IAAIo/E,EAASnoF,EAGb,OAFAA,EAAEuX,EAAI,CAAEw7F,GACJnB,IAAWzpB,EAAOiqB,OAASpyG,EAAEoyG,QAC1BjqB,MAGf,IAAI+qB,EAAuB7tG,EAAKk2C,QAAO,SAASv7C,EAAG+I,GAC/C,MAAsB,aAAf/I,EAAEwxG,UAA0C,YAAfxxG,EAAEwxG,YACvC7qG,SAAWtB,EAAKsB,OACfwsG,EAAiD,OAA/BhC,EAAWgC,gBAA2BH,IAAcE,EAAuB/B,EAAWgC,gBAExGC,EADoBjC,EAAWkC,YAAY/tC,QAAU6rC,EAAWkC,YAAY/tC,QAAUyrC,EAAE8B,aAAeG,GAAa7B,EAAWkC,YAAY/tC,OAAO,IAAM,EACpH6rC,EAAWkC,YAAY/tC,OAAS5lE,EAAG8yG,OAAOO,GAC9EO,EAAoBlvG,KAAK6/B,IAAI8uE,EAAkB,GAAKA,EAAkB,IACtEG,IAAyBF,IAAWM,EAAoB,GAC5D,IAAIC,EAA2BH,EAAc5zF,QACzC2zF,GAAmBH,IAAWO,EAAyB,IAAMD,GACjE,IAAIE,EAAYrC,EAAWkC,YAAYI,YAAc,EACjDD,EAAY,IAAGA,EAAYA,GAAaA,EAAY,GAAKA,EAAY,GACrErC,EAAWkC,YAAYK,YACvBF,GAAaD,EAAyB,GAAKA,EAAyB,IAAMC,GAE9E,IAAIG,EAAmBxC,EAAWkC,YAAYK,YAAcH,EAAyB,GAAKA,EAAyB,KAAOC,GAAarC,EAAWyC,WAAa,IAC3J7xC,IAAO4xC,EAAmBvvG,KAAKc,IAAId,KAAKC,MAAMsvG,GAAmB,IAChEJ,EAAyB,KAAIA,EAAyB,GAAKI,GAChE,IAAIE,EAAmBn0G,EAAG6f,MAAMsjB,MAAMriC,KAAM+yG,GAQ5C,GAPAM,EAAmBA,EAAiBr4F,KAAI,SAASxb,EAAG+I,GAChD,OAAO6O,WAAW5X,EAAE8zG,YAAY,QAEpC/+B,EAAer1E,EAAG4X,MAAMw7F,SAASxtC,OAAOiuC,EAAyB/zF,MAAM,EAAG,IAAID,MAA+B,cAAzB4xF,EAAWjlF,UAA4B,CAAE,EAAG,KAAQ,CAAE,IAAK,IAC/IglF,EAAW7rF,OAAOguF,YAAY/tC,OAASyP,EAAazP,SACpD4rC,EAAW7rF,OAAOguF,YAAYU,WAAaZ,EAAkBG,EAAoB,OAE9D,KADnBhwF,EAAM5jB,EAAGa,OAAOC,MAAMD,OAAO,oBACK+iB,EAAIkoB,QAAS,CAC3C,IACIwoE,GAAM,IAAIC,WAAYC,gBADX,2hBACqC,mBAChDtvB,EAASpkF,KAAKqV,YAAYrV,KAAK2zG,cAAcC,WAAWJ,EAAIK,iBAAiB,IACjF/wF,EAAM5jB,EAAGa,OAAOqkF,GAEpBthE,EAAI/iB,OAAO,iBAAiBG,MAAM,CAC9B,iBAAkB,SAEtB4iB,EAAI/iB,OAAO,uBAAuBG,MAAM,CACpC,iBAAkB,SAEtB4iB,EAAI/iB,OAAO,sBAAsBG,MAAM,CACnC,iBAAkB,SAEtB,IAaI4zG,EAbAC,EAAajxF,EAAI/iB,OAAO,gBACxBi0G,EAAY,CACZvyG,KAAM,OACNpB,OAAQswG,EAAWsD,WAEnBC,EAAY,CACZ,YAAavD,EAAWtvG,KAAKE,KAC7B,cAAeovG,EAAWtvG,KAAKC,OAC/BG,KAAMkvG,EAAWtvG,KAAKf,MACtB,cAAe,CAAE,WAAY,WAAY,WAAY,WAAY0a,KAAI,SAASxb,EAAG+I,GAC7E,MAAO,IAAM/I,EAAI,MAAQmxG,EAAWtvG,KAAK8yG,gBAC1CtrG,KAAK,MAGZ,GAAI8nG,EAAWyD,WAAY,CACvBN,EAAkBhxF,EAAI/iB,OAAO,iBAAiB8B,KAAK,CAC/CoT,UAAW,aAAe,CAAE88F,EAAQpB,EAAW73D,OAAOtpC,KAAQ,MAC/DtP,MAAM,CACL+jC,QAAS,UAEb,IAAIowE,EAAWxvG,EAAKmW,KAAI,SAASxb,EAAG+I,GAChC,IAAI+rG,EAAa/D,EAAEz7B,KAAKC,UAAUv1E,GAIlC,OAHA80G,EAAWxpG,OAAwB,YAAftL,EAAEwxG,SAAyBxxG,EAAE+0G,SAAW,SAAyB,YAAd/0G,EAAEwxG,SAAyB,SAAW,OAC7GsD,EAAWE,qBAA+C,IAAtBh1G,EAAEg1G,iBAAmCh1G,EAAEg1G,gBAC3EF,EAAWh0G,MAAuB,aAAfd,EAAEwxG,SAA0BxxG,EAAEuxG,YAAcvxG,EAAEc,MAC1Dg0G,KAGX/D,EAAEkE,SAASriE,OAAO,CACdvtC,KAAMA,EAAKmW,KAAI,SAASxb,EAAG+I,GACvB,OAAO/I,EAAEuiB,MAAQ,UAAYxZ,KAEjCmsG,aAAc/8E,EAAc,GACxB44E,EAAEkE,OAAOE,gBAAgBD,aACzB,CACI/0F,UAAWm0F,EACXO,SAAUA,EACVO,aAAcjE,EAAWj/D,OAAOkjE,gBAT5CrE,GAcA,IAAIsE,EAAaf,EAAgBvxG,OAAOuyG,UACxC/C,EAASnuG,KAAKi3B,IAAI81E,EAAWvsG,MAAQywG,EAAWzwG,MAAQusG,EAAW73D,OAAO/kC,KAAO48F,EAAW73D,OAAO3jC,MAAOw7F,EAAW38F,OAAS28F,EAAW73D,OAAOtpC,IAAMmhG,EAAW73D,OAAOvpC,QAAU,EAClLwiG,EAASnuG,KAAKc,IAAI,GAAIqtG,GACtBE,EAAc,CAAEtB,EAAW73D,OAAO/kC,KAAOg+F,EAAQpB,EAAW73D,OAAOtpC,IAAMuiG,GACzEv9B,EAAYz1D,MAAM,CAAE,EAAGgzF,IACvBrB,EAAW7rF,OAAOutF,WAAWttC,OAAS0P,EAAY1P,SAClDgvC,EAAgBjyG,KAAK,YAAa,aAAe,CAAEowG,EAAY,GAAKF,EAAQE,EAAY,GAAKF,GAAW,UAExG+B,EAAkBhxF,EAAI/iB,OAAO,iBAAiBG,MAAM,CAChD+jC,QAAS,SAGjBnhB,EAAIjhB,KAAK,CACLuC,MAAOusG,EAAWvsG,MAClB4P,OAAQ28F,EAAW38F,SACpB9T,MAAM,CACLsK,QAASmmG,EAAWnmG,UAExBupG,EAAWlyG,KAAK,YAAa,aAAeowG,EAAc,KAAK/xG,MAAM,CACjE2qC,OAAQ,cAEZ,IAAIkqE,EAAkB,EAAGpE,EAAWvsG,OAASusG,EAAW73D,OAAO/kC,KAAO48F,EAAW73D,OAAO3jC,MAAiB,EAAT48F,GAAc8C,EAAaA,EAAWzwG,MAAQ,KAAO,GAAIusG,EAAW38F,QAAU28F,EAAW73D,OAAOtpC,IAAMmhG,EAAW73D,OAAOvpC,OAAkB,EAATwiG,IAAe,GAIhP,GAHAgD,EAAgB,GAAKnxG,KAAKc,IAAI,EAAGqwG,EAAgB,IACjDA,EAAgB,GAAKnxG,KAAKc,IAAI,EAAGqwG,EAAgB,IACjDjyF,EAAI/iB,OAAO,gBAAgB8B,KAAK,YAAa,aAAekzG,EAAkB,KAC1EpE,EAAW57D,OAAS47D,EAAW57D,MAAMxkC,KAAM,CAC3C,IAAIwkC,EAAQjyB,EAAI/iB,OAAO,sBAAsBG,MAAMg0G,GAAW3jG,KAAKogG,EAAW57D,MAAMxkC,MAChFykG,EAAYjgE,EAAMxyC,OAAOuyG,UAC7B//D,EAAMlzC,KAAK,CACPF,EAAGswG,EAAY,GAAK+C,EAAU5wG,MAAQ,EACtCxC,EAAGqwG,EAAY,GAAKF,EAAS,KAGrC,IAAIK,EAAatvF,EAAI/iB,OAAO,sBAC5B,GAAI4wG,EAAWyB,WAAW6C,iBAAkB,CACxC,IAAIC,EAAc9C,EAAWnyG,UAAU,sBAAsB4E,KAAK2vE,EAAYjT,MAAM,IACpF2zC,EAAYjsG,QAAQC,OAAO,UAAUrH,KAAK,CACtC,MAAS,gBACV3B,MAAM8zG,GACTkB,EAAYrzG,KAAK,IAAK2yE,GACtB0gC,EAAYnsG,OAAOC,SAEvBopG,EAAWryG,OAAO,yBAAyB8B,KAAK,CAC5CyE,EAAGyrG,IACJ7xG,MAAM8zG,GACT,IAAImB,EAAmBryF,EAAI/iB,OAAO,4BAA4B8B,KAAK,CAC/DyE,EAAGyrG,IACJ7xG,MAAM,CACLuB,KAAMkvG,EAAWyE,gBACjB/0G,OAAQswG,EAAWtwG,SAEvB,SAASg1G,EAAa71G,EAAG+I,GACrB,OAAOgsE,EAAa/0E,GAAK,IAAMmxG,EAAWn3F,YAE9C,GAAIm3F,EAAWyB,WAAW9pF,QAAS,CAC/B,IAAI8lF,EAAOlvG,EAAG4jB,IAAIsrF,OAAOt3F,MAAM09D,GAAajT,MAAM,GAAG+zC,SAAS,GAC9DlD,EAAWhyG,KAAKguG,GAAMvsG,KAAK,CACvBoT,UAAW,UAAY07F,EAAWyB,WAAW54F,YAAc,MAE/D44F,EAAWnyG,UAAU,WAAWC,MAAM8zG,GACtC5B,EAAWnyG,UAAU,UAAUsQ,MAAK,SAAS/Q,EAAG+I,GAC5C,OAAOvI,KAAKyqF,YAAckmB,EAAWyB,WAAWmD,eACjDr1G,MAAMg0G,GAAWh0G,MAAM,CACtB,cAAe,UAChB2B,KAAK,CACJF,EAAG,EACHC,EAAG,EACHoO,GAAI,EACJC,GAAI,EACJgF,UAAW,SAASzV,EAAG+I,GACnB,MAA8C,eAA1CooG,EAAWyB,WAAWoD,gBACf,WAAa7E,EAAWyB,WAAW54F,YAAc,eAAiB,CAAE,EAAG06F,EAAU,cAAiB,IAC/F,aAAe,CAAE,EAAGA,EAAU,cAAiB,OAGrE9B,EAAWnyG,UAAU,UAAUC,MAAM,CACjCG,OAAQ,UAGhB,IAAIwyG,EAAc/vF,EAAI/iB,OAAO,uBAAuBE,UAAU,kBAAkB4E,KAAKwuG,GACjFoC,EAAmB5C,EAAY5pG,QAAQC,OAAO,KAAKsiB,QAAQ,gBAAgB,GAC/EqnF,EAAYhxG,KAAK,CACboT,UAAW,SAASzV,EAAG+I,GACnB,MAAO,UAAY8sG,EAAa71G,GAAQ,OAE7CU,MAAM,CACL+jC,QAAS0sE,EAAWkC,YAAYvqF,QAAU,QAAU,SAExDuqF,EAAY9pG,OAAOC,SACnBysG,EAAiBvsG,OAAO,QAAQsiB,QAAQ,aAAa,GAAMA,QAAQ,SAAS,SAAShsB,EAAG+I,GACpF,OAAOA,GAAKooG,EAAWyC,WAAa,IAAM,KAC3C5nF,QAAQ,SAAS,SAAShsB,EAAG+I,GAC5B,QAASA,GAAKooG,EAAWyC,WAAa,IAAM,MAC7ClzG,MAAM8zG,GACTyB,EAAiBx1G,UAAU,UAAUC,MAAM,CACvCG,OAAQswG,EAAW+E,iBAEvB7C,EAAY9yG,OAAO,kBAAkB8B,KAAK,CACtCiF,GAAI6pG,EAAWgF,WAAa5D,EAASpB,EAAWgF,WAAa,EAC7D5uG,GAAIgrG,IACL7xG,MAAM,CACL+jC,QAAS0sE,EAAWkC,YAAYoC,iBAAmB,QAAU,SAEjEQ,EAAiBvsG,OAAO,QAAQsiB,QAAQ,aAAa,GAAMtrB,MAAMg0G,GACjE,IAAI0B,EAAY/C,EAAY9yG,OAAO,kBAAkB8B,KAAK,CACtDF,EAAGowG,EAASpB,EAAWkF,YACvB5lG,GAAIs8C,EAAY,KAChBt3C,UAAW,SAASzV,EAAG+I,GACnB,IAAI89D,EAAQgvC,EAAa71G,GACrBinE,EAAMsrC,EAASpB,EAAWkF,YAC1BC,EAASnF,EAAWkC,YAAY2C,gBACpC,MAAc,cAAVM,EAA+B,WAAazvC,EAAQ,IAAMI,EAAM,MAA0B,UAAVqvC,EAA2BzvC,EAAQ,KAAOA,EAAQ,GAAK,cAAgBI,EAAM,MAAQ,KAAkB,WAAaJ,GAAS,KAAOA,EAAQ,GAAK,GAAK,IAAM,IAAMI,EAAM,SAEjQvmE,MAAM,CACL,cAAe,SACf+jC,QAAS0sE,EAAWkC,YAAYkD,cAAgB,QAAU,SAC3DxlG,MAAK,SAAS/Q,EAAG+I,GAChB,OAAIA,GAAKooG,EAAWyC,WAAa,IAAM,EAAU,GAC7C7xC,EACOA,EAAM/hE,GAAKmxG,EAAWkC,YAAY0C,YAC/B/1G,EAAImxG,EAAWkC,YAAY0C,eAC1Cr1G,MAAMg0G,GACLvD,EAAWkC,YAAYmD,cAAcJ,EAAUrlG,MAAK,SAAS/Q,EAAG+I,GAChE,OAAIA,GAAKooG,EAAWyC,WAAa,IAAM,EAAU,GAC1CzC,EAAWkC,YAAYmD,aAAah2G,KAAKyqF,YAAaliF,MAEjE,IAAI0tG,EAAoB/2G,EAAGwF,IAAIqvG,EAAW9zG,UAAU,sBAAsB,GAAG+a,KAAI,SAASxb,EAAG+I,GACzF,OAAO/I,EAAE02G,SAAS97D,EAAI56C,EAAEs1G,UAAU1wG,UAEtC0vG,EAAgBjyG,KAAK,CACjBoT,UAAW,aAAe,CAAE88F,EAASkE,EAAmBtF,EAAW73D,OAAOtpC,KAAQ,MAEtF,IAAI2mG,GAAcrzF,EAAI/iB,OAAO,oBAAoBE,UAAU,KAAKsB,OAAS,EACrE60G,GAAoBtzF,EAAI/iB,OAAO,oBAAoBE,UAAU,cAAc4E,KAAKA,GAOpF,GANAuxG,GAAkBntG,QAAQC,OAAO,KAAKrH,KAAK,CACvC,MAAS,SAASrC,EAAG+I,GACjB,MAAO,oBAAsBA,KAGrC6tG,GAAkBrtG,OAAOC,SACrBnE,EAAK,IAAMsxG,GAAa,CACxB,IAAIE,GAAkB,GACtBxxG,EAAKY,SAAQ,SAASjG,EAAG+I,GACrB,IAAI+tG,EAAiB,GACrBA,EAAe9hC,YAAcA,EAC7B8hC,EAAe/hC,aAAeA,EAC9B+hC,EAAe32F,UAAYy2F,GAAkBr7D,QAAO,SAASw7D,EAAIC,GAC7D,OAAOA,GAAMjuG,KAEjB+tG,EAAetF,SAAWxxG,EAAEwxG,SAC5BsF,EAAe98F,YAAcm3F,EAAWn3F,YACxC88F,EAAe5qF,UAAYilF,EAAWjlF,UACtC4qF,EAAeztF,MAAQtgB,EACvB8tG,GAAgBxwG,KAAK,CACjBhB,KAAMrF,EACN82G,eAAgBA,OAGxB,IAAIG,GAAyBv3G,EAAGsyG,OAAO7pF,KAAI,SAASnoB,EAAG+I,GACnD,YAAgC,IAAlB/I,EAAEqF,KAAKysG,SAA0B,eAChDj+D,QAAQgjE,IACPK,GAA0B,GAC9BD,GAAuBhxG,SAAQ,SAASjG,EAAG+I,GACzB,cAAV/I,EAAEmoB,IAAqB+uF,GAA0BA,GAAwBx8F,OAAO1a,EAAE8/C,OAAOtkC,KAAI,SAASxb,EAAG+I,GACzG,MAAO,CAAE/I,OACHk3G,GAAwB7wG,KAAKrG,EAAE8/C,WAE7Co3D,GAAwBjxG,SAAQ,SAASjG,EAAG+I,GACxC,IAAIyoG,EACkBA,EAAlB1oG,MAAM+D,QAAQ7M,GAAeA,EAAE,GAAG82G,eAAetF,SAA0BxxG,EAAE82G,eAAetF,SAChG,IAAI2F,EAAsBn3G,EAAEwb,KAAI,SAASu7F,EAAIC,GACzC,OAAO7+E,EAAc44E,EAAES,GAAU2D,gBAAiB4B,MAEtDhG,EAAES,KAAY5+D,OAAOukE,EAArBpG,MAGR,IAcIqG,GAAcC,GAddC,GAASh0F,EAAI/iB,OAAO,iBACpBg3G,GAAmBj0F,EAAI/iB,OAAO,mBAC9Bi3G,GAAiBzG,EAAE0G,eAAe7kE,OAAO,CACzCzyB,UAAWo3F,GACXpnG,SAAU,GAFO4gG,GAIjB2G,GAAgB3G,EAAE0G,eAAe7kE,OAAO,CACxCzyB,UAAWo3F,GACXpnG,SAAU,GAFM4gG,GAIhB4G,GAAkB5G,EAAE0G,eAAe7kE,OAAO,CAC1CzyB,UAAWo3F,GACXK,SAAS,GAFS7G,GAKtB,IAAKiC,EAAW,CACZ,IAAI6E,GAAmBP,GAAO/2G,OAAO,QAAQ8B,KAAK,CAC9CiF,GAAI,EACJE,GAAI,EACJC,GAAI,IACL/G,MAAM,CACLG,OAAQ,OACR,iBAAkB,SAEtB0zG,EAAWloF,GAAG,2BAA2B,SAASrsB,EAAG+I,GACjD,IAAI+uG,EAAa/G,EAAEz7B,KAAKyiC,YAAYpC,GAAkB9uC,MACtDgxC,GAAiBx1G,KAAK,CAClBkF,IAAKgrG,EACL98F,UAAW,UAAYqiG,EAAa,MACrCp3G,MAAM,CACLsK,QAAS,KAEb,IAAIgtG,GAAyBF,EAAa,IAAM,IAAM3G,EAAWn3F,aAAe,IAChFo9F,GAAeriC,EAAakjC,OAAOD,GACnC,IAAIvmG,EAAMs/F,EAAEz7B,KAAK4iC,mBAAmB3F,EAAS,GAAIuF,EAAa,KAC9DN,GAAezmG,KAAKggG,EAAEz7B,KAAKjxE,MAAM+yG,KAAee,KAAK,CAAE1mG,EAAI,GAAKghG,EAAY,GAAIhhG,EAAI,GAAKghG,EAAY,QACtGpmF,GAAG,0BAA0B,SAASrsB,EAAG+I,GACxCuuG,GAAO/2G,OAAO,QAAQG,MAAM,CACxBsK,QAAS,OAIrB,IAAIotG,GAAqBd,GAAO/2G,OAAO,UAAUG,MAAM,CACnDG,OAAQ,OACRoB,KAAM,SAEVsyG,EAAWloF,GAAG,0BAA0B,SAASrsB,EAAG+I,GAChD,IAAIjC,EAAIiqG,EAAEz7B,KAAKyiC,YAAYpC,GAAkBpD,OAC7C6F,GAAmB/1G,KAAK,CACpByE,EAAGA,IACJpG,MAAM,CACLsK,QAAS,KAEbqsG,GAAcriC,EAAYijC,OAAOlH,EAAEz7B,KAAKyiC,YAAYpC,GAAkBpD,QACtE,IAAI9gG,EAAMs/F,EAAEz7B,KAAK4iC,mBAAmBpxG,EAAGqqG,EAAWyB,WAAW54F,aAC7D09F,GAAc3mG,KAAKggG,EAAEz7B,KAAKjxE,MAAMgzG,KAAcc,KAAK,CAAE1mG,EAAI,GAAKghG,EAAY,GAAIhhG,EAAI,GAAKghG,EAAY,QACpGpmF,GAAG,yBAAyB,SAASrsB,EAAG+I,GACvCqvG,GAAmB13G,MAAM,CACrBsK,QAAS,IAEb2sG,GAAgB1rC,OAChBurC,GAAevrC,OACfyrC,GAAczrC,UAElB3oD,EAAI7iB,UAAU,yBAAyB4rB,GAAG,qBAAqB,SAASrsB,EAAG+I,GACvE,IAAIY,EAAKjK,EAAGa,OAAOC,MACfM,EAAQN,KAAKE,MAAMuB,KACnBo2G,EAAW,QACXrtG,EAAUxK,KAAKE,MAAMsK,SAAW,EAIpC,GAHArB,EAAGtH,KAAK,CACJ,eAAgB2I,IAEhBlK,GAAmB,SAAVA,EAAkB,CAC3B6I,EAAGtH,KAAK,CACJ,YAAavB,IAEjBu3G,EAAW34G,EAAG44G,IAAIx3G,GAAO2wG,SAASvpF,WAClCve,EAAGjJ,MAAM,CACLuB,KAAMo2G,EACNrtG,QAAS,IAEb,IAAIutG,EAAW,CACXhhG,EAAGw5F,EAAEz7B,KAAKjxE,MAAMrE,EAAE,IAClB8G,EAAGiqG,EAAEz7B,KAAKjxE,MAAMrE,EAAE,KAElBgzG,IAAWuF,EAAShhG,EAAIwqD,EAAM/hE,EAAE,KACpC,IAAI+Q,EAAO,MAAQwnG,EAAShhG,EAAI,QAAUghG,EAASzxG,EAC/C00C,EAAOh7C,KAAKwV,wBACZuuE,EAAUjhE,EAAIvgB,OAAOiT,wBACrBvE,EAAM,CAAE+pC,EAAKjnC,KAAOinC,EAAK52C,MAAQ,EAAI2wG,EAAgB,GAAKhxB,EAAQhwE,KAAMinC,EAAKxrC,IAAMwrC,EAAKhnC,OAAS,EAAI+gG,EAAgB,GAAKhxB,EAAQv0E,KACtI2nG,GAAgB/kE,OAAO,CACnB9xC,MAAOu3G,IACRtnG,KAAKA,GACR4mG,GAAgBQ,KAAK1mG,QAErB3Q,EAAQN,KAAKE,MAAMG,QAAU,QAC7B8I,EAAGtH,KAAK,CACJ,cAAevB,IAEnBu3G,EAAW34G,EAAG44G,IAAIx3G,GAAO2wG,SAASvpF,WAClCve,EAAGjJ,MAAM,CACLG,OAAQw3G,EACRrtG,QAAS,OAGlBqhB,GAAG,qBAAqB,SAASrsB,EAAG+I,GACnC,GAAsB,GAAlBrJ,EAAGkuB,MAAM29D,MAAY,OAAO,EAC5B7rF,EAAGa,OAAOC,MAAM6B,KAAK,cAAcs1G,GAAgBvvC,UACxD/7C,GAAG,oBAAoB,SAASrsB,EAAG+I,GAClC4uG,GAAgB1rC,OAChB,IAAItiE,EAAKjK,EAAGa,OAAOC,MACfgL,EAAY7B,EAAGtH,KAAK,aACpBmJ,EAAW7B,EAAGjJ,MAAM,CACpBuB,KAAMuJ,EACNR,QAASrB,EAAGtH,KAAK,kBACZsH,EAAGjJ,MAAM,CACdG,OAAQ8I,EAAGtH,KAAK,eAChB2I,QAASrB,EAAGtH,KAAK,wBAO7BoyE,CAAOJ,GACA7zE,MAEXX,QAAQ+yC,OAAS,SAAS4lE,GACtB,IAAK11E,UAAUn8B,OAAQ,OAAOisC,EAC9B,IAAI6lE,EAAS1H,EAAEz7B,KAAKC,UAAUijC,GAQ9B,OAPAC,EAAOpzG,KAAKY,SAAQ,SAASjG,EAAG+I,GACvB6pC,EAAOvtC,KAAK0D,KAAI6pC,EAAOvtC,KAAK0D,GAAK,IACtCovB,EAAcya,EAAOvtC,KAAK0D,GAAIgoG,EAAEz8B,KAAK6gC,gBAAgB9vG,KAAK,IAC1D8yB,EAAcya,EAAOvtC,KAAK0D,GAAI/I,MAElCm4B,EAAcya,EAAOvtB,OAAQ0rF,EAAEz8B,KAAK6gC,gBAAgB9vF,QACpD8S,EAAcya,EAAOvtB,OAAQozF,EAAOpzF,QAC7B7kB,MAEXX,QAAQg1E,cAAgB,WACpB,OAAOq8B,GAEXrxG,QAAQ64G,eAAiB,WACrB,OAAOzH,GAEXpxG,QAAQm1E,YAAc,SAASwjC,GAC3B,OAAOxjC,GAEXn1E,QAAQk1E,aAAe,SAASyjC,GAC5B,OAAOzjC,GAEXl1E,QAAQyjB,IAAM,WACV,OAAOA,GAEX5jB,EAAGysF,OAAOtsF,QAAS6qF,EAAU,MACtB7qF,SAGXkxG,EAAEz8B,KAAK6gC,cAAgB,SAASn1G,EAAG+I,GAmE/B,MAlEa,CACT1D,KAAM,CAAE,CACJkS,EAAG,CAAE,EAAG,EAAG,EAAG,GACdzQ,EAAG,CAAE,GAAI,GAAI,GAAI,IACjByb,KAAM,QACNivF,SAAU,WACV1wG,MAAO,KACP4wG,WAAY,QACZH,YAAa,KACbI,WAAY,IACZqD,iBAAiB,EACjBhqG,QAAS,IAEbqa,OAAQ,CACJisF,kBAAmB5xG,EAAG4X,MAAMqhG,aAAap5F,QACzCg2B,MAAO,KACP/gC,OAAQ,IACR5P,MAAO,IACP00C,OAAQ,CACJtpC,IAAK,GACL2F,MAAO,GACP5F,OAAQ,GACRwE,KAAM,IAEV1S,KAAM,CACFE,KAAM,GACNjB,MAAO,OACP6zG,aAAc,QACd7yG,OAAQ,sBAEZoqB,UAAW,YACXlS,YAAa,EACbq8F,YAAa,GACbzD,WAAY,CACRttC,OAAQ,KACRtrD,aAAc,GACd+7F,YAAa,GACbjtF,SAAS,EACT2sF,kBAAkB,EAClBO,gBAAiB,aACjBQ,aAAc,MAElBnD,YAAa,CACT/tC,OAAQ,CAAE,EAAG,KACbywC,YAAa,GACbjtF,SAAS,EACT2sF,kBAAkB,EAClBc,eAAe,EACfP,gBAAiB,aACjBQ,aAAc,KACd/C,WAAY,KACZC,UAAW,MAEfE,WAAY,EACZuC,WAAY,KACZ1B,UAAW,SACXyB,eAAgB,OAChBN,gBAAiB,OACjBzC,gBAAiB,KACjByB,YAAY,EACZ1iE,OAAQ,CACJkjE,cAAc,GAElBpqG,QAAS,KAMrB+lG,EAAEz7B,KAAO,GAETy7B,EAAE8B,WAAa,aAEf9B,EAAE6H,KAAO,YAET7H,EAAE8H,KAAO,WAET9H,EAAE+H,IAAM,UAER/H,EAAEgI,IAAM,WAERhI,EAAEz7B,KAAK0jC,UAAY,SAASC,EAAOC,GAC/B,IAAK,IAAI/2G,KAAK82G,EAAW92G,KAAK+2G,IAAOA,EAAM/2G,GAAK82G,EAAM92G,KAG1D4uG,EAAEz7B,KAAK6jC,QAAU,SAASF,EAAOC,GAC7B,IAAK,IAAI/2G,KAAK82G,EAAOC,EAAM/2G,GAAK82G,EAAM92G,IAG1C4uG,EAAEz7B,KAAK8jC,QAAU,WACb,OAAuB,EAAhBh1G,KAAK43B,SAAe,GAAqB,EAAhB53B,KAAK43B,SAAe,IAAsB,EAAhB53B,KAAK43B,SAAe,IAGlF+0E,EAAEz7B,KAAK+jC,kBAAoB,SAASC,EAAWC,GAC3C,IAAI/4D,EAAO+4D,GAAS,EAMpB,OALW75G,EAAG6f,MAAM,EAAG,IAAMihC,EAAMA,GAAMhlC,KAAI,SAAS4tE,EAAK//D,GACvD,IAAImwF,EAAQpwB,EAAMhlF,KAAK64B,GAAK,IAE5B,MAAO,CAAEmsD,EADIkwB,EAAUE,QAM/BzI,EAAEz7B,KAAKmkC,iBAAmB,SAASH,EAAWC,EAAOx9F,GACjD,IAAIykC,EAAO+4D,GAAS,EAChBhiG,EAAI,GAAIzQ,EAAI,GAChBpH,EAAG6f,MAAM,EAAG,IAAMihC,EAAMA,GAAMv6C,SAAQ,SAASmjF,EAAK//D,GAChD,IAAImwF,EAAQpwB,EAAMhlF,KAAK64B,GAAK,IACxBs1E,EAAS+G,EAAUE,GACvBjiG,EAAElR,KAAK+iF,GACPtiF,EAAET,KAAKksG,MAEX,IAAIpqB,EAAS,CACT5wE,EAAGA,EACHzQ,EAAGA,GAGP,OADIiV,IAAOosE,EAAO5lE,KAAOxG,GAClBosE,GAGX4oB,EAAEz7B,KAAK5hD,YAAc,SAASgmF,EAAMC,GAChC,QAAoB,IAATD,EAAsB,OAAO,KACxC,IAAIl1F,EAAM,GAAG9J,OAAOg/F,GACpB,OAAOh6G,EAAG6f,MAAMo6F,GAAQn+F,KAAI,SAASxb,EAAG+I,GACpC,OAAOyb,EAAIzb,IAAMyb,EAAI,OAI7BusF,EAAEz7B,KAAKskC,WAAa,SAASC,EAAMC,EAAaH,GAI5C,OAHAG,EAAY7zG,SAAQ,SAASjG,EAAG+I,GAC5B8wG,EAAK75G,GAAK+wG,EAAEz7B,KAAK5hD,YAAYmmF,EAAK75G,GAAI25G,MAEnCE,GAGX9I,EAAEz7B,KAAKC,UAAY,SAAS9xD,GACxB,OAAOq8E,KAAKia,MAAMja,KAAKC,UAAUt8E,KAGrCstF,EAAEz7B,KAAK0kC,aAAe,SAASn5F,EAAK7a,GACZ,iBAATA,IAAmBA,EAAOA,EAAK0Q,MAAM,MAChD,IAAIgiC,EAAO1yC,EAAK2gE,QAChB,OAAO9lD,EAAI63B,MAAW1yC,EAAKW,QAAUszG,WAAWp5F,EAAI63B,GAAO1yC,KAG/D+qG,EAAEz7B,KAAK+8B,UAAY,SAAS9qF,EAAGlD,GAC3B,OAAO3kB,EAAGw6G,IAAI3yF,EAAGlD,GAAG7I,KAAI,SAASxb,EAAG+I,GAChC,OAAOrJ,EAAGy6G,IAAIn6G,OAItB+wG,EAAEz7B,KAAKo9B,UAAY,SAASnrF,GACxB,OAAOA,EAAEA,EAAE5gB,OAAS,IAGxBoqG,EAAEz7B,KAAK8kC,WAAa,SAAS7yF,EAAGlD,GAE5B,IADA,IAAItb,EAAI3E,KAAKc,IAAIqiB,EAAE5gB,OAAQ0d,EAAE1d,OAAQ,GAC9BoC,MAAO,GAAKwe,EAAExe,KAAOsb,EAAEtb,KAC9B,OAAc,IAAPA,GAGXgoG,EAAEz7B,KAAKq9B,aAAe,SAASnuF,GAE3B,IADA,IAAI1d,EAAI,IACAiqG,EAAEz7B,KAAK8kC,WAAWtzG,EAAG0d,IACzB1d,EAAI0d,EACJA,EAAM,GAAG9J,OAAOmoB,MAAM,GAAIre,GAE9B,OAAOA,GAGXusF,EAAEz7B,KAAK29B,YAAc,SAASzuF,GAC1B,OAAOA,EAAI+2B,QAAO,SAASv0C,EAAG+B,EAAGwe,GAC7B,OAAOA,EAAErgB,QAAQF,IAAM+B,MAI/BgoG,EAAEz7B,KAAK4iC,mBAAqB,SAAS3F,EAAQiH,GACzC,IAAIa,EAAeb,EAAQp1G,KAAK64B,GAAK,IAGrC,MAAO,CAFCs1E,EAASnuG,KAAK44B,IAAIq9E,GAClB9H,EAASnuG,KAAK0oC,IAAIutE,KAI9BtJ,EAAEz7B,KAAKjxE,MAAQ,SAASkxD,EAAQ+kD,GAC5B,IAAI1+E,EAAS0+E,GAAW,EACpB3iD,EAAOvzD,KAAKuO,IAAI,GAAIipB,GACxB,OAAOx3B,KAAKC,MAAMkxD,EAASoC,GAAQA,GAGvCo5C,EAAEz7B,KAAKyiC,YAAc,SAASwC,GAC1B,IAAIC,EAAW96G,EAAG+6G,MAAMF,EAAkBx3G,QACtC23G,EAASF,EAAS,GAClBG,EAASH,EAAS,GAClBC,EAAQ,GAMZ,OALAA,EAAMt4G,EAAIu4G,EACVD,EAAMr4G,EAAIu4G,EACVF,EAAMhpG,IAAM+oG,EACZC,EAAM5zC,MAAiD,KAAxCziE,KAAKw2G,MAAMD,EAAQD,GAAUt2G,KAAK64B,IAAY74B,KAAK64B,GAClEw9E,EAAMlI,OAASnuG,KAAKmiC,KAAKm0E,EAASA,EAASC,EAASA,GAC7CF,GAGX1J,EAAEz7B,KAAKulC,gBAAkB,SAASr2F,GAG9B,IAFA,IAAkBtD,EAAd45F,EAAU,GACVC,EAAO,GACFhyG,EAAI,EAAGJ,EAAM6b,EAAI7d,OAAQoC,EAAIJ,EAAKI,KACvCmY,EAAMsD,EAAIzb,MACC+xG,GACPA,EAAQ55F,KACR65F,EAAK75F,GAAO45F,EAAQ55F,IAEpB45F,EAAQ55F,GAAO,EAGvB,OAAO65F,GAGXhK,EAAEz7B,KAAK0lC,WAAa,SAASx2F,GACzB,OAAOze,OAAOC,KAAK+qG,EAAEz7B,KAAKulC,gBAAgBr2F,KAG9CusF,EAAEz7B,KAAK2lC,WAAa,SAASp6F,EAAKq6F,EAAcC,EAAc97D,GAC1D,GAAIA,EAAS,CACT,IAAI+7D,EAAmBD,EAAa37F,QACpC27F,EAAeD,EACfA,EAAeE,EAEnB,IAAIj6E,EAAQ+5E,EAAarsE,QAAO,SAASwsE,EAAeC,GACpD,QAA4B,IAAjBD,EAA8B,OAAOA,EAAcC,KAC/Dz6F,QACkB,IAAVsgB,IACX+5E,EAAarsE,QAAO,SAASwsE,EAAeC,EAAcjyF,GACtD,QAA4B,IAAjBgyF,EAEX,OADIhyF,IAAU6xF,EAAav0G,OAAS,UAAU00G,EAAcC,GACrDD,EAAcC,KACtBz6F,GACHs6F,EAAatsE,QAAO,SAASwsE,EAAeC,EAAcjyF,GAGtD,YAF2C,IAAhCgyF,EAAcC,KAA+BD,EAAcC,GAAgB,IAClFjyF,IAAU8xF,EAAax0G,OAAS,IAAG00G,EAAcC,GAAgBn6E,GAC9Dk6E,EAAcC,KACtBz6F,KAGPkwF,EAAEwK,UAAY,WACV,IAAI3oE,EAAS,CAAEm+D,EAAEwK,UAAUpG,iBACvBzqB,EAAWhrF,EAAGgrF,SAAS,SACvB8wB,EAAY,CACZC,MAAO,OACP52G,KAAM,CAAE,EAAG,GACXyxB,IAAK,CAAE,EAAG,IAGd,SAASz2B,UACL,IAAIi3G,EAAiBlkE,EAAO,GAAGkkE,eAC3B32F,EAAY22F,EAAe32F,UACP,iBAAbA,IAAuBA,EAAYzgB,EAAGa,OAAO4f,IACxDA,EAAUqhB,MAAMoR,GAAQ7yC,MAAK,SAASwjF,EAASv5D,GAC3C,IAAI0xF,IAAYn4B,EAAQ,GAAGl+E,KAAK+sG,OAC5B/sG,EAAOk+E,EAAQ/nE,KAAI,SAASxb,EAAG+I,GAC/B,OAAI2yG,EAAgBh8G,EAAGw6G,IAAIl6G,EAAEqF,KAAKkS,EAAE,GAAIvX,EAAEqF,KAAKyB,EAAE,GAAI9G,EAAEqF,KAAK+sG,OAAO,IAAiB1yG,EAAGw6G,IAAIl6G,EAAEqF,KAAKkS,EAAE,GAAIvX,EAAEqF,KAAKyB,EAAE,OAEjHiuE,EAAe+hC,EAAe/hC,aAC9B4mC,EAAY7E,EAAe9hC,YAAY1P,SAAS,GAChDs2C,EAAY,CAChB,IAAgB,SAAS57G,EAAG+I,EAAG8yG,GAC3B,IAAIC,EAAav4B,EAAQs4B,GAAIx2G,KACzB7C,EAAIs0G,EAAe9hC,YAAYh1E,EAAE,IAAM82G,EAAe9hC,YAAY,GAClE+mC,EAAWjF,EAAe9hC,YAAYh1E,EAAE,IAAM,GAC9CuC,EAAIu5G,EAAWE,SACnBt8G,EAAGa,OAAOC,MAAM6B,KAAK,CACjB,MAAS,WACTrC,EAAG,IAAM,CAAE,CAAEwC,EAAIu5G,GAAWx5G,EAAI,GAAK,CAAEC,EAAIu5G,EAAUx5G,EAAI,GAAK,CAAEw5G,EAAUx5G,EAAI,GAAK,CAAEw5G,GAAWx5G,EAAI,IAAM8G,KAAK,KAAO,IACtHoM,UAAW,SAASzV,EAAG+I,GACnB,MAAO,WAAa+tG,EAAe98F,YAAc+6D,EAAa/0E,EAAE,KAAO,SAInF47G,EAAUtlF,IAAM,SAASt2B,EAAG+I,EAAG8yG,GAC3B,IAAII,EAAcj8G,EAAE,GAAK,CAAEA,EAAE,GAAIA,EAAE,GAAKA,EAAE,IAAOA,EAC7CsL,EAAS5L,EAAG4jB,IAAIhY,SAASvJ,KAAKwhF,EAAQs4B,GAAIx2G,KAAK62G,SAAS1zG,KAAK+6E,EAAQs4B,GAAIx2G,KAAK0vG,QAArEr1G,CAA8EM,EAAG+I,GAC9FrJ,EAAGa,OAAOC,MAAM6B,KAAK,CACjB,MAAS,WACTrC,EAAGsL,EACHmK,UAAW,SAASzV,EAAG+I,GACnB,IAmHgBozG,EACpBh6G,EACAC,EArHQysG,GAmHYsN,EAR5B,SAA6Bn8G,EAAG+I,GAC5B,IAAIjC,EAAIgwG,EAAe9hC,YAAYh1E,EAAE,IACjCuX,GAAKu/F,EAAe/hC,aAAa/0E,EAAE,IAAM82G,EAAe98F,aAAe5V,KAAK64B,GAAK,IACrF,MAAO,CACHn2B,EAAGA,EACHyQ,EAAGA,GAhHgC6kG,CAAoBH,GAoHvD95G,EAAIg6G,EAAiBr1G,EAAI1C,KAAK44B,IAAIm/E,EAAiB5kG,GACnDnV,EAAI+5G,EAAiBr1G,EAAI1C,KAAK0oC,IAAIqvE,EAAiB5kG,GAChD,CACHpV,EAAGA,EACHC,EAAGA,IAvHC,MAAO,aAAe,CAAEysG,EAAM1sG,EAAG0sG,EAAMzsG,GAAM,QAIzD,IAAIsC,EAAOhF,EAAG4jB,IAAI5e,KAAKoD,SAASu0G,YAAY94B,EAAQ,GAAGl+E,KAAKi3G,mBAAmB/J,QAAO,SAASvyG,GAC3F,OAAO82G,EAAe9hC,YAAYh1E,EAAE,OACrC6mE,OAAM,SAAS7mE,GACd,OAAO82G,EAAe/hC,aAAa/0E,EAAE,IAAMoE,KAAK64B,GAAK,OAEzD2+E,EAAUl3G,KAAO,SAAS1E,EAAG+I,EAAG8yG,GAC5B,IAAIU,EAAWv8G,EAAE,GAAKqF,EAAKw2G,GAAIrgG,KAAI,SAASxb,EAAG+I,GAC3C,MAAO,CAAE/I,EAAE,GAAIA,EAAE,GAAKA,EAAE,OACvBqF,EAAKw2G,GASV,GARAn8G,EAAGa,OAAOC,MAAMT,KAAK67G,EAAe,KAAGl7G,MAAM,CACzCsK,QAAS,SAAS+rG,EAAIC,GAClB,OAAQzzB,EAAQs4B,GAAIx2G,KAAKm3G,YAE7Bv6G,KAAMw6G,EAAU57G,OAAOb,EAAG+I,EAAG8yG,KAC9Bx5G,KAAK,CACJ,MAAS,eAET0G,EAAI,GAAR,CACA,IAAI2zG,EAAgBh9G,EAAGa,OAAOC,KAAK2J,YAAY1J,UAAU,aAAa4E,KAAK,CAAE,IAC7Eq3G,EAAcjzG,QAAQ2hC,OAAO,QAC7BsxE,EAAcr6G,KAAK,CACf,MAAS,OACTrC,EAAG0E,EAAK63G,GACR9mG,UAAW,SAASshG,EAAIC,GACpB,MAAO,WAAaF,EAAe98F,YAAc,IAAM,KAE3D,iBAAkB,SACnBtZ,MAAM,CACLuB,KAAM,SAAS80G,EAAIC,GACf,OAAOyF,EAAUx6G,KAAKjC,EAAG+I,EAAG8yG,IAEhC,eAAgB,EAChBh7G,OAAQ,SAASk2G,EAAIC,GACjB,OAAOyF,EAAU57G,OAAOb,EAAG+I,EAAG8yG,IAElC,eAAgB,SAAS9E,EAAIC,GACzB,OAAOyF,EAAU,gBAAgBz8G,EAAG+I,EAAG8yG,IAE3C,mBAAoB,SAAS9E,EAAIC,GAC7B,OAAOyF,EAAU,oBAAoBz8G,EAAG+I,EAAG8yG,IAE/C7wG,QAAS,SAAS+rG,EAAIC,GAClB,OAAOyF,EAAUzxG,QAAQhL,EAAG+I,EAAG8yG,IAEnCp3E,QAAS,SAASsyE,EAAIC,GAClB,OAAOyF,EAAUh4E,QAAQzkC,EAAG+I,EAAG8yG,QAI3C,IAAIc,EAAe7F,EAAe/hC,aAAax1D,QAC3Cq9F,EAAgBx4G,KAAK6/B,IAAI04E,EAAa,GAAKA,EAAa,IAAMt3G,EAAK,GAAGsB,OAASvC,KAAK64B,GAAK,IACzF4/E,EAAMn9G,EAAG4jB,IAAIu5F,MAAMC,YAAW,SAAS98G,GACvC,OAAQ48G,EAAgB,KACzBG,UAAS,SAAS/8G,GACjB,OAAO48G,EAAgB,KACxBI,aAAY,SAASh9G,GACpB,OAAO82G,EAAe9hC,YAAY2mC,GAAa37G,EAAE,IAAM,OACxDi9G,aAAY,SAASj9G,GACpB,OAAO82G,EAAe9hC,YAAY2mC,GAAa37G,EAAE,IAAM,IAAM82G,EAAe9hC,YAAYh1E,EAAE,OAE9F47G,EAAUiB,IAAM,SAAS78G,EAAG+I,EAAG8yG,GAC3Bn8G,EAAGa,OAAOC,MAAM6B,KAAK,CACjB,MAAS,WACTrC,EAAG68G,EACHpnG,UAAW,SAASzV,EAAG+I,GACnB,MAAO,WAAa+tG,EAAe98F,YAAc+6D,EAAa/0E,EAAE,IAAM,IAAM,QAIxF,IAAIy8G,EAAY,CACZx6G,KAAM,SAASjC,EAAG+I,EAAG8yG,GACjB,OAAOt4B,EAAQs4B,GAAIx2G,KAAKvE,OAE5BD,OAAQ,SAASb,EAAG+I,EAAG8yG,GACnB,OAAOt4B,EAAQs4B,GAAIx2G,KAAKksG,aAE5B,eAAgB,SAASvxG,EAAG+I,EAAG8yG,GAC3B,OAAOt4B,EAAQs4B,GAAIx2G,KAAKssG,WAAa,MAEzC,mBAAoB,SAAS3xG,EAAG+I,EAAG8yG,GAC/B,OAAOL,EAAUj4B,EAAQs4B,GAAIx2G,KAAKqsG,aAEtC1mG,QAAS,SAAShL,EAAG+I,EAAG8yG,GACpB,OAAOt4B,EAAQs4B,GAAIx2G,KAAK2F,SAE5By5B,QAAS,SAASzkC,EAAG+I,EAAG8yG,GACpB,YAA2C,IAA7Bt4B,EAAQs4B,GAAIx2G,KAAKyjB,SAA2By6D,EAAQs4B,GAAIx2G,KAAKyjB,QAAU,QAAU,SAGnGo0F,EAAgBx9G,EAAGa,OAAOC,MAAMC,UAAU,WAAW4E,KAAKA,GAC9D63G,EAAczzG,QAAQC,OAAO,KAAKrH,KAAK,CACnC,MAAS,UAEb,IAAImvG,EAAW0L,EAAcz8G,UAAU,aAAa4E,MAAK,SAASrF,EAAG+I,GACjE,OAAO/I,KAEXwxG,EAAS/nG,QAAQC,OAAO,QAAQrH,KAAK,CACjC,MAAS,SAEbmvG,EAAS9wG,MAAM+7G,GAAW18G,KAAK67G,EAAU9E,EAAeqG,eACxD3L,EAASjoG,OAAOC,SAChB0zG,EAAc3zG,OAAOC,YAgC7B,OAbA3J,QAAQ+yC,OAAS,SAAS4lE,GACtB,OAAK11E,UAAUn8B,QACf6xG,EAAGvyG,SAAQ,SAASjG,EAAG+I,GACd6pC,EAAO7pC,KAAI6pC,EAAO7pC,GAAK,IAC5BovB,EAAcya,EAAO7pC,GAAIgoG,EAAEwK,UAAUpG,iBACrCh9E,EAAcya,EAAO7pC,GAAI/I,MAEtBQ,MANuBoyC,GAQlC/yC,QAAQu9G,cAAgB,aAGxB19G,EAAGysF,OAAOtsF,QAAS6qF,EAAU,MACtB7qF,SAGXkxG,EAAEwK,UAAUpG,cAAgB,WA8BxB,MA7Ba,CACT9vG,KAAM,CACFkd,KAAM,QACNhL,EAAG,CAAE,CAAE,EAAG,EAAG,EAAG,IAChBzQ,EAAG,CAAE,CAAE,EAAG,EAAG,EAAG,IAChBiuG,QAAS,SACTmH,QAAS,GACTM,YAAY,EACZR,SAAU,GACVl7G,MAAO,UACP6wG,WAAY,EACZJ,YAAa,SACbG,WAAY,QACZ1mG,QAAS,EACTqe,MAAO,EACPP,SAAS,EACTksF,iBAAiB,GAErB8B,eAAgB,CACZtF,SAAU,WACV2L,aAAc,MACdjxF,UAAW,YACXlS,YAAa,EACbmG,UAAW,OACX60D,YAAa,KACbD,aAAc,KACdsoC,WAAY39G,EAAG4X,MAAMgmG,gBAMjCvM,EAAEwM,SAAW,WACT,OAAOxM,EAAEwK,aAGbxK,EAAEwM,SAASpI,cAAgB,WAMvB,MALa,CACT2B,eAAgB,CACZqG,aAAc,SAM1BpM,EAAEyM,UAAY,WACV,OAAOzM,EAAEwK,aAGbxK,EAAEyM,UAAUrI,cAAgB,WAMxB,MALa,CACT2B,eAAgB,CACZqG,aAAc,SAM1BpM,EAAE0M,QAAU,WACR,OAAO1M,EAAEwK,aAGbxK,EAAE0M,QAAQtI,cAAgB,WAOtB,MANa,CACT2B,eAAgB,CACZqG,aAAc,MACdpI,QAAS,YAMrBhE,EAAE2M,SAAW,WACT,OAAO3M,EAAEwK,aAGbxK,EAAE2M,SAASvI,cAAgB,WAMvB,MALa,CACT2B,eAAgB,CACZqG,aAAc,UAM1BpM,EAAEkE,OAAS,WACP,IAAIriE,EAASm+D,EAAEkE,OAAOE,gBAClBzqB,EAAWhrF,EAAGgrF,SAAS,SAC3B,SAAS7qF,UACL,IAAIq1G,EAAetiE,EAAOsiE,aACtByI,EAAc/qE,EAAOvtC,KAAKmW,KAAI,SAASxb,EAAG+I,GAC1C,MAAO,GAAG2R,OAAO1a,GAAGwb,KAAI,SAASu7F,EAAIC,GACjC,IAAI1gG,EAAU6hB,EAAc,GAAI+8E,EAAaL,SAAS9rG,IAGtD,OAFAuN,EAAQiM,KAAOw0F,EACfzgG,EAAQxV,MAAQ,GAAG4Z,OAAOw6F,EAAaL,SAAS9rG,GAAGjI,OAAOk2G,GACnD1gG,QAGXjR,EAAO3F,EAAG4yG,MAAMqL,GACpBt4G,EAAOA,EAAKk2C,QAAO,SAASv7C,EAAG+I,GAC3B,OAAOmsG,EAAaL,SAAS9rG,KAAOmsG,EAAaL,SAAS9rG,GAAGisG,sBAAuE,IAA7CE,EAAaL,SAAS9rG,GAAGisG,oBAEhHE,EAAaE,eAAc/vG,EAAOA,EAAKg6C,WAC3C,IAAIl/B,EAAY+0F,EAAa/0F,WACL,iBAAbA,GAAyBA,EAAUnd,YAAUmd,EAAYzgB,EAAGa,OAAO4f,IAC9E,IAAIy9F,EAASv4G,EAAKmW,KAAI,SAASxb,EAAG+I,GAC9B,OAAO/I,EAAEc,SAETw0C,EAAa4/D,EAAa/kG,SAC1B0tG,EAA4C,MAA7B3I,EAAa2I,aAA0C,iBAAZx4G,EAAK,GAAkB6vG,EAAa2I,aAC9FrpG,EAASqpG,EAAe3I,EAAa1gG,OAAS8gC,EAAajwC,EAAKsB,OAEhE2c,EADuBnD,EAAU6L,QAAQ,gBAAgB,GAC9BvrB,UAAU,OAAO4E,KAAK,CAAE,IACnDy4G,EAAWx6F,EAAI7Z,QAAQC,OAAO,OAAOrH,KAAK,CAC1CuC,MAAO,IACP4P,OAAQA,EAAS8gC,EACjBuW,MAAO,6BACP,cAAe,+BACfmlD,QAAS,QAEb8M,EAASp0G,OAAO,KAAKsiB,QAAQ,eAAe,GAC5C8xF,EAASp0G,OAAO,KAAKsiB,QAAQ,gBAAgB,GAC7C,IAAI+xF,EAAer+G,EAAG6f,MAAMla,EAAKsB,QAC7B02G,EAAa39G,EAAG4X,MAAMumG,EAAe,SAAW,aAAav4C,OAAOy4C,GAAcx+F,MAAMq+F,GACxFI,EAAYt+G,EAAG4X,MAAMumG,EAAe,SAAW,aAAav4C,OAAOy4C,GAAcF,EAAe,QAAU,eAAe,CAAE,EAAGrpG,IAOlI,GAAIqpG,EAAc,CACd,IAAIv1G,EAAWgb,EAAI/iB,OAAO,iBAAiBmJ,OAAO,QAAQA,OAAO,kBAAkBrH,KAAK,CACpF4+B,GAAI,QACJ35B,GAAI,KACJE,GAAI,KACJD,GAAI,KACJE,GAAI,SACLhH,UAAU,QAAQ4E,KAAKu4G,GAC1Bt1G,EAASmB,QAAQC,OAAO,QACxBpB,EAASjG,KAAK,CACVyH,OAAQ,SAAS9J,EAAG+I,GAChB,OAAOA,GAAK60G,EAAOj3G,OAAS,GAAK,IAAM,OAE5CjG,MAAM,CACL,aAAc,SAASV,EAAG+I,GACtB,OAAO/I,KAGfsjB,EAAI5Z,OAAO,QAAQsiB,QAAQ,eAAe,GAAM3pB,KAAK,CACjDmS,OAAQ0gG,EAAa1gG,OACrB5P,MAAOswG,EAAa+I,eACpBh8G,KAAM,oBAEP,CACH,IAAIi8G,EAAgB56F,EAAI/iB,OAAO,iBAAiBE,UAAU,oBAAoB4E,KAAKA,GACnF64G,EAAcz0G,QAAQC,OAAO,QAAQsiB,QAAQ,eAAe,GAC5DkyF,EAAc77G,KAAK,CACfoT,UAAW,SAASzV,EAAG+I,GACnB,MAAO,aAAe,CAAEusC,EAAa,EAAG0oE,EAAUj1G,GAAKusC,EAAa,GAAM,KAE9Et1C,EAAG,SAASA,EAAG+I,GACX,IArCkBo1G,EAAOhtF,EAC7BitF,EAoCQC,EAAar+G,EAAEsL,OACnB,OArCJ8yG,EAAqB,GADQjtF,EAsCSmkB,GApC5B,UAFY6oE,EAsCIE,GAnCnB,IAAM,CAAE,EAAGltF,EAAQ,GAAIA,EAAQ,IAAM,CAAEA,EAAQ,GAAIA,EAAQ,IAAM,CAAEA,EAAQ,EAAGA,EAAQ,IAAM,EAAGA,EAAQ,EAAGA,EAAQ,KAAS,KACrF,GAAtCzxB,EAAG4jB,IAAIg7F,YAAYp3G,QAAQi3G,GAAqBz+G,EAAG4jB,IAAIhY,SAAS9C,KAAK21G,GAAOp8G,KAAKq8G,EAAjC1+G,GAA4DA,EAAG4jB,IAAIhY,SAAS9C,KAAK,UAAUzG,KAAKq8G,EAApC1+G,IAoCnHuC,KAAM,SAASjC,EAAG+I,GACd,OAAOs0G,EAAWt0G,MAG1Bm1G,EAAc30G,OAAOC,SAEzB,IAAI+0G,EAAa7+G,EAAG4jB,IAAIsrF,OAAOt3F,MAAM0mG,GAAW1H,OAAO,SACnD1H,EAAOtrF,EAAI/iB,OAAO,iBAAiB8B,KAAK,CACxCoT,UAAW,aAAe,CAAEooG,EAAe3I,EAAa+I,eAAiB3oE,EAAYA,EAAa,GAAM,MACzG10C,KAAK29G,GAeR,OAdA3P,EAAKnuG,UAAU,WAAWC,MAAM,CAC5BuB,KAAM,OACNpB,OAAQ,SAEZ+tG,EAAKnuG,UAAU,QAAQC,MAAM,CACzBuB,KAAM,OACNpB,OAAQg9G,EAAe3I,EAAasJ,UAAY,SAEpD5P,EAAKnuG,UAAU,QAAQC,MAAM,CACzBuB,KAAMizG,EAAasJ,UACnB,YAAatJ,EAAa/kG,WAC3BY,MAAK,SAAS/Q,EAAG+I,GAChB,OAAO1D,EAAK0D,GAAGwZ,QAEZ1iB,QAQX,OANAA,QAAQ+yC,OAAS,SAAS4lE,GACtB,OAAK11E,UAAUn8B,QACfwxB,EAAcya,EAAQ4lE,GACfh4G,MAFuBoyC,GAIlClzC,EAAGysF,OAAOtsF,QAAS6qF,EAAU,MACtB7qF,SAGXkxG,EAAEkE,OAAOE,cAAgB,SAASn1G,EAAG+I,GAuBjC,MAtBa,CACT1D,KAAM,CAAE,IAAK,IAAK,KAClB6vG,aAAc,CACVL,SAAU,CAAE,CACRvpG,OAAQ,OACRxK,MAAO,OACR,CACCwK,OAAQ,SACRxK,MAAO,UACR,CACCwK,OAAQ,UACRxK,MAAO,cAEX0T,OAAQ,IACRypG,eAAgB,GAChB9tG,SAAU,GACVgQ,UAAW,OACX09F,aAAc,KACdW,UAAW,OACXpJ,cAAc,KAM1BrE,EAAE0G,aAAe,WACb,IAAIgH,EAAWC,EAAeC,EAC1B/rE,EAAS,CACTzyB,UAAW,KACXy3F,SAAS,EACTznG,SAAU,GACVrP,MAAO,QACPiqF,QAAS,GAET9pD,EAAK,WAAa8vE,EAAE0G,aAAazqG,MACjC8oG,EAAW,GACXj2G,QAAU,WAEV,IAAI++G,GADJH,EAAY7rE,EAAOzyB,UAAU1f,UAAU,KAAOwgC,GAAI57B,KAAK,CAAE,KAC5BoE,QAAQC,OAAO,KAAKsiB,QAAQiV,GAAI,GAAMvgC,MAAM,CACrE,iBAAkB,OAClB+jC,QAAS,SAYb,OAVAk6E,EAAeC,EAAal1G,OAAO,QAAQhJ,MAAM,CAC7CuB,KAAM,QACN,eAAgB,KACjBI,KAAK,CACJrC,EAAG,SAEP0+G,EAAgBE,EAAal1G,OAAO,QAAQrH,KAAK,CAC7CmO,GAAIoiC,EAAOm4C,QAAU+qB,EACrBrlG,GAAuB,IAAlBmiC,EAAOziC,WAETtQ,SA0DX,OAxDAA,QAAQkR,KAAO,SAAS65B,GACpB,IAAIpf,EAAI9rB,EAAG44G,IAAI1lE,EAAO9xC,OAAO0qB,EACzB+lF,EAAc/lF,GAAK,GAAK,OAAS,QACjChgB,EAAYggB,GAAK,GAAK,QAAU,QAChCza,EAAO65B,GAAS,GACpB8zE,EAAch+G,MAAM,CAChBuB,KAAMuJ,EACN,YAAaonC,EAAOziC,SAAW,OAChCY,KAAKA,GACR,IAAIg6E,EAAUn4C,EAAOm4C,QACjBvvC,EAAOkjE,EAAc37G,OAAOuyG,UAC5BuJ,EAAW,CACX58G,KAAM2wC,EAAO9xC,MACbD,OAAQ0wG,EACR,eAAgB,OAEhBuN,EAActjE,EAAK52C,MAAkB,EAAVmmF,EAAc+qB,EACzCiJ,EAAcvjE,EAAKhnC,OAAmB,EAAVu2E,EAUhC,OATA4zB,EAAat8G,KAAK,CACdrC,EAAG,IAAM,CAAE,CAAE81G,GAAWiJ,EAAc,GAAK,CAAEjJ,GAAWiJ,EAAc,GAAK,CAAEnsE,EAAOglE,QAAU,EAAI9B,EAAU,GAAK,CAAEA,EAAUiJ,EAAc,GAAK,CAAEjJ,EAAUiJ,EAAc,GAAK,CAAED,EAAaC,EAAc,GAAK,CAAED,GAAcC,EAAc,IAAM11G,KAAK,KAAO,MAClQ3I,MAAMm+G,GACTJ,EAAUp8G,KAAK,CACXoT,UAAW,aAAe,CAAEqgG,GAAWiJ,EAAc,EAAc,EAAVh0B,GAAgB,MAE7E0zB,EAAU/9G,MAAM,CACZ+jC,QAAS,UAEN5kC,SAEXA,QAAQs4G,KAAO,SAAS6G,GACpB,GAAKP,EAML,OALAA,EAAUp8G,KAAK,CACXoT,UAAW,aAAe,CAAEupG,EAAK,GAAIA,EAAK,IAAO,MAClDt+G,MAAM,CACL+jC,QAAS,UAEN5kC,SAEXA,QAAQosE,KAAO,WACX,GAAKwyC,EAIL,OAHAA,EAAU/9G,MAAM,CACZ+jC,QAAS,SAEN5kC,SAEXA,QAAQuoE,KAAO,WACX,GAAKq2C,EAIL,OAHAA,EAAU/9G,MAAM,CACZ+jC,QAAS,UAEN5kC,SAEXA,QAAQ+yC,OAAS,SAAS4lE,GAEtB,OADArgF,EAAcya,EAAQ4lE,GACf34G,SAEJA,SAGXkxG,EAAE0G,aAAazqG,IAAM,EAErB+jG,EAAEx8B,QAAU,GAEZw8B,EAAEx8B,QAAQC,OAAS,WACf,IAAI30E,QAAU,CACd,QAAkB,SAASu0E,EAAc/0B,GACrC,IAAI4/D,EAAe,GACnB,GAAI7qC,EAAa/uE,OACb45G,EAAa55G,KAAO+uE,EAAa/uE,KAAKmW,KAAI,SAASxb,EAAG+I,GAClD,IAAIjC,EAAIqxB,EAAc,GAAIn4B,GAyC1B,MAxCkB,CACd,CAAE8G,EAAG,CAAE,SAAU,SAAW,CAAE,UAC9B,CAAEA,EAAG,CAAE,SAAU,WAAa,CAAE,YAChC,CAAEA,EAAG,CAAE,SAAU,OAAQ,SAAW,CAAE,gBACtC,CAAEA,EAAG,CAAE,SAAU,OAAQ,QAAU,CAAE,eACrC,CAAEA,EAAG,CAAE,SAAU,OAAQ,SAAW,CAAE,eACtC,CAAEA,EAAG,CAAE,SAAU,UAAY,CAAE,YAC/B,CAAEA,EAAG,CAAE,SAAU,QAAU,CAAE,YAC7B,CAAEA,EAAG,CAAE,SAAU,YAAc,CAAE,aACjC,CAAEA,EAAG,CAAE,OAAQ,iBAAmB,CAAE,sBACpC,CAAEA,EAAG,CAAE,cAAgB,CAAE,qBAEjBb,SAAQ,SAASjG,EAAG+I,GAC5BgoG,EAAEz7B,KAAK2lC,WAAWp4E,MAAM,KAAM7iC,EAAE0a,OAAO2kC,OAGtCA,UAAgBv4C,EAAE6D,OACnB00C,UAAgBv4C,EAAEgrG,QACjBzyD,GAUkB,aAAfv4C,EAAE0qG,UACF1qG,EAAE0B,KAAO,WACY,IAAjB1B,EAAE01G,mBACK11G,EAAE01G,WACT11G,EAAEilE,KAAO,iBACNjlE,EAAEilE,KAAO,SACM,YAAfjlE,EAAE0qG,UACT1qG,EAAE0B,KAAO,UACT1B,EAAEilE,KAAO,WACa,cAAfjlE,EAAE0qG,SAA0B1qG,EAAE0B,KAAO,OAAgC,aAAf1B,EAAE0qG,WAAyB1qG,EAAE0B,KAAO,cAC9F1B,EAAE0qG,WAnBM,YAAX1qG,EAAE0B,KACa,UAAX1B,EAAEilE,KAAkBjlE,EAAE0qG,SAAW,WAAgC,YAAX1qG,EAAEilE,KAAoBjlE,EAAE0qG,SAAW,UAA+B,kBAAX1qG,EAAEilE,OAC/GjlE,EAAE0qG,SAAW,WACb1qG,EAAE01G,YAAa,GAED,SAAX11G,EAAE0B,KAAiB1B,EAAE0qG,SAAW,YAAiC,QAAX1qG,EAAE0B,OAAgB1B,EAAE0qG,SAAW,mBACzF1qG,EAAEilE,YACFjlE,EAAE0B,MAcN1B,MAENu4C,GAAW+0B,EAAa/uD,QAA0C,UAAhC+uD,EAAa/uD,OAAO65F,SAAqB,CAC5E,IAAIlE,EAAajK,EAAEz7B,KAAK0lC,WAAWiE,EAAa55G,KAAKmW,KAAI,SAASxb,EAAG+I,GACjE,OAAO/I,EAAEwxG,aAEbyN,EAAa55G,KAAKY,SAAQ,SAASjG,EAAG+I,GAClC,IAAI04B,EAAMu5E,EAAW9zG,QAAQlH,EAAEwxG,WACnB,GAAR/vE,IAAWw9E,EAAa55G,KAAK0D,GAAG+oG,QAAUrwE,MAI1D,GAAI2yC,EAAa/uD,OAAQ,CACrB,IAAIve,EAAIqxB,EAAc,GAAIi8C,EAAa/uD,QAyDvC,GAxDkB,CACd,CAAEve,EAAG,CAAE,gBAAkB,CAAE,oBAC3B,CAAEA,EAAG,CAAE,cAAgB,CAAE,eACzB,CAAEA,EAAG,CAAE,cAAgB,CAAE,eACzB,CAAEA,EAAG,CAAE,eAAiB,CAAE,gBAC1B,CAAEA,EAAEo9F,YAAa,CAAE,YAAc,CAAE,qBACnC,CAAEp9F,EAAEo9F,YAAa,CAAE,kBAAoB,CAAE,kBACzC,CAAEp9F,EAAEo9F,YAAa,CAAE,UAAY,CAAE,eACjC,CAAEp9F,EAAEo9F,YAAa,CAAE,mBAAqB,CAAE,oBAC1C,CAAEp9F,EAAEo9F,YAAa,CAAE,cAAgB,CAAE,gBACrC,CAAEp9F,EAAEo9F,YAAa,CAAE,SAAW,CAAE,WAChC,CAAEp9F,EAAEo9F,YAAa,CAAE,cAAgB,CAAE,eACrC,CAAEp9F,EAAEm9F,WAAY,CAAE,YAAc,CAAE,qBAClC,CAAEn9F,EAAEm9F,WAAY,CAAE,mBAAqB,CAAE,oBACzC,CAAEn9F,EAAEm9F,WAAY,CAAE,cAAgB,CAAE,gBACpC,CAAEn9F,EAAEm9F,WAAY,CAAE,SAAW,CAAE,WAC/B,CAAEn9F,EAAEusG,YAAa,CAAE,YAAc,CAAE,qBACnC,CAAEvsG,EAAEusG,YAAa,CAAE,kBAAoB,CAAE,kBACzC,CAAEvsG,EAAEusG,YAAa,CAAE,UAAY,CAAE,eACjC,CAAEvsG,EAAEusG,YAAa,CAAE,mBAAqB,CAAE,oBAC1C,CAAEvsG,EAAEusG,YAAa,CAAE,cAAgB,CAAE,gBACrC,CAAEvsG,EAAEusG,YAAa,CAAE,SAAW,CAAE,WAChC,CAAEvsG,EAAEusG,YAAa,CAAE,cAAgB,CAAE,eACrC,CAAEvsG,EAAE8rG,WAAY,CAAE,YAAc,CAAE,qBAClC,CAAE9rG,EAAE8rG,WAAY,CAAE,mBAAqB,CAAE,oBACzC,CAAE9rG,EAAE8rG,WAAY,CAAE,cAAgB,CAAE,gBACpC,CAAE9rG,EAAE8rG,WAAY,CAAE,SAAW,CAAE,WAC/B,CAAE9rG,EAAEjF,KAAM,CAAE,gBAAkB,CAAE,iBAChC,CAAEiF,EAAEorC,OAAQ,CAAE,cAAgB,CAAE,iBAChC,CAAEprC,EAAG,CAAE,eAAiB,CAAE,gBAC1B,CAAEA,EAAG,CAAE,qBAAuB,CAAE,uBAExBb,SAAQ,SAASjG,EAAG+I,GAC5BgoG,EAAEz7B,KAAK2lC,WAAWp4E,MAAM,KAAM7iC,EAAE0a,OAAO2kC,OAGtCA,QAI2B,IAAjBv4C,EAAEqvG,aACTrvG,EAAEo9F,YAAYt/B,QAAU99D,EAAEqvG,kBACnBrvG,EAAEqvG,YAETrvG,EAAE2tG,YACF3tG,EAAEo9F,YAAYv8B,UAAY7gE,EAAE2tG,iBACrB3tG,EAAE2tG,aATT3tG,EAAEusG,kBAAgD,IAA1BvsG,EAAEusG,YAAYzuC,UAAyB99D,EAAEqvG,WAAarvG,EAAEusG,YAAYzuC,SAC5F99D,EAAEusG,kBAAkD,IAA5BvsG,EAAEusG,YAAY1rC,YAA2B7gE,EAAE2tG,UAAY3tG,EAAEusG,YAAY1rC,YAWjG7gE,EAAEorC,QAA0C,kBAAzBprC,EAAEorC,OAAOkjE,eAC5BtuG,EAAEorC,OAAOkjE,aAAwC,UAAzBtuG,EAAEorC,OAAOkjE,cAEjCtuG,EAAEorC,QAAwC,kBAAvBprC,EAAEorC,OAAOitE,aAC5Br4G,EAAEorC,OAAOitE,WAAar4G,EAAEorC,OAAOitE,WAAa,WAAa,gBAClDr4G,EAAEorC,OAAOkjE,cAEhBtuG,EAAEwyC,aAA+B,IAAdxyC,EAAEwyC,OAAO/hC,EAAkB,CAC9C,IAAI4+D,EAAS,CAAE,IAAK,IAAK,IAAK,IAAK,OAC/B12C,EAAS,CAAE,MAAO,QAAS,SAAU,OAAQ,OAC7C6Z,EAAS,GACb55C,EAAGm0C,QAAQ/sC,EAAEwyC,QAAQrzC,SAAQ,SAAS8wG,EAAIC,GACtC19D,EAAO7Z,EAAO02C,EAAOjvE,QAAQ6vG,EAAG5uF,OAAS4uF,EAAG51E,SAEhDr6B,EAAEwyC,OAASA,EAEX+F,WACOv4C,EAAEqsG,uBACFrsG,EAAEovG,sBACFpvG,EAAE8sG,kBACF9sG,EAAEo9F,YAAYuP,kBACd3sG,EAAEo9F,YAAYuP,kBACd3sG,EAAEo9F,YAAYwP,iBACd5sG,EAAEo9F,YAAYsS,oBACd1vG,EAAEo9F,YAAYxxC,cACd5rD,EAAEm9F,WAAWwP,kBACb3sG,EAAEm9F,WAAWwP,kBACb3sG,EAAEm9F,WAAWyP,iBACb5sG,EAAEm9F,WAAWuS,oBACb1vG,EAAEm9F,WAAWvxC,QAExBusD,EAAa55F,OAASve,EAE1B,OAAOm4G,IAEX,OAAOp/G,U,4CCj3CX,IAOIu/G,EAPAC,EAAuB,iBAAZC,QAAuBA,QAAU,KAC5CC,EAAeF,GAAwB,mBAAZA,EAAEx8E,MAC7Bw8E,EAAEx8E,MACF,SAAsBpD,EAAQ+/E,EAAUtxF,GACxC,OAAOuxF,SAASC,UAAU78E,MAAMjiC,KAAK6+B,EAAQ+/E,EAAUtxF,IAKzDkxF,EADEC,GAA0B,mBAAdA,EAAEM,QACCN,EAAEM,QACV55G,OAAO65G,sBACC,SAAwBngF,GACvC,OAAO15B,OAAO85G,oBAAoBpgF,GAC/B/kB,OAAO3U,OAAO65G,sBAAsBngF,KAGxB,SAAwBA,GACvC,OAAO15B,OAAO85G,oBAAoBpgF,IAQtC,IAAIqgF,EAAcp/F,OAAOq/F,OAAS,SAAqB5+E,GACrD,OAAOA,GAAUA,GAGnB,SAASmtC,IACPA,EAAaz+B,KAAKjvC,KAAKJ,MAEzBZ,EAAOC,QAAUyuE,EAGjBA,EAAaA,aAAeA,EAE5BA,EAAaoxC,UAAUjwC,aAAU3kE,EACjCwjE,EAAaoxC,UAAUM,aAAe,EACtC1xC,EAAaoxC,UAAUO,mBAAgBn1G,EAIvC,IAAIo1G,EAAsB,GAE1B,SAASC,EAAcxwC,GACrB,GAAwB,mBAAbA,EACT,MAAM,IAAIywC,UAAU,0EAA4EzwC,GAsCpG,SAAS0wC,EAAiBjrC,GACxB,YAA2BtqE,IAAvBsqE,EAAK6qC,cACA3xC,EAAa4xC,oBACf9qC,EAAK6qC,cAmDd,SAASK,EAAa7gF,EAAQj3B,EAAMmnE,EAAU4wC,GAC5C,IAAI7nD,EACA8nD,EACA/kF,EAzHsBglF,EA+I1B,GApBAN,EAAcxwC,QAGC7kE,KADf01G,EAAS/gF,EAAOgwC,UAEd+wC,EAAS/gF,EAAOgwC,QAAU1pE,OAAO26G,OAAO,MACxCjhF,EAAOugF,aAAe,SAIKl1G,IAAvB01G,EAAOG,cACTlhF,EAAOtR,KAAK,cAAe3lB,EACfmnE,EAASA,SAAWA,EAASA,SAAWA,GAIpD6wC,EAAS/gF,EAAOgwC,SAElBh0C,EAAW+kF,EAAOh4G,SAGHsC,IAAb2wB,EAEFA,EAAW+kF,EAAOh4G,GAAQmnE,IACxBlwC,EAAOugF,kBAeT,GAbwB,mBAAbvkF,EAETA,EAAW+kF,EAAOh4G,GAChB+3G,EAAU,CAAC5wC,EAAUl0C,GAAY,CAACA,EAAUk0C,GAErC4wC,EACT9kF,EAAS6hB,QAAQqyB,GAEjBl0C,EAASp1B,KAAKspE,IAIhBjX,EAAI2nD,EAAiB5gF,IACb,GAAKhE,EAAS90B,OAAS+xD,IAAMj9B,EAASmlF,OAAQ,CACpDnlF,EAASmlF,QAAS,EAGlB,IAAIr+G,EAAI,IAAIw/B,MAAM,+CACEtG,EAAS90B,OAAS,IAAM0Z,OAAO7X,GAAQ,qEAG3DjG,EAAEggB,KAAO,8BACThgB,EAAEs+G,QAAUphF,EACZl9B,EAAEiG,KAAOA,EACTjG,EAAEmgC,MAAQjH,EAAS90B,OA5KG85G,EA6KHl+G,EA5KnBu+G,SAAWA,QAAQlhG,MAAMkhG,QAAQlhG,KAAK6gG,GAgL1C,OAAOhhF,EAcT,SAASshF,IACP,IAAKvgH,KAAKovE,MAGR,OAFApvE,KAAKi/B,OAAOqvC,eAAetuE,KAAKgI,KAAMhI,KAAKwgH,QAC3CxgH,KAAKovE,OAAQ,EACY,IAArB9sC,UAAUn8B,OACLnG,KAAKmvE,SAAS/uE,KAAKJ,KAAKi/B,QAC1Bj/B,KAAKmvE,SAAS9sC,MAAMriC,KAAKi/B,OAAQqD,WAI5C,SAASm+E,EAAUxhF,EAAQj3B,EAAMmnE,GAC/B,IAAIuxC,EAAQ,CAAEtxC,OAAO,EAAOoxC,YAAQl2G,EAAW20B,OAAQA,EAAQj3B,KAAMA,EAAMmnE,SAAUA,GACjFwxC,EAAUJ,EAAYnyC,KAAKsyC,GAG/B,OAFAC,EAAQxxC,SAAWA,EACnBuxC,EAAMF,OAASG,EACRA,EA0HT,SAASC,EAAW3hF,EAAQj3B,EAAM64G,GAChC,IAAIb,EAAS/gF,EAAOgwC,QAEpB,QAAe3kE,IAAX01G,EACF,MAAO,GAET,IAAIc,EAAad,EAAOh4G,GACxB,YAAmBsC,IAAfw2G,EACK,GAEiB,mBAAfA,EACFD,EAAS,CAACC,EAAW3xC,UAAY2xC,GAAc,CAACA,GAElDD,EAsDT,SAAyB78F,GAEvB,IADA,IAAI8Y,EAAM,IAAIx0B,MAAM0b,EAAI7d,QACfoC,EAAI,EAAGA,EAAIu0B,EAAI32B,SAAUoC,EAChCu0B,EAAIv0B,GAAKyb,EAAIzb,GAAG4mE,UAAYnrD,EAAIzb,GAElC,OAAOu0B,EA1DLikF,CAAgBD,GAAcE,EAAWF,EAAYA,EAAW36G,QAoBpE,SAAS86G,EAAcj5G,GACrB,IAAIg4G,EAAShgH,KAAKivE,QAElB,QAAe3kE,IAAX01G,EAAsB,CACxB,IAAIc,EAAad,EAAOh4G,GAExB,GAA0B,mBAAf84G,EACT,OAAO,EACF,QAAmBx2G,IAAfw2G,EACT,OAAOA,EAAW36G,OAItB,OAAO,EAOT,SAAS66G,EAAWh9F,EAAKpe,GAEvB,IADA,IAAIk7F,EAAO,IAAIx4F,MAAM1C,GACZ2C,EAAI,EAAGA,EAAI3C,IAAK2C,EACvBu4F,EAAKv4F,GAAKyb,EAAIzb,GAChB,OAAOu4F,EApWTv7F,OAAO27G,eAAepzC,EAAc,sBAAuB,CACzDqzC,YAAY,EACZpyG,IAAK,WACH,OAAO2wG,GAETv/F,IAAK,SAASyc,GACZ,GAAmB,iBAARA,GAAoBA,EAAM,GAAK0iF,EAAY1iF,GACpD,MAAM,IAAIwkF,WAAW,kGAAoGxkF,EAAM,KAEjI8iF,EAAsB9iF,KAI1BkxC,EAAaz+B,KAAO,gBAEG/kC,IAAjBtK,KAAKivE,SACLjvE,KAAKivE,UAAY1pE,OAAO87G,eAAerhH,MAAMivE,UAC/CjvE,KAAKivE,QAAU1pE,OAAO26G,OAAO,MAC7BlgH,KAAKw/G,aAAe,GAGtBx/G,KAAKy/G,cAAgBz/G,KAAKy/G,oBAAiBn1G,GAK7CwjE,EAAaoxC,UAAUoC,gBAAkB,SAAyB17G,GAChE,GAAiB,iBAANA,GAAkBA,EAAI,GAAK05G,EAAY15G,GAChD,MAAM,IAAIw7G,WAAW,gFAAkFx7G,EAAI,KAG7G,OADA5F,KAAKy/G,cAAgB75G,EACd5F,MAST8tE,EAAaoxC,UAAUqC,gBAAkB,WACvC,OAAO1B,EAAiB7/G,OAG1B8tE,EAAaoxC,UAAUvxF,KAAO,SAAc3lB,GAE1C,IADA,IAAI0lB,EAAO,GACFnlB,EAAI,EAAGA,EAAI+5B,UAAUn8B,OAAQoC,IAAKmlB,EAAK7nB,KAAKy8B,UAAU/5B,IAC/D,IAAIi5G,EAAoB,UAATx5G,EAEXg4G,EAAShgH,KAAKivE,QAClB,QAAe3kE,IAAX01G,EACFwB,EAAWA,QAA4Bl3G,IAAjB01G,EAAOjoF,WAC1B,IAAKypF,EACR,OAAO,EAGT,GAAIA,EAAS,CACX,IAAIC,EAGJ,GAFI/zF,EAAKvnB,OAAS,IAChBs7G,EAAK/zF,EAAK,IACR+zF,aAAclgF,MAGhB,MAAMkgF,EAGR,IAAIC,EAAM,IAAIngF,MAAM,oBAAsBkgF,EAAK,KAAOA,EAAGE,QAAU,IAAM,KAEzE,MADAD,EAAIltG,QAAUitG,EACRC,EAGR,IAAIxyC,EAAU8wC,EAAOh4G,GAErB,QAAgBsC,IAAZ4kE,EACF,OAAO,EAET,GAAuB,mBAAZA,EACT6vC,EAAa7vC,EAASlvE,KAAM0tB,OAE5B,KAAIvlB,EAAM+mE,EAAQ/oE,OACdy7G,EAAYZ,EAAW9xC,EAAS/mE,GACpC,IAASI,EAAI,EAAGA,EAAIJ,IAAOI,EACzBw2G,EAAa6C,EAAUr5G,GAAIvI,KAAM0tB,GAGrC,OAAO,GAiETogD,EAAaoxC,UAAU2C,YAAc,SAAqB75G,EAAMmnE,GAC9D,OAAO2wC,EAAa9/G,KAAMgI,EAAMmnE,GAAU,IAG5CrB,EAAaoxC,UAAUrzF,GAAKiiD,EAAaoxC,UAAU2C,YAEnD/zC,EAAaoxC,UAAU4C,gBACnB,SAAyB95G,EAAMmnE,GAC7B,OAAO2wC,EAAa9/G,KAAMgI,EAAMmnE,GAAU,IAqBhDrB,EAAaoxC,UAAU7wC,KAAO,SAAcrmE,EAAMmnE,GAGhD,OAFAwwC,EAAcxwC,GACdnvE,KAAK6rB,GAAG7jB,EAAMy4G,EAAUzgH,KAAMgI,EAAMmnE,IAC7BnvE,MAGT8tE,EAAaoxC,UAAU6C,oBACnB,SAA6B/5G,EAAMmnE,GAGjC,OAFAwwC,EAAcxwC,GACdnvE,KAAK8hH,gBAAgB95G,EAAMy4G,EAAUzgH,KAAMgI,EAAMmnE,IAC1CnvE,MAIb8tE,EAAaoxC,UAAU5wC,eACnB,SAAwBtmE,EAAMmnE,GAC5B,IAAItzD,EAAMmkG,EAAQlsG,EAAUvL,EAAGy5G,EAK/B,GAHArC,EAAcxwC,QAGC7kE,KADf01G,EAAShgH,KAAKivE,SAEZ,OAAOjvE,KAGT,QAAasK,KADbuR,EAAOmkG,EAAOh4G,IAEZ,OAAOhI,KAET,GAAI6b,IAASszD,GAAYtzD,EAAKszD,WAAaA,EACb,KAAtBnvE,KAAKw/G,aACTx/G,KAAKivE,QAAU1pE,OAAO26G,OAAO,cAEtBF,EAAOh4G,GACVg4G,EAAO1xC,gBACTtuE,KAAK2tB,KAAK,iBAAkB3lB,EAAM6T,EAAKszD,UAAYA,SAElD,GAAoB,mBAATtzD,EAAqB,CAGrC,IAFA/H,GAAY,EAEPvL,EAAIsT,EAAK1V,OAAS,EAAGoC,GAAK,EAAGA,IAChC,GAAIsT,EAAKtT,KAAO4mE,GAAYtzD,EAAKtT,GAAG4mE,WAAaA,EAAU,CACzD6yC,EAAmBnmG,EAAKtT,GAAG4mE,SAC3Br7D,EAAWvL,EACX,MAIJ,GAAIuL,EAAW,EACb,OAAO9T,KAEQ,IAAb8T,EACF+H,EAAKsqD,QAiIf,SAAmBtqD,EAAMgN,GACvB,KAAOA,EAAQ,EAAIhN,EAAK1V,OAAQ0iB,IAC9BhN,EAAKgN,GAAShN,EAAKgN,EAAQ,GAC7BhN,EAAKoF,MAlIGghG,CAAUpmG,EAAM/H,GAGE,IAAhB+H,EAAK1V,SACP65G,EAAOh4G,GAAQ6T,EAAK,SAEQvR,IAA1B01G,EAAO1xC,gBACTtuE,KAAK2tB,KAAK,iBAAkB3lB,EAAMg6G,GAAoB7yC,GAG1D,OAAOnvE,MAGb8tE,EAAaoxC,UAAUgD,IAAMp0C,EAAaoxC,UAAU5wC,eAEpDR,EAAaoxC,UAAU3wC,mBACnB,SAA4BvmE,GAC1B,IAAI45G,EAAW5B,EAAQz3G,EAGvB,QAAe+B,KADf01G,EAAShgH,KAAKivE,SAEZ,OAAOjvE,KAGT,QAA8BsK,IAA1B01G,EAAO1xC,eAUT,OATyB,IAArBhsC,UAAUn8B,QACZnG,KAAKivE,QAAU1pE,OAAO26G,OAAO,MAC7BlgH,KAAKw/G,aAAe,QACMl1G,IAAjB01G,EAAOh4G,KACY,KAAtBhI,KAAKw/G,aACTx/G,KAAKivE,QAAU1pE,OAAO26G,OAAO,aAEtBF,EAAOh4G,IAEXhI,KAIT,GAAyB,IAArBsiC,UAAUn8B,OAAc,CAC1B,IACIwhB,EADAniB,EAAOD,OAAOC,KAAKw6G,GAEvB,IAAKz3G,EAAI,EAAGA,EAAI/C,EAAKW,SAAUoC,EAEjB,oBADZof,EAAMniB,EAAK+C,KAEXvI,KAAKuuE,mBAAmB5mD,GAK1B,OAHA3nB,KAAKuuE,mBAAmB,kBACxBvuE,KAAKivE,QAAU1pE,OAAO26G,OAAO,MAC7BlgH,KAAKw/G,aAAe,EACbx/G,KAKT,GAAyB,mBAFzB4hH,EAAY5B,EAAOh4G,IAGjBhI,KAAKsuE,eAAetmE,EAAM45G,QACrB,QAAkBt3G,IAAds3G,EAET,IAAKr5G,EAAIq5G,EAAUz7G,OAAS,EAAGoC,GAAK,EAAGA,IACrCvI,KAAKsuE,eAAetmE,EAAM45G,EAAUr5G,IAIxC,OAAOvI,MAoBb8tE,EAAaoxC,UAAU0C,UAAY,SAAmB55G,GACpD,OAAO44G,EAAW5gH,KAAMgI,GAAM,IAGhC8lE,EAAaoxC,UAAUiD,aAAe,SAAsBn6G,GAC1D,OAAO44G,EAAW5gH,KAAMgI,GAAM,IAGhC8lE,EAAamzC,cAAgB,SAASZ,EAASr4G,GAC7C,MAAqC,mBAA1Bq4G,EAAQY,cACVZ,EAAQY,cAAcj5G,GAEtBi5G,EAAc7gH,KAAKigH,EAASr4G,IAIvC8lE,EAAaoxC,UAAU+B,cAAgBA,EAiBvCnzC,EAAaoxC,UAAUkD,WAAa,WAClC,OAAOpiH,KAAKw/G,aAAe,EAAIZ,EAAe5+G,KAAKivE,SAAW,K,4CC7ZhE,IAAIxuE,EAAY,EAAQ,YAEpB4hH,EAAS,CACT,MAAS,CACL,CAAC,EAAG,cAAe,CAAC,EAAG,qBAG3B,OAAU,CACN,CAAC,EAAG,gBAAiB,CAAC,KAAO,kBAC7B,CAAC,IAAM,kBAAmB,CAAC,KAAO,mBAClC,CAAC,GAAK,mBAAoB,CAAC,KAAO,oBAClC,CAAC,IAAM,oBAAqB,CAAC,KAAO,oBACpC,CAAC,EAAG,qBAGR,OAAU,CACN,CAAC,EAAG,gBAAiB,CAAC,KAAO,iBAC7B,CAAC,IAAM,kBAAmB,CAAC,KAAO,kBAClC,CAAC,GAAK,oBAAqB,CAAC,KAAO,oBACnC,CAAC,IAAM,oBAAqB,CAAC,KAAO,oBACpC,CAAC,EAAG,qBAGR,OAAU,CACN,CAAC,EAAG,iBAAkB,CAAC,KAAO,iBAC9B,CAAC,IAAM,kBAAmB,CAAC,KAAO,kBAClC,CAAC,GAAK,mBAAoB,CAAC,KAAO,mBAClC,CAAC,IAAM,oBAAqB,CAAC,KAAO,oBACpC,CAAC,EAAG,qBAGR,QAAW,CACP,CAAC,EAAG,gBAAiB,CAAC,EAAG,iBAK7B,KAAQ,CACJ,CAAC,EAAG,iBAAkB,CAAC,IAAM,oBAC7B,CAAC,GAAK,oBAAqB,CAAC,GAAK,oBACjC,CAAC,GAAK,mBAAoB,CAAC,EAAG,mBAIlC,KAAQ,CACJ,CAAC,EAAG,oBAAqB,CAAC,GAAK,oBAC/B,CAAC,GAAK,oBAAqB,CAAC,EAAG,mBAInC,MAAS,CACL,CAAC,EAAG,iBAAkB,CAAC,IAAM,kBAC7B,CAAC,GAAK,mBAAoB,CAAC,GAAK,mBAChC,CAAC,GAAK,oBAAqB,CAAC,EAAG,qBAGnC,OAAU,CACN,CAAC,EAAG,gBAAiB,CAAC,GAAK,mBAC3B,CAAC,GAAK,oBAAqB,CAAC,GAAK,oBACjC,CAAC,GAAK,oBAAqB,CAAC,GAAK,oBACjC,CAAC,GAAK,oBAAqB,CAAC,GAAK,oBACjC,CAAC,GAAK,oBAAqB,CAAC,GAAK,oBACjC,CAAC,EAAG,iBAGR,QAAW,CACP,CAAC,EAAG,iBAAkB,CAAC,KAAO,gBAC9B,CAAC,IAAM,iBAAkB,CAAC,KAAO,kBACjC,CAAC,GAAK,mBAAoB,CAAC,KAAO,kBAClC,CAAC,IAAM,kBAAmB,CAAC,KAAO,kBAClC,CAAC,EAAG,iBAGR,SAAY,CACR,CAAC,EAAG,kBAAmB,CAAC,IAAM,mBAC9B,CAAC,GAAK,mBAAoB,CAAC,IAAM,mBACjC,CAAC,EAAG,mBAGR,IAAO,CACH,CAAC,EAAG,gBAAiB,CAAC,KAAO,iBAC7B,CAAC,KAAO,kBAAmB,CAAC,KAAO,kBACnC,CAAC,KAAO,gBAAiB,CAAC,EAAG,iBAGjC,IAAO,CACH,CAAC,EAAG,cAAe,CAAC,GAAK,gBACzB,CAAC,GAAK,kBAAmB,CAAC,EAAG,qBAGjC,UAAa,CACT,CAAC,EAAG,cAAe,CAAC,GAAK,gBACzB,CAAC,GAAK,kBAAmB,CAAC,GAAK,oBAC/B,CAAC,EAAG,qBAGR,MAAS,CACL,CAAC,EAAG,gBAAiB,CAAC,GAAK,kBAC3B,CAAC,GAAK,kBAAmB,CAAC,GAAK,mBAC/B,CAAC,GAAK,kBAAmB,CAAC,EAAG,qBAGjC,SAAY,CACR,CAAC,EAAG,cAAe,CAAC,IAAM,iBAC1B,CAAC,GAAK,kBAAmB,CAAC,GAAK,iBAC/B,CAAC,GAAK,kBAAmB,CAAC,EAAG,qBAGjC,QAAW,CACP,CAAC,EAAG,WAAY,CAAC,mBAAqB,WACtC,CAAC,mBAAqB,WAAY,CAAC,mBAAqB,WACxD,CAAC,mBAAqB,WAAY,CAAC,kBAAoB,WACvD,CAAC,kBAAoB,WAAY,CAAC,kBAAoB,WACtD,CAAC,kBAAoB,WAAY,CAAC,kBAAoB,WACtD,CAAC,kBAAoB,WAAY,CAAC,kBAAoB,WACtD,CAAC,kBAAoB,WAAY,CAAC,kBAAoB,WACtD,CAAC,kBAAoB,WAAY,CAAC,kBAAoB,WACtD,CAAC,EAAG,YAGR,QAAW,CACP,CAAC,EAAU,gBAAiB,CAAC,QAAU,iBACvC,CAAC,QAAU,iBAAkB,CAAC,QAAU,kBACxC,CAAC,QAAU,kBAAmB,CAAC,QAAU,kBACzC,CAAC,QAAU,kBAAmB,CAAC,QAAU,oBACzC,CAAC,QAAU,oBAAqB,CAAC,QAAU,oBAC3C,CAAC,QAAU,oBAAqB,CAAC,QAAU,oBAC3C,CAAC,QAAU,oBAAqB,CAAC,QAAU,oBAC3C,CAAC,QAAU,oBAAqB,CAAC,QAAU,mBAC3C,CAAC,QAAU,mBAAoB,CAAC,EAAU,qBAI9CC,EAAeD,EAAOE,KAyB1B,SAASC,EAAkBC,GACvB,IAAIC,EAAa,EAEjB,IAAIp6G,MAAM+D,QAAQo2G,IAAQA,EAAIt8G,OAAS,EAAG,OAAO,EAEjD,IAAIs8G,EAAI,KAAOA,EAAIA,EAAIt8G,OAAS,GAAI,OAAO,EAE3C,GAAkB,IAAds8G,EAAI,GAAG,IAAwC,IAA3BA,EAAIA,EAAIt8G,OAAS,GAAG,GAAU,OAAO,EAE7D,IAAI,IAAIoC,EAAI,EAAGA,EAAIk6G,EAAIt8G,OAAQoC,IAAK,CAChC,IAAIo6G,EAAKF,EAAIl6G,GAEb,GAAiB,IAAdo6G,EAAGx8G,SAAiBw8G,EAAG,GAAKD,IAAejiH,EAAUkiH,EAAG,IAAIC,UAC3D,OAAO,EAGXF,GAAcC,EAAG,GAGrB,OAAO,EAQXvjH,EAAOC,QAAU,CACbgjH,OAAQA,EACRC,aAAcA,EAEdvzG,IAtDJ,SAAkB0zG,EAAKh/G,GAEnB,GADIA,IAAMA,EAAO6+G,IACbG,EAAK,OAAOh/G,EAEhB,SAASo/G,IACL,IACIJ,EAAMJ,EAAOI,IAAQnjB,KAAKia,MAAMkJ,GAClC,MAAMroE,GACJqoE,EAAMh/G,GAUd,MANkB,iBAARg/G,IACNI,IAEkB,iBAARJ,GAAkBI,KAG5BL,EAAkBC,GACfA,EAD4Bh/G,GAqCnCm/G,QAVJ,SAAsBH,GAClB,YAAmBn4G,IAAhB+3G,EAAOI,IACED,EAAkBC,M,8CCrLlC,IAAI92G,EAAsB,EAAQ,YAAWA,oBACzCnK,EAAgB,EAAQ,YAS5BpC,EAAOC,QAAU,SAAS0zB,EAAkB+vF,EAAaC,GACrD,IAAI,IAAIr9G,KAAKq9G,EAAe,CACxB,IAAIC,EAAUD,EAAcr9G,GACxBu9G,EAAQH,EAAYp9G,GAExB,GAAGu9G,IAAUD,EAGb,GAAmB,MAAhBt9G,EAAEgX,OAAO,IAAiC,mBAAZsmG,EAAwB,CAGrD,GAAGt9G,KAAKo9G,EAAa,SAErBA,EAAYp9G,GAAKs9G,OACd,GAAGr3G,EAAoBq3G,IAAYr3G,EAAoBs3G,IAAUzhH,EAAcwhH,EAAQ,IAAK,CAI/F,GAAS,eAANt9G,GAA4B,QAANA,EAAa,SAItC,IADA,IAAIw9G,EAASt/G,KAAKi3B,IAAImoF,EAAQ78G,OAAQ88G,EAAM98G,QACpCsS,EAAI,EAAGA,EAAIyqG,EAAQzqG,IACnBwqG,EAAMxqG,KAAOuqG,EAAQvqG,IAAOjX,EAAcwhH,EAAQvqG,KAAOjX,EAAcyhH,EAAMxqG,KAC7Esa,EAAkBkwF,EAAMxqG,GAAIuqG,EAAQvqG,SAGtCjX,EAAcwhH,IAAYxhH,EAAcyhH,KAE9ClwF,EAAkBkwF,EAAOD,GAErBz9G,OAAOC,KAAKy9G,GAAO98G,eAAe28G,EAAYp9G,O,+BC5C9D,SAAS3F,EAAOojH,EAAUxsG,EAAWysG,GACpC,IAAIz7B,EAAS,GAyBb,OAxBAw7B,EAAS19G,SAAQ,SAAS49G,GACzB,IAAIx6F,GACFw6F,EAAIC,OAAOC,MAAQ,EAAI,IACvBF,EAAIC,OAAOE,MAAQ,EAAI,IACtBH,EAAII,WAAaJ,EAAII,UAAUF,MAAS,EAAI,IAC5CF,EAAII,WAAaJ,EAAII,UAAUD,MAAS,EAAI,GACtB,IAArB7sG,EAAUkS,IAEb8+D,EAAO9hF,KAAK,CACX46B,GAAI2iF,EAAWA,EAASM,aAAe,EACvCt0G,MAAOi0G,EAAIj0G,MACXC,IAAKg0G,EAAIh0G,IACTi0G,OAAQ,CACPC,MAA4B,IAArB5sG,EAAUkS,GACjB26F,MAA4B,IAArB7sG,EAAUkS,IAElB46F,UAAW,UAKVL,GACHA,EAASp2G,SAAS26E,GAEZA,EAGR,IAAIg8B,EAAkB,CACrBC,MAAO,SAAST,EAAUC,GAkBzB,OAAOrjH,EAAOojH,EAAU,CACvB,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,GACPC,IAEJS,UAAW,SAASV,EAAUC,GAkB7B,OAAOrjH,EAAOojH,EAAU,CACvB,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,GACPC,IAEJU,WAAY,SAASX,EAAUC,GAkB9B,OAAOrjH,EAAOojH,EAAU,CACvB,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,GACPC,IAEJW,cAAe,SAASZ,EAAUC,GAkBjC,OAAOrjH,EAAOojH,EAAU,CACvB,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,GACPC,IAEJY,IAAK,SAASb,EAAUC,GAkBvB,OAAOrjH,EAAOojH,EAAU,CACvB,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,EACT,EAAG,EAAG,EAAG,GACPC,KAILhkH,EAAOC,QAAUskH,G,4CC3JjB,IAAI/iH,EAAM,EAAQ,YACdq3B,EAAe,EAAQ,YAAmBC,QAC1C+rF,EAAc,EAAQ,YAAsBj8F,WAC5Ck8F,EAAmB,EAAQ,YAAmCj8D,QAC9DzwC,EAAW,EAAQ,YAEnB2sG,EAAY,CACZC,KAAM,CACFjlE,QAAS,UACTtkB,IAAK,EACLukB,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,+DACA,4DACA,8DACFx2C,KAAK,MAEXw7G,SAAU,CACNllE,QAAS,aACTG,OAAQ,CAAC,gBAAiB,iBAC1B77C,KAAM,gBACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,4DACA,6CACFx2C,KAAK,MAEXy7G,QAAS,CACLnlE,QAAS,UACTtkB,IAAK,EACLukB,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,oEACA,+DACA,mEACA,4DACA,8DACFx2C,KAAK,MAEX6Q,SAAU,CACNylC,QAAS,aACTI,YAAY,EACZmmD,WAAY,EACZlmD,MAAO,CAACL,QAAS,aAAcG,OAAQ,CAACrnB,EAAa,MAAMvQ,WAAY,IAAKg4B,SAAU,QACtFN,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,yEACA,wEACA,uEACA,0DACA,+EACA,2DACFx2C,KAAK,MAEXyQ,MAAO,CACH6lC,QAAS,aACTI,YAAY,EACZC,MAAO,CAACL,QAAS,aAAcG,OAAQ,CAAC4kE,EAAiBviH,EAAE+lB,WAAY,IAAKg4B,SAAU,QACtFN,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8EACA,mEACA,0EACA,uEACA,kCACFx2C,KAAK,MAEX0Q,MAAO,CACH4lC,QAAS,aACTI,YAAY,EACZC,MAAO,CAACL,QAAS,aAAcG,OAAQ,CAAC4kE,EAAiBtiH,EAAE8lB,WAAY,IAAKg4B,SAAU,QACtFN,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8EACA,mEACA,sEACA,uEACA,kCACFx2C,KAAK,MAEX07G,QAAS,CACLplE,QAAS,aACTG,OAAQ,CAAC,cAAe,WACxB77C,KAAM,UACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,uFACA,oEACA,gEACA,gFACA,gDACFx2C,KAAK,MAEX27G,KAAM,CACFrlE,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACL06C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,+DACA,4DACA,yDACFx2C,KAAK,MAEX47G,KAAM,CACFtlE,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACL06C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,6DACA,6DACA,yDACFx2C,KAAK,MAEXi8D,OAAQm/C,EAAY,CAACliG,KAAM,OAAQ29B,SAAU,OAAQglE,YAAY,GAAO,CACpErlE,YAAa,CACT,qDACA,0CACFx2C,KAAK,OAEX87G,MAAO,CACHxlE,QAAS,aACTG,OAAQ,CAAC,SAAU,cAAe,WAAY,OAC9C77C,KAAM,cACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,6DACA,gEACA,kEACFx2C,KAAK,MAEX+7G,MAAO,CACHzlE,QAAS,aACTG,OAAQ,CAAC,OAAQ,YAAa,aAAc,SAC5C77C,KAAM,YACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,2DACA,mEACA,sEACFx2C,KAAK,MAEX62C,SAAU,QAGd,SAASmlE,EAAQhgG,EAAQhH,EAAMrD,GAC3B,IAAIsqG,EAAUjnG,EAAKrD,EAAW,QAC1BuqG,EAAWx/G,OAAOC,MAAMqf,EAAOzH,YAAc,IAAI5C,IAAa,IAElE,OAAGlS,MAAM+D,QAAQy4G,GAAiBA,EAC/BC,EAAS5+G,OAAe4+G,OAA3B,EAqEJ,SAASC,EAAkBxqG,EAAUH,EAAQ4qG,EAASC,EAAU/8G,EAAKX,GACjE,IAAI29G,EAAS9qG,EAAOG,EAAW,MAAOyqG,GAClCngD,EAASzqD,EAAO,UAAYG,GAChCH,EAAOG,EAAW,OAAQ0qG,GAM1B,IAJA,IAAIz4G,EAAM,IAAInE,MAAMH,GAChBiH,EAAQ01D,EAAO,GACf9kB,GAAQ8kB,EAAO,GAAK11D,IAAUjH,EAAMg9G,GACpCC,EAAaplE,GAAQ,EAAImlE,GACrB58G,EAAI,EAAGA,EAAIJ,EAAKI,IAAK,CACzB,IAAI88G,EAAYj2G,EAAQ4wC,EAAOz3C,EAC/BkE,EAAIjF,EAAYW,EAAM,EAAII,EAAKA,GAAK,CAAC88G,EAAWA,EAAYD,GAEhE,OAAO34G,EAyIX,SAAS64G,EAAaC,EAAQC,EAAar9G,EAAKs9G,EAASjrG,GACrD,IACIjS,EADAkE,EAAM,IAAInE,MAAMH,GAGpB,SAASu9G,EAAYn9G,EAAGo9G,IACgB,IAAjCH,EAAY9+G,QAAQi/G,SAAsCr7G,IAApBm7G,EAAQE,IAC7Cl5G,EAAIlE,GAAKo9G,EACTF,EAAQE,GAAUp9G,GACfkE,EAAIlE,GAAK,GAGpB,GAAGD,MAAM+D,QAAQk5G,GACb,IAAIh9G,EAAI,EAAGA,EAAIJ,EAAKI,IAChBm9G,EAAYn9G,EAAGg9G,EAAOh9G,SAK1B,IADAm9G,EAAY,EAAGlrG,GACXjS,EAAI,EAAGA,EAAIJ,EAAKI,IAChBm9G,EAAYn9G,EAAGiS,GAAYjS,EAAI,IAIvC,OAAOkE,EAGXrN,EAAOC,QAAU,CACbqrE,WAAY,YACZ3oD,KAAM,OAEN4oD,OAAQ,CACJ9lD,OAAQ,CAAChH,KAAMsmG,IAGnBzsG,iBAAkBysG,EAClByB,aAzPJ,SAAsBttG,EAAUC,GAC5B,IAAIstG,EAASvtG,EAASuF,MAAQ,GAC1BioG,EAAQjB,EAAQtsG,EAAWstG,EAAQ,KACnCE,EAAQlB,EAAQtsG,EAAWstG,EAAQ,KAEvC,GAAIvtG,EAASuF,MAASioG,GAAUC,EAAhC,CAEA,IAQIC,EAAUC,EARVC,EAAiB59G,MAAM+D,QAAQw5G,EAAOnsG,WAAapR,MAAM+D,QAAQw5G,EAAOnsG,SAAS,IACjFysG,EAAW79G,MAAM+D,QAAQy5G,GACzBM,EAAW99G,MAAM+D,QAAQ05G,GACzBM,EACAF,GAAYL,IAAUD,EAAOvsG,OAC7B8sG,GAAYL,IAAUF,EAAOtsG,MAK9B2sG,GACCF,EAAWH,EAAOnsG,SAASvT,OAC3B8/G,EAAcJ,EAAOnsG,SAAS,GAAGvT,SAE9BigH,IAAUJ,EAAWD,EAAM5/G,QAC3BggH,IAAUF,EAAcH,EAAM3/G,SAGrC,IAAImgH,EAAU9uG,EAASmF,aAAapE,EAAW,QAM3C6rG,EAAO/pG,EAAO,OAAQ2rG,GACtB1B,EAAUjqG,EAAO,UAAW4rG,GAEhC,GAAK7B,EAAOE,EAAU,EAAtB,CAKA,IAAI4B,IAAmBC,IAAaC,EACe,gBAAtB/rG,EAAO,aACT6rG,GAAiB,GAE5CI,EAAQC,gBAAkBL,EAE1B,IAMIM,EAAWC,EALXj/G,EAAwB,kBADb6S,EAAO,YAGlBqsG,EAAWR,EAAiB,GAAM,GAClCS,EAAWT,EAAiB,GAAM,GAGnCG,GAAoB9tG,EAAUs6E,iBAC7B2zB,EAAYjuG,EAAUs6E,eAAe8xB,MACrC8B,EAAYluG,EAAUs6E,eAAe+xB,OAGzC0B,EAAQM,SAAW,CACfjlH,EAAGqjH,EAAkB,IAAK3qG,EAAQqsG,EAAUF,EAAWlC,GACvD1iH,EAAGojH,EAAkB,IAAK3qG,EAAQssG,EAAUF,EAAWrC,EAAM58G,gBAxBtD+Q,EAAUsF,KARrB,SAASxD,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOwrG,EAAQS,EAASnC,EAAWtiH,EAAM4B,KA8NxDojH,gBAxKJ,SAAyBvuG,EAAUC,GAC/B,IAAI+tG,EAAU/tG,EAAUsF,KAExB,GAAIyoG,GAAYA,EAAQM,SAAxB,CAEA,IAOIr+G,EAAGkQ,EAAG+tC,EAAKC,EAAKjf,EAAWs/E,EAAaC,EAPxClB,EAASvtG,EAASuF,MAAQ,GAC1BnE,EAAWnB,EAAUoB,UACrBusG,EAAiBI,EAAQC,gBACzBnC,EAAOkC,EAAQlC,KACfE,EAAUgC,EAAQhC,QAClB0C,EAAyC,gBAApBV,EAAQ/B,QAI7BkB,EAAUa,EAAQW,SAAW,GAEjC,GAAGf,EAAgB,CACf,IAAIgB,EAAarB,EAAOnsG,UAAY,GACpCotG,EAAcR,EAAQ5sG,SAAW,IAAIpR,MAAM87G,GAC3C,IAAIv7F,EAAQ,EAEZ,IAAItgB,EAAI,EAAGA,EAAI67G,EAAM77G,IAAK,CACtB,IAAI4+G,EAASL,EAAYv+G,GAAK,IAAID,MAAMg8G,GACpC8C,EAAQF,EAAW3+G,IAAM,GAC7B,IAAIkQ,EAAI,EAAGA,EAAI6rG,EAAS7rG,IAQpB,GAPGuuG,GACCx/E,EAAuB,IAAV3e,EAAe,KAAQ,IAAMA,EAAQ,IAAMA,EACxDA,KACG2e,EAAY4/E,EAAM3uG,GAEzB0uG,EAAO1uG,GAAK,IAEkC,IAA3CiB,EAASivC,UAAUjiD,QAAQ8gC,GAAmB,CAI7C,GAHAu/E,EAAOv/E,EAAU9gC,QAAQ,KACzB8/C,EAAMhf,EAAUxoB,MAAM,EAAG+nG,GACzBtgE,EAAMjf,EAAUxoB,MAAM+nG,QACDz8G,IAAjBm7G,EAAQj/D,IAAsBi/D,EAAQj/D,KAAS/tC,QAC7BnO,IAAjBm7G,EAAQh/D,IAAsBg/D,EAAQh/D,KAASl+C,EAEhD,SAGJ4+G,EAAO1uG,GAAK+uB,EACZi+E,EAAQj/D,GAAO/tC,EACfgtG,EAAQh/D,GAAOl+C,QAIxB,CACH,IAAIu9G,EAAQjB,EAAQtsG,EAAWstG,EAAQ,KACnCE,EAAQlB,EAAQtsG,EAAWstG,EAAQ,KACvCS,EAAQhtG,MAAQgsG,EAAaQ,EAAOpsG,EAASxW,MAAOohH,EAASmB,EAAS,KACtEa,EAAQ/sG,MAAQ+rG,EAAaS,EAAOrsG,EAASvW,MAAOihH,EAAMqB,EAAS,KAGvE,IAAI4B,EAAUf,EAAQgB,SAAW,GAC7B9/G,EAAgC,kBAArB8+G,EAAQjC,SAEvB,IAAI,IAAIsB,KAAUF,EAAS,CACvB,IAGI8B,EAAIC,EAAKC,EAHTjtG,EAAWmrG,EAAOjpG,OAAO,GACzBu6B,EAAOqvE,EAAQ9rG,EAAW,QAI9B,GAAGy8B,EAAK9wC,OAAS,EAGbkhH,EAAQ1B,GAAU,YACf,GAAgB,MAAbnrG,GAUN,GATuB,MAAnBy8B,EAAKv6B,OAAO,KAAgBlV,GAC5B+/G,EAAK,EACLC,EAAM,EACNC,EAASrD,IAETmD,EAAKnD,EAAO,EACZoD,GAAO,EACPC,GAAU,GAEXvB,EAAgB,CACf,IAAIwB,EAASjC,EAAQE,GACrB,IAAIp9G,EAAIg/G,EAAIh/G,IAAMk/G,EAAQl/G,GAAKi/G,EAE3B,IADAhgF,EAAYs/E,EAAYv+G,GAAGm/G,MAE3BX,EAAOv/E,EAAU9gC,QAAQ,KACtB8gC,EAAUxoB,MAAM,EAAG+nG,KAAUpB,GAAQ,CACpC0B,EAAQ1B,GAAUn+E,EAAUxoB,MAAM+nG,GAClC,YAIR,IAAIx+G,EAAIg/G,EAAIh/G,IAAMk/G,EAAQl/G,GAAKi/G,EAE3B,GADA/gE,EAAM6/D,EAAQ/sG,MAAMhR,IAC6B,IAA9CmR,EAASivC,UAAUjiD,QAAQi/G,EAASl/D,GAAa,CAChD4gE,EAAQ1B,GAAUl/D,EAClB,YAcZ,GATuB,MAAnBxP,EAAKv6B,OAAO,IACZ6qG,EAAK,EACLC,EAAM,EACNC,EAASnD,IAETiD,EAAKjD,EAAU,EACfkD,GAAO,EACPC,GAAU,GAEXvB,EAAgB,CACf,IAAIv4C,EAAM83C,EAAQE,GAClB,IAAIp9G,EAAIg/G,EAAIh/G,IAAMk/G,EAAQl/G,GAAKi/G,EAE3B,IADAhgF,EAAYs/E,EAAYn5C,GAAKplE,MAE7Bw+G,EAAOv/E,EAAU9gC,QAAQ,KACtB8gC,EAAUxoB,MAAM+nG,KAAUpB,GAAQ,CACjC0B,EAAQ1B,GAAUn+E,EAAUxoB,MAAM,EAAG+nG,GACrC,YAIR,IAAIx+G,EAAIg/G,EAAIh/G,IAAMk/G,EAAQl/G,GAAKi/G,EAE3B,GADAhhE,EAAM8/D,EAAQhtG,MAAM/Q,IAC6B,IAA9CmR,EAASivC,UAAUjiD,QAAQ8/C,EAAMm/D,GAAgB,CAChD0B,EAAQ1B,GAAUn/D,EAClB,Y,8CC3WxBpnD,EAAOC,QAAU,SAAS+9B,GAGtB,IAFA,IACIrW,EADAiE,EAAIoS,EAAIj3B,OAEJoC,EAAI,EAAGA,EAAIyiB,EAAGziB,IAElB,KADAwe,EAAIqW,EAAIlZ,WAAW3b,IACX,GAAKwe,EAAI,KAAc,KAANA,GAAoB,MAANA,GAAqB,MAANA,GAC3C,OAANA,GAAsB,OAANA,IAAgBA,EAAI,MAAQA,EAAI,OAC1C,OAANA,GAAsB,OAANA,GAAsB,OAANA,GAAsB,OAANA,GAC1C,OAANA,GAAsB,QAANA,GAAuB,QAANA,EAC9B,OAAO,EAGnB,OAAO,I,4CCvBX,IAAInmB,EAAM,EAAQ,YACdimC,EAAK,EAAQ,YACbnmC,EAAW,EAAQ,YACnBinH,EAAgB,EAAQ,YACxBxoH,EAAQ,EAAQ,YAChBukC,EAAW9iC,EAAI8iC,SAEnBtkC,EAAOC,QAAU,SAAqBuoH,EAAWC,EAAMC,EAAMtrG,GACzD,IAAIkhB,EAAKkqF,EAAUlqF,GACfj+B,EAAQi+B,EAAG,GAAGj+B,MACd2C,EAAKwlH,EAAUxlH,GACfC,EAAKulH,EAAUvlH,GACf0lH,EAAM3lH,EAAGE,IAAIulH,GACbG,EAAM3lH,EAAGC,IAAIwlH,GACbp5G,EAAK,CAACq5G,EAAKC,GACXC,EAAUxoH,EAAMwoH,SAAW,GAC3BC,GAA6C,IAAnCzoH,EAAM8rE,KAAK7kE,QAAQ,WAAqB,EAAI,GAI1D,IAAkC,IAA/BuhH,EAAQvhH,QAAQ,UAAkB,CACjC,IAgBIyhH,EAAM,SAASC,GAKf,IAAI3hD,EAAM7iE,KAAKc,IAAIwjH,EAAQE,EAAGz9G,KAAO,GACjCqF,EAAK5N,EAAGE,IAAI8lH,EAAGzmH,GAAKomH,EACpB93G,EAAK5N,EAAGC,IAAI8lH,EAAGxmH,GAAKomH,EACxB,OAAOpkH,KAAKc,IAAId,KAAKmiC,KAAK/1B,EAAKA,EAAKC,EAAKA,GAAMw2D,EAAK,EAAIyhD,EAASzhD,IAEjE4hD,EAASxhF,EAAG0hE,oBAAoB/rF,GA1B3B,SAAS4rG,GAId,IAAI3hD,EAAM7iE,KAAKc,IAAI,EAAG0jH,EAAGz9G,KAAO,GAC5B29G,EAAO,EAAI,EAAI7hD,EACf8hD,EAAQ3kH,KAAK6/B,IAAIrhC,EAAGE,IAAI8lH,EAAGzmH,GAAKomH,GAEpC,OADSQ,EAAQ9hD,EAAQ6hD,EAAOC,EAAQ9hD,EAAQ8hD,EAAQ9hD,EAAM6hD,KAGzD,SAASF,GACd,IAAI3hD,EAAM7iE,KAAKc,IAAI,EAAG0jH,EAAGz9G,KAAO,GAC5B29G,EAAO,EAAI,EAAI7hD,EACf+hD,EAAQ5kH,KAAK6/B,IAAIphC,EAAGC,IAAI8lH,EAAGxmH,GAAKomH,GACpC,OAAQQ,EAAQ/hD,EAAQ6hD,EAAOE,EAAQ/hD,EAAQ+hD,EAAQ/hD,EAAM6hD,IAYVH,GAKvD,GAHAthF,EAAG2hE,WAAW9qE,EAAI2qF,EAAQT,IAGH,IAApBA,EAAU/+F,MAAiB,CAE1B,IAAIu/F,EAAK1qF,EAAGkqF,EAAU/+F,OAClB4/F,EAAKrmH,EAAGE,IAAI8lH,EAAGzmH,GAAG,GAClB+mH,EAAKrmH,EAAGC,IAAI8lH,EAAGxmH,GAAG,GAClB6kE,EAAM2hD,EAAGz9G,KAAO,EAKpBi9G,EAAU/+F,MAAQu/F,EAAG7/G,EAErB,IAAIiR,EAAckkB,EAAG,GAAG3mB,EAAEyC,YAKtBmvG,EAAUnvG,IAAgB4uG,EAAGQ,OAASR,EAAGtoH,GACzC+oH,EAA6B,MAAhBrvG,EAAuBmvG,EAAUP,EAAGzmH,EACjDmnH,EAA6B,MAAhBtvG,EAAuBmvG,EAAUP,EAAGxmH,EAoBrD,OAlBAhB,EAAIiM,WAAW+6G,EAAW,CACtBtnH,MAAOqnH,EAAcloH,EAAO2oH,GAE5B17F,GAAI+7F,EAAKhiD,EACT3/D,GAAI2hH,EAAKhiD,EACToiD,UAAWA,EAEXl8F,GAAI+7F,EAAKjiD,EACTz/D,GAAI0hH,EAAKjiD,EACTqiD,UAAWA,EAEXC,cAAeZ,EAAIC,GACnB/uB,cAAe55F,EAAM45F,gBAGzB31D,EAAS0kF,EAAI3oH,EAAOmoH,GACpBlnH,EAASyX,mBAAmB,YAAa,YAAzCzX,CAAsD0nH,EAAI3oH,EAAOmoH,GAE1D,CAACA,IAKhB,IAAiC,IAA9BK,EAAQvhH,QAAQ,UAAmBjH,EAAMupH,UAAW,CACnD,IAQIzgH,EAAGkQ,EAAGwwG,EAASt2G,EAAKu2G,EAAQx8F,EAAI5lB,EAAI6lB,EAAI3lB,EARxCmiH,EAAW1pH,EAAMupH,UACjBI,EAAa,GACbC,GAAS,EACTC,EAAOhuF,IACPiuF,GAAQjuF,IACRkuF,EAAOluF,IACPmuF,GAAQnuF,IAIZ,IAAI/yB,EAAI,EAAGA,EAAI4gH,EAAShjH,OAAQoC,KAC5B0gH,EAAUE,EAAS5gH,IAIR+kF,SAAS5+E,KAChB26G,GAAUA,EAEVD,EAAWvjH,KAAKojH,GAChBO,EAAO5lH,KAAKi3B,IAAI2uF,EAAMP,EAAQO,MAC9BC,EAAO7lH,KAAKc,IAAI+kH,EAAMR,EAAQQ,OAItC,GAAGJ,EAAQ,CAWP,IAAIK,IARJF,EAAO5lH,KAAKc,IAAI8kH,EAAM,KACtBC,EAAO7lH,KAAKi3B,IAAI4uF,EAAMpnH,EAAG6iC,WAOE,EAC3B,IAAI38B,EAAI,EAAGA,EAAI6gH,EAAWjjH,OAAQoC,IAE9B,IADAoK,EAAMy2G,EAAW7gH,GAAGoK,IAChB8F,EAAI,EAAGA,EAAI9F,EAAIxM,OAAQsS,KACvBkU,EAAKha,EAAI8F,EAAI,GAAG,IAEPixG,IADT1iH,EAAK2L,EAAI8F,GAAG,KACcixG,IACtBh9F,EAAK/Z,EAAI8F,EAAI,GAAG,GAChB3R,EAAK6L,EAAI8F,GAAG,GACTzR,EAAK2lB,IACJu8F,EAASx8F,GAAM5lB,EAAK4lB,IAAOg9F,EAAO/8F,IAAO3lB,EAAK2lB,GAC9C28F,EAAO1lH,KAAKi3B,IAAIyuF,EAAMJ,GACtBK,EAAO3lH,KAAKc,IAAI6kH,EAAML,KAOtCI,EAAO1lH,KAAKc,IAAI4kH,EAAM,GACtBC,EAAO3lH,KAAKi3B,IAAI0uF,EAAMnnH,EAAG8iC,SAGzB,IAAI5kC,EAAQnB,EAAMyM,YAwBlB,OAvBGzM,EAAMqL,QAAQ/K,EAAMmF,WAAYtE,EAAQb,EAAMmF,UACzCzF,EAAMqL,SAAS/K,EAAMyE,MAAQ,IAAI5D,SACrCA,EAAQb,EAAMyE,KAAK5D,OAGvBM,EAAIiM,WAAW+6G,EAAW,CAGtB+B,SAAU/B,EAAUgC,iBACpBl9F,GAAI48F,EACJxiH,GAAIyiH,EACJ58F,GAAI+8F,EACJ1iH,GAAI0iH,EACJppH,MAAOA,EACP+4F,eAAe,WAGZuuB,EAAU/+F,MAEdppB,EAAM8Q,OAASjI,MAAM+D,QAAQ5M,EAAM8Q,MAClCq3G,EAAUr3G,KAAOsP,OAAOpgB,EAAM8Q,MAC3Bq3G,EAAUr3G,KAAO9Q,EAAMsiB,KAEvB,CAAC6lG,O,4CClLpB,IAAI1oH,EAAK,EAAQ,YACbgqB,EAAU,EAAQ,YAClBxoB,EAAW,EAAQ,YA8BvB,SAASmpH,EAAY1nH,EAAK1C,EAAO8D,GAC7B2lB,EAAQnf,WAAW5H,EAAIlC,UAAU,cAAeR,EAAO8D,GAG3D,SAASumH,EAAU3nH,EAAK1C,EAAO8D,GAC3B2lB,EAAQ9Y,eAAejO,EAAIlC,UAAU,QAASR,EAAO8D,GAezDnE,EAAOC,QAAU,CACba,MAjDJ,SAAeqD,GACX,IAAIzD,EAAIZ,EAAGa,OAAOwD,GAAItD,UAAU,mBAEhCH,EAAEI,MAAM,WAAW,SAASV,GACxB,OAAOA,EAAE,GAAGC,MAAM+K,WAGtB1K,EAAEG,UAAU,YAAYV,MAAK,SAASC,GAGlCqqH,EAFU3qH,EAAGa,OAAOC,MACRR,EAAEC,OAASD,EAAE,GAAGC,MACJ8D,MAG5BzD,EAAEG,UAAU,UAAUV,MAAK,SAASC,GAGhCsqH,EAFU5qH,EAAGa,OAAOC,MACRR,EAAEC,OAASD,EAAE,GAAGC,MACN8D,MAG1BzD,EAAEG,UAAU,wBACPG,KAAK8oB,EAAQ3kB,gBAElBzE,EAAEG,UAAU,wBACPG,KAAK8oB,EAAQpkB,gBAElBpE,EAASyX,mBAAmB,YAAa,QAAzCzX,CAAkDZ,IAyBlD+pH,YAAaA,EACbC,UAAWA,EACXC,cAhBJ,SAAuBxmH,EAAIm6B,EAAIv7B,GAC3B,IAAI1C,EAAQi+B,EAAG,GAAGj+B,MAEfA,EAAMmN,gBACLsc,EAAQ1a,mBAAmBrM,EAAIlC,UAAU,cAAeR,GACxDypB,EAAQ3X,kBAAkBpP,EAAIlC,UAAU,QAASR,KAEjDoqH,EAAY1nH,EAAK1C,EAAO8D,GACxBumH,EAAU3nH,EAAK1C,EAAO8D,O,8CCjD9B,IAAIrE,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YAEpBI,EAAM,EAAQ,YACdC,EAAe,EAAQ,YAEvB1B,EAAQ,EAAQ,YAChB+pB,EAAU,EAAQ,YAClBxoB,EAAW,EAAQ,YACnB0yD,EAAW,EAAQ,YAA8BA,SAEjD42D,EAAc,EAAQ,YACtB1+C,EAAoB0+C,EAAY1+C,kBAChCI,EAAmBs+C,EAAYt+C,iBAE/BxrE,EAAQ,EAAQ,YAChB+lC,EAAU,EAAQ,YAClB7c,EAAY,EAAQ,YACpBpB,EAAa,EAAQ,YAErBiiG,EAAgBjiG,EAAWzX,KAC3B25G,EAAwBliG,EAAW7W,aAEnChQ,EAAwB,EAAQ,YAA+BA,sBAE/DgpH,EAAU/gG,EAAU+gG,QAExB,SAASC,EAAQ5qH,GAAI,OAAOA,EAAEihC,GAC9B,SAAS4pF,EAAW5qH,GAChB,GAAGA,EAAM2qD,IACL,OAAOggE,EAIf,SAASE,EAAQvjG,EAAGlD,GAChB,OAAQkD,EAAIlD,EAAK,GAAK,EAmB1B,SAAS4I,EAAW9V,EAAWnO,EAAYsc,EAAM5C,GAEzC,IAAIqoG,EADR,OAAI/hH,EAAWs8B,YAAYymC,MAAQi/C,EAAc1lG,IAE1C5C,IACCqoG,EAAaroG,KAEVvL,EACJ8V,aACAgO,SAAS3V,EAAK2V,UACdgwF,KAAK3lG,EAAK4lG,QACVnrH,KAAK,OAAO,WAAagrH,GAAcA,OACvChrH,KAAK,aAAa,WAAagrH,GAAcA,QAEzC5zG,EAIf,SAAS6zG,EAAcvoG,GACnB,OAAOA,GAAkBA,EAAewY,SAAW,EA2WvD,SAASkwF,EAAmBtkD,GACxB,MAAkB,SAAVA,EAAoB,EAAIA,EAGpC,SAASukD,EAAmBC,EAAQlmF,GAChC,IAAI5d,EAAInjB,KAAK64B,GAAK,IAAMkI,EACpBmmF,EAASlnH,KAAK6/B,IAAI7/B,KAAK0oC,IAAIvlB,IAC3BgkG,EAASnnH,KAAK6/B,IAAI7/B,KAAK44B,IAAIzV,IAE/B,MAAO,CACHplB,EAAGkpH,EAAOzmH,MAAQ2mH,EAASF,EAAO72G,OAAS82G,EAC3ClpH,EAAGipH,EAAOzmH,MAAQ0mH,EAASD,EAAO72G,OAAS+2G,GAInD,SAASC,EAAgBt+F,EAAI5lB,EAAI6lB,EAAI3lB,EAAI6jH,EAAQ/lG,GAC7C,IAAImmG,IAAiBnmG,EAAKmmG,aACtBC,IAAgBpmG,EAAKomG,YACrB7kD,EAAQvhD,EAAKuhD,OAAS,EACtBloD,EAAS2G,EAAK3G,QAAU,MACxBgtG,EAAmB,QAAXhtG,EACRitG,EAAqB,UAAXjtG,EAEVktG,IADcvmG,EAAKwmG,aAAe,GACT,GAAK,EAC9BC,EAAS,EAAIF,EAEbngF,EAAY2/E,EAAOzmH,MACnB+mC,EAAa0/E,EAAO72G,OACpBiY,EAAKroB,KAAK6/B,IAAI38B,EAAK4lB,GACnBR,EAAKtoB,KAAK6/B,IAAIz8B,EAAK2lB,GAGnB6+F,EACAv/F,EAAM,EAAIk+F,GACVj+F,EAAM,EAAIi+F,EACVA,EAAU,EAEdl+F,GAAM,EAAIu/F,EACVt/F,GAAM,EAAIs/F,EAEV,IAAI7mF,EAASgmF,EAAmBtkD,GAClB,SAAVA,GACEn7B,GAAajf,GAAMkf,GAAcjf,KAClCgf,EAAYjf,GAAMkf,EAAajf,KAC9Bgf,EAAYhf,GAAMif,EAAalf,IAC/Bif,EAAYC,GAAiBlf,EAAKC,IAEpCyY,GAAU,IAGd,IAAI5tB,EAAI6zG,EAAmBC,EAAQlmF,GAE/B7tB,EAAQ,EACTo0G,IACCp0G,EAAQlT,KAAKi3B,IACT,EACA5O,EAAKlV,EAAEpV,EACPuqB,EAAKnV,EAAEnV,IAKf,IAAIyiC,EACAwmF,EAAO92G,KAAOw3G,EACdV,EAAO11G,MAAQk2G,EAEf/mF,GAASumF,EAAOr7G,IAAMq7G,EAAOt7G,QAAU,EACvCg1B,GACC7X,EAAKy9F,GAAWoB,GAChBzkH,EAAKqjH,GAAWkB,EAEjB7mF,GAAW7X,EAAK3lB,GAAM,EACtBy9B,EAAU,EACVC,EAAU,EACd,GAAG0mF,GAAWD,EAAO,CACjB,IAAIM,GAAYR,EAAel0G,EAAEpV,EAAIoV,EAAEnV,GAAK,EACxCqgD,EAAMgpE,EAAeX,EAAQ59F,EAAI5lB,GAAMwjH,EAAQ39F,EAAI3lB,GAEpDikH,EACIG,GACC7mF,EAAU7X,EAAKu1B,EAAMupE,EACrB/mF,GAAWwd,EAAMwpE,IAEjBlnF,EAAUz9B,EAAKm7C,EAAMupE,EACrB/mF,EAAUwd,EAAMwpE,GAGjBL,GACC5mF,EAAU7X,EAAKs1B,EAAMupE,EACrB9mF,GAAWud,EAAMwpE,IAEjBjnF,EAAUx9B,EAAKi7C,EAAMupE,EACrB9mF,EAAUud,EAAMwpE,GAK5B,MAAO,CACHpnF,MAAOA,EACPC,MAAOA,EACPC,QAASA,EACTC,QAASA,EACTC,QAASA,EACTC,QAASA,EACT5tB,MAAOA,EACP6tB,OAAQA,GAqOhBvlC,EAAOC,QAAU,CACb2iB,KAvrBJ,SAAcze,EAAImhD,EAAUG,EAAU6mE,EAAY5mG,EAAM5C,GACpD,IAAI9f,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MACdqF,EAAajF,EAAGkF,YAEhBqc,IACAA,EAAO,CACHymD,KAAM/iE,EAAWk2G,QACjBiN,KAAMnjH,EAAWk2G,QACjBv1C,IAAK3gE,EAAWojH,OAChBC,SAAUrjH,EAAWsjH,aAIzBpgD,EAAiB,MAAOljE,IAG5B,IAAIujH,EAAYnrH,EAAIw4B,gBAAgBsyF,EAAY7mE,EAAU,cAActlD,MAAK,SAASm+B,GAClF,IAAIsuF,EAAY9sH,EAAGa,OAAOC,MACtBP,EAAQi+B,EAAG,GAAGj+B,MACdsiD,EAA8B,cAAftiD,EAAMuI,KACrBikH,EAA2B,WAAfxsH,EAAMuI,KAElBkkH,EADwB,QAAfzsH,EAAMuI,MACgBikH,EAE/BE,EAAc,EACfpqE,GAAetiD,EAAM2sH,UAAU9jG,SAAoC,YAAzB7oB,EAAM2sH,UAAU7gD,OACzD4gD,EAAc1sH,EAAM2sH,UAAUloH,KAAKE,MAAQ,GAG/C,IAAI6mH,EAAsC,MAAtBxrH,EAAM+Z,YACtB6yG,EAAiB7B,EAAc1lG,GAE/BwnG,EAAa1rH,EAAIkJ,aAAakiH,EAAW,IAAK,UAE9C5B,EAAUC,EAAW5qH,GACrB8sH,EAAOD,EAAWrsH,UAAU,WAAW4E,KAAKjE,EAAIkI,SAAUshH,GAE9DmC,EAAKtjH,QAAQC,OAAO,KACfsiB,QAAQ,SAAS,GAEtB+gG,EAAKxjH,OAAOC,SAEZujH,EAAKhtH,MAAK,SAAS6oH,EAAI7/G,GACnB,IAsDIxE,EACAgI,EAvDAygH,EAAMttH,EAAGa,OAAOC,MAMhBysH,EAvFhB,SAAerE,EAAIhmH,EAAIC,EAAI4oH,GACvB,IAAInrH,EAAI,GACJwQ,EAAI,GAEJo8G,EAAQzB,EAAe7oH,EAAKC,EAC5BsqH,EAAQ1B,EAAe5oH,EAAKD,EAQhC,OANAtC,EAAE,GAAK4sH,EAAMpqH,IAAI8lH,EAAGwE,IAAI,GACxBt8G,EAAE,GAAKq8G,EAAMrqH,IAAI8lH,EAAGl1G,IAAI,GAExBpT,EAAE,GAAK4sH,EAAMpqH,IAAI8lH,EAAGyE,IAAI,GACxBv8G,EAAE,GAAKq8G,EAAMrqH,IAAI8lH,EAAGj1G,IAAI,GAEjB83G,EAAe,CAACnrH,EAAGwQ,GAAK,CAACA,EAAGxQ,GA0ElBgtH,CAAM1E,EAAIhmH,EAAIC,EAAI4oH,GAEvBv+F,EAAK+/F,EAAG,GAAG,GACX3lH,EAAK2lH,EAAG,GAAG,GACX9/F,EAAK8/F,EAAG,GAAG,GACXzlH,EAAKylH,EAAG,GAAG,GAGXxgH,EAAiD,IAAtCg/G,EAAenkH,EAAK4lB,EAAK1lB,EAAK2lB,GA2C7C,GAxCG1gB,GAAWigH,GAAsBjmF,EAAQ8mF,aAAattH,EAAO2oH,KAC5Dn8G,GAAU,GAIVA,IACAA,IACKzL,EAAUksB,IACVlsB,EAAUsG,IACVtG,EAAUmsB,IACVnsB,EAAUwG,KAKnBohH,EAAGn8G,QAAUA,EAGVA,IACIg/G,EACCnkH,EAAK4lB,EAEL1lB,EAAK2lB,GAKVw/F,IAAgBlgH,IACZg/G,GACCv+F,GAAM49F,EAAQ59F,EAAI5lB,GAAMqlH,EACxBrlH,GAAMwjH,EAAQ59F,EAAI5lB,GAAMqlH,IAExBx/F,GAAM29F,EAAQ39F,EAAI3lB,GAAMmlH,EACxBnlH,GAAMsjH,EAAQ39F,EAAI3lB,GAAMmlH,IAOd,cAAf1sH,EAAMuI,MACL,IAAIiE,EAAS,CACT,IAAI4C,EAAOpP,EAAM2oH,EAAGnmE,KAAK93C,OACzBpG,EAAK8K,EAAK3K,KAAKE,MACf2H,EAAK8C,EAAKvO,YAGdyD,EAAKkiC,EAAQ8mF,aAAattH,EAAO2oH,GACjCr8G,EAAKq8G,EAAGr8G,IAAMtM,EAAM0K,OAAO7J,MAG/B,SAAS0sH,EAAcxmH,GACnB,IAAI8C,EAASpK,EAAG2E,MAAOE,EAAK,EAAK,EAAG,GAIpC,OAAqB,IAAb+gB,EAAKqkD,KAA+B,IAAlBrkD,EAAK+mG,SAC3B3sH,EAAG2E,MAAMD,KAAKC,MAAM2C,GAAK8C,EAAQ,GAAK9C,EAqB9C,IAAIjD,EAAGG,SAASC,WAAY,CAQxB,IACIspH,EADK9tH,EAAMqL,QAAQuB,GACL,GAAKhI,EAAK,IAAQipH,EA3BxC,SAAyBxmH,EAAG0mH,EAAIC,GAC5B,OAAGA,GAAgB3mH,IAAM0mH,EAKd1mH,EAKJ5C,KAAK6/B,IAAIj9B,EAAI0mH,IAAO,EAAIF,EAAcxmH,GAI5CA,EAAI0mH,EAAKtpH,KAAK0sB,KAAK9pB,GAAK5C,KAAKgD,MAAMJ,IAcpCkmB,EAAKugG,EAAMvgG,EAAI5lB,EAAImkH,GACnBnkH,EAAKmmH,EAAMnmH,EAAI4lB,EAAIu+F,GACnBt+F,EAAKsgG,EAAMtgG,EAAI3lB,GAAKikH,GACpBjkH,EAAKimH,EAAMjmH,EAAI2lB,GAAKs+F,GAGxB,IAAI9oH,EAAMsqB,EAAW7rB,EAAIkJ,aAAa0iH,EAAK,QAAShkH,EAAYsc,EAAM5C,GAMtE,GALA/f,EACKjC,MAAM,gBAAiB,sBACvB2B,KAAK,IAAK09G,OAAOz4G,EAAK4lB,IAAO1lB,EAAK2lB,IAAO,QAAU,IAAMD,EAAK,IAAMC,EAAK,IAAM3lB,EAAK,IAAMF,EAAK,IAAM6lB,EAAK,KAC1GvsB,KAAK8oB,EAAQtT,WAAY8uC,EAASe,YAAaliD,IAEhDiF,EAAWs8B,YAAYymC,MAAQ8gD,EAAgB,CAC/C,IAAIe,EAAWlkG,EAAQjf,kBAAkBxK,GACzCypB,EAAQhf,iBAAiBk+G,EAAIjmH,EAAK1C,EAAO2tH,EAAU7pH,IAoBnE,SAAuBA,EAAImhD,EAAU8nE,EAAK9uF,EAAIn1B,EAAGmkB,EAAI5lB,EAAI6lB,EAAI3lB,EAAI8d,EAAM5C,GACnE,IAIIxS,EAJAtN,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAEdqF,EAAajF,EAAGkF,YAGpB,SAAS4kH,EAAeb,EAAKj8G,EAAMlP,GAa/B,OAZoBT,EAAIkJ,aAAa0iH,EAAK,QACrCj8G,KAAKA,GACL1O,KAAK,CACF,MAAS,mBAAqB6N,EAC9B,cAAe,SAGf,aAAc,IAEjBtP,KAAK8oB,EAAQ7nB,KAAMA,GACnBjB,KAAKS,EAAayQ,gBAAiB/N,GAM5C,IAAI9D,EAAQi+B,EAAG,GAAGj+B,MACdwrH,EAAsC,MAAtBxrH,EAAM+Z,YAEtBjJ,EA8TR,SAAiB/H,EAAYk1B,EAAI7U,EAAOzmB,EAAIC,GACxC,IAGIs+B,EAHAlhC,EAAQi+B,EAAG,GAAGj+B,MAKdkhC,EAJelhC,EAAM4Q,aAmB7B,SAA0B7H,EAAYk1B,EAAI7U,EAAOzmB,EAAIC,GACjD,IAAI5C,EAAQi+B,EAAG,GAAGj+B,MACd4Q,EAAezP,EAAIs9B,WAAWz+B,EAAOopB,EAAO,gBAChD,IAAIxY,EAAc,MAAO,GACzB,IAGIi9G,EAASX,EACTY,EAASC,EAJTzrE,EAA8B,cAAftiD,EAAMuI,KACrBikH,EAA2B,WAAfxsH,EAAMuI,KAIG,MAAtBvI,EAAM+Z,aACL8zG,EAAU,IACVX,EAAQtqH,EACRkrH,EAAU,IACVC,EAAQprH,IAERkrH,EAAU,IACVX,EAAQvqH,EACRmrH,EAAU,IACVC,EAAQnrH,GAOZ,SAASorH,EAAajnH,GAClB,OAAO4sD,EAASo6D,GAAQhnH,GAAG,GAAM+J,KAGrC,IAAI0zF,EAAMvmE,EAAG7U,GACTxI,EAAM,GAEVA,EAAI8O,MAAQ80E,EAAI3zF,EAChB+P,EAAIqtG,WAAartG,EAAIitG,EAAU,UAZVK,EAYiC1pB,EAAI3zF,EAX/C8iD,EAASu5D,EAAOgB,GAAG,GAAMp9G,MADpC,IAAqBo9G,EAcrB,IAAIn8G,EAAK5Q,EAAIs9B,WAAWz+B,EAAOwkG,EAAI17F,EAAG,SAC5B,IAAPiJ,GAAYA,KAAI6O,EAAI9P,KAAOiB,GAE9B6O,EAAIsgB,MAAQsjE,EAAInkG,EAChBugB,EAAIutG,WAAavtG,EAAIktG,EAAU,SAAWE,EAAaxpB,EAAInkG,GAE3D,IAAI4O,EAAK,GACTvN,EAAsBuN,EAAIjP,EAAOwkG,EAAI17F,GAElCw5C,IACC1hC,EAAIy3D,OAASmsB,EAAI4pB,MAAQ5pB,EAAInkG,EAC7BugB,EAAIytG,WAAaL,EAAaptG,EAAIy3D,OAClCz3D,EAAI0tG,MAAQ9pB,EAAIz9F,EAChB6Z,EAAI2tG,WAAaP,EAAaptG,EAAI0tG,OAClC1tG,EAAI4tG,QAAU5tG,EAAI0tG,MAAQ1tG,EAAIy3D,MAC9Bz3D,EAAI6tG,aAAeT,EAAaptG,EAAI4tG,UAGrChC,IACC5rG,EAAIsgB,MAAQsjE,EAAInkG,EAChBugB,EAAIutG,WAAaH,EAAaptG,EAAIsgB,OAElCtgB,EAAI8tG,eAAiBlqB,EAAImqB,KACzB/tG,EAAIguG,oBAAsBztH,EAAIijC,cAAcogE,EAAImqB,MAChD/tG,EAAIiuG,gBAAkBrqB,EAAIsqB,KAC1BluG,EAAImuG,qBAAuB5tH,EAAIijC,cAAcogE,EAAIsqB,MACjDluG,EAAIouG,aAAexqB,EAAIyqB,KACvBruG,EAAIsuG,iBAAmB/tH,EAAIijC,cAAcogE,EAAIyqB,OAGjD,IAAIE,EAAahuH,EAAIs9B,WAAWz+B,EAAOwkG,EAAI17F,EAAG,cAC3CqmH,IAAYvuG,EAAIuuG,WAAaA,GAChC,OAAOhuH,EAAImQ,mBAAmBV,EAAcgQ,EAAK7X,EAAWwI,UAAWtC,EAAI2R,EAAK5gB,EAAMqR,OAAS,IAlFnF+9G,CAAiBrmH,EAAYk1B,EAAI7U,EAAOzmB,EAAIC,GAC9C5C,EAAMqvH,SAoFpB,SAAsBpxF,EAAI7U,EAAOzmB,EAAIC,GACjC,IAAI5C,EAAQi+B,EAAG,GAAGj+B,MACdwrH,EAAsC,MAAtBxrH,EAAM+Z,YACtBuoC,EAA8B,cAAftiD,EAAMuI,KACrBikH,EAA2B,WAAfxsH,EAAMuI,KAOtB,SAASylH,EAAajnH,GAElB,OAAO4sD,EADK63D,EAAe7oH,EAAKC,GACRmE,GAAG,GAAM+J,KAGrC,IAKIiB,EALAs9G,EAAWrvH,EAAMqvH,SACjB7qB,EAAMvmE,EAAG7U,GAETtJ,EAAQuvG,EAAS54G,MAAM,KACvB3F,EAAO,GAGPw+G,EAAU,SAASC,GAAQ,OAAgC,IAAzBzvG,EAAM7Y,QAAQsoH,IAEjDD,EAAQ,UACPx+G,EAAK1K,MApBY8nH,EAoBKjwF,EAAG7U,GAAOvY,EAlBzB8iD,EADK63D,EAAe5oH,EAAKD,EACTurH,GAAG,GAAMp9G,OAFpC,IAAqBo9G,EAuBlBoB,EAAQ,UAEG,KADVv9G,EAAK5Q,EAAIs9B,WAAWz+B,EAAOwkG,EAAI17F,EAAG,UACnBiJ,IAAIjB,EAAK1K,KAAK2L,GAGjC,GAAGuwC,EAAa,CACZ,IAAI+1B,GAASmsB,EAAI4pB,MAAQ5pB,EAAInkG,EACzBiuH,EAAQ9pB,EAAIz9F,EACZynH,EAAUF,EAAQj2C,EAEnBi3C,EAAQ,YAAYx+G,EAAK1K,KAAK4nH,EAAaQ,IAC3Cc,EAAQ,UAAUx+G,EAAK1K,KAAK4nH,EAAa31C,IACzCi3C,EAAQ,UAAUx+G,EAAK1K,KAAK4nH,EAAaM,IAGhD,GAAG9B,EAAU,CACN8C,EAAQ,UAAUx+G,EAAK1K,KAAK4nH,EAAaxpB,EAAInkG,IAEhD,IAAImvH,EAAW,EACZF,EAAQ,oBAAoBE,IAC5BF,EAAQ,qBAAqBE,IAC7BF,EAAQ,kBAAkBE,IAE7B,IAAIC,EAAsBD,EAAW,EAElCF,EAAQ,qBACPv9G,EAAK5Q,EAAIijC,cAAcogE,EAAImqB,MACxBc,IAAqB19G,GAAM,eAC9BjB,EAAK1K,KAAK2L,IAEXu9G,EAAQ,sBACPv9G,EAAK5Q,EAAIijC,cAAcogE,EAAIsqB,MACxBW,IAAqB19G,GAAM,gBAC9BjB,EAAK1K,KAAK2L,IAEXu9G,EAAQ,mBACPv9G,EAAK5Q,EAAIijC,cAAcogE,EAAIyqB,MACxBQ,IAAqB19G,GAAM,aAC9BjB,EAAK1K,KAAK2L,IAIlB,OAAOjB,EAAK1H,KAAK,QA1JLsmH,CAAazxF,EAAI7U,EAAOzmB,EAAIC,GAE5B4jC,EAAQmpF,SAAS3vH,EAAM8Q,KAAMsY,GAGzC,OAAOod,EAAQopF,aAAapF,EAAetpF,GA3UhC2uF,CAAQ9mH,EAAYk1B,EAAIn1B,EAAGnG,EAAIC,GAC1CqN,EA6UJ,SAAyBjQ,EAAOopB,GAC5B,IAAI8X,EAAQsF,EAAQmpF,SAAS3vH,EAAM0R,aAAc0X,GACjD,OAAOod,EAAQspF,iBAAiBrF,EAAuBvpF,GA/UxC6uF,CAAgB/vH,EAAO8I,GAGtC,IAAIknH,EACc,UAAd3qG,EAAKymD,MACS,aAAdzmD,EAAKymD,KAELmkD,EAAUhyF,EAAGn1B,GACbonH,GAAgBF,GAAyBC,EAAQE,SAErD,IAAIr/G,GACiB,SAAjBb,IACEggH,EAAQzjH,SAAWygB,IAAO5lB,GAAM6lB,IAAO3lB,KACpB,SAAjB0I,GACiB,WAAjBA,GAEJ,YADA88G,EAAIzsH,OAAO,QAAQiJ,SAIvB,IAAI6mH,EAAarnH,EAAWnH,KACxByuH,EAAW5vH,EAAM6vH,YAAYryF,EAAGn1B,GAAI9I,GACpCuwH,EAAiB9vH,EAAM+vH,kBAAkBxwH,EAAO8I,EAAGsnH,EAAYC,GAC/DI,EAAkBhwH,EAAMiwH,mBAAmB1wH,EAAO8I,EAAGsnH,GAIrDzH,EAAKoE,EAAIxrF,QACViqF,EACgB,QAAZ7oH,EAAG4F,MAAkBogH,EAAGwE,IAAM,IAEzBlgG,EADDtqB,EAAG2c,MAAM,GAAK3c,EAAG2c,MAAM,GACjB,EAEA3c,EAAG8iC,SAID,QAAZ7iC,EAAG2F,MAAkBogH,EAAGwE,IAAM,IAEzBjgG,EADDtqB,EAAG0c,MAAM,GAAK1c,EAAG0c,MAAM,GACjB1c,EAAG6iC,QAEH,GAMjB,IAGIkrF,EACAvF,EACA3/E,EACAC,EACA9pC,EAPAm6G,EAAW53G,KAAK6/B,IAAI38B,EAAK4lB,GAAM,EAAIy9F,EACnCkG,EAAYzsH,KAAK6/B,IAAIz8B,EAAK2lB,GAAM,EAAIw9F,EAQpB,YAAjBz6G,IACKigH,GAAiBD,EAAQY,OAAM5gH,EAAe,WAGtD,GAAoB,SAAjBA,EACC,GAAGigH,EAAc,CAEbjgH,EAAe,SAEfrO,EAAOT,EAAIgkC,sBAAsBrhC,EAAIysH,GAErCI,EAAgB/C,EAAeb,EAAKj8G,EAAMlP,GAE1CwpH,EAAS3hG,EAAQvU,KAAKy7G,EAAc7tH,QACpC2oC,EAAY2/E,EAAOzmH,MACnB+mC,EAAa0/E,EAAO72G,OAEpB,IACIu8G,EAAcrlF,GAAaswE,GAAYrwE,GAAcklF,EACrDG,EAAuBtlF,GAAamlF,GAAallF,GAAcqwE,EAC/DiV,EAAqB,EACpBjV,GAAYtwE,GAAamlF,EAAYllF,GACrCklF,GAAallF,GAAcqwE,EAAWtwE,GALxBA,EAAY,GAAKC,EAAa,IAQ7ColF,GACAC,GACAC,GAEA/gH,EAAe,UAEfA,EAAe,UACf0gH,EAAcpnH,SACdonH,EAAgB,WAGpB1gH,EAAe,SAIvB,IAAI0gH,EAAe,CACf/uH,EAAOT,EAAIgkC,sBAAsBrhC,EAAsB,YAAjBmM,EAA8BwgH,EAAkBF,GAItF,IAAIU,IAFJN,EAAgB/C,EAAeb,EAAKj8G,EAAMlP,IAELQ,KAAK,aAO1C,GANAuuH,EAAcvuH,KAAK,YAAa,IAChCgpH,EAAS3hG,EAAQvU,KAAKy7G,EAAc7tH,QACpC2oC,EAAY2/E,EAAOzmH,MACnB+mC,EAAa0/E,EAAO72G,OACpBo8G,EAAcvuH,KAAK,YAAa6uH,IAE7BxlF,GAAa,GAAKC,GAAc,EAE/B,YADAilF,EAAcpnH,SAKtB,IAGIiM,GAAWi2G,GAHX7kD,GAAQ5mE,EAAM0oC,UAIE,YAAjBz4B,GACCw7G,GAC4B,SAAxBzrH,EAAMkxH,eACkB,YAAxBlxH,EAAMkxH,cAEV17G,GAuIR,SAA0ByX,EAAI5lB,EAAI6lB,EAAI3lB,EAAI6jH,EAAQ/lG,GAC9C,IASI0mG,EATAP,IAAiBnmG,EAAKmmG,aACtBC,IAAgBpmG,EAAKomG,YACrB7kD,EAAQvhD,EAAKuhD,OAAS,EAEtBn7B,EAAY2/E,EAAOzmH,MACnB+mC,EAAa0/E,EAAO72G,OACpBiY,EAAKroB,KAAK6/B,IAAI38B,EAAK4lB,GACnBR,EAAKtoB,KAAK6/B,IAAIz8B,EAAK2lB,GAMnB6+F,EADDP,EACY/+F,EAAK,EAAIi+F,EAAWA,EAAU,EAE9Bl+F,EAAK,EAAIk+F,EAAWA,EAAU,EAI7C,IAAIrzG,EAAQ,EACTo0G,IACCp0G,EAAQ,EACJlT,KAAKi3B,IAAI,EAAG3O,EAAKif,GACjBvnC,KAAKi3B,IAAI,EAAG5O,EAAKif,IAGzB,IAAIvG,EAASgmF,EAAmBtkD,GAC5BtvD,EAAI6zG,EAAmBC,EAAQlmF,GAG/B8mF,GAAYR,EAAel0G,EAAEpV,EAAIoV,EAAEnV,GAAK,EACxCyiC,GAASwmF,EAAO92G,KAAO82G,EAAO11G,OAAS,EACvCmvB,GAASumF,EAAOr7G,IAAMq7G,EAAOt7G,QAAU,EACvCg1B,GAAW7X,EAAK5lB,GAAM,EACtB09B,GAAW7X,EAAK3lB,GAAM,EACtBy9B,EAAU,EACVC,EAAU,EAEVud,EAAMgpE,EAAeX,EAAQxjH,EAAI4lB,GAAM49F,EAAQ39F,EAAI3lB,GACpDikH,GACC1mF,EAAUz9B,EAAKm7C,EAAMupE,EACrB/mF,EAAUwd,EAAMwpE,IAEhBjnF,EAAUx9B,EAAKi7C,EAAMupE,EACrB9mF,GAAWud,EAAMwpE,GAGrB,MAAO,CACHpnF,MAAOA,EACPC,MAAOA,EACPC,QAASA,EACTC,QAASA,EACTC,QAASA,EACTC,QAASA,EACT5tB,MAAOA,EACP6tB,OAAQA,GA/LIisF,CAAiBlkG,EAAI5lB,EAAI6lB,EAAI3lB,EAAI6jH,EAAQ,CACjDI,aAAcA,EACdC,YAAaA,GACb7kD,MAAOA,OAGX6kD,GAC4B,SAAxBzrH,EAAMkxH,eACkB,WAAxBlxH,EAAMkxH,cAEV17G,GAAY+1G,EAAgBt+F,EAAI5lB,EAAI6lB,EAAI3lB,EAAI6jH,EAAQ,CAChDI,aAAcA,EACdC,YAAaA,GACb7kD,MAAOA,GACPloD,OAAQ1e,EAAMoxH,oBAItB57G,GAAUtF,SAAWtO,EAAKE,KAC1B+pE,EAAkB7rE,EAAMuI,KAAMiN,GAAWzM,GACzCknH,EAAQz6G,UAAYA,GAEpBwX,EAAW2jG,EAAe5nH,EAAYsc,EAAM5C,GACvCrgB,KAAK,YAAajB,EAAIujC,iBAAiBlvB,KA9LpC67G,CAAcvtH,EAAImhD,EAAU8nE,EAAK9uF,EAAIn1B,EAAGmkB,EAAI5lB,EAAI6lB,EAAI3lB,EAAI8d,EAAM5C,GAE3DwiC,EAASe,aACRv8B,EAAQxmB,sBAAsB0lH,EAAIoE,EAAIzsH,OAAO,QAASqC,EAAIC,EAAI5C,EAAMkD,UAAWlD,EAAMmD,cAM7F,IAAImuH,GAA0C,IAArBtxH,EAAMm3F,WAC/B1tE,EAAQtT,WAAWo2G,EAAW+E,EAAqB,KAAOrsE,EAASe,YAAaliD,MAIpF7C,EAASyX,mBAAmB,YAAa,OAAzCzX,CAAiD6C,EAAIwoH,EAAWrnE,EAAU5/B,IAmgB1EkmG,gBAAiBA,I,4CCnwBrB,IAAI9rH,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YACpBC,EAAY,EAAQ,YAEpBG,EAAM,EAAQ,YACduwC,EAAS,EAAQ,YACjBtwC,EAAe,EAAQ,YACvBmwH,EAAiB,EAAQ,YACzB9nG,EAAU,EAAQ,YAClB/pB,EAAQ,EAAQ,YAChB4nC,EAAc,EAAQ,YACtBH,EAAO,EAAQ,YACflmC,EAAW,EAAQ,YAEnBulC,EAAU,EAAQ,YAClB7c,EAAY,EAAQ,YAEpB6nG,EAAuB,EAAQ,YAC/BC,EAAa,EAAQ,YAIrBC,EAAS/nG,EAAU+nG,OACnBC,EAAaxtH,KAAK64B,GAAK00F,EAAS,IAGhCE,EAAU,EAAIztH,KAAK0oC,IAAI8kF,GAIvBE,EAAU1tH,KAAK44B,IAAI40F,GACnBG,EAAU3tH,KAAK0oC,IAAI8kF,GAGnBI,EAAiBpoG,EAAUooG,eAC3BC,EAAeroG,EAAUqoG,aA+rB7B,SAASC,EAAalyH,GAClB,MAAO,CAACA,EAAEC,MAAMopB,MAAOrpB,EAAEqpB,MAAOrpB,EAAEktB,GAAIltB,EAAEmtB,GAAIntB,EAAEuiB,KAAMviB,EAAEqC,KAAMrC,EAAE4C,GAAI5C,EAAE6C,IAAM,IAAIwG,KAAK,KAtqBvFxJ,QAAQi4D,MAAQ,SAAe/zD,EAAIsuC,EAAK7uC,EAAS2uH,GAC7CpuH,EAAK3C,EAAIi4B,YAAYt1B,GAErB3C,EAAIw3B,SACA70B,EAAGkF,YAAYE,KAAOygB,EAAUwoG,QAChCxoG,EAAUyoG,cACV,YA2HR,SAAgBtuH,EAAIsuC,EAAK7uC,EAAS2uH,GAC1B3uH,IAASA,EAAU,MAIvB,IAAI0W,EAAWpR,MAAM+D,QAAQrJ,GAAWA,EAAU,CAACA,GAE/CwF,EAAajF,EAAGkF,YAChBqZ,EAAQtZ,EAAWo/C,QAAU,GAC7BlD,EAAW5iC,EAAM9e,GACjB+mD,EAAevhD,EAAWma,KAAK,aAGnC,GAAG+hC,EAAU,CACT,IAAIotE,EAAoBptE,EAASmD,SAAS7sC,KAAI,SAAS+2G,GACnD,OAAOA,EAAGtxF,MAGd/mB,EAAWA,EAASQ,OAAO43G,GAQ/B,IALA,IAAI3pH,EAAMuR,EAASvT,OACf6rH,EAAU,IAAI1pH,MAAMH,GACpB8pH,EAAU,IAAI3pH,MAAMH,GACpB+pH,GAAkB,EAEd3pH,EAAI,EAAGA,EAAIJ,EAAKI,IAAK,CACzB,IAAI4pH,EAAOz4G,EAASnR,GAEpB,GAAGuZ,EAAMqwG,GAELD,GAAkB,EAClBF,EAAQzpH,GAAKuZ,EAAMqwG,GAAMjvH,MACzB+uH,EAAQ1pH,GAAKuZ,EAAMqwG,GAAMhvH,UACtB,KAAGqF,EAAW2pH,KAAS3pH,EAAW2pH,GAAMC,SAO3C,YADAxxH,EAAIwe,KAAK,yBAA2B+yG,GAJpC,IAAIC,EAAW5pH,EAAW2pH,GAAMC,SAChCJ,EAAQzpH,GAAK6pH,EAASlvH,MACtB+uH,EAAQ1pH,GAAK6pH,EAASjvH,OAO9B,IAAIqZ,EAAYq1B,EAAIr1B,WAAahU,EAAWgU,UAEzCA,IAAc01G,IAAiB11G,EAAY,WAE9C,IAA2E,IAAxE,CAAC,IAAK,IAAK,UAAW,YAAa,aAAa9V,QAAQ8V,KAAsBjZ,EAAGoyC,UAC5EpyC,EAAG0sC,cAAc,aAAe1sC,EAAGqlC,UACvC,OAAO7B,EAAYsrF,WAAW9uH,EAAIsuC,GAGtC,IAcIygF,EAAWC,EAEXC,EAASC,EAAU/0F,EAAIj+B,EAAO+nC,EAAWkrF,EAAUnnD,EACnDs8C,EAAMC,EAAMF,EAAW+K,EAjBvBC,GAA8C,IAA9BpqH,EAAWoqH,cAAuBt3F,IAAW9yB,EAAWoqH,cACxEC,GAA8C,IAA9BrqH,EAAWqqH,cAAuBv3F,IAAW9yB,EAAWqqH,cAGxEC,EAAY,GAMZC,EAAa,GAUbC,EAAc,CACdC,WAAY,KACZC,WAAY,MAKZC,GAAwB,EAK5B,GAAG7qH,MAAM+D,QAAQwlC,GAGb,IADAr1B,EAAY,QACRg2G,EAAU,EAAGA,EAAU3gF,EAAI1rC,OAAQqsH,KACnC90F,EAAKn6B,EAAGoyC,SAAS9D,EAAI2gF,GAASzgF,aAAe,MAEzCtyC,EAAQi+B,EAAG,GAAGj+B,MACe,SAA1Bi+B,EAAG,GAAGj+B,MAAMopG,YACXkqB,EAAWltH,KAAK63B,GACS,MAAtBj+B,EAAM+Z,cACL25G,GAAwB,SAKrC,CACH,IAAIV,EAAW,EAAGA,EAAWlvH,EAAGoyC,SAASxvC,OAAQssH,IAC7C/0F,EAAKn6B,EAAGoyC,SAAS88E,GAEM,UADvBhzH,EAAQi+B,EAAG,GAAGj+B,OACLopG,WAAwB5iE,EAAQmtF,kBAAkB3zH,EAAOia,KAC9Dq5G,EAAWltH,KAAK63B,GACS,MAAtBj+B,EAAM+Z,cACL25G,GAAwB,IAQpC,IACIpL,GAAKC,GAET,IAH0Bn2E,EAAI5S,OAIT8oF,GAAd,QAASl2E,EAAWA,EAAIk2E,IAChBiK,EAAQ,GAAG9sF,QAAU,EAEf8iF,GAAd,QAASn2E,EAAWA,EAAIm2E,IAChBiK,EAAQ,GAAG/sF,QAAU,MAC7B,CAIH,IAA4D,IAAzDiM,EAAOoB,eAAehvC,EAAI,qBAAsBsuC,GAC/C,OAGJ,IAAIwhF,GAAMxhF,EAAI5S,OAAOzpB,wBAOrB,GALAuyG,GAAMl2E,EAAIoJ,QAAUo4E,GAAIt/G,KACxBi0G,GAAMn2E,EAAI0I,QAAU84E,GAAI7jH,IAIrBu4G,GAAM,GAAKA,GAAMiK,EAAQ,GAAG9sF,SAAW8iF,GAAM,GAAKA,GAAMiK,EAAQ,GAAG/sF,QAClE,OAAO6B,EAAYsrF,WAAW9uH,EAAIsuC,GAa1C,GATAA,EAAIyhF,SAAWvL,GAAMiK,EAAQ,GAAGplF,QAChCiF,EAAI0hF,SAAWvL,GAAMiK,EAAQ,GAAGrlF,QAEd0lF,EAAf,SAAUzgF,EAAiB5L,EAAQutF,KAAK95G,EAAUm4B,EAAIg2E,MACxC5hF,EAAQwtF,IAAIzB,EAASjK,IAEpBwK,EAAf,SAAU1gF,EAAiB5L,EAAQutF,KAAK95G,EAAUm4B,EAAIi2E,MACxC7hF,EAAQwtF,IAAIxB,EAASjK,KAElCxnH,EAAU8xH,EAAU,MAAQ9xH,EAAU+xH,EAAU,IAEhD,OADA3xH,EAAIwe,KAAK,kBAAmByyB,EAAKtuC,GAC1BwjC,EAAYsrF,WAAW9uH,EAAIsuC,GAM1C,IAAI83E,GAAWruF,IAKf,SAASo4F,GAAgBC,EAAYC,GACjC,IAAInB,EAAW,EAAGA,EAAWM,EAAW5sH,OAAQssH,IAI5C,IAHA/0F,EAAKq1F,EAAWN,KAGL/0F,EAAG,IAAOA,EAAG,GAAGj+B,QAIN,KAFrBA,EAAQi+B,EAAG,GAAGj+B,OAEL6oB,SAAsC,IAAlB7oB,EAAMylC,UAI6B,IAA7D,CAAC,SAAU,iBAAiBx+B,QAAQjH,EAAMiR,QAAQqR,MAArD,CAyEA,GAvEkB,UAAftiB,EAAMuI,KAILw/B,EAAY9tB,EADZg5G,EAAW,IAGXlrF,EAAYvB,EAAQ4tF,WAAWp0H,GAC/BizH,EAAWh5G,EAAShT,QAAQ8gC,IAIhC+jC,EAAO/uD,EACJypB,EAAQ3uB,eAAei0D,KACtBA,EAAOA,EAAK7uD,OAAO,IAIvBkrG,EAAY,CAERlqF,GAAIA,EACJj+B,MAAOA,EACP2C,GAAI4vH,EAAQU,GACZrwH,GAAI4vH,EAAQS,GAMZ9I,iBAAkBgJ,EAClBkB,iBAAkBjB,EAGlBhqG,OAAO,EACP8gG,SAAU/lH,KAAKi3B,IAAI8uF,GAAUiJ,GAK7B7J,cAAeztF,IAIfy4F,YAAQzpH,EACR0pH,YAAQ1pH,EAGRhK,MAAOnB,EAAMyM,YACbmW,KAAMtiB,EAAMsiB,KACZ2K,QAAIpiB,EACJxD,QAAIwD,EACJqiB,QAAIriB,EACJtD,QAAIsD,EACJu+G,eAAWv+G,EACXw+G,eAAWx+G,EACX2pH,eAAW3pH,EACXiG,UAAMjG,GAIP9B,EAAWg/B,KACVogF,EAAU5kH,QAAUwF,EAAWg/B,GAAW4qF,UAG3C5pH,EAAW0rH,cAAgB1rH,EAAW0rH,aAAaz0H,EAAM+M,OACxDo7G,EAAUh9C,MAAQpiE,EAAW0rH,aAAaz0H,EAAM+M,MAGpDmmH,EAA0BG,EAAU3sH,OAIxB,UAATolE,EAAkB,CACjB,IAAI50D,EAAYk7B,EAAI4gF,GACjB,gBAAiB97G,GAChBixG,EAAU/+F,MAAQlS,EAAUw9G,YAC5B5oD,EAAO,YAEPA,EAAO,GACJ,SAAU50D,IACTkxG,EAAOlxG,EAAUkxG,KACjBt8C,EAAO,KAER,SAAU50D,IACTmxG,EAAOnxG,EAAUmxG,KACjBv8C,EAAOA,EAAO,UAAY,gBAGbjhE,IAAfqpH,QAA2CrpH,IAAfspH,GAClC/L,EAAO8L,EACP7L,EAAO8L,IAEP/L,EAAOyK,EAAUI,GACjB5K,EAAOyK,EAAUG,IAIrB,GAAqB,IAAlBE,EACC,GAAGnzH,EAAMiR,SAAWjR,EAAMiR,QAAQi3F,YAAa,CAC3C,IAAIysB,EAAY30H,EAAMiR,QAAQi3F,YAAYigB,EAAWC,EAAMC,EAAMv8C,EAAM/iE,EAAW8gC,aAClF,GAAG8qF,EAEC,IADA,IAAIC,EACIC,EAAc,EAAGA,EAAcF,EAAUjuH,OAAQmuH,IACrDD,EAAWD,EAAUE,GAClB9zH,EAAU6zH,EAAS3nG,KAAOlsB,EAAU6zH,EAAS1nG,KAC5CmmG,EAAUjtH,KAAK0uH,EAAWF,EAAU73G,SAKhD5b,EAAIk3B,IAAI,oCAAqCr4B,GAcrD,GAPiB,YAAd+c,GAA2Bs2G,EAAU3sH,OAASwsH,IAC7CG,EAAUzzG,OAAO,EAAGszG,GACpBhJ,GAAWmJ,EAAU,GAAGnJ,UAKzB5/D,GAAmC,IAAlB8oE,GACQ,IAArBC,EAAU3sH,OAAc,CACvByhH,EAAU+B,SAAWkJ,EACrBjL,EAAU/+F,OAAQ,EAClB,IAAI2rG,EAAgB/0H,EAAMiR,QAAQi3F,YAAYigB,EAAWC,EAAMC,EAAM,UAAWt/G,EAAW8gC,aAQ3F,GAPGkrF,IACCA,EAAgBA,EAAcz5E,QAAO,SAAS05E,GAG1C,OAAOA,EAAM1L,eAAiB8J,MAGnC2B,GAAiBA,EAAcruH,OAAQ,CACtC,IAAIuuH,EACAC,EAAiBH,EAAcz5E,QAAO,SAAS05E,GAC/C,OAAOA,EAAMryH,GAAGstD,YAAqC,iBAAvB+kE,EAAMryH,GAAGub,aAE3C,GAAGg3G,EAAexuH,OAAQ,CACtB,IAAIyuH,EAAaD,EAAe,GAC7Bn0H,EAAUo0H,EAAWloG,KAAOlsB,EAAUo0H,EAAWjoG,MAChD+nG,EAAWG,GAAeD,KACtB5B,EAAYE,YAAeF,EAAYE,WAAWnK,cAAgB2L,EAAS3L,iBAC3EiK,EAAYE,WAAawB,IAKrC,IAAII,EAAiBN,EAAcz5E,QAAO,SAAS05E,GAC/C,OAAOA,EAAMpyH,GAAGqtD,YAAqC,iBAAvB+kE,EAAMpyH,GAAGsb,aAE3C,GAAGm3G,EAAe3uH,OAAQ,CACtB,IAAI4uH,EAAaD,EAAe,GAC7Bt0H,EAAUu0H,EAAWroG,KAAOlsB,EAAUu0H,EAAWpoG,MAChD+nG,EAAWG,GAAeE,KACtB/B,EAAYC,YAAeD,EAAYC,WAAWlK,cAAgB2L,EAAS3L,iBAC3EiK,EAAYC,WAAayB,QAYzD,SAASM,GAAmBC,EAAYpC,GAIpC,IAHA,IAEIqC,EAFAC,EAAc,KACdC,EAAc95F,IAEV/yB,EAAI,EAAGA,EAAI0sH,EAAW9uH,OAAQoC,KAClC2sH,EAAoBD,EAAW1sH,GAAGwgH,gBACVqM,GAAeF,GAAqBrC,IACxDsC,EAAcF,EAAW1sH,GACzB6sH,EAAcF,GAGtB,OAAOC,EAGX,SAASN,GAAeJ,GACpB,OAAIA,EACG,CACHryH,GAAIqyH,EAAMryH,GACVC,GAAIoyH,EAAMpyH,GACVV,OAAoB2I,IAAjBmqH,EAAMV,OAAuBU,EAAMV,QAAUU,EAAM/nG,GAAK+nG,EAAM3tH,IAAM,EACvElF,OAAoB0I,IAAjBmqH,EAAMT,OAAuBS,EAAMT,QAAUS,EAAM9nG,GAAK8nG,EAAMztH,IAAM,EACvE2iH,SAAU8K,EAAM9K,SAChBZ,cAAe0L,EAAM1L,cACrBh3E,YAAa0iF,EAAMh1H,MAAMopB,MACzBvoB,MAAOm0H,EAAMn0H,MACb6zH,YAAaM,EAAM5rG,OAVL,KAjBtB6qG,KA+BA,IAAI2B,GAAgB,CAChB7sH,WAAYA,EACZmX,UAAWnX,EAAW8gC,YACtBC,eAAgB/gC,EAAW8sE,UAC3BloD,MAAOykB,GAEPyjF,GAAiB/xH,EAAGgyH,aACpBC,GAAiB,CACjBtC,WAAYF,EAAYE,WACxBD,WAAYD,EAAYC,YAK5B,GAHA1vH,EAAGgyH,aAAeC,GAGfzrE,GAAmC,IAAlB8oE,GACQ,IAArBC,EAAU3sH,OAAc,CACvB,IAGIsvH,GAAYT,GAHIlC,EAAU/3E,QAAO,SAAS05E,GAC1C,OAAOA,EAAMpyH,GAAGqtD,cAE8BmjE,GAClDG,EAAYC,WAAa4B,GAAeY,IAExC,IAGIC,GAAYV,GAHIlC,EAAU/3E,QAAO,SAAS05E,GAC1C,OAAOA,EAAMryH,GAAGstD,cAE8BmjE,GAClDG,EAAYE,WAAa2B,GAAea,IAKhD,GAAwB,IAArB5C,EAAU3sH,OAAc,CACvB,IAAIwhF,GAAS5gD,EAAYsrF,WAAW9uH,EAAIsuC,GAMxC,OALGkY,GAA6C,OAA3BipE,EAAYC,YAAoD,OAA3BD,EAAYE,YAC/DyC,EAAcL,KACbM,EAAiBryH,EAAIyvH,EAAaqC,IAGnC1tC,GAGR59B,GACI4rE,EAAcL,KACbM,EAAiBryH,EAAIyvH,EAAaqC,IAO1C,GAHAvC,EAAU79F,MAAK,SAAS4gG,EAAIC,GAAM,OAAOD,EAAGlM,SAAWmM,EAAGnM,YAItD1jF,EAAQ8vF,UAAUxqD,IACM,IAAxBunD,EAAU,GAAG3sH,QACe,UAA5B2sH,EAAU,GAAGrzH,MAAMuI,KACrB,CACE,IAAIguH,GAAKlD,EAAU,GACft9B,GAAMwgC,GAAGt4F,GAAGs4F,GAAGntG,OACfytB,GAAoC,UAAvB9tC,EAAWytH,SAAiD,UAA1BztH,EAAW0tH,WAE1Dn5D,GAAOi5D,GAAGj5D,KACV7wB,GAAK8pF,GAAG5zH,GACG,aAAZ8pC,GAAGlkC,OAAqB+0D,GAAO7wB,GAAGy5D,eAAe5oC,KACrC,SAAZ7wB,GAAGlkC,OAAiB+0D,GAAO7wB,GAAG8R,IAAI+e,KAClCy4B,IAAOA,GAAIz+E,GAAKy+E,GAAIz+E,EAAEo/G,YAAcjqF,GAAGzwB,KAAO66B,KAC7CymB,IAAQy4B,GAAIz+E,EAAEq/G,MAGlB,IAAIp5D,GAAOg5D,GAAGh5D,KAEC,cADf9wB,GAAK8pF,GAAG3zH,IACF2F,OAAqBg1D,GAAO9wB,GAAGy5D,eAAe3oC,KACrC,SAAZ9wB,GAAGlkC,OAAiBg1D,GAAO9wB,GAAG8R,IAAIgf,KAClCw4B,IAAOA,GAAIz+E,GAAKy+E,GAAIz+E,EAAEo/G,YAAcjqF,GAAGzwB,KAAO66B,KAC7C0mB,IAAQw4B,GAAIz+E,EAAEq/G,MAGlB1C,GAAgB32D,GAAMC,IAItB,IAAIq5D,GAAW,GACfvD,EAAYA,EAAU/3E,QAAO,SAASi7E,GAClC,IAAIruG,EAAM+pG,EAAasE,GACvB,IAAIK,GAAS1uG,GAET,OADA0uG,GAAS1uG,IAAO,EACT0uG,GAAS1uG,MAM5B,IAAI2uG,GAAe/yH,EAAGk4F,WAClB86B,GAAe,GAInB,IAAI/D,EAAU,EAAGA,EAAUM,EAAU3sH,OAAQqsH,IAAW,CACpD,IAAI9jH,GAAKokH,EAAUN,GACfloF,GAAYrE,EAAQ4C,cAAcn6B,GAAIA,GAAGjP,MAAOiP,GAAGgvB,IAEvD,IAAwB,IAArBhvB,GAAG2qF,cAAyB,CAC3B,IAAIm9B,IAAK,EACN9nH,GAAGgvB,GAAGhvB,GAAGma,QAAUna,GAAGgvB,GAAGhvB,GAAGma,OAAO2tG,KAClCA,GAAK9nH,GAAGgvB,GAAGhvB,GAAGma,OAAO2tG,IAEzB9nH,GAAG2qF,cAAgBm9B,IAAM9nH,GAAGjP,MAAM45F,gBAAiB,EAGvD3qF,GAAG47B,UAAY,CAACA,IAChBisF,GAAa1wH,KAAKykC,IAGtB/mC,EAAGk4F,WAAa86B,GAEhB,IAAIE,GACe,MAAdj6G,IAAsBu2G,EAAW5sH,OAAS,GAAK2sH,EAAU3sH,OAAS,IACpD,YAAdqW,GAA2B22G,GAAyBL,EAAU3sH,OAAS,EAGxEwU,GAAUxb,EAAMyb,QAChBpS,EAAWo2E,cAAgBz/E,EAAMib,WACjC5R,EAAWqS,eAGX67G,GAAY,CACZl6G,UAAWA,EACXi6G,aAAcA,GACd97G,QAASA,GACTgF,UAAWnX,EAAW8gC,YACtBC,eAAgB/gC,EAAW8sE,UAC3BqhD,gBAAiBnuH,EAAWwgC,WAC5B4pF,cAAepqH,EAAWoqH,eAG1BgE,GAAcC,EAAgB/D,EAAW4D,GAAWnzH,GAEpD0iC,EAAQ3uB,eAAekF,MA6kB/B,SAA4Bo6G,EAAaE,EAAOtuH,GAC5C,IAqCIuuH,EAAiBC,EAAYC,EAAe1uH,EAAGkQ,EAAGy+G,EAAKC,EArCvDC,EAAW,EACX1gE,EAAS,EACT2gE,EAAUT,EAAYr1H,OAGtB+1H,EAAc,IAAIhvH,MAAM+uH,GACxB3xH,EAAI,EAiCR,SAAS6xH,EAAeC,GACpB,IAAIC,EAAQD,EAAI,GACZE,EAAQF,EAAIA,EAAIrxH,OAAS,GAY7B,GATA6wH,EAAaS,EAAME,KAAOF,EAAMxmH,IAAMwmH,EAAMn8D,GAAKm8D,EAAMl2H,KAGvD01H,EAAgBS,EAAMzmH,IAAMymH,EAAMp8D,GAAKo8D,EAAMn2H,KAAOk2H,EAAMG,KAMvDZ,EAAa,IAAM,CAClB,IAAIv+G,EAAI++G,EAAIrxH,OAAS,EAAGsS,GAAK,EAAGA,IAAK++G,EAAI/+G,GAAG6iD,IAAM07D,EAClDD,GAAkB,EAEtB,KAAGE,EAAgB,KAAnB,CACA,GAAGD,GAAc,IAAM,CAEnB,IAAIv+G,EAAI++G,EAAIrxH,OAAS,EAAGsS,GAAK,EAAGA,IAAK++G,EAAI/+G,GAAG6iD,IAAM27D,EAClDF,GAAkB,EAEtB,GAAIA,EAAJ,CAKA,IAAIc,EAAc,EAClB,IAAItvH,EAAI,EAAGA,EAAIivH,EAAIrxH,OAAQoC,KACvB2uH,EAAMM,EAAIjvH,IACH0I,IAAMimH,EAAI57D,GAAK47D,EAAI31H,KAAOk2H,EAAMG,MAAMC,IAIjD,IAAItvH,EAAIivH,EAAIrxH,OAAS,EAAGoC,GAAK,KACtBsvH,GAAe,GADUtvH,KAE5B2uH,EAAMM,EAAIjvH,IAIH0I,IAAMwmH,EAAMG,KAAO,IACtBV,EAAIY,KAAM,EACVD,KAGR,IAAItvH,EAAI,EAAGA,EAAIivH,EAAIrxH,UACZ0xH,GAAe,GADKtvH,IAMvB,IAJA2uH,EAAMM,EAAIjvH,IAIH0I,IAAMwmH,EAAME,KAAO,EAMtB,IALAT,EAAIY,KAAM,EACVD,IAGAZ,EAA2B,EAAXC,EAAI31H,KAChBkX,EAAI++G,EAAIrxH,OAAS,EAAGsS,GAAK,EAAGA,IAAK++G,EAAI/+G,GAAG6iD,IAAM27D,EAI1D,IAAI1uH,EAAIivH,EAAIrxH,OAAS,EAAGoC,GAAK,KACtBsvH,GAAe,GADUtvH,KAE5B2uH,EAAMM,EAAIjvH,IACH0I,IAAMimH,EAAI57D,GAAK47D,EAAI31H,KAAOk2H,EAAMG,OACnCV,EAAIY,KAAM,EACVD,OAnGZjB,EAAYr3H,MAAK,SAASC,GACtB,IAAI0sC,EAAK1sC,EAAEs3H,GACPiB,EAA6B,MAArB7rF,EAAGzwB,IAAIiB,OAAO,GACtBmC,EAAMqtB,EAAGntB,MAEJ,IAANrZ,GAAWmZ,GAASA,EAAI,GAAKA,EAAI,KAAQk5G,IACxCrhE,GAAU,GAEd4gE,EAAY5xH,KAAO,CAAC,CAChBs7B,MAAOxhC,EACPuzC,WAAYvzC,EAAEC,MAAMopB,MACpByyC,GAAI,EACJrqD,IAAKzR,EAAEyR,IACP+mH,OAAQx4H,EAAEw4H,OACVz2H,KAAM/B,EAAEy4H,IAAMF,EAAQ1G,EAAU,GAAK,EACrCsG,KAAM,EACNC,KAAOG,EAAQvvH,EAAWpE,MAAQoE,EAAWwL,YAIrDsjH,EAAYriG,MAAK,SAASlO,EAAGlD,GACzB,OAAQkD,EAAE,GAAGixG,OAASn0G,EAAE,GAAGm0G,QAKtBthE,GAAU7yC,EAAE,GAAGkvB,WAAahsB,EAAE,GAAGgsB,eAgF1C,MAAOgkF,GAAmBK,GAAYC,GAAS,CAS3C,IANAD,IAIAL,GAAkB,EAClBxuH,EAAI,EACEA,EAAI+uH,EAAYnxH,OAAS,GAAG,CAE9B,IAAI+xH,EAAKZ,EAAY/uH,GACjB4vH,EAAKb,EAAY/uH,EAAI,GAIrB2K,EAAKglH,EAAGA,EAAG/xH,OAAS,GACpBgN,EAAKglH,EAAG,GAIZ,IAHAnB,EAAa9jH,EAAGjC,IAAMiC,EAAGooD,GAAKpoD,EAAG3R,KAAO4R,EAAGlC,IAAMkC,EAAGmoD,GAAKnoD,EAAG5R,MAG5C,KAAS2R,EAAGykH,OAASxkH,EAAGwkH,MAAUzkH,EAAG0kH,OAASzkH,EAAGykH,KAAO,CAEpE,IAAIn/G,EAAI0/G,EAAGhyH,OAAS,EAAGsS,GAAK,EAAGA,IAAK0/G,EAAG1/G,GAAG6iD,IAAM07D,EAQhD,IALAkB,EAAGryH,KAAKw8B,MAAM61F,EAAIC,GAClBb,EAAYj4G,OAAO9W,EAAI,EAAG,GAG1B4uH,EAAQ,EACJ1+G,EAAIy/G,EAAG/xH,OAAS,EAAGsS,GAAK,EAAGA,IAAK0+G,GAASe,EAAGz/G,GAAG6iD,GAEnD,IADA27D,EAAgBE,EAAQe,EAAG/xH,OACvBsS,EAAIy/G,EAAG/xH,OAAS,EAAGsS,GAAK,EAAGA,IAAKy/G,EAAGz/G,GAAG6iD,IAAM27D,EAChDF,GAAkB,OACfxuH,IAIX+uH,EAAY7xH,QAAQ8xH,GAIxB,IAAIhvH,EAAI+uH,EAAYnxH,OAAS,EAAGoC,GAAK,EAAGA,IAAK,CACzC,IAAIivH,EAAMF,EAAY/uH,GACtB,IAAIkQ,EAAI++G,EAAIrxH,OAAS,EAAGsS,GAAK,EAAGA,IAAK,CACjC,IAAI/J,EAAK8oH,EAAI/+G,GACT2/G,EAAU1pH,EAAGsyB,MACjBo3F,EAAQ9uH,OAASoF,EAAG4sD,GACpB88D,EAAQN,IAAMppH,EAAGopH,MAhvBrBO,CAAmBzB,GAAaH,GAAe,KAAO,KAAMjuH,GAC5D8vH,EAAe1B,GAAaH,KAKhC,GAAG5kF,EAAI5S,QAAU4S,EAAI5S,OAAOs5F,QAAS,CACjC,IAAIC,GAAiB93H,EAASyX,mBAAmB,cAAe,iBAA3CzX,CAA6D6C,EAAIgzH,IACtFvF,EAAe9xH,EAAGa,OAAO8xC,EAAI5S,QAASu5F,GAAiB,UAAY,IAIvE,IAAI3mF,EAAI5S,QAAU0yF,IAkkCtB,SAAsBpuH,EAAIsuC,EAAKykF,GAE3B,IAAIA,GAAgBA,EAAanwH,SAAW5C,EAAGk4F,WAAWt1F,OAAQ,OAAO,EAEzE,IAAI,IAAIoC,EAAI+tH,EAAanwH,OAAS,EAAGoC,GAAK,EAAGA,IAAK,CAC9C,IAAIkwH,EAAQnC,EAAa/tH,GACrBmwH,EAAQn1H,EAAGk4F,WAAWlzF,GAE1B,GAAGkwH,EAAM1mF,cAAgB2mF,EAAM3mF,aAC3BlyB,OAAO44G,EAAMtE,eAAiBt0G,OAAO64G,EAAMvE,cAC3Ct0G,OAAO44G,EAAME,gBAAkB94G,OAAO64G,EAAMC,cAE5C,OAAO,EAGf,OAAO,EAjlC4BC,CAAar1H,EAAIsuC,EAAKykF,IAAe,OAErEA,IACC/yH,EAAGoqB,KAAK,iBAAkB,CACtBP,MAAOykB,EACPuQ,OAAQk0E,KAIhB/yH,EAAGoqB,KAAK,eAAgB,CACpBP,MAAOykB,EACPuQ,OAAQ7+C,EAAGk4F,WACXniF,MAAO04G,EACPz4G,MAAO04G,EACP4G,MAAOvG,EACPwG,MAAOvG,IA3pBMwG,CAAOx1H,EAAIsuC,EAAK7uC,EAAS2uH,OAqC9CtyH,QAAQ8pC,UAAY,SAAmB6vF,EAAYl0G,GAC/C,IAAIm0G,GAAa,EACb3wH,MAAM+D,QAAQ2sH,KACdC,GAAa,EACbD,EAAa,CAACA,IAGlB,IAAI/D,EAAa+D,EAAWh+G,KAAI,SAASk+G,GACrC,MAAO,CACH54H,MAAO44H,EAAU54H,OAASnB,EAAMyM,YAChC8gB,GAAIwsG,EAAUxsG,IAAMwsG,EAAUv3H,GAAK,EACnCmF,GAAIoyH,EAAUpyH,IAAMoyH,EAAUv3H,GAAK,EACnCgrB,GAAIusG,EAAUvsG,IAAMusG,EAAUt3H,GAAK,EACnCoF,GAAIkyH,EAAUlyH,IAAMkyH,EAAUt3H,GAAK,EACnCu3H,OAAQD,EAAUC,OAClBC,OAAQF,EAAUE,OAClBC,OAAQH,EAAUG,OAClB9oH,KAAM2oH,EAAU3oH,KAChBwR,KAAMm3G,EAAUn3G,KAChBu3G,WAAYJ,EAAUI,WAGtBlwF,YAAa8vF,EAAU9vF,YACvBC,WAAY6vF,EAAU7vF,WACtB15B,SAAUupH,EAAUvpH,SACpByB,UAAW8nH,EAAU9nH,UACrBmoH,WAAYL,EAAUK,WACtBC,UAAWN,EAAUM,UAGrB/5H,MAAOy5H,EAAUz5H,OAAS,CACtBopB,MAAO,EACPggF,UAAW,IAEfzmG,GAAI,CAACwqC,QAAS,GACdvqC,GAAI,CAACuqC,QAAS,GACd/jB,MAAO,EAEPwwE,cAAe6/B,EAAU7/B,gBAAiB,EAC1C/uD,UAAW4uF,EAAU5uF,YAAa,EAClCmvF,oBAAqBP,EAAUO,sBAAuB,MAI1DC,EAAax6H,EAAGa,OAAO+kB,EAAKnF,WAC5Bg6G,EAAkB70G,EAAKykB,eAAiBrqC,EAAGa,OAAO+kB,EAAKykB,gBAAkBmwF,EAEzEE,EAAW,CACXp9G,UAAW,UACXi6G,cAAc,EACd97G,QAASmK,EAAKnK,SAAWxb,EAAMib,WAC/BuF,UAAW+5G,EACXnwF,eAAgBowF,GAGhBE,EAAahD,EAAgB5B,EAAY2E,EAAU90G,EAAKvhB,IAIxDu2H,EAAc,EACd37G,EAAS,EAsBb,OArBA07G,EACK5kG,MAAK,SAASlO,EAAGlD,GAAI,OAAOkD,EAAE4F,GAAK9I,EAAE8I,MACrCptB,MAAK,SAASC,EAAG+I,GACd,IAAIwxH,EAAOv6H,EAAEmtB,GAAKntB,EAAEy4H,GAAK,EAGrBz4H,EAAE8J,OADFywH,EARS,EAQgBD,EACbA,EAAcC,EATjB,EAWE,EAGfD,EAAcC,EAAOv6H,EAAEy4H,GAAKz4H,EAAE8J,OAE3Bf,IAAMuc,EAAKk1G,cAAkB77G,EAAS3e,EAAE8J,WAE9C/J,MAAK,SAASC,GACXA,EAAE8J,QAAU6U,KAGpBm6G,EAAeuB,EAAYD,EAASnD,cAE7BwC,EAAaY,EAAaA,EAAWt3H,QA4iBhD,IAAI03H,EAAqB,4BAEzB,SAASpD,EAAgB/D,EAAWhuG,EAAMvhB,GACtC,IAAIiF,EAAajF,EAAGkF,YAChB+T,EAAYsI,EAAKtI,UACjBi6G,EAAe3xG,EAAK2xG,aACpB97G,EAAUmK,EAAKnK,QACfgF,EAAYmF,EAAKnF,UACjB4pB,EAAiBzkB,EAAKykB,eACtBotF,EAAkB7xG,EAAK6xG,iBAAmB,GAK1CttF,EAAavkB,EAAKukB,YAAcjgB,EAAU8wG,UAC1CvqH,EAAWmV,EAAKnV,UAAYyZ,EAAU+wG,cAEtCC,EAAKtH,EAAU,GACf1wH,EAAKg4H,EAAGh4H,GACRC,EAAK+3H,EAAG/3H,GACRg4H,EAAqC,MAAxB79G,EAAUE,OAAO,GAAa,SAAW,SACtD26C,EAAK+iE,EAAGC,GACRC,GAAOz6G,OAAOw3C,IAAO,IAAInhD,MAAM,KAAK,GACpCqkH,EAAmBhxF,EAAehnC,OAAOiT,wBACzCglH,EAAWD,EAAiB/qH,IAC5B87B,EAAaivF,EAAiBn2H,MAC9BmnC,EAAcgvF,EAAiBvmH,OAK/BymH,OACQnwH,IAAP+sD,GACA+iE,EAAGzQ,UAAY7kG,EAAK8tG,gBACN,MAAdp2G,GAAmC,MAAdA,GAK1B,GAAGi+G,EAAiB,CAChB,IACIlyH,EAAGmyH,EADHC,GAAW,EAEf,IAAIpyH,EAAI,EAAGA,EAAIuqH,EAAU3sH,OAAQoC,IAI7B,GAHGoyH,QAAoCrwH,IAAxBwoH,EAAUvqH,GAAG8wH,SAAsBsB,GAAW,GAE7DD,EAAiB5H,EAAUvqH,GAAGsgG,WAAaiqB,EAAUvqH,GAAG9I,MAAMopG,UAC3C,CACf,IAAItpF,EAAQjX,MAAM+D,QAAQquH,GAAkBA,EAAiBA,EAAexkH,MAAM,KAClF,IAA6B,IAA1BqJ,EAAM7Y,QAAQ,SACiB,IAA9B6Y,EAAM7Y,QAAQ8V,GAAmB,CACjCi+G,GAAkB,EAClB,OAMTE,IAAUF,GAAkB,GAGnC,IAAIG,EAAcj7G,EAAU1f,UAAU,cACjC4E,KAAK41H,EAAkB,CAAC,GAAK,IA4JlC,SAASI,EAAkB/H,GACvB,OAAOA,EAAU/3E,QAAO,SAASv7C,GAC7B,YAAwB8K,IAAhB9K,EAAEy0H,YACLz0H,EAAE66H,IAAe,IAAInkH,MAAM,KAAK,KAAOokH,KAKpD,GAnKAM,EAAY3xH,QAAQC,OAAO,KACtBsiB,QAAQ,YAAY,GACzBovG,EAAY7xH,OAAOC,SAEnB4xH,EAAYr7H,MAAK,WACb,IAAI4vB,EAAQjwB,EAAGa,OAAOC,MAClB86H,EAAQl6H,EAAIkJ,aAAaqlB,EAAO,OAAQ,IAAI,SAASrvB,GACrDA,EAAEI,MAAM,CAAC,eAAgB,WAEzB66H,EAAQn6H,EAAIkJ,aAAaqlB,EAAO,OAAQ,IAAI,SAASrvB,GAGrDA,EAAE+B,KAAK,aAAc,MAGrBm5H,EAAgBrE,EAAgB1nG,SAAW9vB,EAAMyM,YACjDqvH,EAAetE,EAAgB3nG,aAAe7vB,EAAMioB,SAAS4zG,GAC7DE,EAAgB/7H,EAAMioB,SAAS4zG,GAC/BG,EAAkB,CAClB75H,OAAQq1H,EAAgBt1H,KAAKC,QAAU+nC,EACvC9nC,KAAMo1H,EAAgBt1H,KAAKE,MAAQoO,EACnCrP,MAAOq2H,EAAgBt1H,KAAKf,OAAS46H,GAGzCJ,EAAM56H,MAAM,CACRuB,KAAMu5H,EACN36H,OAAQ46H,IAGZF,EAAMxqH,KAAK8mD,GACNj3D,KAAK8oB,EAAQ7nB,KAAM85H,GACnB/6H,KAAKS,EAAayU,aAAc,EAAG,GACnClV,KAAKS,EAAayQ,gBAAiB/N,GAExC4rB,EAAMttB,KAAK,YAAa,IAExB,IACIoqB,EAAIC,EADJkvG,EAAML,EAAMx4H,OAAOiT,wBAGvB,GAAiB,MAAdgH,EAAmB,CAClB,IAAI6+G,EAAsB,QAAZj5H,EAAG60C,KAAiB,IAAM,GAExC8jF,EAAMl5H,KAAK,cAAe,UACrBzB,KAAKS,EAAayU,aAAc,EAAgB,QAAZlT,EAAG60C,KACnCujF,EAAWY,EAAI7rH,OAASiiH,EAAiBC,EACzC+I,EAAWY,EAAI5rH,IAAMgiH,EAAiBC,GAE/CxlG,EAAK7pB,EAAGwqC,SAAWwtF,EAAG1tG,GAAK0tG,EAAGtzH,IAAM,EACpColB,EAAK7pB,EAAGuqC,SAAuB,QAAZxqC,EAAG60C,KAAiB,EAAI50C,EAAG6iC,SAE9C,IAAIo2F,EAAYF,EAAIh3H,MAAQ,EAAIqtH,EAE7BxlG,EAAKqvG,GACJrvG,EAAKqvG,EAELR,EAAMj5H,KAAK,IAAK,MAAQy5H,EAAY9J,GAAkB,QAC1C8J,EAA6B,EAAjB9J,GAAsB,IAAM6J,EAAU7J,EAC1D,KAAOC,EAAe2J,EAAIh3H,MAAQ,GAClC,IAAMi3H,GAA0B,EAAf5J,EAAmB2J,EAAIpnH,QACxC,KAAOsnH,EACP,IAAMD,EAAU7J,EAChB,MACEvlG,EAAMzjB,EAAWpE,MAAQk3H,GAC/BrvG,EAAKzjB,EAAWpE,MAAQk3H,EAExBR,EAAMj5H,KAAK,IAAK,KAAOy5H,EAAY9J,GAAkB,MAC3C8J,EAAY,IAAMD,EAAU7J,EAClC,IAAM6J,GAA0B,EAAf5J,EAAmB2J,EAAIpnH,QACxC,KAAOsnH,EACP,IAAMD,EAAU7J,EAChB,KAAO8J,EAA6B,EAAjB9J,GAAsB,MAE7CsJ,EAAMj5H,KAAK,IAAK,QACN2vH,EAAiB,IAAM6J,EAAU7J,EACvC,KAAOC,EAAe2J,EAAIh3H,MAAQ,GAClC,IAAMi3H,GAA0B,EAAf5J,EAAmB2J,EAAIpnH,QACxC,MAAQy9G,EAAe2J,EAAIh3H,MAAQ,GACnC,IAAMi3H,EAAU7J,EAChB,KAAOA,EAAiB,SAE7B,CACH,IAAIrzG,EACAioD,EACAm1D,EACW,UAAZl5H,EAAG40C,MACF94B,EAAS,QACTioD,EAAM,EACNm1D,EAAW,GACXtvG,EAAK7pB,EAAGwqC,QAAUxqC,EAAG8iC,UAErB/mB,EAAS,MACTioD,GAAO,EACPm1D,EAAW,IACXtvG,EAAK7pB,EAAGwqC,SAGZ1gB,EAAK7pB,EAAGuqC,SAAWwtF,EAAGztG,GAAKytG,EAAGpzH,IAAM,EAEpC+zH,EAAMl5H,KAAK,cAAesc,GAE1B28G,EAAMj5H,KAAK,IAAK,QACN05H,EAAW/J,EAAiB,IAAMA,EACxC,KAAOC,EAAe2J,EAAIpnH,OAAS,GACnC,IAAMunH,GAA2B,EAAf9J,EAAmB2J,EAAIh3H,OACzC,MAAQqtH,EAAe2J,EAAIpnH,OAAS,GACpC,IAAMunH,EAAW/J,EAAiB,KAAOA,EAAiB,KAE9D,IAGIz7E,EAHAylF,EAAaJ,EAAIpnH,OAAS,EAC1BynH,EAAMjB,EAAWY,EAAI5rH,IAAMgsH,EAC3B/lF,EAAS,OAASjtC,EAAWG,KAAO,cAAgBtG,EAAGoZ,IAG3D,GAAGwQ,EAAMmvG,EAAIh3H,MAAQ,EAAIqtH,EAAeD,EAAiB,CACrDz7E,EAAW,MAAQy7E,EAAiBC,GAAgB,IAAM+J,EACtD,MAAQJ,EAAIh3H,MAAQqtH,GACpB,IAAM+J,EACN,KAAOJ,EAAIh3H,MAAQqtH,GAAgB,IAEvC,IAAIiK,EAAMN,EAAIh3H,MAAQ6nB,EAAKwlG,EAC3B5wH,EAAayU,aAAaylH,EAAOW,EAAKD,GAIxB,QAAXt9G,GACC48G,EAAM96H,UAAU,SAASV,MAAK,WAC1B,IAAIO,EAAIZ,EAAGa,OAAOC,MACd+hC,EAAQ7Y,EAAQvV,OAAOzK,OAAO,QAC7BqH,KAAKzQ,EAAEyQ,QACPnQ,KAAK8oB,EAAQ7nB,KAAM85H,GACpBQ,EAAU55F,EAAMx/B,OAAOiT,wBACxB5R,KAAKC,MAAM83H,EAAQv3H,OAASR,KAAKC,MAAMu3H,EAAIh3H,QAC1CtE,EAAE+B,KAAK,IAAK65H,EAAMC,EAAQv3H,OAE9B29B,EAAM/4B,iBAIdnI,EAAayU,aAAaylH,EAAO30D,GAAOqrD,EAAeD,GAAiBiK,GACxE1lF,EAAW,KAGf,IAAI6lF,EAAWpzH,EAAWuhC,UAAU9pC,UAAU,IAAMw1C,GAAQ5wC,KAAKkxC,EAAW,CAAC,GAAK,IAClF6lF,EAAS3yH,QAAQC,OAAO,YAAYrH,KAAK,KAAM4zC,GAAQvsC,OAAO,QAC9D0yH,EAAS7yH,OAAOC,SAChB4yH,EAAS77H,OAAO,QAAQ8B,KAAK,IAAKk0C,GAClC7sB,EAAQtT,WAAWmlH,EAAOhlF,EAAWN,EAAS,KAAMlyC,GAGxD4rB,EAAMttB,KAAK,YAAa,aAAeoqB,EAAK,IAAMC,EAAK,KAIvD4mG,EAAY+H,EAAkB/H,MAW/B7sF,EAAQ3uB,eAAekF,GAAY,CAQlC,GANAmD,EAAU1f,UAAU,eAAe+I,cAGxBsB,IAAP+sD,GAAsB+iE,EAAGzQ,UAAY7kG,EAAK8tG,gBAAgBE,EAAY+H,EAAkB/H,IAGpE,IAArBA,EAAU3sH,OAAc,OAG3B,IAAI01H,EAAe,CACflnF,YAAY,EACZjD,OAAQ,CACJqD,MAAO,CAACxkC,KAAM8mD,EAAIh2D,KAAMmH,EAAWwgC,WAAW3nC,MAC9CA,KAAMmH,EAAWwgC,WAAW3nC,KAC5B4tB,QAASzmB,EAAWwgC,WAAW/Z,QAC/BD,YAAaxmB,EAAWwgC,WAAWha,YACnC9B,YAAa,EACbiqB,cAAe,EACfwnE,WAAYn2G,EAAWkpC,OAASlpC,EAAWkpC,OAAOitE,gBAAar0G,EAC/DkP,YAAa,MAGjBsiH,EAAgB,GACpB7K,EAAqB4K,EAAcC,EAAev4H,EAAG8uC,WACrD,IAAI0pF,EAAaD,EAAcpqF,OAG/BqqF,EAAW1oF,QAAU,GACrB,IAAI,IAAI56B,EAAI,EAAGA,EAAIq6G,EAAU3sH,OAAQsS,IAAK,CACtC,IAAIujH,EAAQC,EAAkBnJ,EAAUr6G,IAAI,EAAM+D,EAAWhU,EAAY6uD,GACrE9mD,EAAOyrH,EAAM,GACbj6G,EAAOi6G,EAAM,GACbttH,EAAKokH,EAAUr6G,GACnB/J,EAAGqT,KAAOA,EAENrT,EAAG6B,KADK,KAATwR,EACWA,EAAO,MAAQxR,EAEfA,EAId,IAAImtB,EAAKhvB,EAAGgvB,GAAGhvB,EAAGma,OACf6U,IACIA,EAAG3xB,KAAI2C,EAAG3C,GAAK2xB,EAAG3xB,IAClB2xB,EAAG7xB,MAAK6C,EAAG3C,GAAK2xB,EAAG7xB,KACnB6xB,EAAGhyB,MAAKgD,EAAGhD,IAAMgyB,EAAGhyB,KACpBgyB,EAAGlyB,OAAMkD,EAAGhD,IAAMgyB,EAAGlyB,MACrBkyB,EAAGnyB,MAAKmD,EAAGnD,IAAMmyB,EAAGnyB,KACpBmyB,EAAG/yB,MAAK+D,EAAG/D,IAAM+yB,EAAG/yB,KACpB+yB,EAAGukB,MAAKvzC,EAAGuzC,IAAMvkB,EAAGukB,MAE3BvzC,EAAGszC,WAAY,EAEf+5E,EAAW1oF,QAAQxtC,KAAK,CAAC6I,IAE7BqtH,EAAW1oF,QAAQpe,MAAK,SAASlO,EAAGlD,GAAK,OAAOkD,EAAE,GAAGtnB,MAAMopB,MAAQhF,EAAE,GAAGpkB,MAAMopB,SAC9EkzG,EAAWv7F,MAAQ7gB,EAGnBuxG,EAAW3tH,EAAIw4H,GAGf,IAAI7vG,EAAKtrB,EAAIy0B,KAAKy9F,EAAU93G,KAAI,SAASsL,GAAI,OAAQA,EAAEqG,GAAKrG,EAAEtf,IAAM,MAChEilB,GAAKrrB,EAAIy0B,KAAKy9F,EAAU93G,KAAI,SAASsL,GAAI,OAAQA,EAAEoG,GAAKpG,EAAExf,IAAM,MAChEgtG,GAAkBn0F,EAAU5f,OAAO,YACnCq7H,GAAMtnB,GAAgBvxG,OAAOiT,wBACjCyW,IAAM7pB,EAAGwqC,QACT1gB,GAAM7pB,EAAGuqC,QAAUwuF,GAAIpnH,OAAS,EAGhC,IAAIkoH,GAAUd,GAAIh3H,MAAQ,EAAIqtH,IACVxlG,GAAKiwG,IAAW5wF,IAClBrf,GAAKiwG,IAAW,EAE9BjwG,IAAMiwG,GAENjwG,IAAM,EAAIwlG,EAId,IAAI0K,GAAWf,GAAIpnH,OAAS,EAAIy9G,EAE5B2K,GAAiBlwG,EAAKiwG,IAAY5wF,EAWtC,OAVa4wF,IAAY5wF,IAFPrf,GAAMsuG,EAKhBtuG,EAAK7pB,EAAGuqC,QAAU,EAAI6kF,EAChB2K,KACNlwG,EAAKqf,EAAc4wF,KAG3BroB,GAAgBjyG,KAAK,YAAa,aAAeoqB,GAAK,IAAMC,EAAK,KAE1D4nF,GAMX,IAAI8iB,GAAcj3G,EAAU1f,UAAU,eACjC4E,KAAKiuH,GAAW,SAAStzH,GAGtB,OAAOkyH,EAAalyH,MAwI5B,OAtIAo3H,GAAY3tH,QAAQC,OAAO,KACtBsiB,QAAQ,aAAa,GACrBjsB,MAAK,WACF,IAAIinB,EAAItnB,EAAGa,OAAOC,MAElBwmB,EAAEtd,OAAO,QACJ9I,KAAKjB,EAAMsC,KAAMtC,EAAMoP,WAAWoM,EAAS,KAChD6L,EAAEtd,OAAO,QAAQsiB,QAAQ,QAAQ,GAEjChF,EAAEtd,OAAO,QACJhJ,MAAM,eAAgB,OAC3BsmB,EAAEtd,OAAO,QAAQsiB,QAAQ,QAAQ,GAC5BprB,KAAK8oB,EAAQ7nB,KAAMgoC,EAAY15B,MAE5CinH,GAAY7tH,OAAOC,SAInB4tH,GAAYr3H,MAAK,SAASC,GACtB,IAAIgnB,EAAItnB,EAAGa,OAAOC,MAAM6B,KAAK,YAAa,IAGtCw6H,EAAS78H,EAAEyvB,SAAWzvB,EAAEc,MAExBg8H,EAAYn9H,EAAMyb,QAClBzb,EAAMqL,QAAQ6xH,GAAUA,EAASl9H,EAAMyM,YACvC+O,GAGA4hH,EAAYp9H,EAAMyb,QAClBzb,EAAMqL,QAAQhL,EAAEc,OAASd,EAAEc,MAAQnB,EAAMyM,YACzC+O,GAGAugH,EAAgB17H,EAAE4pC,aAAejqC,EAAMioB,SAASk1G,GAEhDN,EAAQC,EAAkBz8H,EAAGi7H,EAAiBj+G,EAAWhU,EAAY6uD,EAAI7wC,GACzEjW,EAAOyrH,EAAM,GACbj6G,EAAOi6G,EAAM,GAGbxqH,EAAKgV,EAAEzmB,OAAO,aACbK,KAAK8oB,EAAQ7nB,KACV7B,EAAE6pC,YAAcA,EAChB7pC,EAAEmQ,UAAYA,EACdnQ,EAAE4R,WAAa8pH,GAClB3qH,KAAKA,GACL1O,KAAK,aAAc,GACnBzB,KAAKS,EAAayU,aAAc,EAAG,GACnClV,KAAKS,EAAayQ,gBAAiB/N,GAEpCi5H,EAAMh2G,EAAEzmB,OAAO,aACf08H,EAAW,EACXC,EAAY,EAGhB,GAAG36G,GAAQA,IAASxR,EAAM,CACtBisH,EAAIp8H,KAAK8oB,EAAQ7nB,KACT7B,EAAE6pC,YAAcA,EAChB7pC,EAAEmQ,UAAYA,EACd4sH,GACHhsH,KAAKwR,GACLlgB,KAAK,aAAc,GACnBzB,KAAKS,EAAayU,aAAc,EAAG,GACnClV,KAAKS,EAAayQ,gBAAiB/N,GAExC,IAAIo5H,EAAOH,EAAIj6H,OAAOiT,wBACtBinH,EAAWE,EAAKv4H,MAAQ,EAAIqtH,EAC5BiL,EAAYC,EAAK3oH,OAAS,EAAIy9G,OAE9B+K,EAAIxzH,SACJwd,EAAEzmB,OAAO,QAAQiJ,SAGrBwd,EAAEzmB,OAAO,QAAQG,MAAM,CACnBuB,KAAM66H,EACNj8H,OAAQ66H,IAGZ,IAMI0B,EAAeC,EANfzB,EAAM5pH,EAAGjP,OAAOiT,wBAChBouB,EAAMpkC,EAAE4C,GAAGwqC,SAAWptC,EAAEktB,GAAKltB,EAAEsH,IAAM,EACrCg2H,EAAMt9H,EAAE6C,GAAGuqC,SAAWptC,EAAEmtB,GAAKntB,EAAEwH,IAAM,EACrCgJ,EAAKpM,KAAK6/B,IAAIjkC,EAAEsH,GAAKtH,EAAEktB,IACvBzc,EAAKrM,KAAK6/B,IAAIjkC,EAAEwH,GAAKxH,EAAEmtB,IACvBowG,EAAe3B,EAAIh3H,MAAQotH,EAAiBC,EAAegL,EAW/D,GARAj9H,EAAEw9H,IAAMxC,EAAWY,EAAI5rH,IACvBhQ,EAAEy9H,GAAK7B,EAAIh3H,MAAQ,EAAIqtH,EACvBjyH,EAAEy4H,GAAKr0H,KAAKc,IAAI02H,EAAIpnH,OAAS,EAAIy9G,EAAciL,GAC/Cl9H,EAAE2e,OAAS,QACX3e,EAAE09H,QAAU9B,EAAIh3H,MAChB5E,EAAEi9H,SAAWA,EACbj9H,EAAE8J,OAAS,EAERmtH,EACCj3H,EAAEyR,IAAM2yB,EACRg5F,EAAgBE,EAAM7sH,EAAK,EAAI8sH,GAAgBxxF,EAC/CsxF,EAAcC,EAAM7sH,EAAK,EAAI8sH,GAAgB,EACxB,QAAjBv9H,EAAE85H,YAAyBsD,IAAkBC,EAGvCD,GACNE,GAAO7sH,EAAK,EACZzQ,EAAE2e,OAAS,SACR3e,EAAE2e,OAAS,UALd2+G,GAAO7sH,EAAK,EACZzQ,EAAE2e,OAAS,YAUf,GAJA3e,EAAEyR,IAAM6rH,EACRF,EAAgBh5F,EAAM5zB,EAAK,EAAI+sH,GAAgBzxF,EAC/CuxF,EAAcj5F,EAAM5zB,EAAK,EAAI+sH,GAAgB,EAExB,SAAjBv9H,EAAE85H,YAA0BsD,IAAkBC,EAG3C,GAAGD,EACNh5F,GAAO5zB,EAAK,EACZxQ,EAAE2e,OAAS,YACR,CACH3e,EAAE2e,OAAS,SAEX,IAAIg/G,EAAcJ,EAAe,EAC7BK,EAAYx5F,EAAMu5F,EAAc7xF,EAChC+xF,EAAYz5F,EAAMu5F,EACnBC,EAAY,IAAGx5F,GAAOw5F,GACtBC,EAAY,IAAGz5F,IAAQy5F,QAZ1Bz5F,GAAO5zB,EAAK,EACZxQ,EAAE2e,OAAS,MAenB3M,EAAG3P,KAAK,cAAerC,EAAE2e,QACtBs+G,GAAUD,EAAI36H,KAAK,cAAerC,EAAE2e,QACvCqI,EAAE3kB,KAAK,YAAa,aAAe+hC,EAAM,IAAMk5F,EAAM,KAChDrG,EAAe,UAAYtF,EAAS,IAAM,QAG5CyF,GAGX,SAASqF,EAAkBz8H,EAAGi7H,EAAiBj+G,EAAWhU,EAAY6uD,EAAI7wC,GACtE,IAAIzE,EAAO,GACPxR,EAAO,QAEWjG,IAAnB9K,EAAE89H,eAA4B99H,EAAEuiB,KAAOviB,EAAE89H,cAEzC99H,EAAEuiB,OACEviB,EAAEC,MAAMqR,QACPtR,EAAEuiB,KAAOnhB,EAAIwuB,eAAe5vB,EAAEuiB,KAAMviB,EAAEC,MAAMqR,QAEhDiR,EAAO6lE,EAAUpoF,EAAEuiB,KAAMviB,EAAE+5H,kBAGfjvH,IAAb9K,EAAE65H,aACe/uH,IAAb9K,EAAE25H,SAAsB5oH,GAAQ,MAAQ/Q,EAAE25H,OAAS,aACtC7uH,IAAb9K,EAAE45H,SAAsB7oH,GAAQ,MAAQ/Q,EAAE45H,OAAS,QAClC,eAAjB55H,EAAEC,MAAMuI,MAA0C,qBAAjBxI,EAAEC,MAAMuI,OACxCuI,IAASA,EAAO,MAAQ,IAAM/Q,EAAE65H,SAE9BoB,GAAmBj7H,EAAEgd,EAAUE,OAAO,GAAK,WAAa26C,EAC9D9mD,EAAO/Q,GAA2B,MAAxBgd,EAAUE,OAAO,GAAa,IAAM,KAAO,UAAY,QAC9CpS,IAAb9K,EAAE25H,YACQ7uH,IAAb9K,EAAE45H,QAAyC,kBAAjB55H,EAAEC,MAAMuI,OACjCuI,EAAO/Q,EAAE45H,QAEiB7oH,OAAXjG,IAAb9K,EAAE45H,OAA6B55H,EAAE25H,OAC/B,IAAM35H,EAAE25H,OAAS,KAAO35H,EAAE45H,OAAS,KAE3C55H,EAAE+Q,MAAmB,IAAX/Q,EAAE+Q,MAAgBjI,MAAM+D,QAAQ7M,EAAE+Q,QAC5CA,IAASA,EAAO,OAAS,IAAM/Q,EAAE+Q,WAQlBjG,IAAhB9K,EAAE+9H,YAAyBhtH,IAASA,EAAO,OAAS,IAAM/Q,EAAE+9H,WAK5D/2G,GAAc,KAATjW,IAAgB/Q,EAAE65F,gBAEV,KAATt3E,GAAayE,EAAExd,SAClBuH,EAAOwR,GAIX,IAAI0gB,EAAWj6B,EAAWwI,UACtBqoF,EAAgB75F,EAAE65F,gBAAiB,EACnCogC,EAAsBj6H,EAAEi6H,qBAAuBj6H,EAC/C8qC,EAAY9qC,EAAE8qC,UAAU,IAAM,GAiBlC,OAhBG+uD,IASC9oF,GARAA,EAAO3P,EAAIuhC,oBACPk3D,EACAogC,EACAh3F,EACA6H,EACA9qC,EAAEC,MAAMqR,QAGAnK,QAAQszH,GAAoB,SAASjkH,EAAOuwE,GAIpD,OAFAxkE,EAAO6lE,EAAUrB,EAAO/mF,EAAE+5H,YAEnB,OAGR,CAAChpH,EAAMwR,GAwLlB,SAASu2G,EAAe1B,EAAaH,GAGjCG,EAAYr3H,MAAK,SAASC,GACtB,IAAIgnB,EAAItnB,EAAGa,OAAOC,MAClB,GAAGR,EAAEs4H,IAAK,OAAOtxG,EAAExd,SAEnB,IAAIwI,EAAKgV,EAAEzmB,OAAO,aACdoe,EAAS3e,EAAE2e,OACXq/G,EAAsB,QAAXr/G,GAAoB,EAAI,EACnCs/G,EAAa,CAACruH,MAAO,EAAGC,KAAM,EAAGC,OAAQ,GAAG6O,GAC5Cu/G,EAAMD,GAAcjM,EAAiBC,GACrCkM,EAAOD,EAAMD,GAAcj+H,EAAE09H,QAAUzL,GACvCn5E,EAAU,EACVL,EAAUz4C,EAAE8J,OAEF,WAAX6U,IACCu/G,GAAOl+H,EAAEi9H,SAAW,EACpBkB,GAAQn+H,EAAE09H,QAAU,EAAIzL,GAEzBgF,IACCx+E,IAAYs5E,EACZj5E,EAAU94C,EAAE8J,OAASgoH,GAGzB9qG,EAAEzmB,OAAO,QAAQ8B,KAAK,IAAgB,WAAXsc,EAEtB,MAAQ3e,EAAEy9H,GAAK,EAAIz9H,EAAEi9H,SAAW,GAAK,KAAOxkF,EAAUz4C,EAAEy4H,GAAK,GAC5D,IAAMz4H,EAAEy9H,GAAK,IAAMz9H,EAAEy4H,GAAK,KAAOz4H,EAAEy9H,GAAK,IAEzC,SAAWO,EAAWhM,EAAiBl5E,GAAW,KAAOk5E,EAAiBv5E,GACvE,KAAOz4C,EAAEy4H,GAAK,EAAIzG,GAClB,IAAOgM,EAAWh+H,EAAEy9H,GACpB,KAAOz9H,EAAEy4H,GACT,KAAOuF,EAAWhM,EAAiBl5E,GACnC,KAAOL,EAAUu5E,GACjB,KAER,IAAIoM,EAAOF,EAAMplF,EACbulF,EAAO5lF,EAAUz4C,EAAEw9H,IAAMx9H,EAAEy4H,GAAK,EAAIxG,EACpC+H,EAAYh6H,EAAEg6H,WAAa,OAEd,SAAdA,IACkB,SAAdA,GAAmC,UAAXr7G,GACvB3M,EAAG3P,KAAK,cAAe,SACvB+7H,EAAkB,WAAXz/G,GACF3e,EAAEy9H,GAAK,EAAIz9H,EAAEi9H,SAAW,EAAIhL,GAC5BjyH,EAAEy9H,GAAKxL,GACQ,UAAd+H,GAAoC,QAAXr7G,IAC/B3M,EAAG3P,KAAK,cAAe,OACvB+7H,EAAkB,WAAXz/G,EACH3e,EAAEy9H,GAAK,EAAIz9H,EAAEi9H,SAAW,EAAIhL,EAC5BjyH,EAAEy9H,GAAKxL,IAInBjgH,EAAGpR,KAAKS,EAAayU,aAAcsoH,EAAMC,GAEtCr+H,EAAEi9H,WACDj2G,EAAEzmB,OAAO,aACJK,KAAKS,EAAayU,aACfqoH,EAAOF,EAAahM,EAAen5E,EACnCL,EAAUz4C,EAAEw9H,IAAMx9H,EAAEy4H,GAAK,EAAIxG,GACrCjrG,EAAEzmB,OAAO,QACJK,KAAK8oB,EAAQjnB,QACV07H,GAAQF,EAAa,GAAKj+H,EAAEi9H,SAAW,EAAInkF,EAC3CL,EAAUz4C,EAAEy4H,GAAK,EAAI,EACrBz4H,EAAEi9H,SAAUj9H,EAAEy4H,GAAK,OAKvC,SAAS1D,EAAW/0H,EAAGgd,GACnB,IAAIqM,EAAQrpB,EAAEqpB,MACVppB,EAAQD,EAAEC,OAAS,GACnB+1F,EAAMh2F,EAAEk+B,GAAG,GACXA,EAAKl+B,EAAEk+B,GAAG7U,IAAU,GAExB,SAASi1G,EAAKt3H,GACV,OAAOA,GAAMhG,EAAUgG,IAAY,IAANA,EAGjC,IAAIu3H,EAASz1H,MAAM+D,QAAQwc,GACvB,SAASwV,EAASC,GACd,IAAI93B,EAAI5F,EAAIs9B,WAAWs3D,EAAK3sE,EAAOwV,GACnC,OAAOy/F,EAAKt3H,GAAKA,EAAI5F,EAAI4P,cAAc,GAAI/Q,EAAO,GAAI6+B,IAE1D,SAASD,EAASC,GACd,OAAO19B,EAAI4P,cAAcktB,EAAIj+B,EAAO4+B,EAASC,IAGrD,SAAS78B,EAAKkmB,EAAK0W,EAASC,GACxB,IAAI5d,EAAMq9G,EAAO1/F,EAASC,GACvBw/F,EAAKp9G,KAAMlhB,EAAEmoB,GAAOjH,GAsC3B,GAnCAjf,EAAK,YAAa,KAAM,aACxBA,EAAK,UAAW,MAAO,sBACvBA,EAAK,cAAe,MAAO,0BAC3BA,EAAK,aAAc,MAAO,0BAC1BA,EAAK,WAAY,MAAO,wBACxBA,EAAK,YAAa,MAAO,yBACzBA,EAAK,aAAc,MAAO,yBAC1BA,EAAK,YAAa,MAAO,oBAEzBjC,EAAEw4H,OAAwB,MAAdx7G,GAAoC,YAAdA,GAAiD,MAAtB/c,EAAM+Z,YAC9Dha,EAAE4C,GAAGwqC,SAAWptC,EAAEktB,GAAKltB,EAAEsH,IAAM,EAC/BtH,EAAE6C,GAAGuqC,SAAWptC,EAAEmtB,GAAKntB,EAAEwH,IAAM,EAGpCxH,EAAEktB,GAAK9rB,EAAI85B,UAAUl7B,EAAEktB,GAAI,EAAGltB,EAAE4C,GAAG8iC,SACnC1lC,EAAEsH,GAAKlG,EAAI85B,UAAUl7B,EAAEsH,GAAI,EAAGtH,EAAE4C,GAAG8iC,SACnC1lC,EAAEmtB,GAAK/rB,EAAI85B,UAAUl7B,EAAEmtB,GAAI,EAAGntB,EAAE6C,GAAG6iC,SACnC1lC,EAAEwH,GAAKpG,EAAI85B,UAAUl7B,EAAEwH,GAAI,EAAGxH,EAAE6C,GAAG6iC,cAGhB56B,IAAhB9K,EAAEqpH,YACDrpH,EAAE25H,OAAU,WAAY35H,EAAKA,EAAE25H,OAASvyF,EAAK+zB,eAAen7D,EAAE4C,GAAI5C,EAAEqpH,WACpErpH,EAAEu9D,KAAOv9D,EAAE4C,GAAGy6C,IAAIr9C,EAAEqpH,iBAELv+G,IAAhB9K,EAAEspH,YACDtpH,EAAE45H,OAAU,WAAY55H,EAAKA,EAAE45H,OAASxyF,EAAK+zB,eAAen7D,EAAE6C,GAAI7C,EAAEspH,WACpEtpH,EAAEw9D,KAAOx9D,EAAE6C,GAAGw6C,IAAIr9C,EAAEspH,iBAILx+G,IAAhB9K,EAAEy0H,gBAAwC3pH,IAAb9K,EAAE65H,SAC9B75H,EAAE65H,OAASx5G,OAAOrgB,EAAEy0H,cAIpB1U,MAAM//G,EAAEw+H,OAAyB,QAAdx+H,EAAE4C,GAAG4F,MAAkBxI,EAAEw+H,MAAQ,GAAI,CACxD,IAAIC,EAASr3F,EAAKwsB,SAAS5zD,EAAE4C,GAAI5C,EAAE4C,GAAG04D,IAAIt7D,EAAEw+H,MAAO,SAASztH,UAC3CjG,IAAd9K,EAAE0+H,QACD1+H,EAAE25H,QAAU,KAAO8E,EAAS,OACxBr3F,EAAKwsB,SAAS5zD,EAAE4C,GAAI5C,EAAE4C,GAAG04D,IAAIt7D,EAAE0+H,SAAU,SAAS3tH,KACnD/Q,EAAE25H,QAAU,MAAQ8E,EAKV,MAAdzhH,IAAmBhd,EAAEmqH,UAAY,GAExC,KAAIpK,MAAM//G,EAAE2+H,OAAyB,QAAd3+H,EAAE6C,GAAG2F,MAAkBxI,EAAE2+H,MAAQ,GAAI,CACxD,IAAIC,EAASx3F,EAAKwsB,SAAS5zD,EAAE6C,GAAI7C,EAAE6C,GAAGy4D,IAAIt7D,EAAE2+H,MAAO,SAAS5tH,UAC3CjG,IAAd9K,EAAE6+H,QACD7+H,EAAE45H,QAAU,KAAOgF,EAAS,OACxBx3F,EAAKwsB,SAAS5zD,EAAE6C,GAAI7C,EAAE6C,GAAGy4D,IAAIt7D,EAAE6+H,SAAU,SAAS9tH,KACnD/Q,EAAE45H,QAAU,MAAQgF,EAEV,MAAd5hH,IAAmBhd,EAAEmqH,UAAY,GAGxC,IAAI2U,EAAW9+H,EAAEqpG,WAAarpG,EAAEC,MAAMopG,UAWtC,OATGy1B,GAAyB,QAAbA,KAEmB,KAD9BA,EAAWh2H,MAAM+D,QAAQiyH,GAAYA,EAAWA,EAASpoH,MAAM,MACnDxP,QAAQ,OAAalH,EAAE25H,YAAS7uH,IACd,IAA3Bg0H,EAAS53H,QAAQ,OAAalH,EAAE45H,YAAS9uH,IACd,IAA3Bg0H,EAAS53H,QAAQ,OAAalH,EAAE65H,YAAS/uH,IACX,IAA9Bg0H,EAAS53H,QAAQ,UAAgBlH,EAAE+Q,UAAOjG,IACZ,IAA9Bg0H,EAAS53H,QAAQ,UAAgBlH,EAAEuiB,UAAOzX,IAG1C9K,EAGX,SAASo2H,EAAiBryH,EAAIixH,EAAe1vG,GACzC,IAOI1iB,EAAIC,EAPJsd,EAAYmF,EAAKnF,UACjBnX,EAAasc,EAAKtc,WAClBk/B,EAAKl/B,EAAWmoB,MAChBkhB,EAAM/sB,EAAKsI,MACXmxG,IAAU/J,EAAcvB,WACxBuL,IAAUhK,EAActB,WAO5B,GAFAvzG,EAAU1f,UAAU,cAAc+I,SAE7Bw1H,GAASD,EAAd,CAEA,IAAIrD,EAAgB/7H,EAAMyb,QAAQpS,EAAWo2E,aAAcp2E,EAAWqS,eAGtE,GAAG0jH,EAAO,CACN,IACIE,EAAaC,EADbzL,EAAauB,EAAcvB,WAG/B7wH,EAAK6wH,GAAcA,EAAW7wH,GAIjB,YAHbC,EAAK4wH,GAAcA,EAAW5wH,IACfsb,WAGX8gH,EAAc5sF,EAAIyhF,SAClBoL,EAAc7sF,EAAI0hF,WAElBkL,EAAcr8H,EAAGwqC,QAAUqmF,EAAWtxH,EACtC+8H,EAAcr8H,EAAGuqC,QAAUqmF,EAAWrxH,GAE1C,IAMI+8H,EAAOC,EANPC,EAAiBp+H,EAAUq+H,YAAY7L,EAAW3yH,MAAO46H,GAAiB,IAC1E/7H,EAAMioB,SAAS8zG,GAAiBjI,EAAW3yH,MAC3Cy+H,EAAQ18H,EAAGqb,UACXshH,EAAa38H,EAAGmb,eAChByhH,EAAS58H,EAAGkb,YAAcshH,EAC1BK,EAAQt4F,EAAKs9B,cAAc3gE,EAAIlB,GAGnC,IAAgC,IAA7B08H,EAAMr4H,QAAQ,YAAiD,IAA7Bq4H,EAAMr4H,QAAQ,UAAkB,CAKjE,IAJgC,IAA7Bq4H,EAAMr4H,QAAQ,YACbi4H,EAAQO,EACRN,EAAYH,IAEgB,IAA7BM,EAAMr4H,QAAQ,UAAkB,CAC/B,IAAIy4H,EAAW98H,EAAG2iE,kBACdo6D,EAAW/8H,EAAG4iE,kBACD,SAAd5iE,EAAG8b,SACFghH,EAAWv7H,KAAKi3B,IAAIskG,EAAU98H,EAAGyR,UACjCsrH,EAAWx7H,KAAKc,IAAI06H,EAAU/8H,EAAGyR,WAErC6qH,EAAQj3F,EAAG1c,EAAIm0G,EAAWz3F,EAAG3lC,EAC7B68H,EAAYl3F,EAAG1c,EAAIo0G,EAAW13F,EAAG3lC,EAIrC4d,EAAUirB,OAAO,OAAQ,gBACpB/oC,KAAK,CACFiF,GAAI63H,EACJ53H,GAAI63H,EACJ53H,GAAI03H,EACJz3H,GAAIy3H,EACJ,eAAgBM,EAChB3+H,OAAQ4+H,EACR,mBAAoB/1G,EAAQ1kB,UAAUnC,EAAGob,UAAWuhH,KAEvDxzG,QAAQ,aAAa,GACrBA,QAAQ,SAAS,GAGtB7L,EAAUirB,OAAO,OAAQ,gBACpB/oC,KAAK,CACFiF,GAAI63H,EACJ53H,GAAI63H,EACJ53H,GAAI03H,EACJz3H,GAAIy3H,EACJ,eAAgBM,EAAa,EAC7B3+H,OAAQ66H,IAEX1vG,QAAQ,aAAa,GACrBA,QAAQ,SAAS,IAGM,IAA7BuzG,EAAMr4H,QAAQ,WACbiZ,EAAUirB,OAAO,SAAU,gBACtB/oC,KAAK,CACFw9H,GAAIH,GAAqB,UAAZ78H,EAAG40C,KAAmB+nF,GAAcA,GACjDM,GAAIZ,EACJp4H,EAAG04H,EACHv9H,KAAMw9H,IAETzzG,QAAQ,aAAa,GAIlC,GAAGgzG,EAAO,CACN,IACIe,EAAaC,EADbtM,EAAasB,EAActB,WAG/B9wH,EAAK8wH,GAAcA,EAAW9wH,GAC9BC,EAAK6wH,GAAcA,EAAW7wH,GAGjB,WAFDD,EAAGub,WAGX4hH,EAAc1tF,EAAIyhF,SAClBkM,EAAc3tF,EAAI0hF,WAElBgM,EAAcn9H,EAAGwqC,QAAUsmF,EAAWvxH,EACtC69H,EAAcn9H,EAAGuqC,QAAUsmF,EAAWtxH,GAE1C,IAMI69H,EAAOC,EANPC,EAAiBl/H,EAAUq+H,YAAY5L,EAAW5yH,MAAO46H,GAAiB,IAC1E/7H,EAAMioB,SAAS8zG,GAAiBhI,EAAW5yH,MAC3Cs/H,EAAQx9H,EAAGsb,UACXmiH,EAAaz9H,EAAGob,eAChBsiH,EAAS19H,EAAGmb,YAAcoiH,EAC1BI,EAAQn5F,EAAKs9B,cAAc3gE,EAAInB,GAGnC,IAAgC,IAA7Bw9H,EAAMl5H,QAAQ,YAAiD,IAA7Bk5H,EAAMl5H,QAAQ,UAAkB,CAKjE,IAJgC,IAA7Bk5H,EAAMl5H,QAAQ,YACb+4H,EAAQM,EACRL,EAAYF,IAEgB,IAA7BI,EAAMl5H,QAAQ,UAAkB,CAC/B,IAAIs5H,EAAW59H,EAAG4iE,kBACdi7D,EAAW79H,EAAG6iE,kBACD,SAAd7iE,EAAG+b,SACF6hH,EAAWp8H,KAAKi3B,IAAImlG,EAAU59H,EAAG0R,UACjCmsH,EAAWr8H,KAAKc,IAAIu7H,EAAU79H,EAAG0R,WAErC2rH,EAAQ/3F,EAAG3wB,GAAK,EAAIkpH,GAAYv4F,EAAG1lC,EACnC09H,EAAYh4F,EAAG3wB,GAAK,EAAIipH,GAAYt4F,EAAG1lC,EAI3C2d,EAAUirB,OAAO,OAAQ,gBACpB/oC,KAAK,CACFiF,GAAIy4H,EACJx4H,GAAIw4H,EACJv4H,GAAIy4H,EACJx4H,GAAIy4H,EACJ,eAAgBG,EAChBx/H,OAAQy/H,EACR,mBAAoB52G,EAAQ1kB,UAAUpC,EAAGqb,UAAWoiH,KAEvDr0G,QAAQ,aAAa,GACrBA,QAAQ,SAAS,GAGtB7L,EAAUirB,OAAO,OAAQ,gBACpB/oC,KAAK,CACFiF,GAAIy4H,EACJx4H,GAAIw4H,EACJv4H,GAAIy4H,EACJx4H,GAAIy4H,EACJ,eAAgBG,EAAa,EAC7Bx/H,OAAQ66H,IAEX1vG,QAAQ,aAAa,GACrBA,QAAQ,SAAS,IAIM,IAA7Bo0G,EAAMl5H,QAAQ,WACbiZ,EAAUirB,OAAO,SAAU,gBACtB/oC,KAAK,CACFw9H,GAAIE,EACJD,GAAIS,GAAqB,QAAZ39H,EAAG60C,KAAiB4oF,GAAcA,GAC/Cv5H,EAAGu5H,EACHp+H,KAAMq+H,IAETt0G,QAAQ,aAAa,KAuBtC,SAASmqG,EAAcpyH,EAAI+xH,GAEvB,OAAIA,IACDA,EAAepC,aAAe3vH,EAAGgyH,aAAarC,YAC7CoC,EAAerC,aAAe1vH,EAAGgyH,aAAatC,YAKtD,SAASrrC,EAAU9nF,EAAGqI,GAClB,OAAOtH,EAAa+mF,UAAU9nF,GAAK,GAAI,CACnCqI,IAAKA,EACL0/E,YAAa,CAAC,KAAM,MAAO,MAAO,IAAK,IAAK,U,4CC7yDpDzoF,EAAOC,QAAU,CACb6gI,QAAS,SAAS3+H,EAAMmmG,GAGpB,IAFA,IAAID,EAAOlmG,EAAK4E,OACZwlH,EAAO,IAAMjkB,EACT9hG,EAAI,EAAGA,EAAI6hG,EAAM7hG,IAAKrE,EAAKqE,IAAM+lH,GAE7CwU,YAAa,SAAS5+H,EAAMmmG,GAExB,IADA,IAAID,EAAOlmG,EAAK4E,OACRP,EAAI,EAAGA,EAAI6hG,EAAM7hG,IAAKrE,EAAKqE,IAAM8hG,GAE7C04B,QAAS,SAAS7+H,EAAMmmG,EAAO8f,EAAK6Y,GAChC,IAAI54B,EAAOlmG,EAAK4E,OAChBk6H,EAAOA,GAAQ,EACf,IAAI,IAAIz6H,EAAI,EAAGA,EAAI6hG,EAAM7hG,IAAKrE,EAAKqE,IAAM4hH,EAAI5hH,GAAKy6H,GAEtD,sBAAuB,SAAS9+H,EAAMmmG,EAAO8f,EAAK6Y,GAC9C,IAAI54B,EAAOlmG,EAAK4E,OACbk6H,IAAM34B,GAAS24B,GAClB,IAAI,IAAIz6H,EAAI,EAAGA,EAAI6hG,EAAM7hG,IAAKrE,EAAKqE,IAAM4hH,EAAI5hH,GAAK8hG,K,4CCnB1DtoG,EAAOC,QAAU,CAGb0rB,KAAM,IAGNu1G,eAAgB,GAGhBxxG,GAAI,EACJC,GAAI,EAGJ1H,YAAa,GACbC,WAAY,K,4CCdhB,IAAI8B,EAAY,EAAQ,YAEpBxoB,EAAM,EAAQ,YAWlBvB,QAAQkhI,qBAAuB,SAASr0F,GACpC,MAAoB,QAAZA,EAAGlkC,KAAkBkkC,EAAG8pB,IAAM,SAASxvD,GAAK,OAAOA,IAG/DnH,QAAQmhI,qBAAuB,SAASt0F,GACpC,MAAoB,QAAZA,EAAGlkC,KAAkBkkC,EAAGqxC,IAAM,SAAS/2E,GAAK,OAAOA,IAG/DnH,QAAQohI,WAAa,SAASC,GAC1B,OAAO,SAASl6H,GAEZ,OADGA,EAAEG,UAASH,EAAIA,EAAEG,QAAQ,IAAK,MAC1B+5H,EAAYl6H,KAI3BnH,QAAQshI,WAAa,SAASC,GAC1B,OAAO,SAASp6H,GAAK,OAAOo6H,EAAcp6H,GAAGG,QAAQ,IAAK,OAG9DtH,QAAQwhI,kBAAoB,SAASjuH,EAAMkuH,GACvC,IAAIC,EAAuB,GAa3B,OAXenuH,EAAKoD,MAAMoT,EAAU43G,WAC3Bv7H,SAAQ,SAASw7H,GACtB,IAAIC,EAAmBJ,EAAYG,EAAQvkH,OAAO,IAAIykH,MACtD,QAAwB72H,IAArB42H,EAAH,CAEA,IAAIE,EAASH,EAAQnhH,OAAO,GAAG9J,MAAMoT,EAAUi4G,UAC3CD,GAAUA,EAAOj7H,OAAS+6H,GAE9BH,EAAqBl7H,KAAKjF,EAAI64B,YAAY2nG,EAAOF,SAG9CH,GAGX1hI,QAAQiiI,eAAiB,SAAS/9H,EAAI6qG,EAAMxhF,GACxC,IACI20G,EADA75F,EAAKnkC,EAAGkF,YAAYkoB,MAGxB,GAAGy9E,EAAM,CACL,IAAI7wB,EAAMl+E,QAAQmhI,qBAAqBpyB,GAEvCmzB,EAAc,SAAS/6H,GACnB,OAAO4nG,EAAKxhE,QAAUwhE,EAAKvhE,IAAI0wC,EAAI/2E,GAAG,KAGzB,SAAd4nG,EAAKpmG,OAAiBu5H,EAAcliI,QAAQohI,WAAWc,SAE1DA,EADM30G,EACQ,SAASpmB,GAAK,OAAOkhC,EAAG3wB,EAAI2wB,EAAG1lC,GAAK,EAAIwE,IAExC,SAASA,GAAK,OAAOkhC,EAAG1c,EAAI0c,EAAG3lC,EAAIyE,GAGrD,OAAO+6H,GAGXliI,QAAQmiI,eAAiB,SAASj+H,EAAI6qG,EAAMxhF,GACxC,IACI60G,EADA/5F,EAAKnkC,EAAGkF,YAAYkoB,MAGxB,GAAGy9E,EAAM,CACL,IAAIp4C,EAAM32D,QAAQkhI,qBAAqBnyB,GACvCqzB,EAAc,SAASnxH,GAAK,OAAO0lD,EAAIo4C,EAAKz+D,IAAIr/B,EAAI89F,EAAKxhE,gBAEzD60F,EADM70G,EACQ,SAAStc,GAAK,OAAO,GAAKA,EAAIo3B,EAAG3wB,GAAK2wB,EAAG1lC,GAEzC,SAASsO,GAAK,OAAQA,EAAIo3B,EAAG1c,GAAK0c,EAAG3lC,GAGvD,OAAO0/H,GAmBXpiI,QAAQqiI,qCAAuC,SAASzwH,EAAK0wH,GACzD,IAAIC,EAAmD,IAAhCh+H,KAAKC,MAAM89H,EAAc,GAC5CE,EAAcj+H,KAAKC,MAAMoN,GAE7B,OAAO2wH,EAAmBC,EAAc,GAAMA,I,4CC3GlD,IAAIrhI,EAAY,EAAQ,YACpBI,EAAM,EAAQ,YACd26C,EAAS,EAAQ,YAA6BA,OASlDl8C,QAAQsmB,MAAQ,SAASA,EAAOP,GAC5B,IAAI08G,EAAmB,QAAX18G,EACR+2B,EAAoB,SAAX/2B,EACT28G,EAAmB,aAAX38G,EACR48G,EAAY7lF,EAASZ,EAAS,EAElC,IAAI51B,EAAO,OAAOq8G,EAElB,GAAGxhI,EAAUmlB,GAET,OADAA,EAAQzF,OAAOyF,KACH,EAAUq8G,EACnBD,EAEQn+H,KAAKc,IAAI,EAAGd,KAAKC,MAAM8hB,IAE/Bw2B,EAEQv4C,KAAKc,IAAI,GAAKihB,GAElBA,EAGX,GAAoB,iBAAVA,IAAwBw2B,IAAU2lF,EACxC,OAAOE,EAGX,IAAIpzH,EAAS+W,EAAMjJ,OAAO,GACtBulH,EAAWt8G,EAAM7F,OAAO,GAG5B,OAFAmiH,EAAWzhI,EAAUyhI,GAAY/hH,OAAO+hH,GAAY,IAEpC,KAEP9lF,GAAqB,MAAXvtC,GAAkBqzH,IAAar+H,KAAKC,MAAMo+H,IAEpDH,GAAoB,MAAXlzH,GAETkzH,GAAoB,MAAXlzH,IAAgC,IAAbqzH,GAA+B,IAAbA,IAE5CD,EAGJr8G,GAaXtmB,QAAQumB,MAAQ,SAASA,EAAOR,EAAQnI,EAAU0I,GAC9C,MAAc,SAAXP,EACQxkB,EAAIszB,UAAUtO,EAAOhlB,EAAI0zB,UAAUrX,IAEjC,OAAV0I,GAA4B,OAAVA,EAKdnlB,EAAUolB,GAAS1F,OAAO0F,GAAS,OAL1C,I,4CCpEJvmB,QAAQ6iI,OAAS,EAAQ,a,4CCDzB,IAAIthI,EAAM,EAAQ,YAIlBvB,QAAQw0H,WAAa,SAASp0H,GAC1B,OAAOA,EAAMuD,SAAYvD,EAAMyD,MAAQzD,EAAM0D,OAAU1D,EAAM0iI,KAKjE9iI,QAAQ+zH,kBAAoB,SAAS3zH,EAAOia,GACxC,GAAkB,UAAfja,EAAMuI,KAAkB,CAGvB,IAFA,IAAIsR,EAAQ7Z,EAAM6Z,OAAS,GACvBC,EAAQ9Z,EAAM8Z,OAAS,GACnBhR,EAAI,EAAGA,EAAI+Q,EAAMnT,OAAQoC,IAC7B,IAAI,IAAIkQ,EAAI,EAAGA,EAAIc,EAAMpT,OAAQsS,IAC7B,IAA8C,IAA3CiB,EAAShT,QAAQ4S,EAAM/Q,GAAKgR,EAAMd,IACjC,OAAO,EAInB,OAAO,EAGX,OAAwD,IAAjDiB,EAAShT,QAAQrH,QAAQw0H,WAAWp0H,KAI/CJ,QAAQm0H,KAAO,SAAS95G,EAAUlT,GAE9B,IADA,IAAIiG,EAAM,IAAInE,MAAMoR,EAASvT,QACrBoC,EAAI,EAAGA,EAAImR,EAASvT,OAAQoC,IAChCkE,EAAIlE,GAAK/B,EAEb,OAAOiG,GAGXpN,QAAQo0H,IAAM,SAAS3zC,EAASt5E,GAE5B,IADA,IAAIiG,EAAM,IAAInE,MAAMw3E,EAAQ35E,QACpBoC,EAAI,EAAGA,EAAIu3E,EAAQ35E,OAAQoC,IAC/BkE,EAAIlE,GAAKu3E,EAAQv3E,GAAGkrH,IAAIjtH,GAE5B,OAAOiG,GAGXpN,QAAQkpG,oBAAsB,SAASh9B,EAAMv7D,EAAIC,EAAIk4G,GACjD,MAAY,YAAT58C,EAA2B48C,GAAO9oH,QAAQqpG,WAAW14F,EAAIC,GAClC,MAAnBs7D,EAAK7uD,OAAO,GAAa1M,EAAKC,GAGzC5Q,QAAQmpG,WAAa,SAAS9qE,EAAI2qF,EAAQT,GAEtC,IAAuB,IAApBA,EAAU/+F,MACN++F,EAAU/+F,OAAS,GAAK++F,EAAU/+F,MAAQ6U,EAAGv3B,OAC5CyhH,EAAU+B,SAAW,EAClB/B,EAAU/+F,OAAQ,OAMzB,IAAI,IAAItgB,EAAI,EAAGA,EAAIm1B,EAAGv3B,OAAQoC,IAAK,CAC/B,IAAI65H,EAAc/Z,EAAO3qF,EAAGn1B,IACzB65H,GAAexa,EAAU+B,WACxB/B,EAAU/+F,MAAQtgB,EAClBq/G,EAAU+B,SAAWyY,GAIjC,OAAOxa,GAWXvoH,QAAQopG,MAAQ,SAAS9tE,EAAIC,EAAIynG,GAC7B,OAAQ1nG,EAAKC,EAAK,GAAY,IAAPD,EAAY0nG,EAAU/mG,KAGjDj8B,QAAQqpG,WAAa,SAAS14F,EAAIC,GAC9B,OAAO,SAASm4G,GACZ,IAAIzmH,EAAIqO,EAAGo4G,GACPxmH,EAAIqO,EAAGm4G,GACX,OAAOxkH,KAAKmiC,KAAKpkC,EAAIA,EAAIC,EAAIA,KAmBrCvC,QAAQwpC,cAAgB,SAASn6B,EAAIjP,EAAOi+B,GAExC,IAAIy2F,EAAc,UAAWzlH,EAAKA,EAAGma,MAAQna,EAAGylH,YAE5C1nH,EAAM,CACN5H,KAAMpF,EAAMqe,OACZtF,SAAU/Y,EACVsyC,YAAatyC,EAAMopB,MACnBsrG,YAAaA,GAGjB,GAAG10H,EAAMk/B,eAAgB,CACrB,IAAI2jG,EAAe7iI,EAAMk/B,eAAew1F,GAEb,IAAxBmO,EAAan8H,OACZsG,EAAI81H,WAAaD,EAAa,GAE9B71H,EAAI61H,aAAeA,OAGvB71H,EAAI81H,WAAapO,EAmBrB,OAhBG10H,EAAMiR,QAAQ45B,UACb79B,EAAMhN,EAAMiR,QAAQ45B,UAAU79B,EAAKiC,EAAIjP,EAAOi+B,EAAIy2F,IAE/C,SAAUzlH,EAAIjC,EAAI9K,EAAI+M,EAAGquD,KACpB,MAAOruD,IAAIjC,EAAI9K,EAAI+M,EAAG/M,GAE3B,SAAU+M,EAAIjC,EAAI7K,EAAI8M,EAAGsuD,KACpB,MAAOtuD,IAAIjC,EAAI7K,EAAI8M,EAAG9M,GAE3B8M,EAAGtM,KAAIqK,EAAIvJ,MAAQwL,EAAGtM,IACtBsM,EAAGrM,KAAIoK,EAAItJ,MAAQuL,EAAGrM,SACLiI,IAAjBoE,EAAGulH,YAAyBxnH,EAAI0b,EAAIzZ,EAAGulH,YAG9C50H,QAAQ8B,sBAAsBsL,EAAKhN,EAAO00H,GAEnC1nH,GAUXpN,QAAQ8B,sBAAwB,SAASymH,EAAWnoH,EAAO00H,GACvD,IAAIv+B,EAAan2F,EAAMo2F,YAEvB,GAAID,EAIJ,IAAI,IAAIrtF,EAAI,EAAGA,EAAIqtF,EAAWzvF,OAAQoC,IAAK,CACvC,IAAI6X,EAAOw1E,EAAWrtF,GAClBof,EAAM66G,EAAYpiH,GAEtB,QAAsB9V,IAAnBs9G,EAAUjgG,GAAoB,CAC7B,IACI86G,EAAWC,EADL9hI,EAAIkO,eAAerP,EAAO2gB,GAAMrR,MACTolH,QAEjB7pH,IAAbm4H,IAAwB7a,EAAUjgG,GAAO86G,MAexDpjI,QAAQsjI,4BAA8B,SAAS/a,EAAWnoH,EAAOk5H,GAC7D,IAAI/iC,EAAan2F,EAAMo2F,YAEvB,GAAID,EAIJ,IAAI,IAAIrtF,EAAI,EAAGA,EAAIqtF,EAAWzvF,OAAQoC,IAAK,CACvC,IAAI6X,EAAOw1E,EAAWrtF,GAClBof,EAAM66G,EAAYpiH,GAEtB,QAAsB9V,IAAnBs9G,EAAUjgG,GAAoB,CAI7B,IAHA,IAAIjH,EAAM9f,EAAIkO,eAAerP,EAAO2gB,GAAMrR,MACtC6zH,EAAS,IAAIt6H,MAAMqwH,EAAaxyH,QAE5BsS,EAAI,EAAGA,EAAIkgH,EAAaxyH,OAAQsS,IACpCmqH,EAAOnqH,GAAKiqH,EAAahiH,EAAKi4G,EAAalgH,IAE/CmvG,EAAUjgG,GAAOi7G,KAK7B,IAAIC,EAAc,CACdz4E,IAAK,KACL04E,UAAW,WACXryH,OAAQ,QACR6uC,OAAQ,QACR,gBAAiB,QACjByjF,QAAS,UAGb,SAASP,EAAYpiH,GACjB,OAAOyiH,EAAYziH,IAASA,EAGhC,SAASsiH,EAAahiH,EAAKyzG,GACvB,OAAG7rH,MAAM+D,QAAQ8nH,GACV7rH,MAAM+D,QAAQqU,IAAQpY,MAAM+D,QAAQqU,EAAIyzG,EAAY,KAC5CzzG,EAAIyzG,EAAY,IAAIA,EAAY,SAD3C,EAIOzzG,EAAIyzG,GAInB,IAAI6O,EAAc,CACdrhI,GAAG,EACHC,GAAG,GAGHqhI,EAAmB,CACnB,aAAa,EACb,aAAa,GAGjB5jI,QAAQiY,eAAiB,SAASkF,GAC9B,MAAwB,iBAAdA,KACDymH,EAAiBzmH,IAG9Bnd,QAAQ02H,UAAY,SAASv5G,GACzB,MAAwB,iBAAdA,KACDwmH,EAAYxmH,K,8CCxPzB,IAAI0mH,EAAgB,CAAC,cAAe,YAAa,aAEjD9jI,EAAOC,QAAU,SAA6BslB,EAASC,EAAUC,EAAQxK,GACrE,IAAI2xC,EAAYnnC,EAAOonC,kBAEnBk3E,EAAa9oH,EAAO,cACxB,GAAG8oH,EAAY,CAEX,IAAIngI,EAAU4hB,EAAS1hB,MAAQ0hB,EAASzhB,MACpCigI,EAAmBp3E,EAAUhpD,GAC7BogI,IAAkBA,EAAmBp3E,EAAUhpD,GAAW,IAE9D,IAAIkpD,EAAYk3E,EAAiBD,GAC7BE,GAAa,EACdn3E,EACCA,EAAU5sD,OAAOuG,KAAK+e,IAEtBsnC,EAAYk3E,EAAiBD,GAAc,CAIvCtjC,aAAc,GAQdvgG,OAAQ,CAACslB,IAEby+G,GAAa,GAUjB,IAJA,IAAIhuD,EAAQ,CACR77D,YAAcoL,EAASjjB,IAAMijB,EAAShjB,EAAK,IAAM,KAG7C2G,EAAI,EAAGA,EAAI26H,EAAc/8H,OAAQoC,IAAK,CAC1C,IAAI1G,EAAOqhI,EAAc36H,GACrB+6H,EAAYzhI,EAAO,QACvB,IAAIqqD,EAAUo3E,GAAY,CACtB,IAAIC,OAAiCj5H,IAAlBqa,EAAQ9iB,GACvB2hI,EAAyB,gBAAT3hI,EACpB,IAAG0hI,GAAgBF,KACfn3E,EAAUrqD,GAAQwY,EAAOxY,EAAMwzE,EAAMxzE,IAElC2hI,IACCt3E,EAAUu3E,SAA+B,MAApBv3E,EAAUrqD,GAC3B,UAAY,WAGjB0hI,IAGCr3E,EAAUo3E,IAAa,GAenBD,WACOn3E,EAAU5sD,OAAO,GAAGuC,GAGxB2hI,KACC,IAAI,IAAI/qH,EAAI,EAAGA,EAAIyzC,EAAU5sD,OAAO6G,OAAS,EAAGsS,IAAK,CACjD,IAAIirH,EAASx3E,EAAU5sD,OAAOmZ,GAC3BirH,EAAO5lH,OAAOrc,OAASiiI,EAAOjiI,OAC7BiiI,EAAOjiI,KAAOyqD,EAAUu3E,YASxD,OAAOv3E,K,4CCzFf,IAAItrD,EAAM,EAAQ,YAElBxB,EAAOC,QAAU,CACbsjD,SAAU,SAASljD,GACf,OAAOA,EAAM6oB,SAAW7oB,EAAM8rE,OACO,IAAjC9rE,EAAM8rE,KAAK7kE,QAAQ,UAG3By8C,WAAY,SAAS1jD,GACjB,OAAOA,EAAM6oB,UACR7oB,EAAM8rE,OAA2C,IAAnC9rE,EAAM8rE,KAAK7kE,QAAQ,YAEnB,UAAfjH,EAAMuI,OAIdo7C,QAAS,SAAS3jD,GACd,OAAOA,EAAM6oB,SAAW7oB,EAAM8rE,OACM,IAAhC9rE,EAAM8rE,KAAK7kE,QAAQ,SAG3BiG,SAAU,SAASlN,GACf,OAAOmB,EAAIY,cAAc/B,EAAM0K,SAC3BvJ,EAAI+K,oBAAoBlM,EAAM0K,OAAO5I,S,8CCxBjD,IAAIoiI,EAAU,EAAQ,YAEtBvkI,EAAOC,QAAU,CACb2I,KAAM,CACFm3C,QAAS,aACTC,KAAM,OACNE,OAAQ,GACR77C,KAAM,UACNi8C,SAAU,sBACVkkF,eAAe,GAEnBt7G,QAAS,CACL62B,QAAS,aACTG,OAAQ,EAAC,GAAM,EAAO,cACtBF,KAAM,OACN37C,MAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,mDACA,2CACA,kCACA,iDACFx2C,KAAK,MAEX8rC,WAAY,CACRwK,QAAS,UACTC,KAAM,OACN37C,MAAM,EACNi8C,SAAU,QACVL,YAAa,CACT,0DACA,iCACFx2C,KAAK,MAEXg7H,YAAa,CACT1kF,QAAS,SACTC,KAAM,OACN37C,KAAM,GACNi8C,SAAU,QACVL,YAAa,CACT,wCACA,kEACA,+BACFx2C,KAAK,MAEX2B,QAAS,CACL20C,QAAS,SACTC,KAAM,QACNvkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACNi8C,SAAU,QACVL,YAAa,kCAEjBt9B,KAAM,CACFo9B,QAAS,SACTC,KAAM,OACNM,SAAU,QACVL,YAAa,CACT,uBACA,0DACFx2C,KAAK,MAEX2D,IAAK,CACD2yC,QAAS,SACTC,KAAM,OACNM,SAAU,OACV+iD,MAAM,EACNpjD,YAAa,CACT,8BACA,wEACA,oBACFx2C,KAAK,MAEXuhD,IAAK,CACDjL,QAAS,aACTO,SAAU,OACV+iD,MAAM,EACNpjD,YAAa,CACT,mCACA,kEACA,iEACFx2C,KAAK,MAEX+lH,WAAY,CACRzvE,QAAS,aACTO,SAAU,OACVL,YAAa,CACT,iCACA,0EACA,2EACA,gBACFx2C,KAAK,MAEXgI,KAAM,CACFsuC,QAAS,MACTmxD,SAAS,EACTlxD,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,4DACA,+CACA,4FACA,6DACA,sBACA,kFACA,2DACA,oBACA,mDACA,mEACA,+BACFx2C,KAAK,MAQX+D,eAAgB,CACZuyC,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,uDACA,yDACA,2EACA,6EACA,8EACFx2C,KAAK,MAGXggG,UAAW,CACP1pD,QAAS,WACTC,KAAM,OACN0kF,MAAO,CAAC,IAAK,IAAK,IAAK,OAAQ,QAC/BC,OAAQ,CAAC,MAAO,OAAQ,QACxBzzB,SAAS,EACT7sG,KAAM,MACNi8C,SAAU,OACVL,YAAa,CACT,sDACA,0EACA,kEACFx2C,KAAK,MAEXmgC,WAAY26F,EAAQ36F,WACpBo2D,OAAQ,CACJ4kC,MAAO,CACH7kF,QAAS,SACT8kF,SAAS,EACTC,QAAQ,EACR9kF,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,mEACA,kEACFx2C,KAAK,MAEXs7H,UAAW,CACPhlF,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,IACLjB,KAAM,IACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,mBACA,gEACA,6BACFx2C,KAAK,MAEX62C,SAAU,QAEdvoC,WAAY,CACRq1F,iBAAkB,YAClB9sD,SAAU,OACVL,YAAa,CACT,yDACA,qDACFx2C,KAAK,MAEXwU,WAAY,CACR8hC,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,2DACA,sEACA,mCACA,qEACA,0BACA,+DACA,gEACA,oEACA,0CACA,qEACA,sEACA,qEACA,qEACA,2DACFx2C,KAAK,Q,4CC1Mf,IAAIi+B,EAAY,EAAQ,YAEpBs9F,EAAY,mBAShBhlI,EAAOC,QAAU,SAAwB2tE,EAAK58B,GAC1C,IAAIi0F,EAAcr3D,EAAInrE,KAAKuiI,GAC3B,GAAGh0F,EAAK,CACJ,IAAIi0F,EAAa,CAEb,IADA,IAAIC,GAAWt3D,EAAInrE,KAAK,UAAY,IAAIqU,MAAM,KACtC3N,EAAI,EAAGA,EAAI+7H,EAAQn+H,OAAQoC,IAAK,CACpC,IAAI+6D,EAAMghE,EAAQ/7H,GACY,IAA3B+6D,EAAI58D,QAAQ,YACXsmE,EAAInrE,KAAKuiI,EAAW9gE,EAAIxjD,OAAO,IAC1B0L,QAAQ83C,GAAK,GAGtB0J,EAAInrE,KAAKuiI,IACTp3D,EAAInrE,KAAKuiI,EArBT,MAwBRt9F,EAAUkmC,EAAK58B,QACTi0F,IACNr3D,EAAInrE,KAAKuiI,EAAW,MA1BZ,OA4BLC,EAA2Bv9F,EAAUkmC,GACnClmC,EAAUkmC,EAAKq3D,M,4CCjC5B,IAAIzjI,EAAM,EAAQ,YAEd2jI,EAAU,EAAQ,YAElBC,EAAY,EAAQ,YACpBv+F,EAAU,EAAQ,YAoDtB7mC,EAAOC,QAxCP,SAAuBkE,EAAIuhB,GACvB,IAAI0uD,EAOJ,OANI5yE,EAAIY,cAAc+B,KAAKiwE,EAAM5yE,EAAIi4B,YAAYt1B,KAEjDuhB,EAAOA,GAAQ,IACV1d,OAAS0d,EAAK1d,QAAU,MAC7B0d,EAAK2/G,eAAgB,EAEd,IAAIp+F,SAAQ,SAASC,EAASC,GAC9BitC,GAAOA,EAAIkoB,qBACVn1D,EAAO,IAAIhF,MAAM,sCAQlB3gC,EAAI++B,QAA0B,QAAhB7a,EAAK1d,QAClBm/B,EAAO,IAAIhF,MAAM0E,EAAQvhB,oBAG1B8uD,IAAKA,EAAIkoB,qBAAsB,GAClC,IAAIgpC,EAAUH,EAAQhhI,EAAIuhB,GAEtB6/G,EAAW7/G,EAAK6/G,UAAYphI,EAAGq6B,IAAM,UACzC+mG,GAAY,IAAM7/G,EAAK1d,OAAOT,QAAQ,IAAK,KAE3C+9H,EAAQznG,MAAK,SAAS0qD,GAElB,OADGnU,IAAKA,EAAIkoB,qBAAsB,GAC3B8oC,EAAU78C,EAAQg9C,EAAU7/G,EAAK1d,WACzC61B,MAAK,SAASlb,GACbukB,EAAQvkB,MACT6iH,OAAM,SAASljB,GACXluC,IAAKA,EAAIkoB,qBAAsB,GAClCn1D,EAAOm7E,W,8CCpDnB,IAAI9gH,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAChBmY,EAAiB,EAAQ,YAAaA,eAE1ClY,EAAOC,QAAU,SAAkCwlI,EAAQlhG,EAAStpB,EAAQyK,GAGxE,SAASggH,EAAgBjjI,GACjBijB,EAAKzjB,KAAKQ,KACVijB,EAAKzjB,KAAKQ,GAAQ8hC,EAAQ+N,OAAS/N,EAAQ+N,OAAOrwC,KAAKQ,GAAQ8hC,EAAQtiC,KAAKQ,IAJpFijB,EAAOA,GAAQ,GASZ6e,GAAWrsB,EAAeqsB,EAAQnnB,aAC7BsI,EAAKzjB,OAAMyjB,EAAKzjB,KAAO,IAC3ByjI,EAAgB,QAChBA,EAAgB,UAChBA,EAAgB,SAEbnhG,EAAQ+N,QACH5sB,EAAKmK,UAASnK,EAAKmK,QAAU9vB,EAAMyb,QAAQ+oB,EAAQ+N,OAAOziB,QAAS0U,EAAQ9oB,gBAC3EiK,EAAKkK,cAAalK,EAAKkK,YAAc2U,EAAQ+N,OAAO1iB,cAEpDlK,EAAKmK,UAASnK,EAAKmK,QAAU0U,EAAQ9oB,gBAIjDR,EAAO,qBAAsByK,EAAKmK,SAClC5U,EAAO,yBAA0ByK,EAAKkK,aACtC3U,EAAO,wBAAyByK,EAAKmpF,YACrCrtG,EAAImkB,WAAW1K,EAAQ,kBAAmByK,EAAKzjB,MAC/CgZ,EAAO,mBAAoByK,EAAK2lB,S,8CC/BpC,IAAIvrC,EAAK,EAAQ,YAEb2nC,EAAK,EAAQ,YACbE,EAAc,EAAQ,YACtBD,EAAY,EAAQ,YAEpB4zC,EAAc,EAAQ,YAAaA,YACnCqqD,EAAc,EAAQ,YAAeA,YAEzC1lI,QAAQ2lI,iBAAmB,SAA0BzhI,GACjD,IAAIiF,EAAajF,EAAGkF,YAEpB,GAAGlF,EAAGG,SAASC,WAEXzE,EAAGa,OAAOwD,GAAItD,UAAU,SAAS+I,cAIrC,GAAIR,EAAWma,KAAK,cAAiBna,EAAWma,KAAK,SAArD,CAEepd,OAAOC,KAAKgD,EAAWo/C,QAAU,IAAI3yB,MAAK,SAASlO,EAAGlD,GAEjE,IAAIrb,EAAWo/C,OAAO7gC,GAAGs/B,WAAY,MAChC79C,EAAWo/C,OAAO/jC,GAAGwiC,WAAY,GAAO,CACzC,IAAI4Y,EAASl4C,EAAE7Q,MAAM,KACjBgpD,EAASr7C,EAAE3N,MAAM,KACrB,OAAQ+oD,EAAO,KAAOC,EAAO,GACxBh/C,OAAO++C,EAAO,IAAM,GAAK/+C,OAAOg/C,EAAO,IAAM,GAC7Ch/C,OAAO++C,EAAO,IAAM,GAAK/+C,OAAOg/C,EAAO,IAAM,GAEtD,OAAO12D,EAAWo/C,OAAO7gC,GAAGs/B,SAAW,GAAK,KAGvC5gD,SAAQ,SAASzC,GACtB,IAAI0hD,EAAWl8C,EAAWo/C,OAAO5kD,GAC7BZ,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAIlB,IAAIuhD,EAAS2B,SAAU,CAGnB,IAAI4+E,EAAWvqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAASvqC,EAAGuqC,QACpDxqC,EAAG8iC,QAAS7iC,EAAG6iC,QAAS,KAAM,MAElC+/F,EAASC,YAAc,SAASrzF,GAG5BtuC,EAAGkF,YAAYi+F,SAAW,WAClBnjG,EAAGkF,YAAY08H,gBAAkBniI,GAAYO,EAAGkF,YAAYm/C,OAAO5kD,IACnE6jC,EAAGywB,MAAM/zD,EAAIsuC,EAAK7uC,IAI1B6jC,EAAGywB,MAAM/zD,EAAIsuC,EAAK7uC,GAIlBO,EAAGkF,YAAY28H,WAAaH,EAC5B1hI,EAAGkF,YAAY08H,cAAgBniI,GAUnCiiI,EAASI,WAAa,SAASxzF,GACxBtuC,EAAGqlC,YAKNrlC,EAAGkF,YAAY08H,cAAgB,KAE/Bp+F,EAAY+hE,QAAQvlG,EAAIsuC,KAIzBtuC,EAAGG,SAAS4hI,sBACX5qD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAUm4F,EAAa1iI,EAAGuqC,QAAUm4F,EAC7DA,EAAaA,EAAa,IAAK,KACnCrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAUxqC,EAAG8iC,QAAS7iC,EAAGuqC,QAAUm4F,EAC5DA,EAAaA,EAAa,IAAK,KACnCrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAUm4F,EAAa1iI,EAAGuqC,QAAUvqC,EAAG6iC,QAChE6/F,EAAaA,EAAa,IAAK,KACnCrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAUxqC,EAAG8iC,QAAS7iC,EAAGuqC,QAAUvqC,EAAG6iC,QAC/D6/F,EAAaA,EAAa,IAAK,MAG3C,GAAGxhI,EAAGG,SAAS4hI,oBAAqB,CAGhC,GAAGtiI,IAAYZ,EAAG89D,aAAc,CAE5B,IAAIvzC,EAAKvqB,EAAGi+D,kBACG,QAAZj+D,EAAG60C,OAAgBtqB,GAAMo4G,GAC5BrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAuB,GAAbxqC,EAAG8iC,QAAevY,EACxC,GAAbvqB,EAAG8iC,QAAe6/F,EAAa,GAAI,MACvCrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAASjgB,EACrB,GAAbvqB,EAAG8iC,QAAe6/F,EAAa,GAAI,KACvCrqD,EAAYn3E,EAAImhD,EAAUtiD,EAAGwqC,QAAuB,GAAbxqC,EAAG8iC,QAAevY,EACxC,GAAbvqB,EAAG8iC,QAAe6/F,EAAa,GAAI,KAG3C,GAAG/hI,IAAYX,EAAG69D,aAAc,CAE5B,IAAIxzC,EAAKrqB,EAAGg+D,kBACG,UAAZh+D,EAAG40C,OAAkBvqB,GAAMq4G,GAC9BrqD,EAAYn3E,EAAImhD,EAAUh4B,EAAIrqB,EAAGuqC,QAAuB,GAAbvqC,EAAG6iC,QAC1C6/F,EAA0B,GAAb1iI,EAAG6iC,QAAe,KAAM,IACzCw1C,EAAYn3E,EAAImhD,EAAUh4B,EAAIrqB,EAAGuqC,QAAuB,GAAbvqC,EAAG6iC,QAC1C6/F,EAA0B,GAAb1iI,EAAG6iC,QAAe,IAAK,IACxCw1C,EAAYn3E,EAAImhD,EAAUh4B,EAAIrqB,EAAGuqC,QAC7Bm4F,EAA0B,GAAb1iI,EAAG6iC,QAAe,IAAK,SAQpD,IAAIqgG,EAAa/8H,EAAW8gC,YAAY/mC,OAExCgjI,EAAWL,YAAc,SAASrzF,GAC9BA,EAAI5S,OAAS17B,EAAGkF,YAAY28H,WAC5Bv+F,EAAGywB,MAAM/zD,EAAIsuC,EAAKrpC,EAAW28H,gBAGjCI,EAAW9/C,QAAU,SAAS5zC,GAC1BA,EAAI5S,OAAS17B,EAAGkF,YAAY28H,WAC5Bv+F,EAAGF,MAAMpjC,EAAIsuC,IAIjB0zF,EAAWtpD,YAAc,SAASpqC,GAC9BtuC,EAAGkF,YAAY28H,WAAWnpD,YAAYpqC,IAG1CxyC,QAAQksD,SAAShoD,KAQrBlE,QAAQksD,SAAW,SAAShoD,GACxB,IAAIiF,EAAajF,EAAGkF,YAChBoiC,EAAiC,QAAxBriC,EAAWywE,SAAqB,OAAS,YACtDnyC,EAAUt+B,EAAWu/C,UAAWld,K,4CCzJpC,IAAI3rC,EAAK,EAAQ,YACbuB,EAAY,EAAQ,YAEpBC,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdsO,EAA8B,EAAQ,YAA+BA,4BACrEpO,EAAkB,EAAQ,YA0U9B,SAAS0kI,EAAWC,EAAOC,GACvB,IAAIC,EAASD,EAASv/H,OAAS,EAC3By/H,EAAMhlI,EAAI85B,UAAU95B,EAAIg0B,QAAQ6wG,EAAOC,GAAW,EAAGC,GACrDE,EAAOH,EAASE,GAChBE,EAAOJ,EAASE,EAAM,GACtBlwG,EAAS90B,EAAI85B,UAAUkrG,GAAOH,EAAQI,IAASC,EAAOD,GAAQ,GAAK,EAAGF,GACtEI,EAAOniI,KAAKC,MAAM6xB,GAClBsQ,EAAOpiC,KAAK6/B,IAAI/N,EAASqwG,GAE7B,OAAIrwG,GAAUA,IAAWiwG,GAAW3/F,EAO7B,CACH+/F,KAAMA,EACN//F,KAAMA,EACNggG,KAAMpiI,KAAKC,MAAMkiI,EAAO//F,GAAQtQ,EAASqwG,KATlC,CACHA,KAAMA,EACNC,KAAMD,EACN//F,KAAM,GAUlB,SAASigG,EAAsBR,EAAOS,GAClC,IAAIP,EAASO,EAAe//H,OAAS,EACjCy/H,EAAMhlI,EAAI85B,UAAU95B,EAAIg0B,QAAQ6wG,EAAOS,GAAiB,EAAGP,GAC3DE,EAAOK,EAAeN,GAEtB5/F,GAASy/F,EAAQI,IADVK,EAAeN,EAAM,GACKC,IAAU,EAC/C,OAAG7/F,GAAQ,EACA,CACH+/F,KAAMH,EACNI,KAAMJ,EACN5/F,KAAM,GAGXA,EAAO,GACC,CACH+/F,KAAMH,EACNI,KAAMJ,EAAM,EACZ5/F,KAAMA,GAGP,CACH+/F,KAAMH,EAAM,EACZI,KAAMJ,EACN5/F,KAAM,EAAIA,GAIlB,SAASmgG,EAASC,EAAQC,EAAS//G,GAC/B8/G,EAAOC,GAAW//G,EAAE,GACpB8/G,EAAOC,EAAU,GAAK//G,EAAE,GACxB8/G,EAAOC,EAAU,GAAK//G,EAAE,GACxB8/G,EAAOC,EAAU,GAAKziI,KAAKC,MAAa,IAAPyiB,EAAE,IA9XvClnB,EAAOC,QAAU,SAASkE,EAAImhD,EAAU4hF,EAAYC,GAChD,IAAInkI,EAAKsiD,EAASxhD,MACdb,EAAKqiD,EAASvhD,MAElBvC,EAAIw4B,gBAAgBmtG,EAAcD,EAAY,MAAM/mI,MAAK,SAASm+B,GAC9D,IAkBI3pB,EAAMoB,EAAOklB,EAAM7qB,EAAKD,EAAQhH,EAlBhCyjH,EAAY9sH,EAAGa,OAAOC,MACtBw1F,EAAM93D,EAAG,GACTj+B,EAAQ+1F,EAAI/1F,MAEZ0oB,EAAIqtE,EAAIrtE,EACRxmB,EAAI6zF,EAAI7zF,EACRC,EAAI4zF,EAAI5zF,EACR6mH,EAAKjzB,EAAIgxC,QACT9d,EAAKlzB,EAAIixC,QACTC,EAAYhmI,EAAS2C,QAAQ5D,EAAO,WACpC2oB,EAAUs+G,EAAY,OAASjnI,EAAM2oB,QAGrC8vC,EAAI/vC,EAAEhiB,OACNP,EAAIhF,EAAIuyB,aAAahL,GACrBw+G,GAAO,EACPC,GAAO,EAgBX,IADAr+H,EAAI,OACW+B,IAATyJ,GAAsBxL,EAAI5G,EAAEwE,OAAS,GACvC4N,EAAO3R,EAAGE,IAAIX,EAAE4G,IAChBA,IAGJ,IADAA,EAAI5G,EAAEwE,OAAS,OACCmE,IAAV6K,GAAuB5M,EAAI,GAC7B4M,EAAQ/S,EAAGE,IAAIX,EAAE4G,IACjBA,IAWJ,IARG4M,EAAQpB,IACPsmB,EAAOllB,EACPA,EAAQpB,EACRA,EAAOsmB,EACPssG,GAAO,GAGXp+H,EAAI,OACU+B,IAARkF,GAAqBjH,EAAI3G,EAAEuE,OAAS,GACtCqJ,EAAMnN,EAAGC,IAAIV,EAAE2G,IACfA,IAGJ,IADAA,EAAI3G,EAAEuE,OAAS,OACEmE,IAAXiF,GAAwBhH,EAAI,GAC9BgH,EAASlN,EAAGC,IAAIV,EAAE2G,IAClBA,IAuBJ,GApBGgH,EAASC,IACR6qB,EAAO7qB,EACPA,EAAMD,EACNA,EAAS8qB,EACTusG,GAAO,GAKRF,IACCje,EAAK9mH,EACL+mH,EAAK9mH,EACLD,EAAI6zF,EAAIqxC,MACRjlI,EAAI4zF,EAAIsxC,OAOG,SAAZ1+G,EAAoB,CACnB,IAAIm+D,EAAoB,SAAZn+D,EAAqB,EAAI,GACrCrU,EAAOnQ,KAAKc,KAAK6hF,EAAQnkF,EAAG8iC,QAASnxB,GACrCoB,EAAQvR,KAAKi3B,KAAK,EAAI0rD,GAASnkF,EAAG8iC,QAAS/vB,GAC3C3F,EAAM5L,KAAKc,KAAK6hF,EAAQlkF,EAAG6iC,QAAS11B,GACpCD,EAAS3L,KAAKi3B,KAAK,EAAI0rD,GAASlkF,EAAG6iC,QAAS31B,GAGhD,IAAIw3H,EAAanjI,KAAKC,MAAMsR,EAAQpB,GAChCizH,EAAcpjI,KAAKC,MAAM0L,EAASC,GAOtC,GAFmBu3H,GAAc,GAAKC,GAAe,EAErD,CACkBhb,EAAU/rH,UAAU,SAAS4E,KAAK,IACxCkE,OAAOC,aAFnB,CAQA,IAAIi+H,EAASC,EACE,SAAZ9+G,GACC6+G,EAAUrhI,EACVshI,EAAUhvE,IAEV+uE,EAAUF,EACVG,EAAUF,GAGd,IAAIG,EAAS7iH,SAAS6hB,cAAc,UACpCghG,EAAO/iI,MAAQ6iI,EACfE,EAAOnzH,OAASkzH,EAChB,IAKInf,EACAC,EANAxzG,EAAU2yH,EAAOC,WAAW,MAE5BC,EAAUn4H,EAA4BzP,EAAO,CAAC6nI,gBAAgB,EAAMC,aAAa,IAKtE,SAAZn/G,GACC2/F,EAAM4e,EACF,SAAS99G,GAAS,OAAOjjB,EAAI,EAAIijB,GACjCjoB,EAAIkI,SACRk/G,EAAM4e,EACF,SAAS/9G,GAAS,OAAOqvC,EAAI,EAAIrvC,GACjCjoB,EAAIkI,WAERi/G,EAAM,SAASl/F,GACX,OAAOjoB,EAAI85B,UAAU92B,KAAKC,MAAMzB,EAAGE,IAAIX,EAAEknB,IAAU9U,GAC/C,EAAGgzH,IAEX/e,EAAM,SAASn/F,GACX,OAAOjoB,EAAI85B,UAAU92B,KAAKC,MAAMxB,EAAGC,IAAIV,EAAEinB,IAAUrZ,GAC/C,EAAGw3H,KAOf,IAUI3lE,EAAI5oD,EAAG6vC,EAAOqlB,EAAKrnD,EAVnBiiC,EAAKy/D,EAAI,GACTrjD,EAAK,CAACpc,EAAIA,GACVi/E,EAAMb,EAAO,EAAI,EACjBc,EAAMb,EAAO,EAAI,EAEjBc,EAAW,EACXC,GAAS,EACTC,GAAS,EACTC,GAAS,EAgDb,GAAGz/G,EAAS,CACR,IACIg+G,GADAC,GAAU,EAGd,IACID,GAAS,IAAIniH,WAAW8iH,EAAaC,EAAc,GACrD,MAAM5sF,GACJgsF,GAAS,IAAI99H,MAAMy+H,EAAaC,EAAc,GAGlD,GAAe,SAAZ5+G,EAAoB,CACnB,IAOI0/G,GAAS/wE,GAAI6mB,GAPbmqD,GAAStf,GAAM9mH,EACfqmI,GAAStf,GAAM9mH,EACfqmI,GAAY,IAAI3/H,MAAMy/H,GAAO5hI,QAC7B+hI,GAAY,IAAI5/H,MAAM0/H,GAAO7hI,QAC7BgiI,GAAe,IAAI7/H,MAAMy+H,GACzBqB,GAAc3f,EAAKwd,EAAwBT,EAC3C6C,GAAc3f,EAAKud,EAAwBT,EAI/C,IAAIj9H,EAAI,EAAGA,EAAIw/H,GAAO5hI,OAAQoC,IAAK0/H,GAAU1/H,GAAK3E,KAAKC,MAAMzB,EAAGE,IAAIylI,GAAOx/H,IAAMwL,GACjF,IAAIxL,EAAI,EAAGA,EAAIy/H,GAAO7hI,OAAQoC,IAAK2/H,GAAU3/H,GAAK3E,KAAKC,MAAMxB,EAAGC,IAAI0lI,GAAOz/H,IAAMiH,GAIjF,IAAIjH,EAAI,EAAGA,EAAIw+H,EAAYx+H,IAAK4/H,GAAa5/H,GAAK6/H,GAAY7/H,EAAG0/H,IAGjE,IAAIxvH,EAAI,EAAGA,EAAIuuH,EAAavuH,IAIxB,IAFAs+C,GAAK5uC,GADL2/G,GAAUO,GAAY5vH,EAAGyvH,KACVnC,MACfnoD,GAAKz1D,EAAE2/G,GAAQ9B,MACXz9H,EAAI,EAAGA,EAAIw+H,EAAYx+H,IAAK89H,IAAW,EAEvCF,EAASC,GAAQC,GADjB//G,EAAIgiH,GAAYvxE,GAAI6mB,GAAIuqD,GAAa5/H,GAAIu/H,UAKjD,IAAIrvH,EAAI,EAAGA,EAAIy/C,EAAGz/C,IAGd,IAFAk1D,EAAMxlD,EAAE1P,GACRksD,EAAKqjD,EAAIvvG,GACLlQ,EAAI,EAAGA,EAAIw+H,EAAYx+H,IACvB+d,EAAIiiH,GAAS56D,EAAIplE,GAAI,GAErB49H,EAASC,GADTC,GAAuC,GAA5B1hE,EAAKoiE,EAAahf,EAAIx/G,IACP+d,GAKtC,IAAI6kC,GAAY32C,EAAQg0H,gBAAgBzB,EAAYC,GACpD,IACI77E,GAAUtmD,KAAKsb,IAAIimH,IACrB,MAAMhsF,GACJ,IAAIquF,GAAUt9E,GAAUtmD,KACpB6jI,GAAOD,GAAQtiI,OACnB,IAAIsS,EAAI,EAAGA,EAAIiwH,GAAMjwH,IACjBgwH,GAAQhwH,GAAK2tH,GAAO3tH,GAI5BjE,EAAQm0H,aAAax9E,GAAW,EAAG,OAChC,CAGH,IAAIy9E,GAAOnpI,EAAM+kH,KACbqkB,GAAOppI,EAAMglH,KACbqkB,GAAWllI,KAAKgD,MAAMgiI,GAAO,GAC7BG,GAAUnlI,KAAKgD,MAAMiiI,GAAO,GAEhC,IAAIpwH,EAAI,EAAGA,EAAIy/C,EAAGz/C,IAId,GAHAk1D,EAAMxlD,EAAE1P,GACRksD,EAAG9lB,UACH8lB,EAAG8iE,GAAOzf,EAAIvvG,EAAI,GACfksD,EAAG,KAAOA,EAAG,SAAgBr6D,IAAVq6D,EAAG,SAA8Br6D,IAAVq6D,EAAG,GAKhD,IADAtD,EAAK,CADL/Y,EAAKy/D,EAAI,GACCz/D,GACN//C,EAAI,EAAGA,EAAI3C,EAAG2C,IAEd84D,EAAGxiB,UACHwiB,EAAGmmE,GAAOzf,EAAIx/G,EAAI,GACf84D,EAAG,KAAOA,EAAG,SAAgB/2D,IAAV+2D,EAAG,SAA8B/2D,IAAV+2D,EAAG,KAIhD/6C,EAAIiiH,GADA56D,EAAIplE,IACS84D,EAAG,GAAKA,EAAG,KAAOsD,EAAG,GAAKA,EAAG,KAC9CnwD,EAAQw0H,UAAY,QAAU1iH,EAAEzd,KAAK,KAAO,IAE5C2L,EAAQy0H,SAAS5nE,EAAG,GAAKynE,GAAUnkE,EAAG,GAAKokE,GACvC1nE,EAAG,GAAKA,EAAG,GAAKunE,GAAMjkE,EAAG,GAAKA,EAAG,GAAKkkE,KAKtDlB,GAAS/jI,KAAKC,MAAM8jI,GAASD,GAC7BE,GAAShkI,KAAKC,MAAM+jI,GAASF,GAC7BG,GAASjkI,KAAKC,MAAMgkI,GAASH,GAC7B,IAAIwB,GAAWzoI,EAAU,OAASknI,GAAS,IAAMC,GAAS,IAAMC,GAAS,KAEzEtkI,EAAGm7E,aAAen7E,EAAGm7E,aAAa,GAAKgpD,EACvCnkI,EAAGo7E,aAAep7E,EAAGo7E,aAAa,GAAK+oD,EAAWwB,GAASrqD,eAE3D,IAAIsqD,GAASnd,EAAU/rH,UAAU,SAC5B4E,KAAK64B,GAEVyrG,GAAOlgI,QAAQC,OAAO,aAAarH,KAAK,CACpCwpD,MAAOvqD,EAAgBgiB,IACvBwoC,oBAAqB,SAGzB69E,GAAOtnI,KAAK,CACRmS,OAAQgzH,EACR5iI,MAAO2iI,EACPplI,EAAGoS,EACHnS,EAAG4N,EACH,aAAc23H,EAAO/7E,UAAU,eAjKnC,SAASm9E,GAAS/hI,EAAG4iI,GACjB,QAAS9+H,IAAN9D,EAAiB,CAChB,IAAI8f,EAAI+gH,EAAQ7gI,GAShB,OARA8f,EAAE,GAAK1iB,KAAKC,MAAMyiB,EAAE,IACpBA,EAAE,GAAK1iB,KAAKC,MAAMyiB,EAAE,IACpBA,EAAE,GAAK1iB,KAAKC,MAAMyiB,EAAE,IAEpBohH,GAAY0B,EACZzB,IAAUrhH,EAAE,GAAK8iH,EACjBxB,IAAUthH,EAAE,GAAK8iH,EACjBvB,IAAUvhH,EAAE,GAAK8iH,EACV9iH,EAEX,MAAO,CAAC,EAAG,EAAG,EAAG,GAGrB,SAASgiH,GAAYvxE,EAAI6mB,EAAIyrD,EAASvB,GAClC,IAAIwB,EAAMvyE,EAAGsyE,EAAQtD,MACrB,QAAWz7H,IAARg/H,EAAmB,OAAOf,QAASj+H,EAAW,GAEjD,IAKI69G,EALAohB,EAAMxyE,EAAGsyE,EAAQrD,MACjBwD,EAAM5rD,EAAGyrD,EAAQtD,MACjB0D,EAAM7rD,EAAGyrD,EAAQrD,MACjBh2H,EAAMu5H,EAAMD,GAAQ,EACpBr5H,EAAMu5H,EAAMF,GAAQ,EAiBxB,OAT0BnhB,OADf79G,IAARi/H,OACYj/H,IAARm/H,EAAyB,OACZn/H,IAARk/H,EAAyB,GAAKC,EAAMH,GACT,GAAvB,EAAIG,EAAMD,EAAMF,GAAW,OACzBh/H,IAARm/H,OACKn/H,IAARk/H,EAAyB,EACO,GAAvB,EAAIF,EAAMC,EAAMC,GAAW,OACzBl/H,IAARk/H,EAAiD,GAAvB,EAAIC,EAAMF,EAAMD,GAAW,EACnDG,EAAMH,EAAMC,EAAMC,EAEvBjB,GAASe,EAAMD,EAAQrjG,KAAOh2B,EAAK83H,EAAQ9hG,MAAQ/1B,EAAKo5H,EAAQrjG,KAAOmiF,U,4CCnN1F,IAAIuhB,EAAY,EAAQ,YACpBzlB,EAAc,EAAQ,YAAsBj8F,WAC5C82B,EAAY,EAAQ,YACpB/4B,EAAa,EAAQ,YACrB4jH,EAAqB,EAAQ,YAAmCA,mBAChEC,EAAoB,EAAQ,YAAmCA,kBAE/D/8H,EAAa,EAAQ,YAAoBA,WAEzCg9H,EAAgB/qF,EAAU,CAC1BY,SAAU,OACV4wD,SAAS,EACTw5B,cAAe,OACfzqF,YAAa,uCAGjBjgD,EAAOC,QAAU,CACboR,OAAQ,CACJ0uC,QAAS,aACTO,SAAU,OACVL,YAAa,CACT,0BACA,iEACA,2DACA,gEACA,uDACFx2C,KAAK,MAGXkhI,OAAQ,CACJ5qF,QAAS,SACTC,KAAM,OACN37C,KAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,yBACA,kCACA,oBACA,+DACFx2C,KAAK,MAEXmhI,OAAQ,CACJ7qF,QAAS,SACTC,KAAM,OACN37C,KAAM,EACNi8C,SAAU,OACVL,YAAa,oDAGjBC,OAAQ,CACJH,QAAS,aACTO,SAAU,OACVL,YAAa,CACT,kCACA,mDACFx2C,KAAK,MAGXsB,OAAQ,CACJizG,OAAQ,CACJj+D,QAAS,aACTO,SAAU,OACVL,YAAa,CACT,iCACA,wDACA,8BACFx2C,KAAK,MAGX3E,KAAM,CACF5D,MAAO,CACH6+C,QAAS,QACTC,KAAM,QACN37C,KAAMsiB,EAAWna,YACjB0kG,SAAS,EACT5wD,SAAU,QACVL,YAAa,CACT,qDACFx2C,KAAK,MAEXzE,MAAO,CACH+6C,QAAS,SACTC,KAAM,QACNvkB,IAAK,EACLp3B,KAAM,EACN6sG,SAAS,EACT5wD,SAAU,QACVL,YAAa,CACT,6DACFx2C,KAAK,MAEX62C,SAAU,QAEdA,SAAU,QAGdnvC,KAAM,CACF4uC,QAAS,aACTO,SAAU,OACVL,YAAa,CACT,kDACA,0EACA,gBACA,0EACA,oDACFx2C,KAAK,MAEXigC,UAAW,CACPqW,QAAS,SACTC,KAAM,OACN37C,KAAM,GACN6sG,SAAS,EACT5wD,SAAU,QACVL,YAAa,CACT,wDACA,kDACA,mBACA,0DACA,wBACA,6DACFx2C,KAAK,MAOXohI,WAAY,CACR9qF,QAAS,SACTC,KAAM,OACN37C,KAAM,GACNi8C,SAAU,OACVL,YAAa,CACT,qEACA,iEACA,4CACFx2C,KAAK,MAIXimH,SAAU,CACN3vE,QAAS,WACTC,KAAM,OACN0kF,MAAO,CAAC,QAAS,OAAQ,QAAS,WAClCC,OAAQ,CAAC,QACTrkF,SAAU,OACVL,YAAa,CACT,2DACFx2C,KAAK,MAEXggG,UAAWh8F,EAAW,GAAI68H,EAAU7gC,UAAW,CAC3Ci7B,MAAO,CAAC,QAAS,OAAQ,QAAS,UAAW,UAEjDzqC,cAAeswC,EAAmB,GAAI,CAClCnkI,KAAM,CAAC,QAAS,QAAS,QAAS,UAAW,UAEjD6K,aAAcu5H,EAAkB,CAAClqF,SAAU,QAAS,CAChDl6C,KAAM,CAAC,QAAS,QAAS,QAAS,UAAW,UAEjD2L,aAAc,CACVguC,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,SAAU,UAAW,OAAQ,QACtC77C,KAAM,OACN6sG,SAAS,EACT5wD,SAAU,OACVL,YAAa,CACT,6CACFx2C,KAAK,MAEXoF,SAAUpB,EAAW,GAAIg9H,EAAe,CACpCxqF,YAAa,uCAEjB6qF,sBAAuB,CACnB/qF,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,aAAc,SAAU,aAAc,QAC/C77C,KAAM,OACNi8C,SAAU,OACVL,YAAa,CACT,6DACA,qEACA,sDACA,sEACA,yEACA,mEACA,mFACFx2C,KAAK,MAEXshI,eAAgBt9H,EAAW,GAAIg9H,EAAe,CAC1CxqF,YAAa,+DAEjB+qF,gBAAiBv9H,EAAW,GAAIg9H,EAAe,CAC3CxqF,YAAa,gEAEjBniC,WAAY,CACRiiC,QAAS,UACT17C,MAAM,EACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,gEACFx2C,KAAK,MAGXksC,MAAO,CACHxkC,KAAM,CACF4uC,QAAS,SACT17C,KAAM,GACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,+BACA,yCACA,8DACA,+DACA,sCACFx2C,KAAK,MAEXxH,KAAMwL,EAAW,GAAIg9H,EAAe,CAChCxqF,YAAa,CACT,kCACA,4CACA,gDACFx2C,KAAK,OAEXiL,SAAU,CACNqrC,QAAS,aACTG,OAAQ,CACJ,WAAY,aAAc,YAC1B,gBACA,cAAe,gBAAiB,gBAEpCF,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,yCACA,gDACA,oDACFx2C,KAAK,MAGX62C,SAAU,QAIdolB,OAAQm/C,EAAY,CAACliG,KAAM,MAAOtiB,OAAO,EAAMigD,SAAU,SAEzD2qF,KAAM,CACFlrF,QAAS,SACTC,KAAM,QACNvkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,yDACA,mCACFx2C,KAAK,MAIXosB,KAAM,CACFkqB,QAAS,UACTC,KAAM,QACN37C,MAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,sDACA,6BACFx2C,KAAK,MAEX6iB,UAAW,CAQPyzB,QAAS,aACTG,OAAQ,CAAC,YAAa,oBACtBF,KAAM,QACN37C,KAAM,mBACNi8C,SAAU,OACVL,YAAa,CACT,6DACA,gBACFx2C,KAAK,MAEXyhI,SAAU,CACNnrF,QAAS,SACTC,KAAM,QACNvkB,KAAM,IACNn2B,IAAK,IACLjB,KAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,qDACA,+BACFx2C,KAAK,MAGX0hI,KAAM,CACFprF,QAAS,SACTC,KAAM,QACNvkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACN6sG,SAAS,EACT5wD,SAAU,OACVL,YAAa,CACT,yDACA,8CACA,mDACA,gDACFx2C,KAAK,MAGX2hI,YAAa,CACTz1F,MAAO,CACHoK,QAAS,SACT17C,KAAM,GACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,uCACA,mDACA,yCACFx2C,KAAK,MAEX4hI,UAAW59H,EAAW,GAAIg9H,EAAe,CACrCxqF,YAAa,yCAEjBqrF,cAAe,CACXvrF,QAAS,aACTG,OAAQ,CACJ,WAAY,aAAc,YAC1B,gBACA,cAAe,gBAAiB,gBAEpCF,KAAM,OACNM,SAAU,OACVL,YAAa,+C,4CCrVzBjgD,EAAOC,QAAU,CAGb0iB,KAAM,UAGNkQ,mBAAoB,mBACpB04G,eAAgB,eAChBC,eAAgB,oBAChBC,cAAe,mBACfC,mBAAoB,yBACpBC,cAAe,mBACfC,cAAe,mBACfC,gBAAiB,qBACjBC,YAAa,gBACbC,gBAAiB,qBACjBC,WAAY,eACZC,kBAAmB,uBAEnBC,WAAY,EAIZ3hH,kBAAmB,sBAGnB0H,iBAAkB,UAGlBpB,SAAU,GACVI,UAAW,GAGXL,SAAU,GAGVrE,aAAc,EAEd4/G,WAAY,EACZC,UAAW,EACXC,WAAY,EACZC,gBAAiB,EACjBC,gBAAiB,UACjBC,YAAa,UAKbC,UAAW,EAKXC,UAAW,GAEXC,WAAY,GACZC,UAAW,GACXC,WAAY,GACZC,WAAY,GACZC,gBAAiB,EACjBC,gBAAiB,UACjBC,YAAa,UACbC,kBAAmB,UAEnBC,aAAc,EACd12B,YAAa,EAEb22B,UAAW,EACXv4B,UAAW,OACXw4B,WAAY,GACZ92B,WAAY,EAEZ+2B,gBAAiB,GACjBh3B,eAAgB,OAChBi3B,gBAAiB,EAGjBC,oBAAqB,EACrBC,kBAAmB,I,4CChFvB,IAAIjsI,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAChBqY,EAAW,EAAQ,YACnB+9D,EAA+B,EAAQ,YAEvCvtD,EAAa,EAAQ,YACrBoB,EAAY,EAAQ,YAoCxB,SAAS0jH,EAAeC,EAAUC,EAAWC,EAAanoH,GACtD,IAAI7H,EAAW6H,EAAK7H,SAEpB,SAAS5C,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO0yH,EAAUC,EAAWhlH,EAAW2C,QAAS9oB,EAAM4B,GAKrE,GAFc4W,EAAO,WAET,CACR,IAAI2lC,EAAO3lC,EAAO,QACN,QAAT2lC,KACI/iC,GAAyB,cAAbA,GAAsC,UAAT+iC,GAA6B,SAATA,EAG5D3lC,EAAO,YAFP2yH,EAAU/sF,SAAW,WAKzB5lC,EAAO,UAGXA,EAAO,UAtDfjb,EAAOC,QAAU,SAAwB6lB,EAAaC,EAAcN,EAAQ7I,EAAaiB,GACrF,IAAIiwH,EAAahoH,EAAYioH,eAAiB,GAC1CF,EAAcz1H,EAASmF,aAAawI,EAAc,iBAEtD,SAAS9K,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO6yH,EAAYD,EAAajlH,EAAYnmB,EAAM4B,GAUjE,GADc4W,EAAO,UANPk7D,EAA6B23D,EAAYD,EAAa,CAChElrH,KAAM,UACN+zD,mBAAoBg3D,EACpB7vH,SAAUA,IAG0B9W,OAAS,GACrC,CACR,IAAIinI,EA0CZ,SAAoBjoH,EAAcN,EAAQ7I,GAMtC,IALA,IAAIqxH,EAAerxH,EAAY++B,QAAO,SAAS7O,GAC3C,OAAOrnB,EAAOqnB,GAAI/tB,SAAWgH,EAAa1J,OAG1CoiH,EAAO,EACHt1H,EAAI,EAAGA,EAAI8kI,EAAalnI,OAAQoC,IAAK,CACzC,IAAIu8D,EAASjgD,EAAOwoH,EAAa9kI,IAAIu8D,OAClCA,IAAQ+4D,EAAOj6H,KAAKc,IAAIogE,EAAO,GAAI+4D,IAG1C,MAAO,CAAC14G,EAAa2/C,OAAO,GAAI+4D,EAAOz0G,EAAU2B,MArD/BuiH,CAAWnoH,EAAcN,EAAQ7I,GAC/C3B,EAAO,IAAK+yH,EAAQ,IACpB/yH,EAAO,IAAK+yH,EAAQ,IACpBxsI,EAAIy8B,UAAUnY,EAAaC,EAAc,CAAC,IAAK,MAE/C9K,EAAO,WACPA,EAAO,WAEPzZ,EAAImkB,WAAW1K,EAAQ,OAAQwK,EAAOxjB,MAEtC,IAAIsZ,EAAUN,EAAO,WACrBA,EAAO,cAAelb,EAAMioB,SAASzM,EAASyO,EAAU/B,YAAa+B,EAAU9B,aAC/EjN,EAAO,eACPA,EAAO,kB,8CCtCfjb,EAAOC,QAAU,CACbksE,KAAM,CACFpsB,QAAS,aACT17C,KAAM,WACN27C,KAAM,OACNE,OAAQ,CAAC,YAAa,OAAQ,YAC9BD,YAAa,CACT,oEACA,qEACA,wEACA,uEACA,0EACA,eACFx2C,KAAK,MAEX6iB,UAAW,CACPyzB,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,UAAW,WACpB77C,KAAM,UACN47C,YAAa,CACT,6EACFx2C,KAAK,MAEX0kI,YAAa,CACTpuF,QAAS,UACT17C,MAAM,EACN27C,KAAM,OACNC,YAAa,CACT,uEACFx2C,KAAK,MAEX4vF,MAAO,CACHh+D,SAAU,CACN0kB,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,IACN47C,YAAa,CACT,wEACA,uDACFx2C,KAAK,MAEXqnC,OAAQ,CACJiP,QAAS,UACTC,KAAM,OACN37C,MAAM,EACN47C,YAAa,CACT,qEACA,uEACA,qEACA,sBACFx2C,KAAK,OAGf4jB,WAAY,CACRgO,SAAU,CACN0kB,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,IACNi8C,SAAU,OACVL,YAAa,CACT,qEACA,4BACFx2C,KAAK,MAEX6hH,OAAQ,CACJvrE,QAAS,aACT17C,KAAM,eACN67C,OAAQ,CACJ,SACA,OACA,QACA,MACA,MACA,SACA,UACA,OACA,SACA,YACA,UACA,WACA,SACA,SACA,YACA,aACA,UACA,YACA,aACA,WACA,YACA,UACA,UACA,aACA,cACA,WACA,aACA,gBACA,cACA,eACA,aACA,aACA,gBACA,iBACA,cACA,iBAEJF,KAAM,OACNM,SAAU,OACVL,YAAa,+CAEjBwjD,SAAU,CACN1jD,QAAS,aACTG,OAAQ,CAAC,eAAgB,gBACzB77C,KAAM,eACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,wEACA,2DACFx2C,KAAK,S,4CCzHnBzJ,EAAOC,QAAU,CAEb8xH,OAAQ,GAKRK,eAAgB,EAEhBC,aAAc,EAEd0I,cAAe,GACfD,UAAW,oBAGXrI,aAAc,GAGdD,QAAS,W,4CClBbxyH,EAAOC,QAAU,CACbqrE,WAAY,SACZ3oD,KAAM,QACNyrH,WAAY,CACR,kCAAmC,mCAEvCpmI,OAAQ,CACJqmI,KAAM,c,4CCPd,IAAIjtI,EAAY,EAAQ,YACpBktI,EAAa,EAAQ,YAErBhtI,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdqoB,EAAQ,EAAQ,YAChB0kH,EAAU,EAAQ,YAClBxuI,EAAQ,EAAQ,YAEhB0tD,EAAU8gF,EAAQ9gF,QAClBC,EAAe6gF,EAAQ7gF,aACvBzpD,EAAU3C,EAAS2C,QAmMvB,SAASuqI,EAAWjuH,EAAW9d,GAC3B,IAAImiD,EAAQrkC,EAAU9d,GAClB2Y,EAAW3Y,EAAK6a,OAAO,GACxBsnC,GAAmB,UAAVA,IACRrkC,EAAU9d,GAAQgrD,EAAQ7I,EAAOxpC,IASzC,SAASqzH,EAAWC,GAiBhB,SAASC,EAAWC,EAAaC,GAC7B,IAAIC,EAAaJ,EAAeE,GAC5BG,EAAaL,EAAe/4F,OAAS+4F,EAAe/4F,MAAMk5F,GAE3DC,IAAeC,IAEVL,EAAe/4F,QACf+4F,EAAe/4F,MAAQ,IAG3B+4F,EAAe/4F,MAAMk5F,GAAeH,EAAeE,UAC5CF,EAAeE,IA3B3BF,IAIoC,iBAAzBA,EAAe/4F,OAAsD,iBAAzB+4F,EAAe/4F,QACjE+4F,EAAe/4F,MAAQ,CACnBxkC,KAAMu9H,EAAe/4F,QAI7Bg5F,EAAW,YAAa,QACxBA,EAAW,gBAAiB,YAC5BA,EAAW,YAAa,QACxBA,EAAW,cAAe,WAuOlC,SAASK,EAAgBC,GACrB,IAAIztI,EAAIY,cAAc6sI,GAAe,OAAO,EAE5C,IAAIC,EAAUD,EAAatsH,KAK3B,cAHOssH,EAAatsH,YACbssH,EAAa15F,YAEO,iBAAZ25F,GAA2C,iBAAZA,IAAyBzuH,OAAOyuH,GAGlF,SAASC,EAAaC,EAAOC,EAAOC,EAAOC,GAEvC,GAAGD,IAAUC,EAAO,OAAOH,EAC3B,GAAGG,IAAUD,EAAO,OAAOD,EAK3B,IAAID,EAAMl4H,OAAQ,OAAOm4H,EACzB,IAAIA,EAAMn4H,OAAQ,OAAOk4H,EAEzB,IACIjmI,EADA26G,EAASt/G,KAAKi3B,IAAI2zG,EAAMroI,OAAQsoI,EAAMtoI,QAE1C,IAAIoC,EAAI,EAAGA,EAAI26G,GACRsrB,EAAM9xH,OAAOnU,KAAOkmI,EAAM/xH,OAAOnU,GADjBA,KAKvB,OADUimI,EAAM1uH,OAAO,EAAGvX,GACf+N,OAKf,SAASs4H,EAAkBz9H,GACvB,IAAI0sH,EAAO,SACPD,EAAO,SAUX,MAR2B,iBAAjBzsH,KAC8B,IAAjCA,EAAazK,QAAQ,OAAem3H,EAAO,OACF,IAApC1sH,EAAazK,QAAQ,YAAkBm3H,EAAO,WAEjB,IAAlC1sH,EAAazK,QAAQ,QAAgBk3H,EAAO,QACJ,IAAnCzsH,EAAazK,QAAQ,WAAiBk3H,EAAO,UAGlDC,EAAO,IAAMD,EAGxB,SAASiR,EAAeC,EAAOC,GAC3B,OAAQA,KAAYD,GACY,iBAApBA,EAAMC,IAC2B,IAAxCxpI,OAAOC,KAAKspI,EAAMC,IAAW5oI,OAtftC9G,QAAQ2vI,kBAAoB,SAASzrI,GAC9B+E,MAAM+D,QAAQ9I,EAAGmlE,YAAcnlE,EAAGmlE,UAAUviE,OAAS,GACpDvF,EAAIk3B,IAAI,mDAGZv0B,EAAGmlE,UAAY,IAMnBrpE,QAAQ4vI,YAAc,SAASpqH,GAC3B,IAAItc,EAAGkQ,EAEHoM,IAAQA,EAAS,IAGlBA,EAAOqqH,SACFrqH,EAAO3hB,QAAO2hB,EAAO3hB,MAAQ2hB,EAAOqqH,eACjCrqH,EAAOqqH,QAEfrqH,EAAOsqH,SACFtqH,EAAO1hB,QAAO0hB,EAAO1hB,MAAQ0hB,EAAOsqH,eACjCtqH,EAAOsqH,QAEftqH,EAAOuqH,SACFvqH,EAAO+lD,QAAO/lD,EAAO+lD,MAAQ/lD,EAAOuqH,eACjCvqH,EAAOuqH,QAGlB,IAAIC,GAAiBpmH,EAAM+hD,iBAAiBriB,WAAa,IAAIT,UACzDonF,GAAkBrmH,EAAM+hD,iBAAiBw4B,OAAS,IAAIt7C,UACtDqnF,GAAoBtmH,EAAM+hD,iBAAiBwkE,SAAW,IAAItnF,UAC1DunF,GAAkBxmH,EAAM+hD,iBAAiBC,MAAQ,IAAI/iB,UAErD1iD,EAAOD,OAAOC,KAAKqf,GACvB,IAAItc,EAAI,EAAGA,EAAI/C,EAAKW,OAAQoC,IAAK,CAC7B,IAAIof,EAAMniB,EAAK+C,GAEf,GAAG8mI,GAAiBA,EAAc9yH,KAAKoL,GAAM,CAGzC,IAAIukB,EAAKrnB,EAAO8C,GACbukB,EAAG/tB,QAAwB,SAAd+tB,EAAG/tB,SACf+tB,EAAG/tB,OAAS0uC,EAAQ3gB,EAAG/tB,SAExB+tB,EAAGnwB,aAAYmwB,EAAGnwB,WAAa8wC,EAAQ3gB,EAAGnwB,aAGzCmwB,EAAGlkC,OACAkkC,EAAGwjG,OAAQxjG,EAAGlkC,KAAO,OAChBkkC,EAAGyjG,MAAOzjG,EAAGlkC,KAAO,OACN,IAAdkkC,EAAGwjG,SAAiC,IAAbxjG,EAAGyjG,QAAiBzjG,EAAGlkC,KAAO,WAE7C,aAAjBkkC,EAAGptB,WAA6C,WAAjBotB,EAAGptB,YACjCotB,EAAGptB,WAAY,EACfotB,EAAG0jG,UAAY,iBAEZ1jG,EAAGyjG,aACHzjG,EAAGwjG,cACHxjG,EAAGiZ,WAGP0pF,EAAe3iG,EAAI,kBAAkBA,EAAG44B,YAGxBx6D,IAAhB4hC,EAAG2jG,gBACiBvlI,IAAhB4hC,EAAG3mB,WACF2mB,EAAG3mB,SAAW2mB,EAAG2jG,SAAW,OAAS,iBAElC3jG,EAAG2jG,UAGdhC,EAAW3hG,QACR,GAAGojG,GAAkBA,EAAe/yH,KAAKoL,GAAM,CAIlDkmH,EADYhpH,EAAO8C,GACF87E,iBACd,GAAG8rC,GAAoBA,EAAiBhzH,KAAKoL,GAAM,CAGtD,IAAI6nH,EAAU3qH,EAAO8C,GACrBkmH,EAAW2B,EAAQM,OACnBjC,EAAW2B,EAAQO,OACnBlC,EAAW2B,EAAQQ,YAChB,GAAGP,GAAkBA,EAAelzH,KAAKoL,GAAM,CAGlD,IAAIijD,EAAQ/lD,EAAO8C,GAGfsoH,EAAiBrlE,EAAMqlE,eAE3B,GAAG3nI,MAAM+D,QAAQ4jI,IAAgD,IAA7BA,EAAe,GAAG9pI,OAAc,CAChE,IAAImkI,EAAW2F,EAAe,GAC1B7+G,EAAS6+G,EAAe,GACxBl+B,EAASk+B,EAAe,GACxBC,EAAMxC,EAAW,GAAIpD,GACrB6F,EAAM,GAEV,IAAI13H,EAAI,EAAGA,EAAI,IAAKA,EAChB03H,EAAI13H,GAAK2Y,EAAO3Y,GAAKs5F,EAASm+B,EAAI,EAAI,EAAIz3H,GAG9CmyD,EAAMwlE,OAAS,CACXD,IAAK,CAACxuI,EAAGwuI,EAAI,GAAIvuI,EAAGuuI,EAAI,GAAIhoH,EAAGgoH,EAAI,IACnC/+G,OAAQ,CAACzvB,EAAGyvB,EAAO,GAAIxvB,EAAGwvB,EAAO,GAAIjJ,EAAGiJ,EAAO,IAC/Ci/G,GAAI,CAAC1uI,EAAG,EAAGC,EAAG,EAAGumB,EAAG,WAGjByiD,EAAMqlE,eAIjBpC,EAAWjjE,EAAM1nE,OACjB2qI,EAAWjjE,EAAMznE,OACjB0qI,EAAWjjE,EAAM0lE,QAIzB,IAAIC,EAAiBjoI,MAAM+D,QAAQwY,EAAOsiB,aAAetiB,EAAOsiB,YAAYhhC,OAAS,EACrF,IAAIoC,EAAI,EAAGA,EAAIgoI,EAAgBhoI,IAAK,CAChC,IAAIi1D,EAAM34C,EAAOsiB,YAAY5+B,GAEzB3H,EAAIY,cAAcg8D,KAEnBA,EAAI4xC,MACY,UAAZ5xC,EAAI4xC,KACH5xC,EAAIn2B,KAAO,QACXm2B,EAAIl2B,KAAO,SACO,SAAZk2B,EAAI4xC,MACV5xC,EAAIn2B,KAAO,IACXm2B,EAAIl2B,KAAO,YAERk2B,EAAI4xC,KAGfw+B,EAAWpwE,EAAK,QAChBowE,EAAWpwE,EAAK,SAGpB,IAAIgzE,EAAYloI,MAAM+D,QAAQwY,EAAOyvE,QAAUzvE,EAAOyvE,OAAOnuF,OAAS,EACtE,IAAIoC,EAAI,EAAGA,EAAIioI,EAAWjoI,IAAK,CAC3B,IAAIxD,EAAQ8f,EAAOyvE,OAAO/rF,GAEtB3H,EAAIY,cAAcuD,KAEtB6oI,EAAW7oI,EAAO,QAClB6oI,EAAW7oI,EAAO,SAGtB,IAAI2sC,EAAS7sB,EAAO6sB,OAqCpB,OApCGA,IAEIA,EAAO/vC,EAAI,GACV+vC,EAAO/vC,EAAI,KACX+vC,EAAO9gB,QAAU,QACX8gB,EAAO/vC,GAAK,IAClB+vC,EAAO/vC,GAAK,IACZ+vC,EAAO9gB,QAAU,SAGlB8gB,EAAO9vC,EAAI,GACV8vC,EAAO9vC,EAAI,KACX8vC,EAAO3gB,QAAU,UACX2gB,EAAO9vC,GAAK,IAClB8vC,EAAO9vC,GAAK,IACZ8vC,EAAO3gB,QAAU,QAKzB88G,EAAWhpH,GAKY,WAApBA,EAAOo0D,WAAuBp0D,EAAOo0D,SAAW,SAInD95E,EAAMijB,MAAMyC,GAGTA,EAAO+yE,UAAY/yE,EAAO+yE,SAAS/yE,QAClCxlB,QAAQ4vI,YAAYpqH,EAAO+yE,SAAS/yE,QAGjCA,GAwDXxlB,QAAQoxI,UAAY,SAAS5rI,GACzB,IAAI,IAAI6rI,EAAS,EAAGA,EAAS7rI,EAAKsB,OAAQuqI,IAAU,CAChD,IACInoI,EADA9I,EAAQoF,EAAK6rI,GAUjB,GANkB,eAAfjxI,EAAMuI,MAAyB,UAAWvI,KAAW,UAAWA,KAC/DA,EAAMkxI,MAAQlxI,EAAMmxI,aACbnxI,EAAMmxI,OAIdnxI,EAAME,SAAW,YAAaF,EAAME,QAAS,CAC5C,IAAIkxI,EAAK1xI,EAAM6mB,SACX8qH,EAAUrxI,EAAME,QAAQW,QAAU+C,EAAQ5D,EAAO,OACjDN,EAAMyM,YACNilI,EAAGH,EAASG,EAAG1qI,SACnB1G,EAAME,QAAQW,MAAQnB,EAAMoP,WACxBpP,EAAMsnB,IAAIqqH,GACV3xI,EAAMqL,QAAQsmI,GAAWrxI,EAAME,QAAQ6K,gBACpC/K,EAAME,QAAQ6K,QAwCzB,GAnCG,WAAY/K,IACS,MAAjBA,EAAMsxI,SAAmB1tI,EAAQ5D,EAAO,QACX,cAA5BA,EAAMuI,KAAK8X,OAAO,EAAG,KACrBrgB,EAAM+Z,YAAc,IACpBna,QAAQ2xI,WAAWvxI,WAEhBA,EAAMsxI,QAKC,eAAftxI,EAAMuI,MAAuB3I,QAAQ2xI,WAAWvxI,GACjC,eAAfA,EAAMuI,MAAwC,eAAfvI,EAAMuI,OACpCvI,EAAMuI,KAAO,aAId,QAASvI,KAAW,eAAgBA,KACnCA,EAAMwI,WAAaxI,EAAMgjH,WAClBhjH,EAAMgjH,KAEd,eAAgBhjH,KAAW,iBAAkBA,KAC5CA,EAAM8gD,aAAe9gD,EAAMwxI,kBACpBxxI,EAAMwxI,YAIdxxI,EAAMyD,QAAOzD,EAAMyD,MAAQ2pD,EAAQptD,EAAMyD,MAAO,MAChDzD,EAAM0D,QAAO1D,EAAM0D,MAAQ0pD,EAAQptD,EAAM0D,MAAO,MAGhDE,EAAQ5D,EAAO,SAAWA,EAAMmrE,QAC/BnrE,EAAMmrE,MAAQ3hD,EAAM+hD,iBAAiBC,KAAKpe,QAAQptD,EAAMmrE,SAGxDvnE,EAAQ5D,EAAO,cAAgB4D,EAAQ5D,EAAO,YAC9C,GAAG6I,MAAM+D,QAAQ5M,EAAM0R,cACnB,IAAI5I,EAAI,EAAGA,EAAI9I,EAAM0R,aAAahL,OAAQoC,IACtC9I,EAAM0R,aAAa5I,GAAKqmI,EAAkBnvI,EAAM0R,aAAa5I,SAE3D9I,EAAM0R,eACZ1R,EAAM0R,aAAey9H,EAAkBnvI,EAAM0R,eAKrD,IAAIT,EAAUhQ,EAASglD,UAAUjmD,GACjC,GAAGiR,GAAWA,EAAQy7D,SAAU,CAC5B,IAAI+kE,EAAgBxgI,EAAQy7D,SAASxsD,UACjCA,EAAYuxH,EAAgBzxI,EAAMyxI,GAAiBzxI,EACpDkgB,GAAaA,EAAU1X,aACM,WAAzB0X,EAAU1X,aAAyB0X,EAAU1X,WAAa,UACjC,WAAzB0X,EAAU1X,aAAyB0X,EAAU1X,WAAa,WAKrE,GAAkB,YAAfxI,EAAMuI,MAAsBpH,EAAIY,cAAc/B,EAAMmjD,UAAW,CAC9D,IAAIp4B,EAAO,CAAC,IAAK,IAAK,KAEtB,IAAIjiB,EAAI,EAAGA,EAAIiiB,EAAKrkB,OAAQoC,IAAK,CAC7B,IAAIuc,EAAOrlB,EAAMmjD,SAASp4B,EAAKjiB,IAE3B3H,EAAIY,cAAcsjB,KAEnBA,EAAKqsH,iBACJrsH,EAAKssH,eAAiBtsH,EAAKqsH,sBACpBrsH,EAAKqsH,gBAGbrsH,EAAKusH,iBACJvsH,EAAKwsH,eAAiBxsH,EAAKusH,sBACpBvsH,EAAKusH,kBAMxB,GAAkB,gBAAf5xI,EAAMuI,MAAyC,SAAfvI,EAAMuI,KAAiB,CACtD,IAAIupI,GAA+D,KAAvC9xI,EAAM+xI,YAAc,IAAI78F,WAChD88F,GAA+D,KAAvChyI,EAAMiyI,YAAc,IAAI/8F,WAChDg9F,EAAiBvD,EAAgB3uI,EAAM+xI,YACvCI,EAAiBxD,EAAgB3uI,EAAMiyI,YAI3C,IAAuB,IAAnBC,IAAiD,IAAnBC,EAA2B,CAIzD,IAAIn+F,EAAU86F,EACVoD,EAAgBC,EAChBL,EAAsBE,GAGvBh+F,IAASh0C,EAAMsiB,KAAO0xB,QAClBk+F,IAAkBC,GAAoBnyI,EAAMsiB,OAEnDtiB,EAAMsiB,KAAO4vH,GAAkBC,GAKvC,GAAGtpI,MAAM+D,QAAQ5M,EAAM0X,YAAa,CAChC,IAAIA,EAAa1X,EAAM0X,WAEvB,IAAI5O,EAAI,EAAGA,EAAI4O,EAAWhR,OAAQoC,IAAK,CACnC,IAAI0M,EAAYkC,EAAW5O,GAE3B,GAAI3H,EAAIY,cAAcyT,GAEtB,OAAOA,EAAUjN,MACb,IAAK,SACEiN,EAAU48H,YACT58H,EAAUgqB,OAAShqB,EAAU48H,iBACtB58H,EAAU48H,WAGlB58H,EAAUgI,WACLhI,EAAU68H,gBACV78H,EAAU68H,cAAgB78H,EAAUgI,iBAEjChI,EAAUgI,UAErB,MAEJ,IAAK,UAID,GAFAhI,EAAU88H,OAAS98H,EAAU88H,QAAU98H,EAAU/U,MAE9C+U,EAAU88H,SAAWzpI,MAAM+D,QAAQ4I,EAAU88H,QAAS,CACrD,IAAIC,EAAa/8H,EAAU88H,OACvBE,EAAY1sI,OAAOC,KAAKwsI,GAE5B/8H,EAAU88H,OAAS,GACnB,IAAI,IAAIt5H,EAAI,EAAGA,EAAIw5H,EAAU9rI,OAAQsS,IACjCxD,EAAU88H,OAAOlsI,KAAK,CAClBo5B,OAAQgzG,EAAUx5H,GAClBkoB,MAAOqxG,EAAWC,EAAUx5H,SAUrDo2H,EAAepvI,EAAO,gBAAgBA,EAAMyE,KAC5C,WAAYzE,IACRovI,EAAepvI,EAAM0K,OAAQ,gBAAgB1K,EAAM0K,OAAOjG,KAC1D2qI,EAAepvI,EAAO,kBAAkBA,EAAM0K,QAKrDhL,EAAMijB,MAAM3iB,GAMTA,EAAMyyI,kBACEzyI,EAAMyyI,gBACNzyI,EAAMmxI,OAEdnxI,EAAM0yI,kBACE1yI,EAAM0yI,gBACN1yI,EAAMkxI,OAGjB9C,EAAWpuI,GACRA,EAAM0sE,UAAU0hE,EAAWpuI,EAAM0sE,UACjC1sE,EAAM0K,QAAU1K,EAAM0K,OAAOgiE,UAAU0hE,EAAWpuI,EAAM0K,OAAOgiE,UAC/D1sE,EAAMyE,MAAQzE,EAAMyE,KAAKioE,UAAU0hE,EAAWpuI,EAAMyE,KAAKioE,UACzD1sE,EAAMqwI,OAAOjC,EAAWpuI,EAAMqwI,OAC9BrwI,EAAMswI,OAAOlC,EAAWpuI,EAAMswI,SA6DzC1wI,QAAQ2xI,WAAa,SAASvxI,GAC1B,IAAI8I,EAMJ,GALA3H,EAAIm5B,UAAUt6B,EAAO,CAAC,IAAK,KAAM,KAAM,QAAS,SAAU,WAAY,OAAQ,YAC3E6I,MAAM+D,QAAQ5M,EAAM0oB,IAAM7f,MAAM+D,QAAQ5M,EAAM0oB,EAAE,MAC5C1oB,EAAM2yI,iBAAkB3yI,EAAM2yI,UAC5B3yI,EAAM2yI,WAAY,GAExB3yI,EAAMI,SAAWJ,EAAME,QAAS,CAC/B,IAAI0yI,EAAS5yI,EAAME,QACf2yI,EAAc,gBAAiBD,EAC/BA,EAAO9xI,cACL8xI,EAAO/xI,OAAS+xI,EAAOlyI,WAAakyI,EAAOjuI,OACjDxD,EAAIm5B,UAAUt6B,EAAO,CAAC,wBACnB6yI,GACC1xI,EAAIm5B,UAAUt6B,EAAO,CAAC,gBAAiB,oBAAqB,kBAGpE,GAA8B,iBAApBA,EAAMopG,UAAwB,CACpC,IAAI0pC,EAAiB9yI,EAAMopG,UAAU3yF,MAAM,KAC3C,IAAI3N,EAAI,EAAGA,EAAIgqI,EAAepsI,OAAQoC,IACT,MAAtBgqI,EAAehqI,GAAYgqI,EAAehqI,GAAK,IACpB,MAAtBgqI,EAAehqI,KAAYgqI,EAAehqI,GAAK,KAE3D9I,EAAMopG,UAAY0pC,EAAe1pI,KAAK,OAK9CxJ,QAAQmzI,mBAAqB,SAASjvI,EAAIs8F,GACtC,GAAGr/F,EAAUq/F,GACT,MAAO,CAACA,GACL,IAAIv3F,MAAM+D,QAAQwzF,KAAkBA,EAAa15F,OACpD,OAAO5C,EAAGsB,KAAKmW,KAAI,SAASqe,EAAG9wB,GAAK,OAAOA,KACxC,GAAGD,MAAM+D,QAAQwzF,GAAe,CAEnC,IADA,IAAI4yC,EAAkB,GACdlqI,EAAI,EAAGA,EAAIs3F,EAAa15F,OAAQoC,IACjC3H,EAAI+4B,QAAQkmE,EAAat3F,GAAIhF,EAAGsB,KAAKsB,QACpCssI,EAAgB5sI,KAAKg6F,EAAat3F,IAElC3H,EAAIwe,KAAK,gBAAiBygF,EAAat3F,GAAI,yCAGnD,OAAOkqI,EAGX,OAAO5yC,GAeXxgG,QAAQqzI,sBAAwB,SAASh1E,EAAIqV,EAAQ4/D,GACjD,IAAItyH,EAAMq9C,EAAGr9C,IACTd,EAAQm+C,EAAGn+C,MACXqzH,EAAUrzH,EAAMpZ,OAChB4M,EAAQwM,EAAMqzH,EAAU,GAExBC,EAAgBryI,EAAUuS,GAE9B,GAAG8/H,GAA4B,OAAX9/D,EAAiB,CAIjC,IAAI+/D,EAAWvzH,EAAMP,MAAM,EAAG4zH,EAAU,GAAG/pI,KAAK,KACrCjI,EAAIkO,eAAeuR,EAAKyyH,GAAU/jI,MACxCsQ,OAAOtM,EAAO,QAIb8/H,QAA8BvoI,IAAbozD,EAAG3uD,YAIVzE,IAAbozD,EAAG3uD,QAAqB4jI,EAAOj1E,EAAGt9C,MAAQ,MAE7Cs9C,EAAGv9C,IAAI4yD,IAMPrV,EAAGv9C,IAAI4yD,IAUf,IAAIggE,EAAe,iCAEnB,SAASC,EAAUnxI,GACf,IAAIinB,EAAOjnB,EAAKosF,OAAO8kD,GACvB,GAAGjqH,EAAO,EAAG,OAAOjnB,EAAKie,OAAO,EAAGgJ,GAcvCzpB,QAAQ4zI,UAAY,SAASC,EAAMrxI,GAE/B,IADA,IAAIsxI,EAAaH,EAAUnxI,GACrBsxI,GAAY,CACd,GAAGA,KAAcD,EAAM,OAAO,EAC9BC,EAAaH,EAAUG,GAE3B,OAAO,GAWX,IAAIt9D,EAAY,CAAC,IAAK,IAAK,KAC3Bx2E,QAAQ+zI,eAAiB,SAAS7vI,EAAIjE,EAAQuiG,GAC1C,IAAI,IAAIt5F,EAAI,EAAGA,EAAIjJ,EAAO6G,OAAQoC,IAE9B,IADA,IAAI9I,EAAQ8D,EAAG8uC,UAAU9pC,GACjBkQ,EAAI,EAAGA,EAAI,EAAGA,IAAK,CACvB,IAAIyzB,EAAK4gB,EAAavpD,EAAI9D,EAAOo2E,EAAUp9D,IAG3C,GAAGyzB,GAAkB,QAAZA,EAAGlkC,KAAgB,CACxB,IAAIqrI,EAASnnG,EAAG3wB,MACZ+3H,EAAYpnG,EAAGzwB,IAAIqE,OAAO,GAC9B,GAA8B,UAA3BwzH,EAAUxzH,OAAO,EAAG,GAAgB,CACnC,QAA+BxV,IAA5Bu3F,EAAayxC,GAA0B,SAC1CD,EAASC,EAAY,IAAMD,EAE/B,IAAIE,EAAWF,EAAS,aAEI/oI,IAAzBu3F,EAAawxC,SAAoD/oI,IAA3Bu3F,EAAa0xC,IAClD3yI,EAAIkO,eAAevL,EAAGshB,OAAQ0uH,GAAUpzH,IAAI,U,4CClqBhE,IAAIvf,EAAM,EAAQ,YACdgmC,EAAO,EAAQ,YAenB,SAAS4sG,EAAYh2E,EAAKoN,GACtB,IACI9F,EADkB8F,EAAM6oE,gBACC3uE,OACzBvjE,EAAOqpE,EAAMpiE,WAAWmoB,MAExBpqB,EAAO,CAEPmtI,MAAO,KAGP1rI,KAAM,SAGN8W,WAAW,EAKXC,MAAO,EAAEuc,IAAUA,MAGvBkiC,EAAIm2E,IAAM,GACV/yI,EAAIiM,WAAW2wD,EAAIm2E,IAAKptI,GACxBqgC,EAAK+lB,WAAW6Q,EAAIm2E,KACpBn2E,EAAIm2E,IAAI/mG,QAAUrrC,EAAKypB,EAAI85C,EAAOnjE,EAAE,GAAKJ,EAAKQ,EAC9Cy7D,EAAIm2E,IAAIl5E,IAAM,WACV,MAAO,IAAO,EAAI+C,EAAIo2E,OAAO,GAAKp2E,EAAIo2E,OAAO,IAAMryI,EAAKQ,GAAK+iE,EAAOnjE,EAAE,GAAKmjE,EAAOnjE,EAAE,KAGxF67D,EAAIq2E,IAAM,GACVjzI,EAAIiM,WAAW2wD,EAAIq2E,IAAKttI,GACxBqgC,EAAK+lB,WAAW6Q,EAAIq2E,KACpBr2E,EAAIq2E,IAAIjnG,QAAUrrC,EAAKwV,GAAK,EAAI+tD,EAAOljE,EAAE,IAAML,EAAKS,EACpDw7D,EAAIq2E,IAAIp5E,IAAM,WACV,MAAO,IAAO,EAAI+C,EAAIo2E,OAAO,GAAKp2E,EAAIo2E,OAAO,IAAMryI,EAAKS,GAAK8iE,EAAOljE,EAAE,GAAKkjE,EAAOljE,EAAE,KA/C5FxC,EAAOC,QAAU,SAAiBurE,GAI9B,IAHA,IACIkpE,EADkBlpE,EAAM6oE,gBACDtsG,YAEnB5+B,EAAI,EAAGA,EAAIurI,EAAK3tI,OAAQoC,IAC5BirI,EAAYM,EAAKvrI,GAAIqiE,GAGzBA,EAAMpiE,WAAWw/B,WACZ/nC,UAAU,eAAiB2qE,EAAMnqC,IACjCz3B,W,4CCZT5J,EAAOC,QAAU,CACbq/G,QAAS,CACLv/D,QAAS,aACTG,OAAQ,CAAC,QAAS,QAAS,UAAW,YACtC77C,KAAM,QACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,sDACA,8BACA,2DACA,+DACA,6DACA,yDACA,uCACA,yDACA,wDACFx2C,KAAK,MAEXkrI,QAAS,CACL50F,QAAS,aACTG,OAAQ,CAAC,GAAI,WAAY,WACzB77C,KAAM,GACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,sDACA,sEACA,sCACA,oEACFx2C,KAAK,MAEX+iH,OAAQ,CACJzsE,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACL06C,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,kDACA,kCACFx2C,KAAK,MAEXijH,YAAa,CACT3sE,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACN27C,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,kDACA,iCACFx2C,KAAK,Q,4CCtDf,IAAIjI,EAAM,EAAQ,YACdzB,EAAQ,EAAQ,YAGpBC,EAAOC,QAAU,SAAwC20I,EAAOC,EAAQzrI,EAAY6R,GAChFA,EAAO,WACP,IAAIM,EAAUN,EAAO,WAEjB+uB,EAAc/uB,EAAO,eACrB65H,EAAgB/0I,EAAMqL,QAAQ4+B,GAElC/uB,EAAO,aAEP,IAAImX,EAAcnX,EAAO,eACrB85H,EAAY95H,EAAO,aAYvB,GAVAA,EAAO,OAAQ85H,EAAY,IAAM3rI,EAAW+0D,WAAWhzB,YACvDlwB,EAAO,aACPzZ,EAAImkB,WAAW1K,EAAQ,OAAQ7R,EAAWnH,MAE1CgZ,EAAO,SACPA,EAAO,SAECA,EAAO,WACTA,EAAO,UAEV85H,EAAW,CACV,IACIC,EACA3kC,EAFA9gE,EAAYt0B,EAAO,cAIU,IAA9Bs0B,EAAUjoC,QAAQ,SACjB0tI,EAAY/5H,EAAO,aACnBo1F,EAAYp1F,EAAO,eAGY,IAAhCs0B,EAAUjoC,QAAQ,WACjB2T,EAAO,iBAAkB+5H,GACzB/5H,EAAO,iBAAkBo1F,IAE7Bp1F,EAAO,aAAc65H,EAAgBD,EAAOjlH,YAAc7vB,EAAMyM,aAChEyO,EAAO,aAAsD,GAAtC65H,GAAiB1iH,GAAgB,IACxDnX,EAAO,YACPA,EAAO,iBAGX,IAAIg6H,EAAYh6H,EAAO,aACnBi6H,EAAmB9rI,EAAWwgC,YAAc,GAEhD,GAAGqrG,EAAW,CACV,IAAIE,EAAUl6H,EAAO,qBAAsBi6H,EAAiBrlH,UACvD9vB,EAAMqL,QAAQmQ,GAAWxb,EAAMsnB,IAAI9L,GAAWxb,EAAMyM,cAGrD4oI,EAAcn6H,EAAO,yBAA0Bi6H,EAAiBtlH,aAChE7vB,EAAMioB,SAASmtH,IAGnB3zI,EAAImkB,WAAW1K,EAAQ,kBAAmB,CACtC/Y,OAAQgzI,EAAiBjzI,KAAKC,OAC9BC,KAAM+yI,EAAiBjzI,KAAKE,KAC5BjB,MAAOg0I,EAAiBjzI,KAAKf,OAASk0I,IAI9Cn6H,EAAO,kBAAmBg6H,K,8CC1C9Bj1I,EAAOC,QAAU,SAAsB0pB,GAKnC,IAJA,IAAI0rH,EAAO,GACPhoI,EAAM,GACNgM,EAAI,EAEAlQ,EAAI,EAAGA,EAAIwgB,EAAM5iB,OAAQoC,IAAK,CAClC,IAAI8P,EAAO0Q,EAAMxgB,GAEC,IAAfksI,EAAKp8H,KACJo8H,EAAKp8H,GAAQ,EACb5L,EAAIgM,KAAOJ,GAInB,OAAO5L,I,4CCrCX,IAAIjM,EAAY,EAAQ,YAEpBI,EAAM,EAAQ,YACd6xB,EAAU,EAAQ,YAA6BA,QAC/C/xB,EAAW,EAAQ,YAsCvB,SAASqsD,EAAaxpD,EAAI2oC,GACtB,IAAI3jC,EAAGkQ,EACHi8H,EAAW,GAEX5hE,EAASlD,EAAU1jC,GACnB8mC,EAAWnD,EAAetsE,EAAI2oC,GAC9B+mC,EAAWD,EAASn4C,IACpBq4C,EAAWF,EAAStuE,IAExB,GAAuB,IAApBuuE,EAAS9sE,QAAoC,IAApB+sE,EAAS/sE,OACjC,OAAOvF,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KAGtC,IAAI4iF,EAAS1hE,EAAS,GAAGvyD,IACrBk0H,EAAS1hE,EAAS,GAAGxyD,IAEzB,IAAInY,EAAI,EAAGA,EAAI0qE,EAAS9sE,QACjBwuI,IAAWC,EADcrsI,IAE5BosI,EAAS/wI,KAAKi3B,IAAI85G,EAAQ1hE,EAAS1qE,GAAGmY,KAE1C,IAAInY,EAAI,EAAGA,EAAI2qE,EAAS/sE,QACjBwuI,IAAWC,EADcrsI,IAE5BqsI,EAAShxI,KAAKc,IAAIkwI,EAAQ1hE,EAAS3qE,GAAGmY,KAG1C,IAAIm0H,GAAY,EAEhB,GAAG3oG,EAAGntB,MAAO,CACT,IAAIF,EAAMje,EAAImZ,UAAUmyB,EAAGntB,MAAOmtB,EAAG6lB,KACrC8iF,EAAYh2H,EAAI,GAAKA,EAAI,GAIT,aAAjBqtB,EAAGptB,YACF+1H,GAAY,EACZ3oG,EAAGptB,WAAY,GAGnB,IAqBIg2H,EAAOC,EAAOC,EAASC,EAAS35E,EAAIpf,EArBpCg5F,EAAYhpG,EAAG0jG,UACfuF,EAAuB,WAAdD,EACTE,EAA4B,gBAAdF,EACdG,EAAQnpG,EAAGhH,QAEXowG,EAAUD,EAAQ,GAGlBE,EAAmB,SAAS56G,EAAIC,GAChC,IAAI46G,EAAU,EACd,GAAGtpG,EAAGonB,YAEF,IADA,IAAImiF,EAAiBvpG,EAAGwpG,aAAa/6G,EAAIC,GACjCryB,EAAI,EAAGA,EAAIktI,EAAetvI,OAAQoC,IAAK,CAC3C,IAAI6rD,EAAMqhF,EAAeltI,GACzBitI,GAAWphF,EAAI1vD,IAAM0vD,EAAIv5B,IAGjC,OAAO26G,GAGPG,EAAQ,EAGZ,IAAIptI,EAAI,EAAGA,EAAI0qE,EAAS9sE,OAAQoC,IAE5B,IADAusI,EAAQ7hE,EAAS1qE,GACbkQ,EAAI,EAAGA,EAAIy6D,EAAS/sE,OAAQsS,KAE5ByjC,GADA64F,EAAQ7hE,EAASz6D,IACNiI,IAAMo0H,EAAMp0H,IAAM60H,EAAiBT,EAAMp0H,IAAKq0H,EAAMr0H,MACvD,KACJ46C,EAAK+5E,EAAQviE,EAAOgiE,GAAShiE,EAAOiiE,IAC5BO,EACDp5F,EAAKof,EAAKq6E,IACTX,EAAUF,EACVG,EAAUF,EACVY,EAAQz5F,EAAKof,GAEXpf,EAAKm5F,EAAQM,IAGnBX,EAAU,CAACt0H,IAAKo0H,EAAMp0H,IAAKoK,IAAK,GAChCmqH,EAAU,CAACv0H,IAAKq0H,EAAMr0H,IAAKoK,IAAK,GAChC6qH,EAAQz5F,EAAKm5F,IAU7B,GAAGV,IAAWC,EAAQ,CAClB,IAAIgB,EAAQjB,EAAS,EACjBkB,EAAQlB,EAAS,EACrB,GAAGQ,EACC,GAAc,IAAXR,EAKCD,EAAW,CAAC,EAAG,OACZ,CACH,IAAIoB,GAAUnB,EAAS,EAAIzhE,EAAWD,GAAU5kC,QAf5D,SAAmB0nG,EAAMrnI,GACrB,OAAO9K,KAAKc,IAAIqxI,EAAMjjE,EAAOpkE,MAc6C,GAI9DsnI,EAAWrB,GAAU,EAAI/wI,KAAKi3B,IAAI,GAAKi7G,EAAST,IACpDX,EAAWC,EAAS,EAAI,CAAC,EAAGqB,GAAY,CAACA,EAAU,QAGvDtB,EADMU,EACK,CAACxxI,KAAKc,IAAI,EAAGkxI,GAAQhyI,KAAKc,IAAI,EAAGmxI,IAEjC,CAACD,EAAOC,QAGpBV,GACIH,EAAQt0H,KAAO,IACds0H,EAAU,CAACt0H,IAAK,EAAGoK,IAAK,IAEzBmqH,EAAQv0H,KAAO,IACdu0H,EAAU,CAACv0H,IAAK,EAAGoK,IAAK,KAEtBsqH,IACHJ,EAAQt0H,IAAMi1H,EAAQ7iE,EAAOkiE,GAAW,IACvCA,EAAU,CAACt0H,IAAK,EAAGoK,IAAK,IAEzBmqH,EAAQv0H,KAAO,IACdu0H,EAAU,CAACv0H,IAAK,EAAGoK,IAAK,KAKhC6qH,GAASV,EAAQv0H,IAAMs0H,EAAQt0H,IAAM60H,EAAiBT,EAAMp0H,IAAKq0H,EAAMr0H,OAClE20H,EAAQviE,EAAOkiE,GAAWliE,EAAOmiE,IAEtCP,EAAW,CACPM,EAAQt0H,IAAMi1H,EAAQ7iE,EAAOkiE,GAC7BC,EAAQv0H,IAAMi1H,EAAQ7iE,EAAOmiE,IAOrC,OAFGJ,GAAWH,EAAS71F,UAEhBj+C,EAAImZ,UAAU26H,EAAUxoG,EAAGomB,KAAOpyC,QAO7C,SAAS0vD,EAAU1jC,GAEf,IAAI+pG,EAAY/pG,EAAGhH,QAAU,GAS7B,MALqB,WAAjBgH,EAAGxR,WAA2BwR,EAAGklC,eACjC6kE,IAAc/pG,EAAGklC,aAAa,GAAKllC,EAAGklC,aAAa,KAC9CllC,EAAG44B,OAAO,GAAK54B,EAAG44B,OAAO,KAG3B,SAAgBp2D,GAAM,OAAOA,EAAGoc,KAAOpc,EAAG+8G,SAAWwqB,EAAY,IAG5E,SAASpmE,EAAetsE,EAAI2oC,GACxB,IAKI3jC,EAAGkQ,EAAGjZ,EALN+a,EAAO2xB,EAAGzwB,IACVjD,EAAWjV,EAAG8uC,UACd7pC,EAAajF,EAAGkF,YAChBwqE,EAAW,GACXC,EAAW,GAGf,SAASgjE,EAAQrnI,EAAMmR,GACnB,IAAIzX,EAAI,EAAGA,EAAIyX,EAAQ7Z,OAAQoC,IAAK,CAChC,IAAI8P,EAAOxJ,EAAKmR,EAAQzX,IACpByqE,GAAY36D,EAAKirF,WAAa,IAAI/oF,GACtC,IAAoB,IAAjBlC,EAAKiQ,SAAoB0qD,EAAU,CAClC,IAAIv6D,EAAI,EAAGA,EAAIu6D,EAASn4C,IAAI10B,OAAQsS,IAChCjZ,EAAIwzE,EAASn4C,IAAIpiB,GACjB09H,EAAiBljE,EAAUzzE,EAAEkhB,IAAKlhB,EAAEsrB,IAAK,CAAC2gG,SAAUjsH,EAAEisH,WAE1D,IAAIhzG,EAAI,EAAGA,EAAIu6D,EAAStuE,IAAIyB,OAAQsS,IAChCjZ,EAAIwzE,EAAStuE,IAAI+T,GACjB29H,EAAiBljE,EAAU1zE,EAAEkhB,IAAKlhB,EAAEsrB,IAAK,CAAC2gG,SAAUjsH,EAAEisH,aAUtE,OAJAyqB,EAAQ19H,EAAU0zB,EAAGnxB,eACrBm7H,EAAQ1tI,EAAW2+B,aAAe,GAAI+E,EAAGhxB,aAAe,IACxDg7H,EAAQ1tI,EAAW8rF,QAAU,GAAIpoD,EAAG/wB,eAAiB,IAE9C,CAAC0f,IAAKo4C,EAAUvuE,IAAKwuE,GA4LhC,SAASijE,EAAiBptH,EAAOgqD,EAAQsjE,EAAQvxH,GAC7CwxH,EAAcvtH,EAAOgqD,EAAQsjE,EAAQvxH,EAAMyxH,GAG/C,SAASH,EAAiBrtH,EAAOgqD,EAAQsjE,EAAQvxH,GAC7CwxH,EAAcvtH,EAAOgqD,EAAQsjE,EAAQvxH,EAAM0xH,GAwC/C,SAASF,EAAcvtH,EAAOgqD,EAAQsjE,EAAQvxH,EAAM2xH,GAKhD,IAJA,IAAI5nC,EAAS/pF,EAAK+pF,OACd4c,EAAW3mG,EAAK2mG,SAChBirB,GAAc,EAEVj+H,EAAI,EAAGA,EAAIsQ,EAAM5iB,QAAUuwI,EAAaj+H,IAAK,CACjD,IAAIjS,EAAIuiB,EAAMtQ,GACd,GAAGg+H,EAAiBjwI,EAAEka,IAAKqyD,IAAWvsE,EAAEskB,KAAOurH,IAAW7vI,EAAEilH,WAAaA,GAAW,CAChFirB,GAAc,EACd,MACMD,EAAiB1jE,EAAQvsE,EAAEka,MAAQla,EAAEskB,KAAOurH,IAAW5qB,IAAajlH,EAAEilH,YAC5E1iG,EAAM1J,OAAO5G,EAAG,GAChBA,KAGR,GAAGi+H,EAAa,CACZ,IAAIC,EAAc9nC,GAAqB,IAAX97B,EAC5BhqD,EAAMljB,KAAK,CACP6a,IAAKqyD,EACLjoD,IAAK6rH,EAAa,EAAIN,EACtB5qB,UAAUkrB,GAAqBlrB,KAO3C,SAASmrB,EAAWpwI,GAChB,OAAOhG,EAAUgG,IAAM5C,KAAK6/B,IAAIj9B,GAAKisB,EAGzC,SAAS8jH,EAAY57G,EAAIC,GAAM,OAAOD,GAAMC,EAC5C,SAAS47G,EAAe77G,EAAIC,GAAM,OAAOD,GAAMC,EA7e/Cx7B,EAAOC,QAAU,CACb0tD,aAAcA,EACd6iB,UAAWA,EACXinE,YAoOJ,SAAqBtzI,EAAI2oC,GAGrB,GAFAA,EAAG11B,WAEA01B,EAAGptB,UAAW,CACbotB,EAAGntB,MAAQguC,EAAaxpD,EAAI2oC,GAE5BA,EAAG8zB,GAAK9zB,EAAGntB,MAAMC,QACjBktB,EAAG+zB,IAAMr/D,EAAImZ,UAAUmyB,EAAG8zB,GAAI9zB,EAAG6lB,KAKjC,IAAI+kF,EAAO5qG,EAAGpuB,OAGV6pB,EAAQ,GACZA,EAAMuE,EAAG1wB,MAAQ,UAAY0wB,EAAGntB,MAChC4oB,EAAMuE,EAAG1wB,MAAQ,cAAgB0wB,EAAGptB,UACpCpe,EAASN,KAAK,sBAAuBmD,EAAGshB,OAAQthB,EAAGkF,YAAYysF,QAASvtD,GAExEmvG,EAAK/3H,MAAQmtB,EAAGntB,MAAMC,QACtB83H,EAAKh4H,UAAYotB,EAAGptB,UAGxB,IAAIixE,EAAW7jD,EAAGy2B,YAElB,GAAGotB,GAAYA,EAASxgB,YAAa,CACjC,IAAIwnE,EAAehnD,EAASxgB,YAAYrjC,EAAG3wB,OACxCw7H,GAC+B,SAA3BA,EAAanH,YACZmH,EAAah4H,MAAQguC,EAAaxpD,EAAI2oC,IAG9C6jD,EAASjyE,OAAOyxD,YAAYrjC,EAAG3wB,OAAS3a,EAAIiM,WAAW,GAAIkqI,KApQ/D/pF,aAiTJ,SAAsB9gB,EAAIrnC,EAAMigB,GACxBA,IAAMA,EAAO,IACbonB,EAAGg9B,IAAIh9B,EAAG11B,WAEd,IASIjO,EAAG/B,EAAG4hH,EAAI4uB,EAAMC,EAAMC,EAAWC,EAAYC,EAAMC,EATnDpkE,EAAW,GACXC,EAAW,GAEX/qE,EAAMtD,EAAKsB,OACXslH,EAAW3mG,EAAKgqF,SAAU,EAC1BD,EAAS/pF,EAAK+pF,SAAuB,WAAZ3iE,EAAGlkC,MAAiC,MAAZkkC,EAAGlkC,MACpD85H,EAAoB,QAAZ51F,EAAGlkC,KACXsvI,GAAiB,EACjBC,EAAiBzyH,EAAKyyH,iBAAkB,EAG5C,SAASC,EAAgBn/H,GACrB,GAAG/P,MAAM+D,QAAQgM,GAEb,OADAi/H,GAAiB,EACV,SAAS/uI,GAAK,OAAO3E,KAAKc,IAAIwb,OAAO7H,EAAK9P,IAAI,GAAI,IAEzD,IAAI/B,EAAI5C,KAAKc,IAAIwb,OAAO7H,GAAM,GAAI,GAClC,OAAO,WAAa,OAAO7R,GAInC,IAAI0pG,EAAWsnC,GAAiBtrG,EAAGg9B,GAAK,EACpCpkD,EAAKorF,SAAWprF,EAAKqrF,YAAcrrF,EAAK2yH,MAAQ,GAChDtnC,EAAYqnC,GAAiBtrG,EAAGg9B,GAAK,EACrCpkD,EAAKqrF,UAAYrrF,EAAKorF,WAAaprF,EAAK2yH,MAAQ,GAChDC,EAAWF,EAAgB1yH,EAAK4yH,UAAY5yH,EAAK6yH,MACjDC,EAAYJ,EAAgB1yH,EAAK8yH,WAAa9yH,EAAK6yH,MAEvD,IAAIL,EAAgB,CAMhB,GAHAF,EAAO97G,IACP+7G,GAAQ/7G,IAELwmG,EACC,IAAIv5H,EAAI,EAAGA,EAAIJ,EAAKI,KAChB/B,EAAI3B,EAAK0D,IAEF6uI,GAAQ5wI,EAAI,IAAG4wI,EAAO5wI,GAC1BA,EAAI6wI,GAAQ7wI,EAAIisB,IAAS4kH,EAAO7wI,QAGvC,IAAI+B,EAAI,EAAGA,EAAIJ,EAAKI,KAChB/B,EAAI3B,EAAK0D,IACF6uI,GAAQ5wI,GAAKisB,IAAS2kH,EAAO5wI,GACjCA,EAAI6wI,GAAQ7wI,EAAIisB,IAAS4kH,EAAO7wI,GAI3C3B,EAAO,CAACuyI,EAAMC,GACdlvI,EAAM,EAGV,IAAI0vI,EAAe,CAAChpC,OAAQA,EAAQ4c,SAAUA,GAE9C,SAASqsB,EAAQvvI,GACb6/G,EAAKvjH,EAAK0D,GACN/H,EAAU4nH,KACd8uB,EAAYhnC,EAAS3nG,GACrB4uI,EAAahnC,EAAU5nG,GAEpBgvI,GACCP,EAAO9qG,EAAG4uB,IAAIstD,GAAMwvB,EAAUrvI,GAC9B0uI,EAAO/qG,EAAG4uB,IAAIstD,GAAMsvB,EAASnvI,KAE7B6uI,EAAOhvB,EAAKwvB,EAAUrvI,GACtB8uI,EAAOjvB,EAAKsvB,EAASnvI,GAKlBu5H,GAASsV,EAAOC,EAAO,KAAID,EAAOC,EAAO,IAE5CL,EAAO9qG,EAAG4uB,IAAIs8E,GACdH,EAAO/qG,EAAG4uB,IAAIu8E,IAGfxoC,IACCmoC,EAAOpzI,KAAKi3B,IAAI,EAAGm8G,GACnBC,EAAOrzI,KAAKc,IAAI,EAAGuyI,IAEpBL,EAAWI,IACVb,EAAiBljE,EAAU+jE,EAAMG,EAAYU,GAE9CjB,EAAWK,IACVb,EAAiBljE,EAAU+jE,EAAMC,EAAWW,IAOpD,IAAIE,EAAOn0I,KAAKi3B,IAAI,EAAG1yB,GACvB,IAAII,EAAI,EAAGA,EAAIwvI,EAAMxvI,IAAKuvI,EAAQvvI,GAClC,IAAIA,EAAIJ,EAAM,EAAGI,GAAKwvI,EAAMxvI,IAAKuvI,EAAQvvI,GAEzC,MAAO,CACHsyB,IAAKo4C,EACLvuE,IAAKwuE,EACLpuD,KAAMA,IAvZV+qD,eAAgBA,I,4CCXpB,IAAIrvE,EAAY,EAAQ,YAEpBI,EAAM,EAAQ,YACdF,EAAW,EAAQ,YACnBkmC,EAAO,EAAQ,YAEfoxG,EAAmB,EAAQ,YAC3BC,EAAe,EAAQ,YACvBC,EAAgB,EAAQ,YACxBC,EAAQ,EAAQ,YAChBC,EAAuB,EAAQ,YAiNnC,SAASC,EAAgB90I,EAAI9D,EAAOw8C,EAAIq8F,EAAUC,GAC9C,IAKIhwI,EAAGjJ,EAAQoxI,EAAQzzH,EAAUu7H,EAAMC,EAAUC,EAL7CC,EAAUL,EAAW,OACrB9vI,EAAajF,EAAGkF,YAChBmwI,EAAYn5I,EAAM,IAAM64I,EAAW,YACnCO,EAAUrwI,EAAWswI,kBAAkBF,GACvCG,EAAmC,YAAvBvwI,EAAWk2G,QAGvBzO,EAAM,SAASzpG,GAAK,OAAOy1C,EAAGg0D,IAAIzpG,EAAG,EAAGyW,IACxCmzC,EAAM,SAAS5pD,GAAK,OAAOy1C,EAAGmU,IAAI5pD,EAAG,EAAGyW,IAExC+7H,EAAyB,SAAZ/8F,EAAGj0C,KAChB,SAASxB,GAAK,OAAQA,GAAW,IAANA,EAAW5F,EAAIszB,UAAU1tB,EAAG,KAAMyW,GAAY,MACzE,SAASzW,GAAK,OAAOhG,EAAUgG,GAAK0Z,OAAO1Z,GAAK,MAEpD,SAASyyI,EAASp3I,EAAMq3I,EAAMC,GACvBD,EAAKr3I,EAAO,UACXq3I,EAAKr3I,GAAQm3I,EAAWE,EAAKr3I,IACX,OAAfq3I,EAAKr3I,KAAgBq3I,EAAKr3I,GAAQs3I,EAAQt3I,MAE7C42I,EAAS52I,GAAQq3I,EAAKr3I,GAAQs3I,EAAQt3I,GACtCjB,EAAIkO,eAAexP,EAAO,GAAIq5I,EAAU,IAAM92I,GAAMse,IAAIg5H,EAAQt3I,KAMxE,GAAGpC,EAAM,IAAM64I,EAAW,0BACf74I,EAAM,IAAM64I,EAAW,uBAC3B,CACHh5I,EAASu5I,EAAQv5I,OACjB,IAAI85I,EAAS,GAMTC,GAAiB,EACjBC,GAAW,EACXC,GAAmB,EACvB,IAAIhxI,EAAI,EAAGA,EAAIjJ,EAAO6G,OAAQoC,IAG1B,IAFAmoI,EAASpxI,EAAOiJ,IAEN+f,QAAS,CACf,IAAIkxH,EAAYX,EAAQY,KAAKlxI,GAC7BiwI,EAAO9H,EAAO,IAAM8I,EAAY,QAAUv9F,EAAGy9F,aAAahJ,EAAQ8I,GAElEJ,EAASx4I,EAAIsZ,OAAOk/H,EAAQZ,UACrB9H,EAAO,IAAM4H,EAAW,oBAEV,IAAlB74I,EAAM6oB,UACF+wH,EACCA,GAAiB,UAEV3I,EAAOiJ,SACdjJ,EAAO,IAAM4H,EAAW,mBAAqB,GAE9C53I,EAAS2C,QAAQqtI,EAAQ,WACxB4I,GAAW,GAEI,uBAAhB5I,EAAO1oI,OACNuxI,GAAmB,IAMnCt8H,EAAW3d,EAAO,GAAGg5I,EAAW,YAChC,IAAIsB,EAAahzG,EAAKipB,QAAQupF,EAAQn9F,EAAI48F,EAAQ/oF,MAAOwpF,EAAUr8H,EAAU47H,EAAQgB,WAAahB,EAAQt3I,MAEtGsuD,EAAUvwD,EAAO,GAAGq6I,SAAW,GAkBnC,GAjBAlB,EAAW5oF,EAAQgpF,EAAQY,KAAK,IAAM,GAEnCF,IAGKV,EAAQt3I,OACRq4I,EAAWxqI,MAAQghD,EAAIxpB,EAAKkV,cACxBm0D,EAAI2pC,EAAWxqI,OAAQwqI,EAAWr4I,MAAM,EAAM0b,UAEnC3S,IAAhBuuI,EAAQxpI,MACPuqI,EAAWvqI,IAAM+gD,EAAIxpB,EAAKkV,cACtBm0D,EAAI2pC,EAAWvqI,KAAMuqI,EAAWr4I,MAAM,EAAO0b,MAMtD87H,IAAcr4I,EAAS2C,QAAQ5D,EAAO,UAAqC,IAAzBm6I,EAAWzpF,WAChD,aAAZlU,EAAGj0C,MAAmC,kBAAZi0C,EAAGj0C,KAA0B,CAIvD,GAAGuwI,EAAkB,MAAO,CAACqB,EAAYpB,GAAM,GAE/CoB,EA8FZ,SAAmCr2I,EAAI9D,EAAOw8C,EAAIq8F,EAAUK,GACxD,IAKIpwI,EAAGmoI,EAAQmI,EALXrwI,EAAajF,EAAGkF,YAChBqxI,EAoFR,SAAgCv2I,EAAI9D,GAOhC,IANA,IAAIs6I,EAAMt6I,EAAMyD,MACZ82I,EAAMv6I,EAAM0D,MACZqW,EAAc/Z,EAAM+Z,YAEpB/M,EAAM,GACN+L,EAAWjV,EAAG8uC,UACV9pC,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK,CACrC,IAAImoI,EAASl4H,EAASjQ,GACH,cAAhBmoI,EAAO1oI,OACa,IAAnB0oI,EAAOpoH,SACPooH,EAAOl3H,cAAgBA,GACvBk3H,EAAOxtI,QAAU62I,GAAOrJ,EAAOvtI,QAAU62I,GAEzCvtI,EAAI5G,KAAK6qI,GAIjB,OAAOjkI,EAtGkBwtI,CAAuB12I,EAAI9D,GAChDy6I,GAAgB,EAChBzpF,EAAUn1B,IACV6+G,EAAqB,CAAC16I,GAM1B,IAAI8I,EAAI,EAAGA,EAAIuxI,EAAmB3zI,OAAQoC,IAGtC,IAFAmoI,EAASoJ,EAAmBvxI,MAEd9I,EACVy6I,GAAgB,OACb,GAAIA,EAMJ,CACH,IAAIE,EAAU/B,EAAgB90I,EAAImtI,EAAQz0F,EAAIq8F,GAAU,GACpD+B,EAAWD,EAAQ,GACnBE,EAAiBF,EAAQ,GAI7B1J,EAAO,IAAM4H,EAAW,mBAAqB,EAC7C5H,EAAO,IAAM4H,EAAW,QAAU8B,EAAQ,GAEvCE,EACCH,EAAmBt0I,KAAK6qI,GAExBjgF,EAAU7sD,KAAKi3B,IAAI41B,EAAS4pF,EAAS94I,WAfzCs3I,EAAUrwI,EAAWswI,kBAAkBpI,EAAO,IAAM4H,EAAW,aAC/D7nF,EAAU7sD,KAAKi3B,IAAI41B,EAASooF,EAAQt3I,MAAQmvI,EAAOiI,GAASp3I,MAqBpE,IAAIg5I,EAAW,IAAIjyI,MAAM6xI,EAAmBh0I,QAC5C,IAAIoC,EAAI,EAAGA,EAAI4xI,EAAmBh0I,OAAQoC,IAEtC,IADA,IAAIiwI,EAAO2B,EAAmB5xI,GAAG,IAAM+vI,EAAW,QAC1C7/H,EAAI,EAAGA,EAAI+/H,EAAKryI,OAAQsS,IAC5B,QAAenO,IAAZkuI,EAAK//H,GAAkB,CACtB8hI,EAAShyI,GAAKiwI,EAAK//H,GACnB,MAORulB,SAASyyB,KACTA,EAAU7vD,EAAIm0B,aAAawlH,GAAU/pF,SAIzC,IAAIjoD,EAAI,EAAGA,EAAI4xI,EAAmBh0I,OAAQoC,IAAK,CAE3C,IAAI0U,GADJyzH,EAASyJ,EAAmB5xI,IACN+vI,EAAW,YAE7Ba,EAAU,CACV/pI,MAAO6sC,EAAGmU,IAAImqF,EAAShyI,GAAKkoD,EAAU,EAAG,EAAGxzC,GAC5C5N,IAAK4sC,EAAGmU,IAAImqF,EAAShyI,GAAKkoD,EAAU,EAAG,EAAGxzC,GAC1C1b,KAAMkvD,GAGVigF,EAAO5yH,OAAO66H,GAAWjI,EAAOiI,GAAWQ,GAE3CN,EAAUrwI,EAAWswI,kBAAkBpI,EAAO,IAAM4H,EAAW,eACnD13I,EAAIiM,WAAWgsI,EAASM,GAGxC,OAAO15I,EAAMk5I,GA1KQ6B,CAA0Bj3I,EAAI9D,EAAOw8C,EAAIq8F,EAAUK,IAIpED,EAAiBhI,EAAO+J,YAAc,IACpB97E,SAA0C,YAA9B+5E,EAAegC,aACT,eAA7BhC,EAAehtH,UACdkuH,EAAWxqI,MAAQghD,EAAIxpB,EAAKkV,cACxBm0D,EAAI2pC,EAAWxqI,OAAQwqI,EAAWr4I,MAAM,EAAM0b,IAElD28H,EAAWvqI,IAAM+gD,EAAIxpB,EAAKkV,cACtBm0D,EAAI2pC,EAAWvqI,KAAMuqI,EAAWr4I,MAAM,EAAO0b,KAIzD47H,EAAQt3I,KAAOq4I,EAAWr4I,KACtBs3I,EAAQgB,YACRpB,EAASl3I,KAAOq4I,EAAWr4I,KAC3BX,EAAIkO,eAAexP,EAAO,GAAIq5I,EAAU,SAASx4H,IAAIy5H,EAAWr4I,OAGpE03I,EAAS,QAASJ,EAASe,GAC3BX,EAAS,MAAOJ,EAASe,GAG7BpB,EAAO/4I,EAAM,IAAM64I,EAAW,eACvB74I,EAAM,IAAM64I,EAAW,QAK9B,IAAIqC,EAAiBl7I,EAAMqe,OAAO66H,IAAY,GAC1CiC,EAAmBh6I,EAAIiM,WAAW,GAAIgsI,GACtCgC,EAAYhC,EAAQzpI,MACpB0rI,EAAU7+F,EAAG8V,IAAI4oF,EAAevrI,OAChC2rI,OAAuBzwI,IAAZwwI,EACf,IAAIjC,EAAQmC,YAAcD,IAAaD,IAAY7+F,EAAG8V,IAAI8oF,GAAY,CAKlE,IAAII,EAAaF,EACbD,EACAl6I,EAAIw0B,QAAQxxB,KAAKi3B,IAAK,KAAM29G,GAE5BxoF,EAAU,CACVhoD,KAAmB,aAAZi0C,EAAGj0C,MAAmC,kBAAZi0C,EAAGj0C,KAA4B,SAAWi0C,EAAGj0C,KAC9E+pD,IAAK9V,EAAG8V,IACRpsC,MAAOkzH,EAAQt3I,KACfqkB,MAAOi1H,EACP59H,SAAUA,EACV8B,MAAO,CAAEk8H,EAAYr0G,EAAKkV,cAAcm/F,EAAYpC,EAAQt3I,MAAM,EAAO0b,IAAYjC,IAAIihC,EAAGqW,MAE5F4oF,EAAWt0G,EAAKkqB,UAAUd,GAC3BkrF,EAAWj/F,EAAG8V,IAAIkpF,KACjBC,EAAWt0G,EAAKkV,cAAco/F,EAAUrC,EAAQt3I,MAAM,EAAM0b,IAEhE29H,EAAiBxrI,MAAQ6sC,EAAGqW,IAAI4oF,GAC5BH,GAAUn6I,EAAIkO,eAAerP,EAAOk5I,EAAU,UAAUx4H,IAAIy6H,EAAiBxrI,OAGrF,IAAI+rI,EAAUtC,EAAQxpI,IAClB+rI,EAAQn/F,EAAG8V,IAAI4oF,EAAetrI,KAC9BgsI,OAAmB/wI,IAAV8wI,EACb,IAAIvC,EAAQyC,UAAYD,IAAWD,IAAUn/F,EAAG8V,IAAIopF,GAAU,CAG1D,IAAII,EAAWF,EACXD,EACAx6I,EAAIw0B,QAAQxxB,KAAKc,IAAK,KAAM8zI,GAEhCoC,EAAiBvrI,IAAM4sC,EAAGqW,IAAIipF,GAC1BF,GAAQz6I,EAAIkO,eAAerP,EAAOk5I,EAAU,UAAUx4H,IAAIy6H,EAAiBvrI,KAMnF,IAAImsI,EAAc,UAAYlD,EAO9B,OANiC,IAA9B74I,EAAMqe,OAAO09H,KACZ/7I,EAAMqe,OAAO66H,GAAW/3I,EAAIiM,WAAW,GAAIpN,EAAMk5I,IAAY,WACtDl5I,EAAMqe,OAAO09H,UACb/7I,EAAM+7I,IAGV,CAACZ,EAAkBpC,GAoK9Bp5I,EAAOC,QAAU,CACb2kG,KAxiBJ,SAAczgG,EAAI9D,GACd,IAOI8I,EAiBAkzI,EAAI9qF,EAAQ/qD,EAxBZqL,EAAM,GACN1P,EAAO,GACP06C,EAAKrV,EAAKQ,UAAU7jC,EAA0B,MAAtB9D,EAAM+Z,YAAsB/Z,EAAM0D,MAAQ1D,EAAMyD,OACxEo1I,EAAiC,MAAtB74I,EAAM+Z,YAAsB,IAAM,IAC7CkiI,EAAc,CAAC/5I,EAAG,IAAKC,EAAG,KAAK02I,GAC/Br7H,EAAWxd,EAAM64I,EAAW,YAC5BI,EAAiBj5I,EAAMg7I,WAGvBkB,EAAatD,EAAgB90I,EAAI9D,EAAOw8C,EAAIq8F,GAC5CsD,EAAUD,EAAW,GACrBnD,EAAOmD,EAAW,GAElBE,EAAyC,iBAAjBD,EAAQr6I,KAChC07C,EAAW,GACXi8F,EAAO2C,EAAiB5+F,EAAW2+F,EAEnCp0B,EAAM,GACNhgB,EAAS,GACTs0C,EAAc,GACdp0C,EAAQ,EACRikB,EAAOlsH,EAAMs8I,SACbhhH,EAAOt7B,EAAMu8I,SACbC,GAA2C,IAA7BtwB,EAAKjlH,QAAQ,WAG5BgyI,EAAe/5E,SAAWs9E,IAGzBtwB,EAAOA,EAAKhlH,QAAQ,aAAc,IAClCs1I,GAAc,GAGlB,IAMIC,EALAC,EADuB,QAATphH,GAA2B,QAATA,EACP,KAAO,EAChCqhH,EAAUnE,EAAa/1G,MACvBm6G,EAAWnE,EAAcvsB,GACzB2wB,GAAQ,EACRC,EAAO,SAAS/1I,GAAK,OAAOy1C,EAAGg0D,IAAIzpG,EAAG,EAAGyW,IAgB7C,IAbGrc,EAAI+K,oBAAoBlM,EAAMi8I,KAA0B,UAAT3gH,IAC9CmhH,EAAiBz8I,EAAMi8I,GACvBY,EAAiB,QAATvhH,EACRqhH,EAAUnE,EAAal9G,IAK3BxyB,EAAIg0I,EAAKX,EAAQxsI,OAGjBuhD,EAAS4rF,EAAKX,EAAQvsI,MAAQ9G,EAAIq+B,EAAKkV,cAAcvzC,EAAGqzI,EAAQr6I,MAAM,EAAO0b,IAAa,IAEpF1U,EAAIooD,GAAU1/C,EAAI9K,OAAS,MAC7Bs1I,EAAK70G,EAAKkV,cAAcvzC,EAAGqzI,EAAQr6I,MAAM,EAAO0b,GAChDhM,EAAIpL,MAAM0C,EAAIkzI,GAAM,GACpBl6I,EAAKsE,KAAKs2I,GACVL,EAAYj2I,KAAK,IAGjBo3C,EAASp3C,KAAK0C,GAEX0zI,GAAaz0B,EAAI3hH,KAAK,GAAK41I,EAAKlzI,IAChC+zI,GAAO90C,EAAO3hG,KAAK,KAEnB41I,GAAMlzI,KACTA,EAAIkzI,EAERx+F,EAASp3C,KAAK0C,GAIVszI,GAA8B,SAAZ5/F,EAAGj0C,OACrBkxI,EAAO,CACH9pI,MAAOmtI,EAAKrD,EAAK9pI,OACjBC,IAAKktI,EAAKrD,EAAK7pI,KACf9N,KAAM23I,EAAK33I,OAKfgC,EAAGkF,YAAY+zI,eAAcj5I,EAAGkF,YAAY+zI,aAAe,IAC/D,IAAI5D,EAAYn5I,EAAM,IAAM64I,EAAW,YACnCmE,EAAc,CAAC1/F,QAASzhB,IAAU0hB,SAAU1hB,KAC7Cs9G,IACKr1I,EAAGkF,YAAY+zI,aAAa5D,KAAYr1I,EAAGkF,YAAY+zI,aAAa5D,GAAa6D,GACrFA,EAAcl5I,EAAGkF,YAAY+zI,aAAa5D,IAK9C,IAuBI8D,EAvBAj1C,EAAOlmG,EAAK4E,OACZw2I,GAAmB,EACnB5/F,EAAU0/F,EAAY1/F,QACtBC,EAAWy/F,EAAYz/F,SACvBte,EAAmB,GACvB,IAAIn2B,EAAI,EAAGA,EAAIiwI,EAAKryI,OAAQoC,IAAK,CAC7B,IAAIq0I,EAAOpE,EAAKjwI,IAChB3C,EAAIhF,EAAIg0B,QAAQgoH,EAAM1D,KACd,GAAKtzI,EAAI6hG,IACbC,GAAS00C,EAAQx2I,EAAG2C,EAAGhH,EAAM26I,EAAgB10C,GAC1Cm1C,GAAoBb,EAAYl2I,GAAGO,QAAUy2I,IAASpE,EAAKsD,EAAYl2I,GAAG,MACzE+2I,GAAmB,GAEvBb,EAAYl2I,GAAGC,KAAK0C,GACpBm2B,EAAiBn2B,GAAK3C,EAEtBm3C,EAAUn5C,KAAKi3B,IAAIkiB,EAAS6/F,EAAO3/F,EAASr3C,IAC5Co3C,EAAWp5C,KAAKi3B,IAAImiB,EAAUC,EAASr3C,EAAI,GAAKg3I,IAGxDH,EAAY1/F,QAAUA,EACtB0/F,EAAYz/F,SAAWA,EAGnB2/F,IACAD,EAAU,SAASl2I,EAAGo3C,GAClB,OAAO,WACH,IAAI6+F,EAAcl5I,EAAGkF,YAAY+zI,aAAa5D,GAC9C,OAAOR,EACHqE,EAAY1/F,QACZ0/F,EAAYz/F,SACZC,EAAUhB,EAAIh/B,EAHXm7H,CAIL5xI,EAAGo3C,MAMd0+F,IAAO50C,EAAQywC,EAAM52I,EAAMimG,IAC3B60C,GAAUA,EAAS96I,EAAMmmG,EAAO8f,GAGhCkxB,EAAe/5E,SAgXtB,SAAap9D,EAAMmqB,EAAWmxH,GAC1B,IAAIt0I,EAAGu0I,EAAIC,EAEX,SAASC,EAAez0I,GACpBw0I,EAAUx7I,EAAKgH,GACfhH,EAAKgH,IAAM,EAGf,SAAS00I,EAAc10I,GACnBu0I,EAAKv7I,EAAKgH,GACVhH,EAAKgH,GAAKw0I,EAAUD,EAAK,EACzBC,GAAWD,EAGf,GAAkB,SAAfD,EACC,GAAiB,eAAdnxH,EAEC,IADAsxH,EAAe,GACXz0I,EAAI,EAAGA,EAAIhH,EAAK4E,OAAQoC,IACxB00I,EAAc10I,QAIlB,IADAy0I,EAAez7I,EAAK4E,OAAS,GACzBoC,EAAIhH,EAAK4E,OAAS,EAAGoC,GAAK,EAAGA,IAC7B00I,EAAc10I,QAGnB,GAAiB,eAAdmjB,EAA4B,CAClC,IAAInjB,EAAI,EAAGA,EAAIhH,EAAK4E,OAAQoC,IACxBhH,EAAKgH,IAAMhH,EAAKgH,EAAI,GAIN,YAAfs0I,IACCt7I,EAAKu7C,QAAQ,GACbv7C,EAAK0f,WAEN,CACH,IAAI1Y,EAAIhH,EAAK4E,OAAS,EAAGoC,GAAK,EAAGA,IAC7BhH,EAAKgH,IAAMhH,EAAKgH,EAAI,GAGN,YAAfs0I,IACCt7I,EAAKsE,KAAK,GACVtE,EAAK4kE,UA3Zc+2E,CAAI37I,EAAMm3I,EAAehtH,UAAWgtH,EAAegC,YAE9E,IAAIyC,EAAYv5I,KAAKi3B,IAAI5pB,EAAI9K,OAAQ5E,EAAK4E,QACtCu3B,EAAK,GACL0/G,EAAe,EACfC,GAAcF,EAAY,EAG9B,IAAI50I,EAAI,EAAGA,EAAI40I,EAAW50I,IACtB,GAAGhH,EAAKgH,GAAI,CACR60I,EAAe70I,EACf,MAGR,IAAIA,EAAI40I,EAAY,EAAG50I,GAAK60I,EAAc70I,IACtC,GAAGhH,EAAKgH,GAAI,CACR80I,GAAc90I,EACd,MAKR,IAAIA,EAAI60I,EAAc70I,GAAK80I,GAAa90I,IACpC,GAAI/H,EAAUyQ,EAAI1I,KAAO/H,EAAUe,EAAKgH,IAAM,CAC1C,IAAI07F,GAAM,CACN3zF,EAAGW,EAAI1I,GACPzI,EAAGyB,EAAKgH,GACRsb,EAAG,GAMH60H,EAAe/5E,UACfslC,GAAItxF,IAAMmpI,EAAYvzI,GACnBo0I,EACC14C,GAAIq5C,IAAMr5C,GAAIs5C,IAAOzB,EAAYvzI,GAAS,OAAIiwI,EAAKsD,EAAYvzI,GAAG,IAAM0I,EAAI1I,IAG5E9I,EAAM+9I,YAAa,EACnBv5C,GAAIq5C,IAAMZ,EAAQz/F,EAAS10C,IAC3B07F,GAAIs5C,IAAMb,EAAQz/F,EAAS10C,EAAI,IAAI,KAG3Cm1B,EAAG73B,KAAKo+F,IAgBhB,OAZiB,IAAdvmE,EAAGv3B,SAGFu3B,EAAG,GAAGjO,OAASmX,EAAKkV,cAAcpe,EAAG,GAAGptB,EAAGsrI,EAAQr6I,MAAM,EAAO0b,GAAYygB,EAAG,GAAGptB,GAGtF0nI,EAAiBt6G,EAAIj+B,GAElBmB,EAAI+K,oBAAoBlM,EAAMmN,iBAC7BhM,EAAI49B,YAAYd,EAAIj+B,EAAOi/B,GAGxBhB,GAsWP26G,gBAAiBA,I,4CCrjBrBj5I,EAAOC,QAAU,CACbmtG,iBAAkB,eAElB38F,MAAO,CACHsvC,QAAS,SACTC,KAAM,OACNC,YAAa,CACT,qEACA,iDACFx2C,KAAK,MAEXkZ,KAAM,CACFo9B,QAAS,SACTC,KAAM,OACNC,YAAa,0CAEjB//C,OAAQ,CACJ6/C,QAAS,MACTC,KAAM,OACNC,YAAa,CACT,qEACA,kBACFx2C,KAAK,MAEXs3F,UAAW,CACPhhD,QAAS,SACTC,KAAM,OACNC,YAAa,CACT,sEACA,sEACA,0EACFx2C,KAAK,MAEXhE,KAAM,CACFs6C,QAAS,MACTC,KAAM,SACNC,YAAa,CACT,uEACA,4BACFx2C,KAAK,MAEXgc,OAAQ,CACJs6B,QAAS,MACTC,KAAM,SACNC,YAAa,CACT,uEACA,oCACFx2C,KAAK,Q,4CC/Cf,IAAInI,EAAW,EAAQ,YACnBE,EAAM,EAAQ,YACdgmC,EAAO,EAAQ,YAEf62G,EAAkB,EAAQ,YAC1BC,EAAiB,EAAQ,YACzBC,EAAoB,EAAQ,YAC5BC,EAAe,EAAQ,YACvBC,EAAW,EAAQ,YACnBC,EAAc,EAAQ,YACtBC,EAAiB,EAAQ,YAE7B3+I,EAAOC,QAAU,SAAckE,EAAI9D,GAG/B,IAMIkC,EACA+qB,EACA1c,EACApO,EACA+qB,EACA1c,EACAkY,EACA5f,EACAy1I,EAdA57I,EAAKwkC,EAAKQ,UAAU7jC,EAAI9D,EAAMyD,OAAS,KACvCb,EAAKukC,EAAKQ,UAAU7jC,EAAI9D,EAAM0D,OAAS,KACvCujI,EAAYhmI,EAAS2C,QAAQ5D,EAAO,WACpCw+I,EAASv9I,EAAS2C,QAAQ5D,EAAO,aACjCy+I,EAASx9I,EAAS2C,QAAQ5D,EAAO,QACjC2oB,EAAUs+G,EAAY,OAASjnI,EAAM2oB,QAezC,GAHAhmB,EAAG0sD,UAAY,EACfzsD,EAAGysD,UAAY,EAEZmvF,EAECt8I,GADAq8I,EAASP,EAAgBl6I,EAAI9D,IAClBkC,EACX+qB,EAAKsxH,EAAOtxH,GACZ1c,EAAKguI,EAAOhuI,GACZpO,EAAIo8I,EAAOp8I,EACX+qB,EAAKqxH,EAAOrxH,GACZ1c,EAAK+tI,EAAO/tI,GACZkY,EAAI61H,EAAO71H,MACR,CACH,IAAIg2H,EAAM1+I,EAAM0oB,EACbvnB,EAAIsnB,UAAUi2H,IACbR,EAAkBl+I,EAAO2C,EAAIC,EAAI,IAAK,IAAK,CAAC,MAC5CV,EAAIlC,EAAMu4G,GACVp2G,EAAInC,EAAM2+I,GACVD,EAAM1+I,EAAM4+I,KAEZ18I,EAAIlC,EAAMu4G,GAAKv4G,EAAMkC,EAAIS,EAAGs3I,aAAaj6I,EAAO,KAAO,GACvDmC,EAAInC,EAAM2+I,GAAK3+I,EAAMmC,EAAIS,EAAGq3I,aAAaj6I,EAAO,KAAO,IAG3DitB,EAAKjtB,EAAMitB,GACX1c,EAAKvQ,EAAMuQ,GACX2c,EAAKltB,EAAMktB,GACX1c,EAAKxQ,EAAMwQ,GAEXkY,EAAIy1H,EAAaO,EAAK1+I,EAAO2C,EAAIC,IAE9BqkI,GAAajnI,EAAM6+I,eAClB7+I,EAAM8+I,aAAeT,EAAY31H,GACjC01H,EAAS11H,EAAG1oB,EAAM8+I,eAI1B,SAASC,EAAUC,GACfr2H,EAAU3oB,EAAMqe,OAAOsK,QAAU3oB,EAAM2oB,SAAU,EACjDxnB,EAAIwe,KAAK,+BAAiCq/H,GAI9C,GAAe,SAAZr2H,EACC,GAAe,QAAZhmB,EAAG4F,MAA8B,QAAZ3F,EAAG2F,KACvBw2I,EAAU,uBACP,IAAIP,EAAQ,CACf,GAAGt8I,EAAEwE,OAAQ,CACT,IAAIu4I,GAAS/8I,EAAEA,EAAEwE,OAAS,GAAKxE,EAAE,KAAOA,EAAEwE,OAAS,GAC/Cw4I,EAAU/6I,KAAK6/B,IAAIi7G,EAAQ,KAC/B,IAAIn2I,EAAI,EAAGA,EAAI5G,EAAEwE,OAAS,EAAGoC,IACzB,GAAG3E,KAAK6/B,IAAI9hC,EAAE4G,EAAI,GAAK5G,EAAE4G,GAAKm2I,GAASC,EAAS,CAC5CH,EAAU,yBACV,OAIZ,GAAG58I,EAAEuE,QAAsB,SAAZiiB,EAAoB,CAC/B,IAAIw2H,GAASh9I,EAAEA,EAAEuE,OAAS,GAAKvE,EAAE,KAAOA,EAAEuE,OAAS,GAC/C04I,EAAUj7I,KAAK6/B,IAAIm7G,EAAQ,KAC/B,IAAIr2I,EAAI,EAAGA,EAAI3G,EAAEuE,OAAS,EAAGoC,IACzB,GAAG3E,KAAK6/B,IAAI7hC,EAAE2G,EAAI,GAAK3G,EAAE2G,GAAKq2I,GAASC,EAAS,CAC5CL,EAAU,yBACV,QAQpB,IAAIv5G,EAAOrkC,EAAIuyB,aAAahL,GACxB22H,EAAsB,WAAhBr/I,EAAMs/I,MAAqB,GAAKp9I,EACtCq9I,EAASjB,EAAet+I,EAAOq/I,EAAKpyH,EAAI1c,EAAIi1B,EAAM7iC,GAClD68I,EAAsB,WAAhBx/I,EAAMy/I,MAAqB,GAAKt9I,EACtCu9I,EAASpB,EAAet+I,EAAOw/I,EAAKtyH,EAAI1c,EAAIkY,EAAEhiB,OAAQ9D,GAGtD67I,IACAz+I,EAAM6jG,UAAUlhG,EAAGqZ,KAAOmrB,EAAKomB,aAAa5qD,EAAI48I,GAChDv/I,EAAM6jG,UAAUjhG,EAAGoZ,KAAOmrB,EAAKomB,aAAa3qD,EAAI88I,IAGpD,IAAI3pD,EAAM,CACN7zF,EAAGq9I,EACHp9I,EAAGu9I,EACHh3H,EAAGA,EACH5X,KAAM9Q,EAAM2qC,OAAS3qC,EAAM8Q,KAC3Bu4B,UAAWrpC,EAAM2/I,YAAc3/I,EAAMqpC,WAgBzC,GAbGg2G,GAAOA,EAAI34I,SAAW64I,EAAO74I,OAAS,IAAGqvF,EAAIgxC,QAAUsY,GACvDG,GAAOA,EAAI94I,SAAWg5I,EAAOh5I,OAAS,IAAGqvF,EAAIixC,QAAUwY,GAEvDhB,IACCzoD,EAAI6pD,QAAUrB,EAAOqB,QACrB7pD,EAAI8pD,QAAUtB,EAAOsB,QACrB9pD,EAAI7iF,IAAMqrI,EAAOrrI,KAGjB+zH,GACAgX,EAAen6I,EAAI9D,EAAO,CAACk/C,KAAMx2B,EAAGE,QAAS,MAG9Cq+G,GAAajnI,EAAMmjD,UAAwC,YAA5BnjD,EAAMmjD,SAASG,SAAwB,CACrE,IAAIw8F,EAAa,CACbv3I,KAAqB,YAAfvI,EAAMuI,KAAqB,UAAY,cAC7CrF,UAAWlD,EAAMkD,UACjBC,UAAWnD,EAAMmD,WAErB4yF,EAAIqxC,MAAQkX,EAAewB,EAAYT,EAAKpyH,EAAI1c,EAAIi1B,EAAM7iC,GAC1DozF,EAAIsxC,MAAQiX,EAAewB,EAAYN,EAAKtyH,EAAI1c,EAAIkY,EAAEhiB,OAAQ9D,GAGlE,MAAO,CAACmzF,K,8CCjJZp2F,EAAOC,QAAU,CACbmgJ,cAAe,GAKfC,aAAc,GAEdC,gBAAiB,GAIjBC,eAAgB,GAEhBC,cAAe,K,8CCfnB,IAAIh/I,EAAM,EAAQ,YACd20E,EAA+B,EAAQ,YAEvCvtD,EAAa,EAAQ,YAGrBjG,EAFY,EAAQ,YAEHA,KACjBg+B,EAAc/3B,EAAW2C,QAY7B,SAASk1H,EAAaC,EAAQC,EAASxnI,GACnC,SAAS8B,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAOylI,EAAQC,EAAS/3H,EAAYnmB,EAAM4B,GAQ3C4W,EAAO,UALPk7D,EAA6BuqE,EAAQC,EAAS,CACxDh+H,KAAM,UACN+zD,mBAAoBg3D,IAGgB3mI,OAAS,KAGjDkU,EAAO,UACPA,EAAO,aACPA,EAAO,QACPA,EAAO,cAEPA,EAAO,KACPA,EAAO,KACPzZ,EAAIy8B,UAAUyiH,EAAQC,EAAS,CAAC,IAAK,MAErC1lI,EAAO,WACPA,EAAO,WAEPA,EAAO,SACPA,EAAO,SACPA,EAAO,SACPA,EAAO,SAEPzZ,EAAImkB,WAAW1K,EAAQ,OAAQ9B,EAAUlX,MAEzCgZ,EAAO,UAAW9B,EAAUsC,eAC5BR,EAAO,eACPA,EAAO,gBAGX,SAASyyH,EAAeC,EAAUC,GAC9B,SAAS3yH,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO0yH,EAAUC,EAAWjtF,EAAal+C,EAAM4B,GAGhD4W,EAAO,UACI,SAApB0yH,EAASt/G,QAAqBnlB,MAAM+D,QAAQ0gI,EAASr/G,SAEtDrT,EAAO,UACPA,EAAO,QACPA,EAAO,SACPA,EAAO,SACPA,EAAO,YA1Dfjb,EAAOC,QAAU,SAA6BiZ,EAAUC,GAMpDg9D,EAA6Bj9D,EAAUC,EAL5B,CACPwJ,KAAMA,EACN+zD,mBAAoB+pE,M,4CCb5B,IAAI3gJ,EAAK,EAAQ,YAajBE,EAAOC,QAAU,SAAyBqsH,EAAY7mE,EAAUye,GAC5D,IAAIhkE,EAASosH,EAAWzrH,UAAU,KAAOqjE,EAAI38D,QAAQ,MAAO,MACvD9B,KAAKggD,GAAU,SAASnnB,GAAM,OAAOA,EAAG,GAAGj+B,MAAM+M,OAEtDlN,EAAOyJ,OAAOC,SAEd1J,EAAO2J,QAAQC,OAAO,KACjBrH,KAAK,QAASyhE,GAEnBhkE,EAAO++C,QAIP,IAAI34C,EAAIgmH,EAAWlgG,QAAQ,aAAe,iBAAmB,QAG7D,OAFAlsB,EAAOC,MAAK,SAASm+B,GAAMA,EAAG,GAAGh4B,GAAKxG,EAAGa,OAAOC,SAEzCV,I,4CC7BX,IAAIw/C,EAAY,EAAQ,YACpBmtC,EAAiB,EAAQ,YACzBlmE,EAAa,EAAQ,YACrBi5B,EAAW,EAAQ,YACnBnyC,EAAa,EAAQ,YAAiBA,WAEtCktF,EAAaj7C,EAAU,CACvBY,SAAU,OACVL,YAAa,CACT,wBACA,2CACA,mDACFx2C,KAAK,OAEXkxF,EAAWz4F,OAAOmC,KAAO,0CACzBs2F,EAAWx4F,KAAKkC,KAAO,GACvBs2F,EAAWz5F,MAAMmD,KAAOsiB,EAAWna,YAEnCxM,EAAOC,QAAU,CACbgC,KAAM04F,EACNhlD,MAAO,CACHxkC,KAAM,CACF4uC,QAAS,SACTC,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,yBACA,8DACA,+DACA,sCACFx2C,KAAK,MAEXxH,KAAMy9C,EAAU,CACZY,SAAU,cACVL,YAAa,CACT,uBACA,mDACA,gDACFx2C,KAAK,OAEXw+B,KAAM,CACF8X,QAAS,aACT17C,KAAM,YACN67C,OAAQ,CAAC,YAAa,SACtBF,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,oCACA,oDACA,0DACFx2C,KAAK,MAEXy+B,KAAM,CACF6X,QAAS,aACT17C,KAAM,YACN67C,OAAQ,CAAC,YAAa,SACtBF,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,oCACA,qDACA,2DACFx2C,KAAK,MAEXlH,EAAG,CACCw9C,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,GACN27C,KAAM,QACNM,SAAU,cACVL,YAAa,CACT,2DACA,+CACFx2C,KAAK,MAEXjH,EAAG,CACCu9C,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,OACN27C,KAAM,QACNM,SAAU,cACVL,YAAa,CACT,2DACA,8CACA,mDACA,sCACFx2C,KAAK,MAEX+nB,QAAS,CACLuuB,QAAS,aACT17C,KAAM,OACN67C,OAAQ,CAAC,OAAQ,OAAQ,SAAU,SACnCF,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,wEACA,2CACA,yCACA,sDACA,8DACA,kDACFx2C,KAAK,MAEXkoB,QAAS,CACLouB,QAAS,aACT17C,KAAM,OACN67C,OAAQ,CAAC,OAAQ,MAAO,SAAU,UAClCF,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,sEACA,iDACA,mDACA,uDACA,8DACA,kDACFx2C,KAAK,MAEXiiB,IAAKje,EAAWmyC,EAAS,CAACU,SAAU,gBAAiB,CACjDL,YAAa,CACT,iCACA,yDACA,8DACA,2DACA,4EACA,yEACFx2C,KAAK,OAEX62C,SAAU,eAEd5a,YAAa,CACTymC,KAAM,CACFpsB,QAAS,aACTG,OAAQ,EAAC,EAAO,OAAQ,QACxB77C,MAAM,EACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,gDACA,kDACA,+CACA,oDACA,0CACA,kEACA,oEACA,+DACFx2C,KAAK,MAEXk8B,QAAS,CACLoa,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,+DACFx2C,KAAK,MAEX62C,SAAU,QAEdutC,SAAU,CACN9tC,QAAS,UACTC,KAAM,OACN37C,MAAM,EAGNi8C,SAAU,OACVL,YAAa,CACT,qDACA,2CACA,mCAEA,2CACA,sCACA,oDACFx2C,KAAK,MAEXzE,MAAO,CACH+6C,QAAS,SACTC,KAAM,OACNvkB,IAAK,GACLp3B,KAAM,IACNi8C,SAAU,OACVL,YAAa,CACT,kCACFx2C,KAAK,MAEXmL,OAAQ,CACJmrC,QAAS,SACTC,KAAM,OACNvkB,IAAK,GACLp3B,KAAM,IACNi8C,SAAU,OACVL,YAAa,CACT,mCACFx2C,KAAK,MAEXiwC,OAAQ,CACJ9tB,EAAG,CACCm0B,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,GACNi8C,SAAU,OACVL,YAAa,iCAEjB/4C,EAAG,CACC64C,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,GACNi8C,SAAU,OACVL,YAAa,kCAEjBtoC,EAAG,CACCooC,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,IACNi8C,SAAU,OACVL,YAAa,gCAEjBx7B,EAAG,CACCs7B,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,GACNi8C,SAAU,OACVL,YAAa,mCAEjBv0B,IAAK,CACDq0B,QAAS,SACTC,KAAM,OACNvkB,IAAK,EACLp3B,KAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,qCACA,gDACFx2C,KAAK,MAEXkwC,WAAY,CACRoG,QAAS,UACTC,KAAM,OACN37C,MAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,8CACA,+EACA,gDACFx2C,KAAK,MAEX62C,SAAU,QAEd7kC,cAAe,CACXskC,QAAS,QACTC,KAAM,QACN37C,KAAMsiB,EAAW3L,WACjBslC,SAAU,OACVL,YAAa,oEAEjBu/B,aAAc,CAGVz/B,QAAS,QACTC,KAAM,QACN37C,KAAMsiB,EAAW3L,WACjBslC,SAAU,cACVL,YAAa,CACT,2EACFx2C,KAAK,MAEXw4B,WAAY,CACR8d,QAAS,SACTC,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,4CACA,2DACA,0DACA,yCACFx2C,KAAK,MAEXm3I,YAAa,CACT7gG,QAAS,UACTC,KAAM,OACN37C,MAAM,EACNi8C,SAAU,OACVL,YAAa,CACT,kEACA,kDACA,iEACA,iGACFx2C,KAAK,MAEX8rC,WAAY,CAGRwK,QAAS,UACTC,KAAM,OACNM,SAAU,SACVL,YAAa,CACT,+CACA,kEACA,iEACA,2CACA,6DACFx2C,KAAK,MAEXowF,SAAU,CACN95C,QAAS,YACT17C,KAAMsiB,EAAWC,SACjBo5B,KAAM,QACNM,SAAU,OACVL,YAAa,kCAEjB4gG,aAAc,CACV9gG,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,yDACA,+DACA,gEACA,sBACA,+DACA,yDACA,8DACFx2C,KAAK,MAEXwU,WAAY,CACR8hC,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,+DACA,oEACA,kEACA,8DACA,oEACA,qEACA,0DACA,+DACA,kEACA,mEACA,qEACA,qDACA,oEACA,sDACFx2C,KAAK,MAEXq3I,aAAc,CACV/gG,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,kEACA,yDACA,oCACFx2C,KAAK,MAEXs3I,kBAAmB,CACfhhG,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,oBACFx2C,KAAK,MAEX+uF,SAAU,CACNz4C,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,iEACA,8DACA,wDACA,wEACA,gEACA,qDACA,iEACA,6DACA,sEACA,kEACA,qEACA,sEACA,mEACA,uEACA,wEACA,uEACFx2C,KAAK,MAEXoxF,QAAS,CACLzgF,YAAa,CACT2lC,QAAS,aACTG,OAAQ,CAAC,IAAK,KACd77C,KAAM,IACN27C,KAAM,OACNM,SAAU,UACVL,YAAa,wCAEjBpwB,QAAS,CACLkwB,QAAS,QACTC,KAAM,QACNM,SAAU,UACVL,YAAa,6CAEjB/+C,MAAO,CACH6+C,QAAS,QACTC,KAAM,QACNM,SAAU,UACVL,YAAa,+CAEjBa,YAAa,CACTf,QAAS,QACTC,KAAM,QACNM,SAAU,UACVL,YAAa,oEAEjBhiC,WAAY,CACR8hC,QAAS,MACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,sEACA,kEACA,oEACFx2C,KAAK,MAEX62C,SAAU,WAGd7uC,KAAM,CACFsuC,QAAS,MACTmxD,SAAS,EACTlxD,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,gFACA,kFACA,0FACA,2EACA,oDACA,oBACA,gFACA,iBACFx2C,KAAK,MAGX4jB,WAAY5f,EAAW,GAAIo/E,EAAex/D,WAAY,CAClD4yB,YAAa,CACT,6DACFx2C,KAAK,KACP62C,SAAU,SAEd8qF,YAAa,CACTz1F,MAAO,CACHoK,QAAS,SACTC,KAAM,OACNM,SAAU,cACVL,YAAa,CACT,+EACA,kEACFx2C,KAAK,MAEX4hI,UAAW3rF,EAAU,CACjBY,SAAU,cACVL,YAAa,CACT,iEACA,oEACFx2C,KAAK,U,8CC1dnB,IAAI85H,EAA8B,EAAQ,YAA+BA,4BAKzEvjI,EAAOC,QAAU,SAAmBqP,EAAIjP,GACpC,IAAIgN,EAAM,CACNslC,YAAatyC,EAAMopB,MACnB8vG,aAAcjqH,EAAGiE,IACjB9N,KAAMpF,EAAMqe,OACZtF,SAAU/Y,EACV0vB,MAAOzgB,EAAGygB,MACV7uB,MAAOoO,EAAGpO,MACVqgC,MAAOjyB,EAAGlI,EACV05H,QAASxxH,EAAGwxH,QACZ3vH,KAAM7B,EAAG6B,KAGT/J,EAAGkI,EAAGlI,GAiBV,OAbqB,IAAlBkI,EAAGiE,IAAIxM,SAAcsG,EAAI0nH,YAAc1nH,EAAIlE,EAAImG,EAAGiE,IAAI,IAKzDgwH,EAA4Bl2H,EAAKhN,EAAOiP,EAAGiE,KAGzB,eAAflT,EAAMuI,cACEyE,EAAIjG,SACJiG,EAAIlE,GAGRkE,I,8CCpBXrN,EAAOC,QAAU,CAEb,CACIuT,KAAM,GACNwtI,QAAS,GAGb,CACIxtI,KAAM,oBACNwtI,QAAS,IAGb,CACIxtI,KAAM,wBACNwtI,QAAS,KAGb,CACIxtI,KAAM,2CACNwtI,QAAS,MAGb,CACIxtI,KAAM,0DACNwtI,QAAS,KAGb,CACIxtI,KAAM,oDACNwtI,QAAS,GAGb,CACIxtI,KAAM,qCACNwtI,QAAS,EACTC,UAAU,GAGd,CACIztI,KAAM,gBACNwtI,QAAS,EACTC,UAAU,K,4CCxDlB,IAAIz/I,EAAM,EAAQ,YACd4W,EAAW,EAAQ,YAiCvBpY,EAAOC,QAAU,SAAsCihJ,EAAaC,EAAcz7H,GAC9E,IAQIvc,EAAGmlG,EARH3rF,EAAO+C,EAAK/C,KACZ+qF,EAAgBhoF,EAAKgoF,eAAiB,UAEtC0zC,EAAkBD,EAAax+H,GAE/B8iH,EAASjkI,EAAI+K,oBAAoB20I,EAAYv+H,IAASu+H,EAAYv+H,GAAQ,GAC1E4hB,EAAU48G,EAAax+H,GAAQ,GAC/B81E,EAAYrgF,EAASq1F,eAAe0zC,EAAcx+H,EAAM+qF,GAG5D,IAAIvkG,EAAI,EAAGA,EAAIs8H,EAAO1+H,OAAQoC,IAAK,CAC/B,IAAI4kG,EAAS03B,EAAOt8H,GAEhB3H,EAAIY,cAAc2rG,GAIlBO,EAAU7V,EAAUqV,QAAQC,IAH5BO,EAAU7V,EAAUqV,QAAQ,KACpBJ,IAAiB,EAK7BY,EAAQlkF,OAASjhB,GAEa,IAA3BmlG,EAAQZ,IACPhoF,EAAKgxD,mBAAmBq3B,EAAQO,EAAS6yC,EAAcz7H,GAG3D6e,EAAQ99B,KAAK6nG,GAGjB,IAAIJ,EAAezV,EAAUyV,eAC7B,IAAI/kG,EAAI,EAAGA,EAAI+kG,EAAannG,OAAQoC,KAChCmlG,EAAUJ,EAAa/kG,IACfihB,OAASma,EAAQx9B,OACzB2e,EAAKgxD,mBAAmB,GAAI43B,EAAS6yC,EAAcz7H,EAAM,IACzD6e,EAAQ99B,KAAK6nG,GAKjB,GAAG9sG,EAAI+K,oBAAoB60I,GAAkB,CACzC,IAAIr4I,EAAMvE,KAAKi3B,IAAI2lH,EAAgBr6I,OAAQw9B,EAAQx9B,QACnD,IAAIoC,EAAI,EAAGA,EAAIJ,EAAKI,IAChB3H,EAAImyB,kBAAkB4Q,EAAQp7B,GAAIi4I,EAAgBj4I,IAI1D,OAAOo7B,I,4CCjFX,IAAIjjC,EAAW,EAAQ,YACnB+/I,EAAkB,EAAQ,YAAyBA,gBAWvDphJ,QAAQqhJ,mBAAqB,SAASC,EAAU34I,EAAMw/B,GAClD,IAAI+vD,EAAiB72F,EAASsqE,iBAAiBhjE,GAC/C,IAAIuvF,EAAgB,MAAO,GAK3B,IAHA,IAAI11F,EAAO01F,EAAe11F,KACtBglG,EAAkB,GAEdt+F,EAAI,EAAGA,EAAIo4I,EAASx6I,OAAQoC,IAAK,CACrC,IAAIk2B,EAAYkiH,EAASp4I,GACbk2B,EAAU,GAAGh/B,MAEhBoC,KAAU2lC,GAAWq/D,EAAgBhhG,KAAK44B,GAGvD,OAAOooE,GAgBXxnG,QAAQklD,kBAAoB,SAAS5O,EAAUirG,GAC3C,IAGIv7F,EAHA+hD,EAAiB,GACjBy5C,EAAoB,GAUxB,KANIx7F,EADe,iBAATu7F,EACOlgJ,EAASglD,UAAUk7F,GAAM5+H,KAChB,mBAAT4+H,EACAA,EAEAA,EAAK5+H,MAGlB,MAAO,CAAColF,EAAgBzxD,GAG5B,IAAI,IAAIptC,EAAI,EAAGA,EAAIotC,EAASxvC,OAAQoC,IAAK,CACrC,IAAIm1B,EAAKiY,EAASptC,GACd9I,EAAQi+B,EAAG,GAAGj+B,OAIG,IAAlBA,EAAM6oB,SAAsC,IAAlB7oB,EAAMylC,UAMhCzlC,EAAMiR,QAAQsR,OAASqjC,EACtB+hD,EAAevhG,KAAK63B,GAEpBmjH,EAAkBh7I,KAAK63B,IAI/B,MAAO,CAAC0pE,EAAgBy5C,IAa5BxhJ,QAAQyhJ,eAAiB,SAAwBj8I,EAAMmD,EAAMw/B,GACzD,IAAI9mC,EAASsqE,iBAAiBhjE,GAAO,MAAO,GAE5C,IAEIvI,EAAOshJ,EAAUC,EAFjBn/I,EAAOnB,EAASsqE,iBAAiBhjE,GAAMnG,KACvCsoD,EAAc,GAGlB,GAAY,SAATniD,EAAiB,CAChB,IAAIi5I,EAAUz5G,EAAUxxB,MAAMyqI,GAC9BM,EAAW,IAAME,EAAQ,GACzBD,EAAW,IAAMC,EAAQ,GAG7B,IAAI,IAAI14I,EAAI,EAAGA,EAAI1D,EAAKsB,OAAQoC,IAC5B9I,EAAQoF,EAAK0D,GAED,SAATP,GAAmBtH,EAAS2C,QAAQ5D,EAAO,QACvCA,EAAMoC,EAAK,MAAQk/I,GAAYthJ,EAAMoC,EAAK,MAAQm/I,GACjD72F,EAAYtkD,KAAKpG,GAGlBA,EAAMoC,KAAU2lC,GAAW2iB,EAAYtkD,KAAKpG,GAIvD,OAAO0qD,I,8CCnHX/qD,EAAOC,QAAU,CACbw2C,aAAc,CACVsJ,QAAS,aACTC,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,uDACA,uBACA,yDACA,mDACFx2C,KAAK,MAEXq4I,YAAa,CACT/hG,QAAS,YACTC,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,0DACA,yDACA,6DACA,kCACFx2C,KAAK,MAEXs4I,gBAAiB,CACbhiG,QAAS,UACT17C,MAAM,EACN27C,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,qEACA,iEACA,kEACA,mEACA,mEACA,0BACA,iEACA,aACFx2C,KAAK,Q,4CCrCf,IAAIjI,EAAM,EAAQ,YACd4W,EAAW,EAAQ,YAEnB4pI,EAAkB,EAAQ,YAC1BC,EAAqB,EAAQ,YAEjCjiJ,EAAOC,QAAU,SAA8BiZ,EAAUC,GACrD,SAAS8B,EAAOxY,EAAM4B,GAClB,OAAO7C,EAAIyZ,OAAO/B,EAAUC,EAAW6oI,EAAiBv/I,EAAM4B,GAGlE4W,EAAO,yBACPA,EAAO,8BACPA,EAAO,wBAEP,IACIinI,EAAWC,EADXC,EAAYjpI,EAAUy6E,WAG1B,SAASyuD,EAAS5/I,EAAM4B,GACpB,OAAO7C,EAAIyZ,OAAOinI,EAAWC,EAAYH,EAAgBM,UAAW7/I,EAAM4B,GAG9E,IAAI,IAAIiC,KAAK87I,EAAW,CACpB,IAAIvzF,EAAQuzF,EAAU97I,GAEtB,GAAGuoD,EAAM,GACLqzF,EAAYhpI,EAAS5S,IAAM,IAC3B67I,EAAa/pI,EAASmF,aAAapE,EAAW7S,EAAG,cACtC6V,MAAQ7V,EACnB27I,EAAmBC,EAAWC,EAAYhpI,EAAWkpI,EAAU,CAAC7yI,OAAQ,GAAIyZ,QAAS,UAClF,CAEH,IAAI,IAAI9f,EAAI,EAAGA,EAAI0lD,EAAM,GAAG9nD,OAAQoC,IAChC0lD,EAAM,GAAG1lD,YAENgQ,EAAUy6E,WAAWttF,O,8CCnCxC,IAAIlF,EAAY,EAAQ,YACpBI,EAAM,EAAQ,YAEdF,EAAW,EAAQ,YAuCvB,SAASihJ,EAAcC,EAAUvnI,GAC7B,IAAIg0F,EAAQh0F,EAAOunI,GAQnB,MALiB,YAFDvzC,EAAQh0F,EAAOunI,EAAW,OAAQ,SAAW,YAGzDvnI,EAAOunI,EAAW,KAClBvnI,EAAO,IAAMunI,IAGVvzC,EA9CXjvG,EAAOC,QAAU,SAA2BslB,EAASC,EAAUvK,EAAQwK,EAAQg9H,EAAOC,GAClF,IAGIngJ,EAAGC,EAHHumB,EAAI9N,EAAO,KAKf,GAJAwnI,EAAQA,GAAS,IACjBC,EAAQA,GAAS,SAGRx3I,IAAN6d,IAAoBA,EAAEhiB,OAAQ,OAAO,EAExC,GAAGvF,EAAIsnB,UAAUvD,EAAQwD,GAAI,CACzBxmB,EAAI0Y,EAAOwnI,GACXjgJ,EAAIyY,EAAOynI,GAEX,IAAI78G,EAAOrkC,EAAIwyB,aAAazxB,GACxBogJ,EAAOnhJ,EAAIwyB,aAAaxxB,GAG5B,GAAY,IAATqjC,GAAuB,IAAT88G,EAAY,OAAO,EAEpCn9H,EAASsgB,QAAUthC,KAAKi3B,IAAIoK,EAAM88G,EAAM55H,EAAEhiB,YACvC,CAKH,GAJAxE,EAAIggJ,EAAcE,EAAOxnI,GACzBzY,EAAI+/I,EAAcG,EAAOznI,IA4BjC,SAAkB8N,GAcd,IAbA,IAGI65H,EAHAC,GAAmB,EACnBC,GAAiB,EACjBC,GAAe,EAWX55I,EAAI,EAAGA,EAAI4f,EAAEhiB,OAAQoC,IAAK,CAE9B,GADAy5I,EAAK75H,EAAE5f,IACH3H,EAAI+K,oBAAoBq2I,GAAK,CAC7BC,GAAmB,EACnB,MAEDD,EAAG77I,OAAS,IAAG+7I,GAAiB,GACnC,IAAI,IAAIzpI,EAAI,EAAGA,EAAIupI,EAAG77I,OAAQsS,IAC1B,GAAGjY,EAAUwhJ,EAAGvpI,IAAK,CACjB0pI,GAAe,EACf,OAKZ,OAAQF,GAAoBC,GAAkBC,EAtDtCC,CAASj6H,GAAI,OAAO,EAExB9N,EAAO,aAEPuK,EAASsgB,QAAU,KAMvB,OAH6BxkC,EAASyX,mBAAmB,YAAa,sBACtE6sB,CAAuBrgB,EAASC,EAAU,CAACi9H,EAAOC,GAAQj9H,IAEnD,I,8CCvCXzlB,EAAOC,QAAU,EAAQ,a,4CCEzBA,QAAQ2mB,SAAW,CACf,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,WAGJ3mB,QAAQuM,YAAc,OAEtBvM,QAAQ4mB,UAAY,OAEpB5mB,QAAQ+a,WAAa,OAErB/a,QAAQsgD,WAAa,UAMrBtgD,QAAQgjJ,cAAgB,IAAoB,I,4CC1B5C,IAmEI5tH,EAAQC,EAnERx1B,EAAK,EAAQ,YACbsB,EAAY,EAAQ,YAEpB8hJ,EAAU,EAAQ,YAClBhvH,EAAM,EAAQ,YAASA,IAEvBlK,EAAY,EAAQ,YACpBsJ,EAAStJ,EAAUsJ,OACnB6oB,EAASnyB,EAAUmyB,OACnBE,EAAUryB,EAAUqyB,QACpBE,EAASvyB,EAAUuyB,OACnBE,EAASzyB,EAAUyyB,OACnB4P,EAAUriC,EAAUqiC,QAEpB/qD,EAAW,EAAQ,YAEnB6hJ,EAAYrjJ,EAAG2jC,KAAKz7B,OAAOiH,IAE3Bm0I,EAAkB,mIAElBC,EAAqB,qIAGrBC,GAAS,IAAInuG,MAAOouG,cAAgB,GAExC,SAASC,EAAgB3lI,GACrB,OACIA,GACAvc,EAASs6F,mBAAmB6nD,WACR,iBAAb5lI,GAAsC,cAAbA,EA6LxC,SAAS6lI,EAAKpiI,EAAK0a,GACf,OAAOvb,OAAOa,EAAM9c,KAAKuO,IAAI,GAAIipB,IAAStb,OAAO,GArLrDzgB,QAAQi1B,UAAY,SAASrX,EAAU8lI,GACnC,OAAGH,EAAgB3lI,GACR8lI,EACHriJ,EAASyX,mBAAmB,YAAa,oBAAoB8E,GAC7Dvc,EAASyX,mBAAmB,YAAa,kBAAkB8E,GAExD8lI,EAAS,aAAe,cAOvC1jJ,QAAQk1B,UAAY,SAAStX,GACzB,OAAG2lI,EAAgB3lI,GACRvc,EAASyX,mBAAmB,YAAa,aAAa8E,GAEtD,CAAC,aAAc,eAK9B5d,QAAQ80B,SAAW,SAAS3tB,GACxB,MAAoB,iBAANA,GAAwB,OAANA,GAAmC,mBAAdA,EAAEguC,SA6D3Dn1C,QAAQy0B,YAAc,SAASh0B,EAAGmd,GAE9B,GAAG5d,QAAQ80B,SAASr0B,GAAI,CAGpB,IAAIkjJ,EAAWljJ,EAAEmjJ,oBAAsBtnG,EACnCunG,GAAepjJ,EAAEqjJ,gBAAkBrjJ,EAAEsjJ,cAAgBznG,GACpD77C,EAAEujJ,gBAAkBvjJ,EAAEwjJ,cAAgBznG,GACtC/7C,EAAEyjJ,qBAAuBzjJ,EAAE0jJ,mBAEhC,GAAGN,EAAa,CACZ,IAAIO,EAAO,EAAI9nG,EACfqnG,EAAWA,EAAWS,EAAO,EAAInwH,EAAI4vH,EAAcF,EAAWS,EAAO,EAAGA,GAG5E,OADA3jJ,EAAIogB,OAAOpgB,GAAKkjJ,IACRvuH,GAAU30B,GAAK40B,EAAe50B,EAC/B4yB,EAGX,GAAgB,iBAAN5yB,GAA+B,iBAANA,EAAgB,OAAO4yB,EAE1D5yB,EAAI+f,OAAO/f,GAEX,IAAI4jJ,EAAUd,EAAgB3lI,GAI1B2vG,EAAK9sH,EAAE4c,OAAO,IACfgnI,GAAmB,MAAP92B,GAAqB,MAAPA,IACzB9sH,EAAIA,EAAEggB,OAAO,GACb7C,EAAW,IAGf,IAAI0mI,EAAYD,GAAqC,YAA1BzmI,EAAS6C,OAAO,EAAG,GAE1C9J,EAAQlW,EAAEkW,MAAM2tI,EAAYlB,EAAqBD,GACrD,IAAIxsI,EAAO,OAAO0c,EAClB,IAAI9wB,EAAIoU,EAAM,GACVkiD,EAAIliD,EAAM,IAAM,IAChBxW,EAAI0gB,OAAOlK,EAAM,IAAM,GACvB4tI,EAAI1jI,OAAOlK,EAAM,IAAM,GACvBmiD,EAAIj4C,OAAOlK,EAAM,IAAM,GACvBoiD,EAAIl4C,OAAOlK,EAAM,KAAO,GAE5B,GAAG0tI,EAAS,CAER,GAAgB,IAAb9hJ,EAAEuE,OAAc,OAAOusB,EAG1B,IAAImxH,EAFJjiJ,EAAIse,OAAOte,GAGX,IACI,IAAIkiJ,EAAcpjJ,EAASyX,mBAAmB,YAAa,SAAzCzX,CAAmDuc,GACrE,GAAG0mI,EAAW,CACV,IAAII,EAA2C,MAA3B7rF,EAAEx7C,OAAOw7C,EAAE/xD,OAAS,GACxC+xD,EAAIx8B,SAASw8B,EAAG,IAChB2rF,EAAQC,EAAYE,QAAQpiJ,EAAGkiJ,EAAYG,aAAariJ,EAAGs2D,EAAG6rF,GAAgBvkJ,QAE9EqkJ,EAAQC,EAAYE,QAAQpiJ,EAAGse,OAAOg4C,GAAI14D,GAEhD,MAAM46C,GAAK,OAAO1nB,EAEpB,OAAImxH,GAEKA,EAAMK,OAASz4F,GAAWlQ,EAC9BqoG,EAAInoG,EAAY0c,EAAIxc,EAAWyc,EAAIvc,EAHtBnpB,EAOlB9wB,EADY,IAAbA,EAAEuE,QACI+Z,OAAOte,GAAK,IAAO8gJ,GAAU,IAAMA,EACjCxiI,OAAOte,GAIlBs2D,GAAK,EAKL,IAAIu1E,EAAO,IAAIl5F,KAAKA,KAAK4vG,IAAI,IAAMjsF,EAAG14D,EAAGokJ,EAAGzrF,IAG5C,OAFAs1E,EAAK2W,eAAexiJ,GAEjB6rI,EAAK4W,gBAAkBnsF,GACvBu1E,EAAK6W,eAAiB9kJ,EADWkzB,EAG7B+6G,EAAKj5F,UAAY4jB,EAAIvc,GAGhCpnB,EAASp1B,QAAQo1B,OAASp1B,QAAQy0B,YAAY,SAC9CY,EAASr1B,QAAQq1B,OAASr1B,QAAQy0B,YAAY,4BAG9Cz0B,QAAQ00B,WAAa,SAASj0B,EAAGmd,GAC7B,OAAQ5d,QAAQy0B,YAAYh0B,EAAGmd,KAAcyV,GAgBjD,IAAI6xH,EAAa,GAAKhpG,EAClBipG,EAAa,EAAI/oG,EACjBgpG,EAAU,EAAI9oG,EAyElB,SAAS+oG,EAAY7mG,EAAS77C,EAAGk2D,EAAGp4D,EAAG6kJ,GAEnC,IAAG3iJ,GAAKk2D,GAAKp4D,GAAK6kJ,KACd9mG,GAAW,IAAMilG,EAAK9gJ,EAAG,GAAK,IAAM8gJ,EAAK5qF,EAAG,IACzCp4D,GAAK6kJ,KACJ9mG,GAAW,IAAMilG,EAAKhjJ,EAAG,GACtB6kJ,IAAQ,CAEP,IADA,IAAIvpH,EAAS,EACPupH,EAAS,IAAO,GAClBvpH,GAAU,EACVupH,GAAU,GAEd9mG,GAAW,IAAMilG,EAAK6B,EAAQvpH,GAI1C,OAAOyiB,EAxFXx+C,QAAQ20B,YAAc,SAAStpB,EAAIpE,EAAG2W,GAClC,GAAiB,iBAAPvS,KAAqBA,GAAM+pB,GAAU/pB,GAAMgqB,GAAS,OAAOhC,EAEjEpsB,IAAGA,EAAI,GAEX,IAEIu3C,EAAS77C,EAAGk2D,EAAGp4D,EAAG6kJ,EAAQnlJ,EAF1BolJ,EAAahhJ,KAAKgD,MAA0B,GAApB0sB,EAAI5oB,EAAK,IAAM,IACvCm6I,EAAYjhJ,KAAKC,MAAM6G,EAAKk6I,EAAa,IAG7C,GAAGhC,EAAgB3lI,GAAW,CAC1B,IAAI6nI,EAASlhJ,KAAKgD,MAAMi+I,EAAYtpG,GAAUkQ,EAC1Cs5F,EAASnhJ,KAAKgD,MAAM0sB,EAAI5oB,EAAI6wC,IAChC,IACIsC,EAAUn9C,EAASyX,mBAAmB,YAAa,SAAzCzX,CAAmDuc,GACxD+nI,OAAOF,GAAQ1wH,WAAW,cACjC,MAAMgmB,GAEJyD,EAAU0kG,EAAU,YAAVA,CAAuB,IAAIhuG,KAAKswG,IAM9C,GAAyB,MAAtBhnG,EAAQnhC,OAAO,GACd,KAAMmhC,EAAQ13C,OAAS,IAAI03C,EAAU,KAAOA,EAAQ/9B,OAAO,QAE3D,KAAM+9B,EAAQ13C,OAAS,IAAI03C,EAAU,IAAMA,EAK/C77C,EAAKsE,EAAIi+I,EAAc3gJ,KAAKgD,MAAMm+I,EAAStpG,GAAW,EACtDyc,EAAK5xD,EAAIi+I,EAAc3gJ,KAAKgD,MAAOm+I,EAAStpG,EAAWE,GAAU,EACjE77C,EAAKwG,EAAIk+I,EAAc5gJ,KAAKgD,MAAOm+I,EAASppG,EAAUE,GAAU,EAChE8oG,EAAUr+I,EAAIm+I,EAAYM,EAASlpG,EAAU,GAAK+oG,EAAa,OAE/DplJ,EAAI,IAAI+0C,KAAKswG,GAEbhnG,EAAU0kG,EAAU,WAAVA,CAAsB/iJ,GAGhCwC,EAAKsE,EAAIi+I,EAAc/kJ,EAAEylJ,cAAgB,EACzC/sF,EAAK5xD,EAAIi+I,EAAc/kJ,EAAE2jJ,gBAAkB,EAE3CrjJ,EAAKwG,EAAIk+I,EAAchlJ,EAAE6jJ,gBAAkB,EAE3CsB,EAAUr+I,EAAIm+I,EAAoC,GAAzBjlJ,EAAE+jJ,qBAA4BqB,EAAa,EAGxE,OAAOF,EAAY7mG,EAAS77C,EAAGk2D,EAAGp4D,EAAG6kJ,IASzCtlJ,QAAQ40B,iBAAmB,SAASvpB,GAChC,KAAKA,GAAM+pB,EAAS8mB,GAAU7wC,GAAMgqB,EAAS6mB,GAAS,OAAO7oB,EAE7D,IAAIkyH,EAAahhJ,KAAKgD,MAA0B,GAApB0sB,EAAI5oB,EAAK,IAAM,IACvClL,EAAI,IAAI+0C,KAAK3wC,KAAKC,MAAM6G,EAAKk6I,EAAa,KAO9C,OAAOF,EANOxlJ,EAAG2jC,KAAKz7B,OAAO,WAAflI,CAA2BM,GACjCA,EAAE0lJ,WACF1lJ,EAAE4jJ,aACF5jJ,EAAE8jJ,aAC4B,GAAzB9jJ,EAAE+jJ,qBAA4BqB,IA2B/CvlJ,QAAQ60B,UAAY,SAAS1tB,EAAG/C,EAAMwZ,GAElC,GAAGzW,IAAMksB,EAAQ,OAAOjvB,EACxB,GAAGpE,QAAQ80B,SAAS3tB,IAAoB,iBAANA,GAAkBw3B,SAASx3B,GAAK,CAG9D,GAAGo8I,EAAgB3lI,GAEf,OADAqlI,EAAQvqH,MAAM,kEAAmEvxB,GAC1E/C,EAOX,KADA+C,EAAInH,QAAQ40B,kBAAkBztB,UACZ8D,IAAT7G,EAAoB,OAAOA,OACjC,IAAIpE,QAAQ00B,WAAWvtB,EAAGyW,GAE7B,OADAqlI,EAAQvqH,MAAM,oBAAqBvxB,GAC5B/C,EAEX,OAAO+C,GAYX,IAAI2+I,EAAY,SAChB,SAASC,EAAc1iH,EAAK/gC,EAAG0jJ,EAAWpoI,GACtCylB,EAAMA,EAAI/7B,QAAQw+I,GAAW,SAASnvI,GAClC,IAAIolB,EAASx3B,KAAKi3B,KAAM7kB,EAAM0G,OAAO,IAAO,EAAG,GAI/C,OAHiB/a,EAAI,IAAO,EAAK,GAC5BoiC,QAAQ3I,GACRtb,OAAO,GAAGnZ,QAAQ,MAAO,KAAO,OAIzC,IAAInH,EAAI,IAAI+0C,KAAK3wC,KAAKgD,MAAMjF,EAAI,MAEhC,GAAGihJ,EAAgB3lI,GACf,IACIylB,EAAMhiC,EAASyX,mBAAmB,YAAa,cAAzCzX,CAAwDgiC,EAAK/gC,EAAGsb,GACxE,MAAMm9B,GACJ,MAAO,UAGf,OAAOirG,EAAU3iH,EAAV2iH,CAAe7lJ,GAS1B,IAAI8lJ,EAAa,CAAC,GAAI,KAAM,MAAO,OAAQ,SAsD3CjmJ,QAAQ+0B,WAAa,SAASzyB,EAAG+gC,EAAKq1B,EAAIstF,EAAWpoI,EAAUsoI,GAG3D,GAFAtoI,EAAW2lI,EAAgB3lI,IAAaA,GAEpCylB,EACA,GAAU,MAAPq1B,EAAYr1B,EAAM6iH,EAAYC,UAC5B,GAAU,MAAPztF,EAAYr1B,EAAM6iH,EAAYE,UACjC,IAAU,MAAP1tF,EAGJ,OA9DZ,SAAoBp2D,EAAGo2D,GACnB,IAAI2tF,EAAWpyH,EAAI3xB,EAAI,IAAM45C,GAEzBoqG,EAAU7C,EAAKl/I,KAAKgD,MAAM8+I,EAAWjqG,GAAU,GAAK,IACpDqnG,EAAKxvH,EAAI1vB,KAAKgD,MAAM8+I,EAAW/pG,GAAS,IAAK,GAEjD,GAAU,MAAPoc,EAAY,CACPv3D,EAAUu3D,KAAKA,EAAK,GAiBxB,IAEI6tF,GAAU,IAFJhiJ,KAAKi3B,IAAIvH,EAAI3xB,EAAIk6C,EAAQ,IAAKypG,EAAWvtF,KAE1Bh0B,QAAQg0B,GAAIj4C,OAAO,GACzCi4C,EAAK,IACJ6tF,EAASA,EAAOj/I,QAAQ,MAAO,IAAIA,QAAQ,QAAS,KAGxDg/I,GAAW,IAAMC,EAErB,OAAOD,EA6BQE,CAAWlkJ,EAAGo2D,GAAM,KAAOqtF,EAAcG,EAAYO,aAAcnkJ,EAAG0jJ,EAAWpoI,GAFxFylB,EAAM6iH,EAAYQ,SAAW,KAAOR,EAAYC,KAMxD,OAAOJ,EAAc1iH,EAAK/gC,EAAG0jJ,EAAWpoI,IA6B5C,IAAI+oI,EAAY,EAAIzqG,EACpBl8C,QAAQg1B,eAAiB,SAAS3pB,EAAIu7I,EAAQhpI,GAC1CA,EAAW2lI,EAAgB3lI,IAAaA,EAKxC,IAAI8nI,EAASzxH,EAAI5oB,EAAI6wC,GAGrB,GAFA7wC,EAAK9G,KAAKC,MAAM6G,EAAKq6I,GAElB9nI,EACC,IACI,IAAI6nI,EAASlhJ,KAAKC,MAAM6G,EAAK6wC,GAAUkQ,EACnCq4F,EAAcpjJ,EAASyX,mBAAmB,YAAa,SAAzCzX,CAAmDuc,GACjE4mI,EAAQC,EAAYkB,OAAOF,GAK/B,OAHGmB,EAAS,GAAInC,EAAY9uE,IAAI6uE,EAAOoC,EAAQ,KAC1CnC,EAAY9uE,IAAI6uE,EAAOoC,EAAS,GAAI,MAEjCpC,EAAMK,OAASz4F,GAAWlQ,EAASwpG,EAC7C,MAAM3qG,GACJkoG,EAAQvqH,MAAM,cAAgBrtB,EAAK,gBAAkBuS,GAK7D,IAAIrb,EAAI,IAAI2yC,KAAK7pC,EAAKs7I,GACtB,OAAOpkJ,EAAEskJ,YAAYtkJ,EAAEyiJ,cAAgB4B,GAAUlB,EAASiB,GAS9D3mJ,QAAQm1B,eAAiB,SAAS3vB,EAAMoY,GAapC,IAZA,IAIIzd,EACA4oH,EALA12D,EAAa,EACbC,EAAc,EACdH,EAAY,EACZN,EAAa,EAIb4yF,EACAlB,EAAgB3lI,IAChBvc,EAASyX,mBAAmB,YAAa,SAAzCzX,CAAmDuc,GAG/C1U,EAAI,EAAGA,EAAI1D,EAAKsB,OAAQoC,IAI5B,GAHA6/G,EAAKvjH,EAAK0D,GAGN/H,EAAU4nH,IAMd,KAAGA,EAAK7sE,GAER,GAAGuoG,EACC,IAEmB,KADftkJ,EAAIskJ,EAAYkB,OAAO58B,EAAK7sE,EAASkQ,IAChC06F,MACgB,IAAd3mJ,EAAEimJ,QAAe/zF,IACfC,IACFH,IACT,MAAMpX,SAKc,KADtB56C,EAAI,IAAI+0C,KAAK6zE,IACRk8B,aACsB,IAApB9kJ,EAAE6kJ,cAAqB3yF,IACrBC,IACFH,SAtBPN,IA0BRM,GADAG,GAAeD,EAGf,IAAIN,EAAYvsD,EAAKsB,OAAS+qD,EAE9B,MAAO,CACHQ,WAAYA,EAAaN,EACzBO,YAAaA,EAAcP,EAC3BI,UAAWA,EAAYJ,K,8CC3jB/B,IAAIvkD,EAAa,EAAQ,YAAoBA,WAEzCu0I,EAAkB,EAAQ,YAC1B/+B,EAAS,EAAQ,YAAYA,OAE7Bo8B,EAAM,sEAEVr/I,EAAOC,QAAU,CACbqgD,SAAU,OAEVz3C,WAAY,CACRy3C,SAAU,OAEV0mG,WAAY,CACRjnG,QAAS,aACT17C,KAAM4+G,EAAOgkC,KACbjnG,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,8DACAo/F,GACF51I,KAAK,MAEXy9I,gBAAiB,CACbnnG,QAAS,aACT17C,KAAM4+G,EAAOkkC,MACbnnG,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,8DACAo/F,GACF51I,KAAK,MAEX29I,UAAW,CACPrnG,QAAS,aACT17C,KAAM4+G,EAAOE,KACbnjE,KAAM,QACNM,SAAU,OACVL,YAAa,CACT,yCACAo/F,GACF51I,KAAK,OAIf64I,UAAW70I,EAAW,CAIlB45I,eAAe,EACf/mG,SAAU,OACVL,YAAa,CACT,IACFx2C,KAAK,MACRu4I,EAAgB,GAAI,CACnBsF,UAAW,qCACXC,aAAa,EACbC,eAAe,O,8CCzDvB,IAAIhmJ,EAAM,EAAQ,YACdimJ,EAAgB,EAAQ,YAAaA,cACrC1mG,EAAc,EAAQ,YAAaA,YAEvC/gD,EAAOC,QAAU,SAA4BmZ,EAAUhQ,GACnD,SAAS7B,EAAQkI,EAAMnJ,GACnB,IAAIgb,EAAM7R,EAAK,IAAMnJ,QACV4E,IAARoW,IACC7R,EAAKnJ,GAAKgb,GAIlB,SAASomI,EAAiBC,EAAWC,GACjC,IAAIn4I,EAAOm4I,EAAMrnI,UACb/e,EAAIkO,eAAei4I,EAAWC,EAAMrnI,WAAW5Q,MAC/Cg4I,EAEJ,GAAGl4I,EACC,GAAGA,EAAK6yI,UAEJ7yI,EAAKI,SAAWzG,EAAWqG,EAAK6yI,eAC7B,CACH,IAAI9/F,EAAQzB,EAAYtxC,GACpBo4I,EAASrlG,EAAMslG,MAEhBD,QAAwB38I,IAAds3C,EAAM/mB,MACfl0B,EAAQkI,EAAMm4I,EAAMnsH,MAErBosH,QAAwB38I,IAAds3C,EAAMl9C,MACfiC,EAAQkI,EAAMm4I,EAAMtiJ,KAErBk9C,EAAMulG,gBACLxgJ,EAAQkI,EAAM,eAM9B,IAAI,IAAItG,EAAI,EAAGA,EAAIiQ,EAASrS,OAAQoC,IAAK,CACrC,IAAI9I,EAAQ+Y,EAASjQ,GACjB6+I,EAAS3nJ,EAAMiR,QAAQy7D,SAE3B,GAAGi7E,EACC,GAAG9+I,MAAM+D,QAAQ+6I,GACb,IAAI,IAAI3uI,EAAI,EAAGA,EAAI2uI,EAAOjhJ,OAAQsS,IAC9BquI,EAAiBrnJ,EAAO2nJ,EAAO3uI,SAGnCquI,EAAiBrnJ,EAAO2nJ,GAI7BP,EAAcpnJ,EAAO,gBACpBqnJ,EAAiBrnJ,EAAO,CACpBkgB,UAAW,cACXkb,IAAK,OACLn2B,IAAK,SAKjB,IAAI,IAAIgB,KAAK8C,EAAWwqF,WACpB8zD,EAAiBt+I,EAAW9C,GAAI,CAACm1B,IAAK,OAAQn2B,IAAK,W,4CC9D3D,IAAI2iJ,EAAa,EAAQ,YACrBvoG,EAAY,EAAQ,YACpBwoG,EAAqB,EAAQ,YAC7BroG,EAAiB,EAAQ,YAAgCA,eAG7D7/C,EAAOC,QAAU4/C,EAAe,aAAc,CAC1C32B,QAAS,CACL62B,QAAS,UACTC,KAAM,OACN37C,MAAM,EACNi8C,SAAU,iBACVL,YAAa,CACT,yDACFx2C,KAAK,MAGX0H,KAAM,CACF4uC,QAAS,SACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,iDACA,sDACA,qDACA,2DACA,8BACFx2C,KAAK,MAEXs/B,UAAW,CACPgX,QAAS,QACT17C,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,8CACA,mCACFx2C,KAAK,MAEXxH,KAAMy9C,EAAU,CACZY,SAAU,iBACVoqF,cAAe,YACfzqF,YAAa,mCAEjBj7C,MAAO,CACH+6C,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,KACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,mEACA,sDACA,iEACFx2C,KAAK,MAEXmL,OAAQ,CACJmrC,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,KACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,oEACA,yDACFx2C,KAAK,MAEX2B,QAAS,CACL20C,QAAS,SACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,sDAEjB5U,MAAO,CACH0U,QAAS,aACTG,OAAQ,CAAC,OAAQ,SAAU,SAC3B77C,KAAM,SACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,8DACA,uDACA,6DACA,qDACFx2C,KAAK,MAEXwkC,OAAQ,CACJ8R,QAAS,aACTG,OAAQ,CAAC,MAAO,SAAU,UAC1B77C,KAAM,SACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,4DACA,8DACA,oBACFx2C,KAAK,MAEXomB,QAAS,CACLkwB,QAAS,QACT17C,KAAM,gBACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,gDAEjBrwB,YAAa,CACTmwB,QAAS,QACT17C,KAAM,gBACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,iEACFx2C,KAAK,MAEX6gC,UAAW,CACPyV,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,8CACA,6BACFx2C,KAAK,MAEXqkB,YAAa,CACTiyB,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,iDACA,0BACFx2C,KAAK,MAGX0/B,UAAW,CACP4W,QAAS,UACT17C,MAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,mEACA,qDACA,8DACFx2C,KAAK,MAEX4lC,WAAY,CACR0Q,QAAS,QACTC,KAAM,QACNM,SAAU,YACVL,YAAa,2CAEjB+0F,UAAW,CACPj1F,QAAS,UACTtkB,IAAK,EACLn2B,IAAK2iJ,EAAWlhJ,OAChB1C,KAAM,EACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,6CAEjBkoG,eAAgB,CACZpoG,QAAS,UACTtkB,IAAK,EACLn2B,IAAK2iJ,EAAWlhJ,OAChB1C,KAAM,EACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,+CAEjB1Q,UAAW,CACPwQ,QAAS,WACT2kF,MAAO,CAAC,MAAO,SACfC,OAAQ,CAAC,QACTtgI,KAAM,MACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,4CAEjBowD,UAAW,CACPtwD,QAAS,SACTtkB,IAAK,GACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,4EACA,qEACFx2C,KAAK,MAEXgnG,eAAgB,CACZ1wD,QAAS,SACTtkB,IAAK,GACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,8EACA,qEACFx2C,KAAK,MAEX0lC,WAAY,CACR4Q,QAAS,SACTtkB,IAAK,GACLukB,KAAM,QACNM,SAAU,iBACVL,YAAa,oDAEjBpQ,SAAU,CACNkQ,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,sEACA,kEACA,kEACA,kEACA,0CACFx2C,KAAK,MAEX2+I,cAAe,CACXroG,QAAS,SACTtkB,IAAK,EACLp3B,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,wEACA,kEACA,kEACA,kEACA,0CACFx2C,KAAK,MAEXqjC,GAAI,CACAiT,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,+DACA,gDACA,6CACA,sCACA,iEACA,mCACFx2C,KAAK,MAEXinC,GAAI,CACAqP,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,+DACA,gDACA,6CACA,sCACA,iEACA,mCACFx2C,KAAK,MAEX+mC,MAAO,CACHuP,QAAS,aACT17C,KAAM,QACN67C,OAAQ,CACJ,QACAgoG,EAAmBr/F,QAAQtmD,EAAE+lB,YAEjC03B,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8DACA,iEACA,gEACA,4DACA,+DACA,kCACFx2C,KAAK,MAEXgnC,MAAO,CACHsP,QAAS,aACT17C,KAAM,QACN67C,OAAQ,CACJ,QACAgoG,EAAmBr/F,QAAQrmD,EAAE8lB,YAEjC03B,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8DACA,iEACA,+DACA,4DACA,+DACA,kCACFx2C,KAAK,MAGXw+B,KAAM,CACF8X,QAAS,aACTG,OAAQ,CACJ,QACAgoG,EAAmBr/F,QAAQtmD,EAAE+lB,YAEjC03B,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,2CACA,8DACA,4BACA,kEACA,+DACA,qDACFx2C,KAAK,MAEXlH,EAAG,CACCw9C,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,oCACA,sDACA,6BACA,2DACA,4DACA,6CACA,0DACA,2DACA,6CACFx2C,KAAK,MAEX+nB,QAAS,CACLuuB,QAAS,aACTG,OAAQ,CAAC,OAAQ,OAAQ,SAAU,SACnC77C,KAAM,OACN27C,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,iDACA,6DACA,gCACA,yDACA,0DACA,sDACA,iBACA,sDACA,uDACA,gEACA,oCACFx2C,KAAK,MAEX6nC,OAAQ,CACJyO,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,+DACA,4DACFx2C,KAAK,MAEXy+B,KAAM,CACF6X,QAAS,aACTG,OAAQ,CACJ,QACAgoG,EAAmBr/F,QAAQrmD,EAAE8lB,YAEjC03B,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,2CACA,8DACA,4BACA,kEACA,4DACA,gDACFx2C,KAAK,MAEXjH,EAAG,CACCu9C,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,oCACA,sDACA,6BACA,2DACA,4DACA,6CACA,0DACA,2DACA,6CACFx2C,KAAK,MAEXkoB,QAAS,CACLouB,QAAS,aACTG,OAAQ,CAAC,OAAQ,MAAO,SAAU,UAClC77C,KAAM,OACN27C,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,+CACA,4DACA,iCACA,yDACA,sDACA,oDACA,iBACA,sDACA,uDACA,gEACA,oCACFx2C,KAAK,MAEXioC,OAAQ,CACJqO,QAAS,SACT17C,KAAM,EACN27C,KAAM,QACNM,SAAU,iBACVL,YAAa,CACT,2DACA,sDACFx2C,KAAK,MAEX4+I,YAAa,CACTtoG,QAAS,aACTG,OAAQ,EAAC,EAAO,QAAS,SACzB77C,MAAM,EACN27C,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,uDACA,iEACA,gEACA,iEACA,+DACA,8DACA,gEACA,wBACA,oEACA,mEACA,kEACA,+DACFx2C,KAAK,MAEX6+I,OAAQ,CACJvoG,QAAS,MACTC,KAAM,OACNM,SAAU,YACVL,YAAa,CACT,oEACA,uDACFx2C,KAAK,MAEX8+I,OAAQ,CACJxoG,QAAS,MACTC,KAAM,OACNM,SAAU,YACVL,YAAa,CACT,oEACA,uDACFx2C,KAAK,MAEXigC,UAAW,CACPqW,QAAS,SACTC,KAAM,OACNM,SAAU,YACVL,YAAa,CACT,0DACA,oDACFx2C,KAAK,MAEXmgC,WAAY,CACR/Z,QAAS,CACLkwB,QAAS,QACTC,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,gDACA,0DACA,mCACFx2C,KAAK,MAEXmmB,YAAa,CACTmwB,QAAS,QACTC,KAAM,QACNM,SAAU,YACVL,YAAa,CACT,4CACA,yDACA,uCACFx2C,KAAK,MAEXxH,KAAMy9C,EAAU,CACZY,SAAU,YACVL,YAAa,CACT,kCACA,kDACA,6CACFx2C,KAAK,OAEX62C,SAAU,aAEdjX,cAAe,CACX0W,QA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ACA,qCACA,uEACA,4CACFx2C,KAAK,MAEXitJ,eAAgB,CACZ32G,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,kDACA,2DACFx2C,KAAK,MAEX6/B,eAAgB,CACZyW,QAAS,UACT17C,MAAM,EACN47C,YAAa,oCAEjB02G,cAAe,CACX52G,QAAS,UACT17C,MAAM,EACN47C,YAAa,oCAEjB22G,iBAAkB,CACd72G,QAAS,UACT17C,MAAM,EACN47C,YAAa,6BAEjB42G,kBAAmB,CACf92G,QAAS,UACT17C,MAAM,EACN47C,YAAa,wCAEjB5G,eAAgB,CACZ0G,QAAS,UACT17C,MAAM,EACN47C,YAAa,8BAEjBnM,WAAY,CACRiM,QAAS,UACT17C,MAAM,EACN47C,YAAa,yDAEjB62G,cAAe,CACX/2G,QAAS,UACT17C,MAAM,EACN47C,YAAa,0BAEjB82G,UAAW,CACPh3G,QAAS,UACT17C,MAAM,EACN47C,YAAa,6CAIrB0yC,YAAa,CACT5yC,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,4DACA,sDACFx2C,KAAK,MAEXutJ,WAAY,CACRj3G,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,uEACA,+DACFx2C,KAAK,MAEXwxF,UAAW,CACPl7C,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,oEACA,uEACFx2C,KAAK,MAEXuxF,aAAc,CACVj7C,QAAS,SACT17C,KAAM,EACNo3B,IAAK,EACLn2B,IAAK,GACL26C,YAAa,CACT,6DACA,kCACFx2C,KAAK,MAGXwtJ,WAAY,CACRl3G,QAAS,WACT2kF,MAAO,CAAC,YAAa,OAAQ,MAAO,UACpCC,OAAQ,EAAC,GAAM,GACftgI,KAAM,kBACN47C,YAAa,CACT,uEACA,yDACA,wDACA,oDACA,sEACFx2C,KAAK,MAEX4zE,YAAa,CACTt9B,QAAS,aACTG,OAAQ,EAAC,EAAO,QAAS,WAAY,kBACrC77C,KAAM,iBACN47C,YAAa,CACT,0CACA,yCACA,uCACA,2EACA,6EACA,oEACA,qEACA,8BACFx2C,KAAK,MAEX6pC,iBAAkB,CACdyM,QAAS,SACT17C,KAAM,IACNo3B,IAAK,EACLwkB,YAAa,CACT,uDACA,gEACA,4CACA,0DACA,4DACFx2C,KAAK,MAGXy8H,oBAAqB,CACjBnmF,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,gEACFx2C,KAAK,MAEXs0E,wBAAyB,CACrBh+B,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,yEACA,sEACFx2C,KAAK,MAGXkwE,SAAU,CACN55B,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,6DACA,8BACFx2C,KAAK,MAGXskF,SAAU,CACNhuC,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,+DACA,kDACA,uCACFx2C,KAAK,MAEX+kF,SAAU,CACNzuC,QAAS,SACT17C,KAAM,aACNwgI,SAAS,EACT5kF,YAAa,CACT,mDACFx2C,KAAK,MAEXglF,SAAU,CACN1uC,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,8CACA,2CACFx2C,KAAK,MAEXukF,YAAa,CACTjuC,QAAS,MACT17C,MAAM,EACN47C,YAAa,CACT,uDACA,yBACFx2C,KAAK,MAGXkhG,eAAgB,CACZ5qD,QAAS,aACTG,OAAQ,CAAC,SAAS,GAAM,GACxB77C,KAAM,QACN47C,YAAa,CACT,wCACA,6CACA,6CACA,6DACA,8BACFx2C,KAAK,MAEX4iG,gBAAiB,CACbtsD,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,sEACA,+FACA,sFACA,yEACA,sFACA,wEACA,qEACFx2C,KAAK,MAEX2iG,sBAAuB,CACnBrsD,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,6EACA,8EACA,iDACFx2C,KAAK,MAEXohG,uBAAwB,CACpB9qD,QAAS,MACT17C,KAAM,GACN47C,YAAa,CACT,mCACA,8DACFx2C,KAAK,MAEXqhG,oBAAqB,CACjB/qD,QAAS,MACT17C,KAAM,GACN47C,YAAa,CACT,2CACA,8DACFx2C,KAAK,MAEXghG,eAAgB,CACZ1qD,QAAS,MACT17C,MAAM,EACN47C,YAAa,CACT,wDACA,uDACA,2EACA,sDACFx2C,KAAK,MAEXytJ,qBAAsB,CAClBn3G,QAAS,MACT17C,KAAM,GACN47C,YAAa,CACT,yDACA,0DACA,wCACFx2C,KAAK,MAEX0tJ,YAAa,CACTp3G,QAAS,UACT17C,MAAM,EACN47C,YAAa,CACT,yDACA,+BACFx2C,KAAK,MAEXmhG,UAAW,CACP7qD,QAAS,UACT17C,MAAM,EACN47C,YAAa,gDAGjBm3G,iBAAkB,CACdr3G,QAAS,SACT17C,KAAM,EACNo3B,IAAK,EACLn2B,IAAK,EACL26C,YAAa,CACT,iDACA,2DACA,4BACFx2C,KAAK,MAGX4tJ,cAAe,CACXt3G,QAAS,MACT17C,KAAM,cACN47C,YAAa,CACT,uEACA,4BACA,gFACA,4BACA,6EACFx2C,KAAK,MAGX6tJ,YAAa,CACTv3G,QAAS,SACT8kF,SAAS,EACTxgI,KAAM,uBACN47C,YAAa,CACT,8CACA,+DACA,mCACA,qCACA,0DACA,wCACFx2C,KAAK,MAGX2oF,kBAAmB,CACfryC,QAAS,SACT17C,KAAM,KACN47C,YAAa,CACT,4DACA,yDACA,gFACFx2C,KAAK,MAGX8tJ,QAAS,CACLx3G,QAAS,UACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACN47C,YAAa,CACT,6DACA,mDACA,oBACA,aACA,yDACA,mBACFx2C,KAAK,MAGX+tJ,gBAAiB,CACbz3G,QAAS,UACTtkB,IAAK,EACLn2B,IAAK,EACLjB,KAAM,EACN47C,YAAa,CACT,wCACA,mDACA,oBACA,sBACA,yDACA,mBACFx2C,KAAK,MAGXguJ,YAAa,CACT13G,QAAS,UACTtkB,IAAK,EACLp3B,KAAM,EACN47C,YAAa,2CAGjBw0C,iBAAkB,CACd10C,QAAS,MACT17C,KAAM,GACN47C,YAAa,CACT,2DACA,wBACFx2C,KAAK,MAGXmmF,OAAQ,CACJ7vC,QAAS,SACT17C,KAAM,QACN47C,YAAa,CACT,oCACA,4CACFx2C,KAAK,MAGX0mF,QAAS,CACLpwC,QAAS,MACT17C,KAAM,GACN47C,YAAa,CACT,2BACA,0EACA,kCACA,8EACA,IACA,UACA,2DACA,oD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EXjH,EAAG,CACCu9C,QAAS,aACTO,SAAU,sBACV+iD,MAAM,EACNpjD,YAAa,2BAEjB1yB,GAAI,CACAwyB,QAAS,MACT17C,KAAM,EACN27C,KAAM,OACNM,SAAU,sBACV+iD,MAAM,EACNpjD,YAAa,CACT,oBACA,0CACA,gBACA,4DACFx2C,KAAK,MAEXoH,GAAI,CACAkvC,QAAS,SACT17C,KAAM,EACN27C,KAAM,OACNM,SAAU,OACV+iD,MAAM,EACNpjD,YAAa,CACT,8BACA,2BACFx2C,KAAK,MAGXsjD,WAAY,CACRhN,QAAS,SACTC,KAAM,OACN37C,KAAM,GACNi8C,SAAU,OACVL,YAAa,CACT,+DACA,kEACA,oEACA,qEACA,iEACA,iDACA,wDACA,qEACA,gEACA,qEACA,yEACFx2C,KAAK,MAEX2Q,YAAa,CACT2lC,QAAS,aACTC,KAAM,OACNE,OAAQ,CAAC,IAAK,KACdI,SAAU,OACVL,YAAa,CACT,8DACA,mEACA,kEACA,qEACA,+DACFx2C,KAAK,MAEX8pK,UAAW,CACPxzH,QAAS,aACTG,OAAQ,CAAC,GAAI,WAAY,WACzB77C,KAAM,GACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8DACA,iEACA,yDACA,2DACA,+DACA,2DACA,mEACA,mEACA,wDACFx2C,KAAK,MAEX+pK,UAAW,CACPzzH,QAAS,aACTG,OAAQ,CAAC,aAAc,eACvB77C,KAAM,aACN27C,KAAM,OACNM,SAAU,OACVL,YAAa,CACT,8DACA,iEACA,yDACA,mEACA,yCACA,yDACA,8DACA,kEAIFx2C,KAAK,MAGX0H,KAAM,CACF4uC,QAAS,SACTC,KAAM,OACN37C,KAAM,GACN6sG,SAAS,EACT5wD,SAAU,OACVL,YAAa,CACT,sDACA,mDACA,uBACA,8DACA,kCACA,0EACA,oDACFx2C,KAAK,MAGXwH,aAAcu5H,EAAkB,GAAI,IAGpC9gG,UAAW,CACPqW,QAAS,SACTC,KAAM,OACN37C,KAAM,GACN6sG,SAAS,EACT5wD,SAAU,QACVL,YAAa,CACT,4DACA,mDACA,uBACA,8DACA,kCACA,6DACFx2C,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yCAEA,sCACA,kCACA,cACA,mDACA,yCAEA,0CACA,kEACA,yCAEA,kDACA,0CACFx2C,KAAK,MAGX23B,MAAO,CACH2e,QAAS,aACTG,OAAQ,CAAC,QAAS,SAClB77C,KAAM,QACN27C,KAAM,OACNM,SAAU,YACVL,YAAa,6DAGjBhY,KAAMx6B,EAAW,GAAI6uO,EAASr0M,KAAM,CAChCgY,YAAa,CACT,sCACA,8DACA,6BACA,kEACA,+DACA,wDACA,sDACA,6BACA,sDACA,0CACFx2C,KAAK,OAEXihK,UAAW,CACP3qH,QAAS,aACTG,OAAQ,CAAC,SAAU,SACnB77C,KAAM,SACN27C,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,kDACA,0EACA,mEACA,2BACA,iEACA,0EACA,iEACA,iEACA,kBACFx2C,KAAK,MAEX+nB,QAAS,CACLuuB,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,gEACA,+DACA,mDACA,qEACA,kDACFx2C,KAAK,MAEX6jB,GAAI,CACAyyB,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,wCACA,6CACFx2C,KAAK,MAEX/B,GAAI,CACAq4C,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,mCACA,6CACFx2C,KAAK,MAGXy+B,KAAMz6B,EAAW,GAAI6uO,EAASp0M,KAAM,CAChC+X,YAAa,CACT,2CACA,8DACA,4BACA,kEACA,4DACA,oDACFx2C,KAAK,OAEXmhK,UAAW,CACP7qH,QAAS,aACTG,OAAQ,CAAC,SAAU,SACnB77C,KAAM,SACN27C,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,kDACA,0EACA,oEACA,2BACA,iEACA,0EACA,iEACA,kEACA,kBACFx2C,KAAK,MAEXkoB,QAAS,CACLouB,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,gEACA,+DACA,mDACA,qEACA,kDACFx2C,KAAK,MAEX8jB,GAAI,CACAwyB,QAAS,MACTC,KAAM,OACNM,SAAU,iBACVL,YAAa,CACT,wCACA,6CACFx2C,KAAK,MAEX7B,GAAI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","file":"0c1a66a2-34.1ec71fc30880f2142b45.js","sourcesContent":["/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Color = require('../color');\n\n\nmodule.exports = function style(traces) {\n    traces.each(function(d) {\n        var trace = d[0].trace;\n        var yObj = trace.error_y || {};\n        var xObj = trace.error_x || {};\n\n        var s = d3.select(this);\n\n        s.selectAll('path.yerror')\n            .style('stroke-width', yObj.thickness + 'px')\n            .call(Color.stroke, yObj.color);\n\n        if(xObj.copy_ystyle) xObj = yObj;\n\n        s.selectAll('path.xerror')\n            .style('stroke-width', xObj.thickness + 'px')\n            .call(Color.stroke, xObj.color);\n    });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Color = require('../color');\nvar Colorscale = require('../colorscale');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\nvar alignment = require('../../constants/alignment');\nvar LINE_SPACING = alignment.LINE_SPACING;\nvar DESELECTDIM = require('../../constants/interactions').DESELECTDIM;\n\nvar subTypes = require('../../traces/scatter/subtypes');\nvar makeBubbleSizeFn = require('../../traces/scatter/make_bubble_size_func');\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar drawing = module.exports = {};\n\n// -----------------------------------------------------\n// styling functions for plot elements\n// -----------------------------------------------------\n\ndrawing.font = function(s, family, size, color) {\n    // also allow the form font(s, {family, size, color})\n    if(Lib.isPlainObject(family)) {\n        color = family.color;\n        size = family.size;\n        family = family.family;\n    }\n    if(family) s.style('font-family', family);\n    if(size + 1) s.style('font-size', size + 'px');\n    if(color) s.call(Color.fill, color);\n};\n\n/*\n * Positioning helpers\n * Note: do not use `setPosition` with  nodes modified by\n * `svgTextUtils.convertToTspans`. Use `svgTextUtils.positionText`\n * instead, so that  elements get updated to match.\n */\ndrawing.setPosition = function(s, x, y) { s.attr('x', x).attr('y', y); };\ndrawing.setSize = function(s, w, h) { s.attr('width', w).attr('height', h); };\ndrawing.setRect = function(s, x, y, w, h) {\n    s.call(drawing.setPosition, x, y).call(drawing.setSize, w, h);\n};\n\n/** Translate node\n *\n * @param {object} d : calcdata point item\n * @param {sel} sel : d3 selction of node to translate\n * @param {object} xa : corresponding full xaxis object\n * @param {object} ya : corresponding full yaxis object\n *\n * @return {boolean} :\n *  true if selection got translated\n *  false if selection could not get translated\n */\ndrawing.translatePoint = function(d, sel, xa, ya) {\n    var x = xa.c2p(d.x);\n    var y = ya.c2p(d.y);\n\n    if(isNumeric(x) && isNumeric(y) && sel.node()) {\n        // for multiline text this works better\n        if(sel.node().nodeName === 'text') {\n            sel.attr('x', x).attr('y', y);\n        } else {\n            sel.attr('transform', 'translate(' + x + ',' + y + ')');\n        }\n    } else {\n        return false;\n    }\n\n    return true;\n};\n\ndrawing.translatePoints = function(s, xa, ya) {\n    s.each(function(d) {\n        var sel = d3.select(this);\n        drawing.translatePoint(d, sel, xa, ya);\n    });\n};\n\ndrawing.hideOutsideRangePoint = function(d, sel, xa, ya, xcalendar, ycalendar) {\n    sel.attr(\n        'display',\n        (xa.isPtWithinRange(d, xcalendar) && ya.isPtWithinRange(d, ycalendar)) ? null : 'none'\n    );\n};\n\ndrawing.hideOutsideRangePoints = function(traceGroups, subplot) {\n    if(!subplot._hasClipOnAxisFalse) return;\n\n    var xa = subplot.xaxis;\n    var ya = subplot.yaxis;\n\n    traceGroups.each(function(d) {\n        var trace = d[0].trace;\n        var xcalendar = trace.xcalendar;\n        var ycalendar = trace.ycalendar;\n        var selector = Registry.traceIs(trace, 'bar-like') ? '.bartext' : '.point,.textpoint';\n\n        traceGroups.selectAll(selector).each(function(d) {\n            drawing.hideOutsideRangePoint(d, d3.select(this), xa, ya, xcalendar, ycalendar);\n        });\n    });\n};\n\ndrawing.crispRound = function(gd, lineWidth, dflt) {\n    // for lines that disable antialiasing we want to\n    // make sure the width is an integer, and at least 1 if it's nonzero\n\n    if(!lineWidth || !isNumeric(lineWidth)) return dflt || 0;\n\n    // but not for static plots - these don't get antialiased anyway.\n    if(gd._context.staticPlot) return lineWidth;\n\n    if(lineWidth < 1) return 1;\n    return Math.round(lineWidth);\n};\n\ndrawing.singleLineStyle = function(d, s, lw, lc, ld) {\n    s.style('fill', 'none');\n    var line = (((d || [])[0] || {}).trace || {}).line || {};\n    var lw1 = lw || line.width || 0;\n    var dash = ld || line.dash || '';\n\n    Color.stroke(s, lc || line.color);\n    drawing.dashLine(s, dash, lw1);\n};\n\ndrawing.lineGroupStyle = function(s, lw, lc, ld) {\n    s.style('fill', 'none')\n    .each(function(d) {\n        var line = (((d || [])[0] || {}).trace || {}).line || {};\n        var lw1 = lw || line.width || 0;\n        var dash = ld || line.dash || '';\n\n        d3.select(this)\n            .call(Color.stroke, lc || line.color)\n            .call(drawing.dashLine, dash, lw1);\n    });\n};\n\ndrawing.dashLine = function(s, dash, lineWidth) {\n    lineWidth = +lineWidth || 0;\n\n    dash = drawing.dashStyle(dash, lineWidth);\n\n    s.style({\n        'stroke-dasharray': dash,\n        'stroke-width': lineWidth + 'px'\n    });\n};\n\ndrawing.dashStyle = function(dash, lineWidth) {\n    lineWidth = +lineWidth || 1;\n    var dlw = Math.max(lineWidth, 3);\n\n    if(dash === 'solid') dash = '';\n    else if(dash === 'dot') dash = dlw + 'px,' + dlw + 'px';\n    else if(dash === 'dash') dash = (3 * dlw) + 'px,' + (3 * dlw) + 'px';\n    else if(dash === 'longdash') dash = (5 * dlw) + 'px,' + (5 * dlw) + 'px';\n    else if(dash === 'dashdot') {\n        dash = (3 * dlw) + 'px,' + dlw + 'px,' + dlw + 'px,' + dlw + 'px';\n    } else if(dash === 'longdashdot') {\n        dash = (5 * dlw) + 'px,' + (2 * dlw) + 'px,' + dlw + 'px,' + (2 * dlw) + 'px';\n    }\n    // otherwise user wrote the dasharray themselves - leave it be\n\n    return dash;\n};\n\n// Same as fillGroupStyle, except in this case the selection may be a transition\ndrawing.singleFillStyle = function(sel) {\n    var node = d3.select(sel.node());\n    var data = node.data();\n    var fillcolor = (((data[0] || [])[0] || {}).trace || {}).fillcolor;\n    if(fillcolor) {\n        sel.call(Color.fill, fillcolor);\n    }\n};\n\ndrawing.fillGroupStyle = function(s) {\n    s.style('stroke-width', 0)\n    .each(function(d) {\n        var shape = d3.select(this);\n        // N.B. 'd' won't be a calcdata item when\n        // fill !== 'none' on a segment-less and marker-less trace\n        if(d[0].trace) {\n            shape.call(Color.fill, d[0].trace.fillcolor);\n        }\n    });\n};\n\nvar SYMBOLDEFS = require('./symbol_defs');\n\ndrawing.symbolNames = [];\ndrawing.symbolFuncs = [];\ndrawing.symbolNeedLines = {};\ndrawing.symbolNoDot = {};\ndrawing.symbolNoFill = {};\ndrawing.symbolList = [];\n\nObject.keys(SYMBOLDEFS).forEach(function(k) {\n    var symDef = SYMBOLDEFS[k];\n    var n = symDef.n;\n    drawing.symbolList.push(\n        n,\n        k,\n        n + 100,\n        k + '-open'\n    );\n    drawing.symbolNames[n] = k;\n    drawing.symbolFuncs[n] = symDef.f;\n\n    if(symDef.needLine) {\n        drawing.symbolNeedLines[n] = true;\n    }\n    if(symDef.noDot) {\n        drawing.symbolNoDot[n] = true;\n    } else {\n        drawing.symbolList.push(\n            n + 200,\n            k + '-dot',\n            n + 300,\n            k + '-open-dot'\n        );\n    }\n    if(symDef.noFill) {\n        drawing.symbolNoFill[n] = true;\n    }\n});\n\nvar MAXSYMBOL = drawing.symbolNames.length;\n// add a dot in the middle of the symbol\nvar DOTPATH = 'M0,0.5L0.5,0L0,-0.5L-0.5,0Z';\n\ndrawing.symbolNumber = function(v) {\n    if(typeof v === 'string') {\n        var vbase = 0;\n        if(v.indexOf('-open') > 0) {\n            vbase = 100;\n            v = v.replace('-open', '');\n        }\n        if(v.indexOf('-dot') > 0) {\n            vbase += 200;\n            v = v.replace('-dot', '');\n        }\n        v = drawing.symbolNames.indexOf(v);\n        if(v >= 0) { v += vbase; }\n    }\n\n    return (v % 100 >= MAXSYMBOL || v >= 400) ?\n        0 : Math.floor(Math.max(v, 0));\n};\n\nfunction makePointPath(symbolNumber, r) {\n    var base = symbolNumber % 100;\n    return drawing.symbolFuncs[base](r) + (symbolNumber >= 200 ? DOTPATH : '');\n}\n\nvar HORZGRADIENT = {x1: 1, x2: 0, y1: 0, y2: 0};\nvar VERTGRADIENT = {x1: 0, x2: 0, y1: 1, y2: 0};\nvar stopFormatter = d3.format('~.1f');\nvar gradientInfo = {\n    radial: {node: 'radialGradient'},\n    radialreversed: {node: 'radialGradient', reversed: true},\n    horizontal: {node: 'linearGradient', attrs: HORZGRADIENT},\n    horizontalreversed: {node: 'linearGradient', attrs: HORZGRADIENT, reversed: true},\n    vertical: {node: 'linearGradient', attrs: VERTGRADIENT},\n    verticalreversed: {node: 'linearGradient', attrs: VERTGRADIENT, reversed: true}\n};\n\n/**\n * gradient: create and apply a gradient fill\n *\n * @param {object} sel: d3 selection to apply this gradient to\n *     You can use `selection.call(Drawing.gradient, ...)`\n * @param {DOM element} gd: the graph div `sel` is part of\n * @param {string} gradientID: a unique (within this plot) identifier\n *     for this gradient, so that we don't create unnecessary definitions\n * @param {string} type: 'radial', 'horizontal', or 'vertical', optionally with\n *     'reversed' at the end. Normally radial goes center to edge,\n *     horizontal goes right to left, and vertical goes bottom to top\n * @param {array} colorscale: as in attribute values, [[fraction, color], ...]\n * @param {string} prop: the property to apply to, 'fill' or 'stroke'\n */\ndrawing.gradient = function(sel, gd, gradientID, type, colorscale, prop) {\n    var len = colorscale.length;\n    var info = gradientInfo[type];\n    var colorStops = new Array(len);\n    for(var i = 0; i < len; i++) {\n        if(info.reversed) {\n            colorStops[len - 1 - i] = [stopFormatter((1 - colorscale[i][0]) * 100), colorscale[i][1]];\n        } else {\n            colorStops[i] = [stopFormatter(colorscale[i][0] * 100), colorscale[i][1]];\n        }\n    }\n\n    var fullLayout = gd._fullLayout;\n    var fullID = 'g' + fullLayout._uid + '-' + gradientID;\n\n    var gradient = fullLayout._defs.select('.gradients')\n        .selectAll('#' + fullID)\n        .data([type + colorStops.join(';')], Lib.identity);\n\n    gradient.exit().remove();\n\n    gradient.enter()\n        .append(info.node)\n        .each(function() {\n            var el = d3.select(this);\n            if(info.attrs) el.attr(info.attrs);\n\n            el.attr('id', fullID);\n\n            var stops = el.selectAll('stop')\n                .data(colorStops);\n            stops.exit().remove();\n            stops.enter().append('stop');\n\n            stops.each(function(d) {\n                var tc = tinycolor(d[1]);\n                d3.select(this).attr({\n                    offset: d[0] + '%',\n                    'stop-color': Color.tinyRGB(tc),\n                    'stop-opacity': tc.getAlpha()\n                });\n            });\n        });\n\n    sel.style(prop, getFullUrl(fullID, gd))\n        .style(prop + '-opacity', null);\n\n    var className2query = function(s) {\n        return '.' + s.attr('class').replace(/\\s/g, '.');\n    };\n    var k = className2query(d3.select(sel.node().parentNode)) +\n        '>' + className2query(sel);\n    fullLayout._gradientUrlQueryParts[k] = 1;\n};\n\n/*\n * Make the gradients container and clear out any previous gradients.\n * We never collect all the gradients we need in one place,\n * so we can't ever remove gradients that have stopped being useful,\n * except all at once before a full redraw.\n * The upside of this is arbitrary points can share gradient defs\n */\ndrawing.initGradients = function(gd) {\n    var fullLayout = gd._fullLayout;\n\n    var gradientsGroup = Lib.ensureSingle(fullLayout._defs, 'g', 'gradients');\n    gradientsGroup.selectAll('linearGradient,radialGradient').remove();\n\n    // initialize stash of query parts filled in Drawing.gradient,\n    // used to fix URL strings during image exports\n    fullLayout._gradientUrlQueryParts = {};\n};\n\n\ndrawing.pointStyle = function(s, trace, gd) {\n    if(!s.size()) return;\n\n    var fns = drawing.makePointStyleFns(trace);\n\n    s.each(function(d) {\n        drawing.singlePointStyle(d, d3.select(this), trace, fns, gd);\n    });\n};\n\ndrawing.singlePointStyle = function(d, sel, trace, fns, gd) {\n    var marker = trace.marker;\n    var markerLine = marker.line;\n\n    sel.style('opacity',\n        fns.selectedOpacityFn ? fns.selectedOpacityFn(d) :\n            (d.mo === undefined ? marker.opacity : d.mo)\n    );\n\n    if(fns.ms2mrc) {\n        var r;\n\n        // handle multi-trace graph edit case\n        if(d.ms === 'various' || marker.size === 'various') {\n            r = 3;\n        } else {\n            r = fns.ms2mrc(d.ms);\n        }\n\n        // store the calculated size so hover can use it\n        d.mrc = r;\n\n        if(fns.selectedSizeFn) {\n            r = d.mrc = fns.selectedSizeFn(d);\n        }\n\n        // turn the symbol into a sanitized number\n        var x = drawing.symbolNumber(d.mx || marker.symbol) || 0;\n\n        // save if this marker is open\n        // because that impacts how to handle colors\n        d.om = x % 200 >= 100;\n\n        sel.attr('d', makePointPath(x, r));\n    }\n\n    var perPointGradient = false;\n    var fillColor, lineColor, lineWidth;\n\n    // 'so' is suspected outliers, for box plots\n    if(d.so) {\n        lineWidth = markerLine.outlierwidth;\n        lineColor = markerLine.outliercolor;\n        fillColor = marker.outliercolor;\n    } else {\n        var markerLineWidth = (markerLine || {}).width;\n\n        lineWidth = (\n            d.mlw + 1 ||\n            markerLineWidth + 1 ||\n            // TODO: we need the latter for legends... can we get rid of it?\n            (d.trace ? (d.trace.marker.line || {}).width : 0) + 1\n        ) - 1 || 0;\n\n        if('mlc' in d) lineColor = d.mlcc = fns.lineScale(d.mlc);\n        // weird case: array wasn't long enough to apply to every point\n        else if(Lib.isArrayOrTypedArray(markerLine.color)) lineColor = Color.defaultLine;\n        else lineColor = markerLine.color;\n\n        if(Lib.isArrayOrTypedArray(marker.color)) {\n            fillColor = Color.defaultLine;\n            perPointGradient = true;\n        }\n\n        if('mc' in d) {\n            fillColor = d.mcc = fns.markerScale(d.mc);\n        } else {\n            fillColor = marker.color || 'rgba(0,0,0,0)';\n        }\n\n        if(fns.selectedColorFn) {\n            fillColor = fns.selectedColorFn(d);\n        }\n    }\n\n    if(d.om) {\n        // open markers can't have zero linewidth, default to 1px,\n        // and use fill color as stroke color\n        sel.call(Color.stroke, fillColor)\n            .style({\n                'stroke-width': (lineWidth || 1) + 'px',\n                fill: 'none'\n            });\n    } else {\n        sel.style('stroke-width', (d.isBlank ? 0 : lineWidth) + 'px');\n\n        var markerGradient = marker.gradient;\n\n        var gradientType = d.mgt;\n        if(gradientType) perPointGradient = true;\n        else gradientType = markerGradient && markerGradient.type;\n\n        // for legend - arrays will propagate through here, but we don't need\n        // to treat it as per-point.\n        if(Array.isArray(gradientType)) {\n            gradientType = gradientType[0];\n            if(!gradientInfo[gradientType]) gradientType = 0;\n        }\n\n        if(gradientType && gradientType !== 'none') {\n            var gradientColor = d.mgc;\n            if(gradientColor) perPointGradient = true;\n            else gradientColor = markerGradient.color;\n\n            var gradientID = trace.uid;\n            if(perPointGradient) gradientID += '-' + d.i;\n\n            drawing.gradient(sel, gd, gradientID, gradientType,\n                [[0, gradientColor], [1, fillColor]], 'fill');\n        } else {\n            Color.fill(sel, fillColor);\n        }\n\n        if(lineWidth) {\n            Color.stroke(sel, lineColor);\n        }\n    }\n};\n\ndrawing.makePointStyleFns = function(trace) {\n    var out = {};\n    var marker = trace.marker;\n\n    // allow array marker and marker line colors to be\n    // scaled by given max and min to colorscales\n    out.markerScale = drawing.tryColorscale(marker, '');\n    out.lineScale = drawing.tryColorscale(marker, 'line');\n\n    if(Registry.traceIs(trace, 'symbols')) {\n        out.ms2mrc = subTypes.isBubble(trace) ?\n            makeBubbleSizeFn(trace) :\n            function() { return (marker.size || 6) / 2; };\n    }\n\n    if(trace.selectedpoints) {\n        Lib.extendFlat(out, drawing.makeSelectedPointStyleFns(trace));\n    }\n\n    return out;\n};\n\ndrawing.makeSelectedPointStyleFns = function(trace) {\n    var out = {};\n\n    var selectedAttrs = trace.selected || {};\n    var unselectedAttrs = trace.unselected || {};\n\n    var marker = trace.marker || {};\n    var selectedMarker = selectedAttrs.marker || {};\n    var unselectedMarker = unselectedAttrs.marker || {};\n\n    var mo = marker.opacity;\n    var smo = selectedMarker.opacity;\n    var usmo = unselectedMarker.opacity;\n    var smoIsDefined = smo !== undefined;\n    var usmoIsDefined = usmo !== undefined;\n\n    if(Lib.isArrayOrTypedArray(mo) || smoIsDefined || usmoIsDefined) {\n        out.selectedOpacityFn = function(d) {\n            var base = d.mo === undefined ? marker.opacity : d.mo;\n\n            if(d.selected) {\n                return smoIsDefined ? smo : base;\n            } else {\n                return usmoIsDefined ? usmo : DESELECTDIM * base;\n            }\n        };\n    }\n\n    var mc = marker.color;\n    var smc = selectedMarker.color;\n    var usmc = unselectedMarker.color;\n\n    if(smc || usmc) {\n        out.selectedColorFn = function(d) {\n            var base = d.mcc || mc;\n\n            if(d.selected) {\n                return smc || base;\n            } else {\n                return usmc || base;\n            }\n        };\n    }\n\n    var ms = marker.size;\n    var sms = selectedMarker.size;\n    var usms = unselectedMarker.size;\n    var smsIsDefined = sms !== undefined;\n    var usmsIsDefined = usms !== undefined;\n\n    if(Registry.traceIs(trace, 'symbols') && (smsIsDefined || usmsIsDefined)) {\n        out.selectedSizeFn = function(d) {\n            var base = d.mrc || ms / 2;\n\n            if(d.selected) {\n                return smsIsDefined ? sms / 2 : base;\n            } else {\n                return usmsIsDefined ? usms / 2 : base;\n            }\n        };\n    }\n\n    return out;\n};\n\ndrawing.makeSelectedTextStyleFns = function(trace) {\n    var out = {};\n\n    var selectedAttrs = trace.selected || {};\n    var unselectedAttrs = trace.unselected || {};\n\n    var textFont = trace.textfont || {};\n    var selectedTextFont = selectedAttrs.textfont || {};\n    var unselectedTextFont = unselectedAttrs.textfont || {};\n\n    var tc = textFont.color;\n    var stc = selectedTextFont.color;\n    var utc = unselectedTextFont.color;\n\n    out.selectedTextColorFn = function(d) {\n        var base = d.tc || tc;\n\n        if(d.selected) {\n            return stc || base;\n        } else {\n            if(utc) return utc;\n            else return stc ? base : Color.addOpacity(base, DESELECTDIM);\n        }\n    };\n\n    return out;\n};\n\ndrawing.selectedPointStyle = function(s, trace) {\n    if(!s.size() || !trace.selectedpoints) return;\n\n    var fns = drawing.makeSelectedPointStyleFns(trace);\n    var marker = trace.marker || {};\n    var seq = [];\n\n    if(fns.selectedOpacityFn) {\n        seq.push(function(pt, d) {\n            pt.style('opacity', fns.selectedOpacityFn(d));\n        });\n    }\n\n    if(fns.selectedColorFn) {\n        seq.push(function(pt, d) {\n            Color.fill(pt, fns.selectedColorFn(d));\n        });\n    }\n\n    if(fns.selectedSizeFn) {\n        seq.push(function(pt, d) {\n            var mx = d.mx || marker.symbol || 0;\n            var mrc2 = fns.selectedSizeFn(d);\n\n            pt.attr('d', makePointPath(drawing.symbolNumber(mx), mrc2));\n\n            // save for Drawing.selectedTextStyle\n            d.mrc2 = mrc2;\n        });\n    }\n\n    if(seq.length) {\n        s.each(function(d) {\n            var pt = d3.select(this);\n            for(var i = 0; i < seq.length; i++) {\n                seq[i](pt, d);\n            }\n        });\n    }\n};\n\ndrawing.tryColorscale = function(marker, prefix) {\n    var cont = prefix ? Lib.nestedProperty(marker, prefix).get() : marker;\n\n    if(cont) {\n        var colorArray = cont.color;\n        if((cont.colorscale || cont._colorAx) && Lib.isArrayOrTypedArray(colorArray)) {\n            return Colorscale.makeColorScaleFuncFromTrace(cont);\n        }\n    }\n    return Lib.identity;\n};\n\nvar TEXTOFFSETSIGN = {\n    start: 1, end: -1, middle: 0, bottom: 1, top: -1\n};\n\nfunction textPointPosition(s, textPosition, fontSize, markerRadius) {\n    var group = d3.select(s.node().parentNode);\n\n    var v = textPosition.indexOf('top') !== -1 ?\n        'top' :\n        textPosition.indexOf('bottom') !== -1 ? 'bottom' : 'middle';\n    var h = textPosition.indexOf('left') !== -1 ?\n        'end' :\n        textPosition.indexOf('right') !== -1 ? 'start' : 'middle';\n\n    // if markers are shown, offset a little more than\n    // the nominal marker size\n    // ie 2/1.6 * nominal, bcs some markers are a bit bigger\n    var r = markerRadius ? markerRadius / 0.8 + 1 : 0;\n\n    var numLines = (svgTextUtils.lineCount(s) - 1) * LINE_SPACING + 1;\n    var dx = TEXTOFFSETSIGN[h] * r;\n    var dy = fontSize * 0.75 + TEXTOFFSETSIGN[v] * r +\n        (TEXTOFFSETSIGN[v] - 1) * numLines * fontSize / 2;\n\n    // fix the overall text group position\n    s.attr('text-anchor', h);\n    group.attr('transform', 'translate(' + dx + ',' + dy + ')');\n}\n\nfunction extracTextFontSize(d, trace) {\n    var fontSize = d.ts || trace.textfont.size;\n    return (isNumeric(fontSize) && fontSize > 0) ? fontSize : 0;\n}\n\n// draw text at points\ndrawing.textPointStyle = function(s, trace, gd) {\n    if(!s.size()) return;\n\n    var selectedTextColorFn;\n    if(trace.selectedpoints) {\n        var fns = drawing.makeSelectedTextStyleFns(trace);\n        selectedTextColorFn = fns.selectedTextColorFn;\n    }\n\n    var texttemplate = trace.texttemplate;\n    var fullLayout = gd._fullLayout;\n\n    s.each(function(d) {\n        var p = d3.select(this);\n\n        var text = texttemplate ?\n            Lib.extractOption(d, trace, 'txt', 'texttemplate') :\n            Lib.extractOption(d, trace, 'tx', 'text');\n\n        if(!text && text !== 0) {\n            p.remove();\n            return;\n        }\n\n        if(texttemplate) {\n            var labels = trace._module.formatLabels ? trace._module.formatLabels(d, trace, fullLayout) : {};\n            var pointValues = {};\n            appendArrayPointValue(pointValues, trace, d.i);\n            var meta = trace._meta || {};\n            text = Lib.texttemplateString(text, labels, fullLayout._d3locale, pointValues, d, meta);\n        }\n\n        var pos = d.tp || trace.textposition;\n        var fontSize = extracTextFontSize(d, trace);\n        var fontColor = selectedTextColorFn ?\n            selectedTextColorFn(d) :\n            (d.tc || trace.textfont.color);\n\n        p.call(drawing.font,\n                d.tf || trace.textfont.family,\n                fontSize,\n                fontColor)\n            .text(text)\n            .call(svgTextUtils.convertToTspans, gd)\n            .call(textPointPosition, pos, fontSize, d.mrc);\n    });\n};\n\ndrawing.selectedTextStyle = function(s, trace) {\n    if(!s.size() || !trace.selectedpoints) return;\n\n    var fns = drawing.makeSelectedTextStyleFns(trace);\n\n    s.each(function(d) {\n        var tx = d3.select(this);\n        var tc = fns.selectedTextColorFn(d);\n        var tp = d.tp || trace.textposition;\n        var fontSize = extracTextFontSize(d, trace);\n\n        Color.fill(tx, tc);\n        textPointPosition(tx, tp, fontSize, d.mrc2 || d.mrc);\n    });\n};\n\n// generalized Catmull-Rom splines, per\n// http://www.cemyuksel.com/research/catmullrom_param/catmullrom.pdf\nvar CatmullRomExp = 0.5;\ndrawing.smoothopen = function(pts, smoothness) {\n    if(pts.length < 3) { return 'M' + pts.join('L');}\n    var path = 'M' + pts[0];\n    var tangents = [];\n    var i;\n    for(i = 1; i < pts.length - 1; i++) {\n        tangents.push(makeTangent(pts[i - 1], pts[i], pts[i + 1], smoothness));\n    }\n    path += 'Q' + tangents[0][0] + ' ' + pts[1];\n    for(i = 2; i < pts.length - 1; i++) {\n        path += 'C' + tangents[i - 2][1] + ' ' + tangents[i - 1][0] + ' ' + pts[i];\n    }\n    path += 'Q' + tangents[pts.length - 3][1] + ' ' + pts[pts.length - 1];\n    return path;\n};\n\ndrawing.smoothclosed = function(pts, smoothness) {\n    if(pts.length < 3) { return 'M' + pts.join('L') + 'Z'; }\n    var path = 'M' + pts[0];\n    var pLast = pts.length - 1;\n    var tangents = [makeTangent(pts[pLast], pts[0], pts[1], smoothness)];\n    var i;\n    for(i = 1; i < pLast; i++) {\n        tangents.push(makeTangent(pts[i - 1], pts[i], pts[i + 1], smoothness));\n    }\n    tangents.push(\n        makeTangent(pts[pLast - 1], pts[pLast], pts[0], smoothness)\n    );\n\n    for(i = 1; i <= pLast; i++) {\n        path += 'C' + tangents[i - 1][1] + ' ' + tangents[i][0] + ' ' + pts[i];\n    }\n    path += 'C' + tangents[pLast][1] + ' ' + tangents[0][0] + ' ' + pts[0] + 'Z';\n    return path;\n};\n\nfunction makeTangent(prevpt, thispt, nextpt, smoothness) {\n    var d1x = prevpt[0] - thispt[0];\n    var d1y = prevpt[1] - thispt[1];\n    var d2x = nextpt[0] - thispt[0];\n    var d2y = nextpt[1] - thispt[1];\n    var d1a = Math.pow(d1x * d1x + d1y * d1y, CatmullRomExp / 2);\n    var d2a = Math.pow(d2x * d2x + d2y * d2y, CatmullRomExp / 2);\n    var numx = (d2a * d2a * d1x - d1a * d1a * d2x) * smoothness;\n    var numy = (d2a * d2a * d1y - d1a * d1a * d2y) * smoothness;\n    var denom1 = 3 * d2a * (d1a + d2a);\n    var denom2 = 3 * d1a * (d1a + d2a);\n    return [\n        [\n            d3.round(thispt[0] + (denom1 && numx / denom1), 2),\n            d3.round(thispt[1] + (denom1 && numy / denom1), 2)\n        ], [\n            d3.round(thispt[0] - (denom2 && numx / denom2), 2),\n            d3.round(thispt[1] - (denom2 && numy / denom2), 2)\n        ]\n    ];\n}\n\n// step paths - returns a generator function for paths\n// with the given step shape\nvar STEPPATH = {\n    hv: function(p0, p1) {\n        return 'H' + d3.round(p1[0], 2) + 'V' + d3.round(p1[1], 2);\n    },\n    vh: function(p0, p1) {\n        return 'V' + d3.round(p1[1], 2) + 'H' + d3.round(p1[0], 2);\n    },\n    hvh: function(p0, p1) {\n        return 'H' + d3.round((p0[0] + p1[0]) / 2, 2) + 'V' +\n            d3.round(p1[1], 2) + 'H' + d3.round(p1[0], 2);\n    },\n    vhv: function(p0, p1) {\n        return 'V' + d3.round((p0[1] + p1[1]) / 2, 2) + 'H' +\n            d3.round(p1[0], 2) + 'V' + d3.round(p1[1], 2);\n    }\n};\nvar STEPLINEAR = function(p0, p1) {\n    return 'L' + d3.round(p1[0], 2) + ',' + d3.round(p1[1], 2);\n};\ndrawing.steps = function(shape) {\n    var onestep = STEPPATH[shape] || STEPLINEAR;\n    return function(pts) {\n        var path = 'M' + d3.round(pts[0][0], 2) + ',' + d3.round(pts[0][1], 2);\n        for(var i = 1; i < pts.length; i++) {\n            path += onestep(pts[i - 1], pts[i]);\n        }\n        return path;\n    };\n};\n\n// off-screen svg render testing element, shared by the whole page\n// uses the id 'js-plotly-tester' and stores it in drawing.tester\ndrawing.makeTester = function() {\n    var tester = Lib.ensureSingleById(d3.select('body'), 'svg', 'js-plotly-tester', function(s) {\n        s.attr(xmlnsNamespaces.svgAttrs)\n            .style({\n                position: 'absolute',\n                left: '-10000px',\n                top: '-10000px',\n                width: '9000px',\n                height: '9000px',\n                'z-index': '1'\n            });\n    });\n\n    // browsers differ on how they describe the bounding rect of\n    // the svg if its contents spill over... so make a 1x1px\n    // reference point we can measure off of.\n    var testref = Lib.ensureSingle(tester, 'path', 'js-reference-point', function(s) {\n        s.attr('d', 'M0,0H1V1H0Z')\n            .style({\n                'stroke-width': 0,\n                fill: 'black'\n            });\n    });\n\n    drawing.tester = tester;\n    drawing.testref = testref;\n};\n\n/*\n * use our offscreen tester to get a clientRect for an element,\n * in a reference frame where it isn't translated (or transformed) and\n * its anchor point is at (0,0)\n * always returns a copy of the bbox, so the caller can modify it safely\n *\n * @param {SVGElement} node: the element to measure. If possible this should be\n *   a  or MathJax  element that's already passed through\n *   `convertToTspans` because in that case we can cache the results, but it's\n *   possible to pass in any svg element.\n *\n * @param {boolean} inTester: is this element already in `drawing.tester`?\n *   If you are measuring a dummy element, rather than one you really intend\n *   to use on the plot, making it in `drawing.tester` in the first place\n *   allows us to test faster because it cuts out cloning and appending it.\n *\n * @param {string} hash: for internal use only, if we already know the cache key\n *   for this element beforehand.\n *\n * @return {object}: a plain object containing the width, height, left, right,\n *   top, and bottom of `node`\n */\ndrawing.savedBBoxes = {};\nvar savedBBoxesCount = 0;\nvar maxSavedBBoxes = 10000;\n\ndrawing.bBox = function(node, inTester, hash) {\n    /*\n     * Cache elements we've already measured so we don't have to\n     * remeasure the same thing many times\n     * We have a few bBox callers though who pass a node larger than\n     * a  or a MathJax , such as an axis group containing many labels.\n     * These will not generate a hash (unless we figure out an appropriate\n     * hash key for them) and thus we will not hash them.\n     */\n    if(!hash) hash = nodeHash(node);\n    var out;\n    if(hash) {\n        out = drawing.savedBBoxes[hash];\n        if(out) return Lib.extendFlat({}, out);\n    } else if(node.childNodes.length === 1) {\n        /*\n         * If we have only one child element, which is itself hashable, make\n         * a new hash from this element plus its x,y,transform\n         * These bounding boxes *include* x,y,transform - mostly for use by\n         * callers trying to avoid overlaps (ie titles)\n         */\n        var innerNode = node.childNodes[0];\n\n        hash = nodeHash(innerNode);\n        if(hash) {\n            var x = +innerNode.getAttribute('x') || 0;\n            var y = +innerNode.getAttribute('y') || 0;\n            var transform = innerNode.getAttribute('transform');\n\n            if(!transform) {\n                // in this case, just varying x and y, don't bother caching\n                // the final bBox because the alteration is quick.\n                var innerBB = drawing.bBox(innerNode, false, hash);\n                if(x) {\n                    innerBB.left += x;\n                    innerBB.right += x;\n                }\n                if(y) {\n                    innerBB.top += y;\n                    innerBB.bottom += y;\n                }\n                return innerBB;\n            }\n            /*\n             * else we have a transform - rather than make a complicated\n             * (and error-prone and probably slow) transform parser/calculator,\n             * just continue on calculating the boundingClientRect of the group\n             * and use the new composite hash to cache it.\n             * That said, `innerNode.transform.baseVal` is an array of\n             * `SVGTransform` objects, that *do* seem to have a nice matrix\n             * multiplication interface that we could use to avoid making\n             * another getBoundingClientRect call...\n             */\n            hash += '~' + x + '~' + y + '~' + transform;\n\n            out = drawing.savedBBoxes[hash];\n            if(out) return Lib.extendFlat({}, out);\n        }\n    }\n    var testNode, tester;\n    if(inTester) {\n        testNode = node;\n    } else {\n        tester = drawing.tester.node();\n\n        // copy the node to test into the tester\n        testNode = node.cloneNode(true);\n        tester.appendChild(testNode);\n    }\n\n    // standardize its position (and newline tspans if any)\n    d3.select(testNode)\n        .attr('transform', null)\n        .call(svgTextUtils.positionText, 0, 0);\n\n    var testRect = testNode.getBoundingClientRect();\n    var refRect = drawing.testref\n        .node()\n        .getBoundingClientRect();\n\n    if(!inTester) tester.removeChild(testNode);\n\n    var bb = {\n        height: testRect.height,\n        width: testRect.width,\n        left: testRect.left - refRect.left,\n        top: testRect.top - refRect.top,\n        right: testRect.right - refRect.left,\n        bottom: testRect.bottom - refRect.top\n    };\n\n    // make sure we don't have too many saved boxes,\n    // or a long session could overload on memory\n    // by saving boxes for long-gone elements\n    if(savedBBoxesCount >= maxSavedBBoxes) {\n        drawing.savedBBoxes = {};\n        savedBBoxesCount = 0;\n    }\n\n    // cache this bbox\n    if(hash) drawing.savedBBoxes[hash] = bb;\n    savedBBoxesCount++;\n\n    return Lib.extendFlat({}, bb);\n};\n\n// capture everything about a node (at least in our usage) that\n// impacts its bounding box, given that bBox clears x, y, and transform\nfunction nodeHash(node) {\n    var inputText = node.getAttribute('data-unformatted');\n    if(inputText === null) return;\n    return inputText +\n        node.getAttribute('data-math') +\n        node.getAttribute('text-anchor') +\n        node.getAttribute('style');\n}\n\n/**\n * Set clipPath URL in a way that work for all situations.\n *\n * In details, graphs on pages with  HTML tags need to prepend\n * the clip path ids with the page's base url EXCEPT during toImage exports.\n *\n * @param {d3 selection} s : node to add clip-path attribute\n * @param {string} localId : local clip-path (w/o base url) id\n * @param {DOM element || object} gd\n * - context._baseUrl {string}\n * - context._exportedPlot {boolean}\n */\ndrawing.setClipUrl = function(s, localId, gd) {\n    s.attr('clip-path', getFullUrl(localId, gd));\n};\n\nfunction getFullUrl(localId, gd) {\n    if(!localId) return null;\n\n    var context = gd._context;\n    var baseUrl = context._exportedPlot ? '' : (context._baseUrl || '');\n    return 'url(\\'' + baseUrl + '#' + localId + '\\')';\n}\n\ndrawing.getTranslate = function(element) {\n    // Note the separator [^\\d] between x and y in this regex\n    // We generally use ',' but IE will convert it to ' '\n    var re = /.*\\btranslate\\((-?\\d*\\.?\\d*)[^-\\d]*(-?\\d*\\.?\\d*)[^\\d].*/;\n    var getter = element.attr ? 'attr' : 'getAttribute';\n    var transform = element[getter]('transform') || '';\n\n    var translate = transform.replace(re, function(match, p1, p2) {\n        return [p1, p2].join(' ');\n    })\n    .split(' ');\n\n    return {\n        x: +translate[0] || 0,\n        y: +translate[1] || 0\n    };\n};\n\ndrawing.setTranslate = function(element, x, y) {\n    var re = /(\\btranslate\\(.*?\\);?)/;\n    var getter = element.attr ? 'attr' : 'getAttribute';\n    var setter = element.attr ? 'attr' : 'setAttribute';\n    var transform = element[getter]('transform') || '';\n\n    x = x || 0;\n    y = y || 0;\n\n    transform = transform.replace(re, '').trim();\n    transform += ' translate(' + x + ', ' + y + ')';\n    transform = transform.trim();\n\n    element[setter]('transform', transform);\n\n    return transform;\n};\n\ndrawing.getScale = function(element) {\n    var re = /.*\\bscale\\((\\d*\\.?\\d*)[^\\d]*(\\d*\\.?\\d*)[^\\d].*/;\n    var getter = element.attr ? 'attr' : 'getAttribute';\n    var transform = element[getter]('transform') || '';\n\n    var translate = transform.replace(re, function(match, p1, p2) {\n        return [p1, p2].join(' ');\n    })\n    .split(' ');\n\n    return {\n        x: +translate[0] || 1,\n        y: +translate[1] || 1\n    };\n};\n\ndrawing.setScale = function(element, x, y) {\n    var re = /(\\bscale\\(.*?\\);?)/;\n    var getter = element.attr ? 'attr' : 'getAttribute';\n    var setter = element.attr ? 'attr' : 'setAttribute';\n    var transform = element[getter]('transform') || '';\n\n    x = x || 1;\n    y = y || 1;\n\n    transform = transform.replace(re, '').trim();\n    transform += ' scale(' + x + ', ' + y + ')';\n    transform = transform.trim();\n\n    element[setter]('transform', transform);\n\n    return transform;\n};\n\nvar SCALE_RE = /\\s*sc.*/;\n\ndrawing.setPointGroupScale = function(selection, xScale, yScale) {\n    xScale = xScale || 1;\n    yScale = yScale || 1;\n\n    if(!selection) return;\n\n    // The same scale transform for every point:\n    var scale = (xScale === 1 && yScale === 1) ?\n        '' :\n        ' scale(' + xScale + ',' + yScale + ')';\n\n    selection.each(function() {\n        var t = (this.getAttribute('transform') || '').replace(SCALE_RE, '');\n        t += scale;\n        t = t.trim();\n        this.setAttribute('transform', t);\n    });\n};\n\nvar TEXT_POINT_LAST_TRANSLATION_RE = /translate\\([^)]*\\)\\s*$/;\n\ndrawing.setTextPointsScale = function(selection, xScale, yScale) {\n    if(!selection) return;\n\n    selection.each(function() {\n        var transforms;\n        var el = d3.select(this);\n        var text = el.select('text');\n\n        if(!text.node()) return;\n\n        var x = parseFloat(text.attr('x') || 0);\n        var y = parseFloat(text.attr('y') || 0);\n\n        var existingTransform = (el.attr('transform') || '').match(TEXT_POINT_LAST_TRANSLATION_RE);\n\n        if(xScale === 1 && yScale === 1) {\n            transforms = [];\n        } else {\n            transforms = [\n                'translate(' + x + ',' + y + ')',\n                'scale(' + xScale + ',' + yScale + ')',\n                'translate(' + (-x) + ',' + (-y) + ')',\n            ];\n        }\n\n        if(existingTransform) {\n            transforms.push(existingTransform);\n        }\n\n        el.attr('transform', transforms.join(' '));\n    });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar isUnifiedHover = require('../../components/fx/helpers').isUnifiedHover;\nvar handleHoverModeDefaults = require('../../components/fx/hovermode_defaults');\nvar Template = require('../../plot_api/plot_template');\nvar basePlotLayoutAttributes = require('../layout_attributes');\n\nvar layoutAttributes = require('./layout_attributes');\nvar handleTypeDefaults = require('./type_defaults');\nvar handleAxisDefaults = require('./axis_defaults');\nvar handleConstraintDefaults = require('./constraints').handleConstraintDefaults;\nvar handlePositionDefaults = require('./position_defaults');\n\nvar axisIds = require('./axis_ids');\nvar id2name = axisIds.id2name;\nvar name2id = axisIds.name2id;\n\nvar AX_ID_PATTERN = require('./constants').AX_ID_PATTERN;\n\nvar Registry = require('../../registry');\nvar traceIs = Registry.traceIs;\nvar getComponentMethod = Registry.getComponentMethod;\n\nfunction appendList(cont, k, item) {\n    if(Array.isArray(cont[k])) cont[k].push(item);\n    else cont[k] = [item];\n}\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n    var ax2traces = {};\n    var xaMayHide = {};\n    var yaMayHide = {};\n    var xaMustDisplay = {};\n    var yaMustDisplay = {};\n    var yaMustNotReverse = {};\n    var yaMayReverse = {};\n    var axHasImage = {};\n    var outerTicks = {};\n    var noGrids = {};\n    var i, j;\n\n    // look for axes in the data\n    for(i = 0; i < fullData.length; i++) {\n        var trace = fullData[i];\n        if(!traceIs(trace, 'cartesian') && !traceIs(trace, 'gl2d')) continue;\n\n        var xaName;\n        if(trace.xaxis) {\n            xaName = id2name(trace.xaxis);\n            appendList(ax2traces, xaName, trace);\n        } else if(trace.xaxes) {\n            for(j = 0; j < trace.xaxes.length; j++) {\n                appendList(ax2traces, id2name(trace.xaxes[j]), trace);\n            }\n        }\n\n        var yaName;\n        if(trace.yaxis) {\n            yaName = id2name(trace.yaxis);\n            appendList(ax2traces, yaName, trace);\n        } else if(trace.yaxes) {\n            for(j = 0; j < trace.yaxes.length; j++) {\n                appendList(ax2traces, id2name(trace.yaxes[j]), trace);\n            }\n        }\n\n        // logic for funnels\n        if(trace.type === 'funnel') {\n            if(trace.orientation === 'h') {\n                if(xaName) xaMayHide[xaName] = true;\n                if(yaName) yaMayReverse[yaName] = true;\n            } else {\n                if(yaName) yaMayHide[yaName] = true;\n            }\n        } else if(trace.type === 'image') {\n            if(yaName) axHasImage[yaName] = true;\n            if(xaName) axHasImage[xaName] = true;\n        } else {\n            if(yaName) {\n                yaMustDisplay[yaName] = true;\n                yaMustNotReverse[yaName] = true;\n            }\n\n            if(!traceIs(trace, 'carpet') || (trace.type === 'carpet' && !trace._cheater)) {\n                if(xaName) xaMustDisplay[xaName] = true;\n            }\n        }\n\n        // Two things trigger axis visibility:\n        // 1. is not carpet\n        // 2. carpet that's not cheater\n\n        // The above check for definitely-not-cheater is not adequate. This\n        // second list tracks which axes *could* be a cheater so that the\n        // full condition triggering hiding is:\n        //   *could* be a cheater and *is not definitely visible*\n        if(trace.type === 'carpet' && trace._cheater) {\n            if(xaName) xaMayHide[xaName] = true;\n        }\n\n        // check for default formatting tweaks\n        if(traceIs(trace, '2dMap')) {\n            outerTicks[xaName] = true;\n            outerTicks[yaName] = true;\n        }\n\n        if(traceIs(trace, 'oriented')) {\n            var positionAxis = trace.orientation === 'h' ? yaName : xaName;\n            noGrids[positionAxis] = true;\n        }\n    }\n\n    var subplots = layoutOut._subplots;\n    var xIds = subplots.xaxis;\n    var yIds = subplots.yaxis;\n    var xNames = Lib.simpleMap(xIds, id2name);\n    var yNames = Lib.simpleMap(yIds, id2name);\n    var axNames = xNames.concat(yNames);\n\n    // plot_bgcolor only makes sense if there's a (2D) plot!\n    // TODO: bgcolor for each subplot, to inherit from the main one\n    var plotBgColor = Color.background;\n    if(xIds.length && yIds.length) {\n        plotBgColor = Lib.coerce(layoutIn, layoutOut, basePlotLayoutAttributes, 'plot_bgcolor');\n    }\n\n    var bgColor = Color.combine(plotBgColor, layoutOut.paper_bgcolor);\n\n    // name of single axis (e.g. 'xaxis', 'yaxis2')\n    var axName;\n    // id of single axis (e.g. 'y', 'x5')\n    var axId;\n    // 'x' or 'y'\n    var axLetter;\n    // input layout axis container\n    var axLayoutIn;\n    // full layout axis container\n    var axLayoutOut;\n\n    function newAxLayoutOut() {\n        var traces = ax2traces[axName] || [];\n        axLayoutOut._traceIndices = traces.map(function(t) { return t._expandedIndex; });\n        axLayoutOut._annIndices = [];\n        axLayoutOut._shapeIndices = [];\n        axLayoutOut._imgIndices = [];\n        axLayoutOut._subplotsWith = [];\n        axLayoutOut._counterAxes = [];\n        axLayoutOut._name = axLayoutOut._attr = axName;\n        axLayoutOut._id = axId;\n    }\n\n    function coerce(attr, dflt) {\n        return Lib.coerce(axLayoutIn, axLayoutOut, layoutAttributes, attr, dflt);\n    }\n\n    function coerce2(attr, dflt) {\n        return Lib.coerce2(axLayoutIn, axLayoutOut, layoutAttributes, attr, dflt);\n    }\n\n    function getCounterAxes(axLetter) {\n        return (axLetter === 'x') ? yIds : xIds;\n    }\n\n    function getOverlayableAxes(axLetter, axName) {\n        var list = (axLetter === 'x') ? xNames : yNames;\n        var out = [];\n\n        for(var j = 0; j < list.length; j++) {\n            var axName2 = list[j];\n\n            if(axName2 !== axName && !(layoutIn[axName2] || {}).overlaying) {\n                out.push(name2id(axName2));\n            }\n        }\n\n        return out;\n    }\n\n    // list of available counter axis names\n    var counterAxes = {x: getCounterAxes('x'), y: getCounterAxes('y')};\n    // list of all x AND y axis ids\n    var allAxisIds = counterAxes.x.concat(counterAxes.y);\n    // lookup and list of axis ids that axes in axNames have a reference to,\n    // even though they are missing from allAxisIds\n    var missingMatchedAxisIdsLookup = {};\n    var missingMatchedAxisIds = [];\n\n    // fill in 'missing' axis lookup when an axis is set to match an axis\n    // not part of the allAxisIds list, save axis type so that we can propagate\n    // it to the missing axes\n    function addMissingMatchedAxis() {\n        var matchesIn = axLayoutIn.matches;\n        if(AX_ID_PATTERN.test(matchesIn) && allAxisIds.indexOf(matchesIn) === -1) {\n            missingMatchedAxisIdsLookup[matchesIn] = axLayoutIn.type;\n            missingMatchedAxisIds = Object.keys(missingMatchedAxisIdsLookup);\n        }\n    }\n\n    var hovermode = handleHoverModeDefaults(layoutIn, layoutOut, fullData);\n    var unifiedHover = isUnifiedHover(hovermode);\n\n    // first pass creates the containers, determines types, and handles most of the settings\n    for(i = 0; i < axNames.length; i++) {\n        axName = axNames[i];\n        axId = name2id(axName);\n        axLetter = axName.charAt(0);\n\n        if(!Lib.isPlainObject(layoutIn[axName])) {\n            layoutIn[axName] = {};\n        }\n\n        axLayoutIn = layoutIn[axName];\n        axLayoutOut = Template.newContainer(layoutOut, axName, axLetter + 'axis');\n        newAxLayoutOut();\n\n        var visibleDflt =\n            (axLetter === 'x' && !xaMustDisplay[axName] && xaMayHide[axName]) ||\n            (axLetter === 'y' && !yaMustDisplay[axName] && yaMayHide[axName]);\n\n        var reverseDflt =\n            (axLetter === 'y' &&\n              (\n                (!yaMustNotReverse[axName] && yaMayReverse[axName]) ||\n                axHasImage[axName]\n              ));\n\n        var defaultOptions = {\n            letter: axLetter,\n            font: layoutOut.font,\n            outerTicks: outerTicks[axName],\n            showGrid: !noGrids[axName],\n            data: ax2traces[axName] || [],\n            bgColor: bgColor,\n            calendar: layoutOut.calendar,\n            automargin: true,\n            visibleDflt: visibleDflt,\n            reverseDflt: reverseDflt,\n            splomStash: ((layoutOut._splomAxes || {})[axLetter] || {})[axId]\n        };\n\n        coerce('uirevision', layoutOut.uirevision);\n\n        handleTypeDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions);\n        handleAxisDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions, layoutOut);\n\n        var unifiedSpike = unifiedHover && axLetter === hovermode.charAt(0);\n        var spikecolor = coerce2('spikecolor', unifiedHover ? axLayoutOut.color : undefined);\n        var spikethickness = coerce2('spikethickness', unifiedHover ? 1.5 : undefined);\n        var spikedash = coerce2('spikedash', unifiedHover ? 'dot' : undefined);\n        var spikemode = coerce2('spikemode', unifiedHover ? 'across' : undefined);\n        var spikesnap = coerce2('spikesnap', unifiedHover ? 'hovered data' : undefined);\n        var showSpikes = coerce('showspikes', !!unifiedSpike || !!spikecolor || !!spikethickness || !!spikedash || !!spikemode || !!spikesnap);\n\n        if(!showSpikes) {\n            delete axLayoutOut.spikecolor;\n            delete axLayoutOut.spikethickness;\n            delete axLayoutOut.spikedash;\n            delete axLayoutOut.spikemode;\n            delete axLayoutOut.spikesnap;\n        }\n\n        handlePositionDefaults(axLayoutIn, axLayoutOut, coerce, {\n            letter: axLetter,\n            counterAxes: counterAxes[axLetter],\n            overlayableAxes: getOverlayableAxes(axLetter, axName),\n            grid: layoutOut.grid\n        });\n\n        coerce('title.standoff');\n\n        addMissingMatchedAxis();\n\n        axLayoutOut._input = axLayoutIn;\n    }\n\n    // coerce the 'missing' axes\n    i = 0;\n    while(i < missingMatchedAxisIds.length) {\n        axId = missingMatchedAxisIds[i++];\n        axName = id2name(axId);\n        axLetter = axName.charAt(0);\n\n        if(!Lib.isPlainObject(layoutIn[axName])) {\n            layoutIn[axName] = {};\n        }\n\n        axLayoutIn = layoutIn[axName];\n        axLayoutOut = Template.newContainer(layoutOut, axName, axLetter + 'axis');\n        newAxLayoutOut();\n\n        var defaultOptions2 = {\n            letter: axLetter,\n            font: layoutOut.font,\n            outerTicks: outerTicks[axName],\n            showGrid: !noGrids[axName],\n            data: [],\n            bgColor: bgColor,\n            calendar: layoutOut.calendar,\n            automargin: true,\n            visibleDflt: false,\n            reverseDflt: false,\n            splomStash: ((layoutOut._splomAxes || {})[axLetter] || {})[axId]\n        };\n\n        coerce('uirevision', layoutOut.uirevision);\n\n        axLayoutOut.type = missingMatchedAxisIdsLookup[axId] || 'linear';\n\n        handleAxisDefaults(axLayoutIn, axLayoutOut, coerce, defaultOptions2, layoutOut);\n\n        handlePositionDefaults(axLayoutIn, axLayoutOut, coerce, {\n            letter: axLetter,\n            counterAxes: counterAxes[axLetter],\n            overlayableAxes: getOverlayableAxes(axLetter, axName),\n            grid: layoutOut.grid\n        });\n\n        coerce('fixedrange');\n\n        addMissingMatchedAxis();\n\n        axLayoutOut._input = axLayoutIn;\n    }\n\n    // quick second pass for range slider and selector defaults\n    var rangeSliderDefaults = getComponentMethod('rangeslider', 'handleDefaults');\n    var rangeSelectorDefaults = getComponentMethod('rangeselector', 'handleDefaults');\n\n    for(i = 0; i < xNames.length; i++) {\n        axName = xNames[i];\n        axLayoutIn = layoutIn[axName];\n        axLayoutOut = layoutOut[axName];\n\n        rangeSliderDefaults(layoutIn, layoutOut, axName);\n\n        if(axLayoutOut.type === 'date') {\n            rangeSelectorDefaults(\n                axLayoutIn,\n                axLayoutOut,\n                layoutOut,\n                yNames,\n                axLayoutOut.calendar\n            );\n        }\n\n        coerce('fixedrange');\n    }\n\n    for(i = 0; i < yNames.length; i++) {\n        axName = yNames[i];\n        axLayoutIn = layoutIn[axName];\n        axLayoutOut = layoutOut[axName];\n\n        var anchoredAxis = layoutOut[id2name(axLayoutOut.anchor)];\n\n        var fixedRangeDflt = getComponentMethod('rangeslider', 'isVisible')(anchoredAxis);\n\n        coerce('fixedrange', fixedRangeDflt);\n    }\n\n    // Finally, handle scale constraints and matching axes.\n    //\n    // We need to do this after all axes have coerced both `type`\n    // (so we link only axes of the same type) and\n    // `fixedrange` (so we can avoid linking from OR TO a fixed axis).\n\n    // sets of axes linked by `scaleanchor` along with the scaleratios compounded\n    // together, populated in handleConstraintDefaults\n    var constraintGroups = layoutOut._axisConstraintGroups = [];\n    // similar to _axisConstraintGroups, but for matching axes\n    var matchGroups = layoutOut._axisMatchGroups = [];\n    // make sure to include 'missing' axes here\n    var allAxisIdsIncludingMissing = allAxisIds.concat(missingMatchedAxisIds);\n    var axNamesIncludingMissing = axNames.concat(Lib.simpleMap(missingMatchedAxisIds, id2name));\n\n    for(i = 0; i < axNamesIncludingMissing.length; i++) {\n        axName = axNamesIncludingMissing[i];\n        axLetter = axName.charAt(0);\n        axLayoutIn = layoutIn[axName];\n        axLayoutOut = layoutOut[axName];\n\n        var scaleanchorDflt;\n        if(axLetter === 'y' && !axLayoutIn.hasOwnProperty('scaleanchor') && axHasImage[axName]) {\n            scaleanchorDflt = axLayoutOut.anchor;\n        } else {\n            scaleanchorDflt = undefined;\n        }\n\n        var constrainDflt;\n        if(!axLayoutIn.hasOwnProperty('constrain') && axHasImage[axName]) {\n            constrainDflt = 'domain';\n        } else {\n            constrainDflt = undefined;\n        }\n\n        handleConstraintDefaults(axLayoutIn, axLayoutOut, coerce, {\n            allAxisIds: allAxisIdsIncludingMissing,\n            layoutOut: layoutOut,\n            scaleanchorDflt: scaleanchorDflt,\n            constrainDflt: constrainDflt\n        });\n    }\n\n    for(i = 0; i < matchGroups.length; i++) {\n        var group = matchGroups[i];\n        var rng = null;\n        var autorange = null;\n\n        // find 'matching' range attrs\n        for(axId in group) {\n            axLayoutOut = layoutOut[id2name(axId)];\n            if(!axLayoutOut.matches) {\n                rng = axLayoutOut.range;\n                autorange = axLayoutOut.autorange;\n            }\n        }\n        // if `ax.matches` values are reciprocal,\n        // pick values of first axis in group\n        if(rng === null || autorange === null) {\n            for(axId in group) {\n                axLayoutOut = layoutOut[id2name(axId)];\n                rng = axLayoutOut.range;\n                autorange = axLayoutOut.autorange;\n                break;\n            }\n        }\n        // apply matching range attrs\n        for(axId in group) {\n            axLayoutOut = layoutOut[id2name(axId)];\n            if(axLayoutOut.matches) {\n                axLayoutOut.range = rng.slice();\n                axLayoutOut.autorange = autorange;\n            }\n            axLayoutOut._matchGroup = group;\n        }\n\n        // remove matching axis from scaleanchor constraint groups (for now)\n        if(constraintGroups.length) {\n            for(axId in group) {\n                for(j = 0; j < constraintGroups.length; j++) {\n                    var group2 = constraintGroups[j];\n                    for(var axId2 in group2) {\n                        if(axId === axId2) {\n                            Lib.warn('Axis ' + axId2 + ' is set with both ' +\n                                'a *scaleanchor* and *matches* constraint; ' +\n                                'ignoring the scale constraint.');\n\n                            delete group2[axId2];\n                            if(Object.keys(group2).length < 2) {\n                                constraintGroups.splice(j, 1);\n                            }\n                        }\n                    }\n                }\n            }\n        }\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\n/**\n * convert a string s (such as 'xaxis.range[0]')\n * representing a property of nested object into set and get methods\n * also return the string and object so we don't have to keep track of them\n * allows [-1] for an array index, to set a property inside all elements\n * of an array\n * eg if obj = {arr: [{a: 1}, {a: 2}]}\n * you can do p = nestedProperty(obj, 'arr[-1].a')\n * but you cannot set the array itself this way, to do that\n * just set the whole array.\n * eg if obj = {arr: [1, 2, 3]}\n * you can't do nestedProperty(obj, 'arr[-1]').set(5)\n * but you can do nestedProperty(obj, 'arr').set([5, 5, 5])\n */\nmodule.exports = function nestedProperty(container, propStr) {\n    if(isNumeric(propStr)) propStr = String(propStr);\n    else if(typeof propStr !== 'string' ||\n            propStr.substr(propStr.length - 4) === '[-1]') {\n        throw 'bad property string';\n    }\n\n    var j = 0;\n    var propParts = propStr.split('.');\n    var indexed;\n    var indices;\n    var i;\n\n    // check for parts of the nesting hierarchy that are numbers (ie array elements)\n    while(j < propParts.length) {\n        // look for non-bracket chars, then any number of [##] blocks\n        indexed = String(propParts[j]).match(/^([^\\[\\]]*)((\\[\\-?[0-9]*\\])+)$/);\n        if(indexed) {\n            if(indexed[1]) propParts[j] = indexed[1];\n            // allow propStr to start with bracketed array indices\n            else if(j === 0) propParts.splice(0, 1);\n            else throw 'bad property string';\n\n            indices = indexed[2]\n                .substr(1, indexed[2].length - 2)\n                .split('][');\n\n            for(i = 0; i < indices.length; i++) {\n                j++;\n                propParts.splice(j, 0, Number(indices[i]));\n            }\n        }\n        j++;\n    }\n\n    if(typeof container !== 'object') {\n        return badContainer(container, propStr, propParts);\n    }\n\n    return {\n        set: npSet(container, propParts, propStr),\n        get: npGet(container, propParts),\n        astr: propStr,\n        parts: propParts,\n        obj: container\n    };\n};\n\nfunction npGet(cont, parts) {\n    return function() {\n        var curCont = cont;\n        var curPart;\n        var allSame;\n        var out;\n        var i;\n        var j;\n\n        for(i = 0; i < parts.length - 1; i++) {\n            curPart = parts[i];\n            if(curPart === -1) {\n                allSame = true;\n                out = [];\n                for(j = 0; j < curCont.length; j++) {\n                    out[j] = npGet(curCont[j], parts.slice(i + 1))();\n                    if(out[j] !== out[0]) allSame = false;\n                }\n                return allSame ? out[0] : out;\n            }\n            if(typeof curPart === 'number' && !isArrayOrTypedArray(curCont)) {\n                return undefined;\n            }\n            curCont = curCont[curPart];\n            if(typeof curCont !== 'object' || curCont === null) {\n                return undefined;\n            }\n        }\n\n        // only hit this if parts.length === 1\n        if(typeof curCont !== 'object' || curCont === null) return undefined;\n\n        out = curCont[parts[i]];\n        if(out === null) return undefined;\n        return out;\n    };\n}\n\n/*\n * Can this value be deleted? We can delete `undefined`, and `null` except INSIDE an\n * *args* array.\n *\n * Previously we also deleted some `{}` and `[]`, in order to try and make set/unset\n * a net noop; but this causes far more complication than it's worth, and still had\n * lots of exceptions. See https://github.com/plotly/plotly.js/issues/1410\n *\n * *args* arrays get passed directly to API methods and we should respect null if\n * the user put it there, but otherwise null is deleted as we use it as code\n * in restyle/relayout/update for \"delete this value\" whereas undefined means\n * \"ignore this edit\"\n */\nvar ARGS_PATTERN = /(^|\\.)args\\[/;\nfunction isDeletable(val, propStr) {\n    return (val === undefined) || (val === null && !propStr.match(ARGS_PATTERN));\n}\n\nfunction npSet(cont, parts, propStr) {\n    return function(val) {\n        var curCont = cont;\n        var propPart = '';\n        var containerLevels = [[cont, propPart]];\n        var toDelete = isDeletable(val, propStr);\n        var curPart;\n        var i;\n\n        for(i = 0; i < parts.length - 1; i++) {\n            curPart = parts[i];\n\n            if(typeof curPart === 'number' && !isArrayOrTypedArray(curCont)) {\n                throw 'array index but container is not an array';\n            }\n\n            // handle special -1 array index\n            if(curPart === -1) {\n                toDelete = !setArrayAll(curCont, parts.slice(i + 1), val, propStr);\n                if(toDelete) break;\n                else return;\n            }\n\n            if(!checkNewContainer(curCont, curPart, parts[i + 1], toDelete)) {\n                break;\n            }\n\n            curCont = curCont[curPart];\n\n            if(typeof curCont !== 'object' || curCont === null) {\n                throw 'container is not an object';\n            }\n\n            propPart = joinPropStr(propPart, curPart);\n\n            containerLevels.push([curCont, propPart]);\n        }\n\n        if(toDelete) {\n            if(i === parts.length - 1) {\n                delete curCont[parts[i]];\n\n                // The one bit of pruning we still do: drop `undefined` from the end of arrays.\n                // In case someone has already unset previous items, continue until we hit a\n                // non-undefined value.\n                if(Array.isArray(curCont) && +parts[i] === curCont.length - 1) {\n                    while(curCont.length && curCont[curCont.length - 1] === undefined) {\n                        curCont.pop();\n                    }\n                }\n            }\n        } else curCont[parts[i]] = val;\n    };\n}\n\nfunction joinPropStr(propStr, newPart) {\n    var toAdd = newPart;\n    if(isNumeric(newPart)) toAdd = '[' + newPart + ']';\n    else if(propStr) toAdd = '.' + newPart;\n\n    return propStr + toAdd;\n}\n\n// handle special -1 array index\nfunction setArrayAll(containerArray, innerParts, val, propStr) {\n    var arrayVal = isArrayOrTypedArray(val);\n    var allSet = true;\n    var thisVal = val;\n    var thisPropStr = propStr.replace('-1', 0);\n    var deleteThis = arrayVal ? false : isDeletable(val, thisPropStr);\n    var firstPart = innerParts[0];\n    var i;\n\n    for(i = 0; i < containerArray.length; i++) {\n        thisPropStr = propStr.replace('-1', i);\n        if(arrayVal) {\n            thisVal = val[i % val.length];\n            deleteThis = isDeletable(thisVal, thisPropStr);\n        }\n        if(deleteThis) allSet = false;\n        if(!checkNewContainer(containerArray, i, firstPart, deleteThis)) {\n            continue;\n        }\n        npSet(containerArray[i], innerParts, propStr.replace('-1', i))(thisVal);\n    }\n    return allSet;\n}\n\n/**\n * make new sub-container as needed.\n * returns false if there's no container and none is needed\n * because we're only deleting an attribute\n */\nfunction checkNewContainer(container, part, nextPart, toDelete) {\n    if(container[part] === undefined) {\n        if(toDelete) return false;\n\n        if(typeof nextPart === 'number') container[part] = [];\n        else container[part] = {};\n    }\n    return true;\n}\n\nfunction badContainer(container, propStr, propParts) {\n    return {\n        set: function() { throw 'bad container'; },\n        get: function() {},\n        astr: propStr,\n        parts: propParts,\n        obj: container\n    };\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar plots = require('../../plots/plots');\n\nexports.name = 'pie';\n\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n    plots.plotBasePlot(exports.name, gd, traces, transitionOpts, makeOnCompleteCallback);\n};\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n    plots.cleanBasePlot(exports.name, newFullData, newFullLayout, oldFullData, oldFullLayout);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../registry');\n\nexports.getDelay = function(fullLayout) {\n    if(!fullLayout._has) return 0;\n\n    return (\n        fullLayout._has('gl3d') ||\n        fullLayout._has('gl2d') ||\n        fullLayout._has('mapbox')\n    ) ? 500 : 0;\n};\n\nexports.getRedrawFunc = function(gd) {\n    return function() {\n        var fullLayout = gd._fullLayout || {};\n        var hasPolar = fullLayout._has && fullLayout._has('polar');\n        var hasLegacyPolar = !hasPolar && gd.data && gd.data[0] && gd.data[0].r;\n\n        if(!hasLegacyPolar) {\n            Registry.getComponentMethod('colorbar', 'draw')(gd);\n        }\n    };\n};\n\nexports.encodeSVG = function(svg) {\n    return 'data:image/svg+xml,' + encodeURIComponent(svg);\n};\n\nexports.encodeJSON = function(json) {\n    return 'data:application/json,' + encodeURIComponent(json);\n};\n\nvar DOM_URL = window.URL || window.webkitURL;\n\nexports.createObjectURL = function(blob) {\n    return DOM_URL.createObjectURL(blob);\n};\n\nexports.revokeObjectURL = function(url) {\n    return DOM_URL.revokeObjectURL(url);\n};\n\nexports.createBlob = function(url, format) {\n    if(format === 'svg') {\n        return new window.Blob([url], {type: 'image/svg+xml;charset=utf-8'});\n    } else if(format === 'full-json') {\n        return new window.Blob([url], {type: 'application/json;charset=utf-8'});\n    } else {\n        var binary = fixBinary(window.atob(url));\n        return new window.Blob([binary], {type: 'image/' + format});\n    }\n};\n\nexports.octetStream = function(s) {\n    document.location.href = 'data:application/octet-stream' + s;\n};\n\n// Taken from https://bl.ocks.org/nolanlawson/0eac306e4dac2114c752\nfunction fixBinary(b) {\n    var len = b.length;\n    var buf = new ArrayBuffer(len);\n    var arr = new Uint8Array(buf);\n    for(var i = 0; i < len; i++) {\n        arr[i] = b.charCodeAt(i);\n    }\n    return buf;\n}\n\nexports.IMAGE_URL_PREFIX = /^data:image\\/\\w+;base64,/;\n\nexports.MSG_IE_BAD_FORMAT = 'Sorry IE does not support downloading from canvas. Try {format:\\'svg\\'} instead.';\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n/*\n * opts: object of flags to control features not all text users support\n *   noSelect: caller does not support selected/unselected attribute containers\n */\nmodule.exports = function(traceIn, traceOut, layout, coerce, opts) {\n    opts = opts || {};\n\n    coerce('textposition');\n    Lib.coerceFont(coerce, 'textfont', layout.font);\n\n    if(!opts.noSelect) {\n        coerce('selected.textfont.color');\n        coerce('unselected.textfont.color');\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar cleanTicks = require('./clean_ticks');\n\nmodule.exports = function handleTickValueDefaults(containerIn, containerOut, coerce, axType) {\n    function readInput(attr) {\n        var v = containerIn[attr];\n        return (\n            v !== undefined\n        ) ? v : (containerOut._template || {})[attr];\n    }\n\n    var _tick0 = readInput('tick0');\n    var _dtick = readInput('dtick');\n    var _tickvals = readInput('tickvals');\n    var _tickmode = readInput('tickmode');\n    var tickmode;\n\n    if(_tickmode === 'array' &&\n            (axType === 'log' || axType === 'date')) {\n        tickmode = containerOut.tickmode = 'auto';\n    } else {\n        var tickmodeDefault = Array.isArray(_tickvals) ? 'array' :\n            _dtick ? 'linear' :\n            'auto';\n        tickmode = coerce('tickmode', tickmodeDefault);\n    }\n\n    if(tickmode === 'auto') coerce('nticks');\n    else if(tickmode === 'linear') {\n        // dtick is usually a positive number, but there are some\n        // special strings available for log or date axes\n        // tick0 also has special logic\n        var dtick = containerOut.dtick = cleanTicks.dtick(\n            _dtick, axType);\n        containerOut.tick0 = cleanTicks.tick0(\n            _tick0, axType, containerOut.calendar, dtick);\n    } else if(axType !== 'multicategory') {\n        var tickvals = coerce('tickvals');\n        if(tickvals === undefined) containerOut.tickmode = 'auto';\n        else coerce('ticktext');\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * Clear responsive handlers (if any).\n *\n * @param {DOM node or object} gd : graph div object\n */\nmodule.exports = function clearResponsive(gd) {\n    if(gd._responsiveChartHandler) {\n        window.removeEventListener('resize', gd._responsiveChartHandler);\n        delete gd._responsiveChartHandler;\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar tinycolor = require('tinycolor2');\nvar isNumeric = require('fast-isnumeric');\n\nvar color = module.exports = {};\n\nvar colorAttrs = require('./attributes');\ncolor.defaults = colorAttrs.defaults;\nvar defaultLine = color.defaultLine = colorAttrs.defaultLine;\ncolor.lightLine = colorAttrs.lightLine;\nvar background = color.background = colorAttrs.background;\n\n/*\n * tinyRGB: turn a tinycolor into an rgb string, but\n * unlike the built-in tinycolor.toRgbString this never includes alpha\n */\ncolor.tinyRGB = function(tc) {\n    var c = tc.toRgb();\n    return 'rgb(' + Math.round(c.r) + ', ' +\n        Math.round(c.g) + ', ' + Math.round(c.b) + ')';\n};\n\ncolor.rgb = function(cstr) { return color.tinyRGB(tinycolor(cstr)); };\n\ncolor.opacity = function(cstr) { return cstr ? tinycolor(cstr).getAlpha() : 0; };\n\ncolor.addOpacity = function(cstr, op) {\n    var c = tinycolor(cstr).toRgb();\n    return 'rgba(' + Math.round(c.r) + ', ' +\n        Math.round(c.g) + ', ' + Math.round(c.b) + ', ' + op + ')';\n};\n\n// combine two colors into one apparent color\n// if back has transparency or is missing,\n// color.background is assumed behind it\ncolor.combine = function(front, back) {\n    var fc = tinycolor(front).toRgb();\n    if(fc.a === 1) return tinycolor(front).toRgbString();\n\n    var bc = tinycolor(back || background).toRgb();\n    var bcflat = bc.a === 1 ? bc : {\n        r: 255 * (1 - bc.a) + bc.r * bc.a,\n        g: 255 * (1 - bc.a) + bc.g * bc.a,\n        b: 255 * (1 - bc.a) + bc.b * bc.a\n    };\n    var fcflat = {\n        r: bcflat.r * (1 - fc.a) + fc.r * fc.a,\n        g: bcflat.g * (1 - fc.a) + fc.g * fc.a,\n        b: bcflat.b * (1 - fc.a) + fc.b * fc.a\n    };\n    return tinycolor(fcflat).toRgbString();\n};\n\n/*\n * Create a color that contrasts with cstr.\n *\n * If cstr is a dark color, we lighten it; if it's light, we darken.\n *\n * If lightAmount / darkAmount are used, we adjust by these percentages,\n * otherwise we go all the way to white or black.\n */\ncolor.contrast = function(cstr, lightAmount, darkAmount) {\n    var tc = tinycolor(cstr);\n\n    if(tc.getAlpha() !== 1) tc = tinycolor(color.combine(cstr, background));\n\n    var newColor = tc.isDark() ?\n        (lightAmount ? tc.lighten(lightAmount) : background) :\n        (darkAmount ? tc.darken(darkAmount) : defaultLine);\n\n    return newColor.toString();\n};\n\ncolor.stroke = function(s, c) {\n    var tc = tinycolor(c);\n    s.style({'stroke': color.tinyRGB(tc), 'stroke-opacity': tc.getAlpha()});\n};\n\ncolor.fill = function(s, c) {\n    var tc = tinycolor(c);\n    s.style({\n        'fill': color.tinyRGB(tc),\n        'fill-opacity': tc.getAlpha()\n    });\n};\n\n// search container for colors with the deprecated rgb(fractions) format\n// and convert them to rgb(0-255 values)\ncolor.clean = function(container) {\n    if(!container || typeof container !== 'object') return;\n\n    var keys = Object.keys(container);\n    var i, j, key, val;\n\n    for(i = 0; i < keys.length; i++) {\n        key = keys[i];\n        val = container[key];\n\n        if(key.substr(key.length - 5) === 'color') {\n            // only sanitize keys that end in \"color\" or \"colorscale\"\n\n            if(Array.isArray(val)) {\n                for(j = 0; j < val.length; j++) val[j] = cleanOne(val[j]);\n            } else container[key] = cleanOne(val);\n        } else if(key.substr(key.length - 10) === 'colorscale' && Array.isArray(val)) {\n            // colorscales have the format [[0, color1], [frac, color2], ... [1, colorN]]\n\n            for(j = 0; j < val.length; j++) {\n                if(Array.isArray(val[j])) val[j][1] = cleanOne(val[j][1]);\n            }\n        } else if(Array.isArray(val)) {\n            // recurse into arrays of objects, and plain objects\n\n            var el0 = val[0];\n            if(!Array.isArray(el0) && el0 && typeof el0 === 'object') {\n                for(j = 0; j < val.length; j++) color.clean(val[j]);\n            }\n        } else if(val && typeof val === 'object') color.clean(val);\n    }\n};\n\nfunction cleanOne(val) {\n    if(isNumeric(val) || typeof val !== 'string') return val;\n\n    var valTrim = val.trim();\n    if(valTrim.substr(0, 3) !== 'rgb') return val;\n\n    var match = valTrim.match(/^rgba?\\s*\\(([^()]*)\\)$/);\n    if(!match) return val;\n\n    var parts = match[1].trim().split(/\\s*[\\s,]\\s*/);\n    var rgba = valTrim.charAt(3) === 'a' && parts.length === 4;\n    if(!rgba && parts.length !== 3) return val;\n\n    for(var i = 0; i < parts.length; i++) {\n        if(!parts[i].length) return val;\n        parts[i] = Number(parts[i]);\n\n        if(!(parts[i] >= 0)) {\n            // all parts must be non-negative numbers\n\n            return val;\n        }\n\n        if(i === 3) {\n            // alpha>1 gets clipped to 1\n\n            if(parts[i] > 1) parts[i] = 1;\n        } else if(parts[i] >= 1) {\n            // r, g, b must be < 1 (ie 1 itself is not allowed)\n\n            return val;\n        }\n    }\n\n    var rgbStr = Math.round(parts[0] * 255) + ', ' +\n        Math.round(parts[1] * 255) + ', ' +\n        Math.round(parts[2] * 255);\n\n    if(rgba) return 'rgba(' + rgbStr + ', ' + parts[3] + ')';\n    return 'rgb(' + rgbStr + ')';\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nvar handleXYZDefaults = require('./xyz_defaults');\nvar handleStyleDefaults = require('./style_defaults');\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n    function coerce(attr, dflt) {\n        return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n    }\n\n    var validData = handleXYZDefaults(traceIn, traceOut, coerce, layout);\n    if(!validData) {\n        traceOut.visible = false;\n        return;\n    }\n\n    coerce('text');\n    coerce('hovertext');\n    coerce('hovertemplate');\n\n    handleStyleDefaults(traceIn, traceOut, coerce, layout);\n\n    coerce('hoverongaps');\n    coerce('connectgaps', Lib.isArray1D(traceOut.z) && (traceOut.zsmooth !== false));\n\n    colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: '', cLetter: 'z'});\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Registry = require('../registry');\n\n/*\n * containerArrayMatch: does this attribute string point into a\n * layout container array?\n *\n * @param {String} astr: an attribute string, like *annotations[2].text*\n *\n * @returns {Object | false} Returns false if `astr` doesn't match a container\n *  array. If it does, returns:\n *     {array: {String}, index: {Number}, property: {String}}\n *  ie the attribute string for the array, the index within the array (or ''\n *  if the whole array) and the property within that (or '' if the whole array\n *  or the whole object)\n */\nmodule.exports = function containerArrayMatch(astr) {\n    var rootContainers = Registry.layoutArrayContainers;\n    var regexpContainers = Registry.layoutArrayRegexes;\n    var rootPart = astr.split('[')[0];\n    var arrayStr;\n    var match;\n\n    // look for regexp matches first, because they may be nested inside root matches\n    // eg updatemenus[i].buttons is nested inside updatemenus\n    for(var i = 0; i < regexpContainers.length; i++) {\n        match = astr.match(regexpContainers[i]);\n        if(match && match.index === 0) {\n            arrayStr = match[0];\n            break;\n        }\n    }\n\n    // now look for root matches\n    if(!arrayStr) arrayStr = rootContainers[rootContainers.indexOf(rootPart)];\n\n    if(!arrayStr) return false;\n\n    var tail = astr.substr(arrayStr.length);\n    if(!tail) return {array: arrayStr, index: '', property: ''};\n\n    match = tail.match(/^\\[(0|[1-9][0-9]*)\\](\\.(.+))?$/);\n    if(!match) return false;\n\n    return {array: arrayStr, index: Number(match[1]), property: match[3] || ''};\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar LINE_SPACING = require('../../constants/alignment').LINE_SPACING;\n\nvar constants = require('./constants');\nvar ScrollBox = require('./scrollbox');\n\nmodule.exports = function draw(gd) {\n    var fullLayout = gd._fullLayout;\n    var menuData = Lib.filterVisible(fullLayout[constants.name]);\n\n    /* Update menu data is bound to the header-group.\n     * The items in the header group are always present.\n     *\n     * Upon clicking on a header its corresponding button\n     * data is bound to the button-group.\n     *\n     * We draw all headers in one group before all buttons\n     * so that the buttons *always* appear above the headers.\n     *\n     * Note that only one set of buttons are visible at once.\n     *\n     * \n     *\n     *     \n     *         \n     *         \n     *     \n     *         \n     *         \n     *     ...\n     *\n     *     \n     *         \n     *         \n     *         ...\n     */\n\n    function clearAutoMargin(menuOpts) {\n        Plots.autoMargin(gd, autoMarginId(menuOpts));\n    }\n\n    // draw update menu container\n    var menus = fullLayout._menulayer\n        .selectAll('g.' + constants.containerClassName)\n        .data(menuData.length > 0 ? [0] : []);\n\n    menus.enter().append('g')\n        .classed(constants.containerClassName, true)\n        .style('cursor', 'pointer');\n\n    menus.exit().each(function() {\n        // Most components don't need to explicitly remove autoMargin, because\n        // marginPushers does this - but updatemenu updates don't go through\n        // a full replot so we need to explicitly remove it.\n        // This is for removing *all* updatemenus, removing individuals is\n        // handled below, in headerGroups.exit\n        d3.select(this).selectAll('g.' + constants.headerGroupClassName)\n            .each(clearAutoMargin);\n    }).remove();\n\n    // return early if no update menus are visible\n    if(menuData.length === 0) return;\n\n    // join header group\n    var headerGroups = menus.selectAll('g.' + constants.headerGroupClassName)\n        .data(menuData, keyFunction);\n\n    headerGroups.enter().append('g')\n        .classed(constants.headerGroupClassName, true);\n\n    // draw dropdown button container\n    var gButton = Lib.ensureSingle(menus, 'g', constants.dropdownButtonGroupClassName, function(s) {\n        s.style('pointer-events', 'all');\n    });\n\n    // find dimensions before plotting anything (this mutates menuOpts)\n    for(var i = 0; i < menuData.length; i++) {\n        var menuOpts = menuData[i];\n        findDimensions(gd, menuOpts);\n    }\n\n    // setup scrollbox\n    var scrollBoxId = 'updatemenus' + fullLayout._uid;\n    var scrollBox = new ScrollBox(gd, gButton, scrollBoxId);\n\n    // remove exiting header, remove dropped buttons and reset margins\n    if(headerGroups.enter().size()) {\n        // make sure gButton is on top of all headers\n        gButton.node().parentNode.appendChild(gButton.node());\n        gButton.call(removeAllButtons);\n    }\n\n    headerGroups.exit().each(function(menuOpts) {\n        gButton.call(removeAllButtons);\n        clearAutoMargin(menuOpts);\n    }).remove();\n\n    // draw headers!\n    headerGroups.each(function(menuOpts) {\n        var gHeader = d3.select(this);\n\n        var _gButton = menuOpts.type === 'dropdown' ? gButton : null;\n\n        Plots.manageCommandObserver(gd, menuOpts, menuOpts.buttons, function(data) {\n            setActive(gd, menuOpts, menuOpts.buttons[data.index], gHeader, _gButton, scrollBox, data.index, true);\n        });\n\n        if(menuOpts.type === 'dropdown') {\n            drawHeader(gd, gHeader, gButton, scrollBox, menuOpts);\n\n            // if this menu is active, update the dropdown container\n            if(isActive(gButton, menuOpts)) {\n                drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n            }\n        } else {\n            drawButtons(gd, gHeader, null, null, menuOpts);\n        }\n    });\n};\n\n// Note that '_index' is set at the default step,\n// it corresponds to the menu index in the user layout update menu container.\n// Because a menu can be set invisible,\n// this is a more 'consistent' field than the index in the menuData.\nfunction keyFunction(menuOpts) {\n    return menuOpts._index;\n}\n\nfunction isFolded(gButton) {\n    return +gButton.attr(constants.menuIndexAttrName) === -1;\n}\n\nfunction isActive(gButton, menuOpts) {\n    return +gButton.attr(constants.menuIndexAttrName) === menuOpts._index;\n}\n\nfunction setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, buttonIndex, isSilentUpdate) {\n    // update 'active' attribute in menuOpts\n    menuOpts.active = buttonIndex;\n\n    // due to templating, it's possible this slider doesn't even exist yet\n    arrayEditor(gd.layout, constants.name, menuOpts)\n        .applyUpdate('active', buttonIndex);\n\n    if(menuOpts.type === 'buttons') {\n        drawButtons(gd, gHeader, null, null, menuOpts);\n    } else if(menuOpts.type === 'dropdown') {\n        // fold up buttons and redraw header\n        gButton.attr(constants.menuIndexAttrName, '-1');\n\n        drawHeader(gd, gHeader, gButton, scrollBox, menuOpts);\n\n        if(!isSilentUpdate) {\n            drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n        }\n    }\n}\n\nfunction drawHeader(gd, gHeader, gButton, scrollBox, menuOpts) {\n    var header = Lib.ensureSingle(gHeader, 'g', constants.headerClassName, function(s) {\n        s.style('pointer-events', 'all');\n    });\n\n    var dims = menuOpts._dims;\n    var active = menuOpts.active;\n    var headerOpts = menuOpts.buttons[active] || constants.blankHeaderOpts;\n    var posOpts = { y: menuOpts.pad.t, yPad: 0, x: menuOpts.pad.l, xPad: 0, index: 0 };\n    var positionOverrides = {\n        width: dims.headerWidth,\n        height: dims.headerHeight\n    };\n\n    header\n        .call(drawItem, menuOpts, headerOpts, gd)\n        .call(setItemPosition, menuOpts, posOpts, positionOverrides);\n\n    // draw drop arrow at the right edge\n    var arrow = Lib.ensureSingle(gHeader, 'text', constants.headerArrowClassName, function(s) {\n        s.classed('user-select-none', true)\n            .attr('text-anchor', 'end')\n            .call(Drawing.font, menuOpts.font)\n            .text(constants.arrowSymbol[menuOpts.direction]);\n    });\n\n    arrow.attr({\n        x: dims.headerWidth - constants.arrowOffsetX + menuOpts.pad.l,\n        y: dims.headerHeight / 2 + constants.textOffsetY + menuOpts.pad.t\n    });\n\n    header.on('click', function() {\n        gButton.call(removeAllButtons,\n            String(isActive(gButton, menuOpts) ? -1 : menuOpts._index)\n        );\n\n        drawButtons(gd, gHeader, gButton, scrollBox, menuOpts);\n    });\n\n    header.on('mouseover', function() {\n        header.call(styleOnMouseOver);\n    });\n\n    header.on('mouseout', function() {\n        header.call(styleOnMouseOut, menuOpts);\n    });\n\n    // translate header group\n    Drawing.setTranslate(gHeader, dims.lx, dims.ly);\n}\n\nfunction drawButtons(gd, gHeader, gButton, scrollBox, menuOpts) {\n    // If this is a set of buttons, set pointer events = all since we play\n    // some minor games with which container is which in order to simplify\n    // the drawing of *either* buttons or menus\n    if(!gButton) {\n        gButton = gHeader;\n        gButton.attr('pointer-events', 'all');\n    }\n\n    var buttonData = (!isFolded(gButton) || menuOpts.type === 'buttons') ?\n        menuOpts.buttons :\n        [];\n\n    var klass = menuOpts.type === 'dropdown' ? constants.dropdownButtonClassName : constants.buttonClassName;\n\n    var buttons = gButton.selectAll('g.' + klass)\n        .data(Lib.filterVisible(buttonData));\n\n    var enter = buttons.enter().append('g')\n        .classed(klass, true);\n\n    var exit = buttons.exit();\n\n    if(menuOpts.type === 'dropdown') {\n        enter.attr('opacity', '0')\n            .transition()\n            .attr('opacity', '1');\n\n        exit.transition()\n            .attr('opacity', '0')\n            .remove();\n    } else {\n        exit.remove();\n    }\n\n    var x0 = 0;\n    var y0 = 0;\n    var dims = menuOpts._dims;\n\n    var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n\n    if(menuOpts.type === 'dropdown') {\n        if(isVertical) {\n            y0 = dims.headerHeight + constants.gapButtonHeader;\n        } else {\n            x0 = dims.headerWidth + constants.gapButtonHeader;\n        }\n    }\n\n    if(menuOpts.type === 'dropdown' && menuOpts.direction === 'up') {\n        y0 = -constants.gapButtonHeader + constants.gapButton - dims.openHeight;\n    }\n\n    if(menuOpts.type === 'dropdown' && menuOpts.direction === 'left') {\n        x0 = -constants.gapButtonHeader + constants.gapButton - dims.openWidth;\n    }\n\n    var posOpts = {\n        x: dims.lx + x0 + menuOpts.pad.l,\n        y: dims.ly + y0 + menuOpts.pad.t,\n        yPad: constants.gapButton,\n        xPad: constants.gapButton,\n        index: 0,\n    };\n\n    var scrollBoxPosition = {\n        l: posOpts.x + menuOpts.borderwidth,\n        t: posOpts.y + menuOpts.borderwidth\n    };\n\n    buttons.each(function(buttonOpts, buttonIndex) {\n        var button = d3.select(this);\n\n        button\n            .call(drawItem, menuOpts, buttonOpts, gd)\n            .call(setItemPosition, menuOpts, posOpts);\n\n        button.on('click', function() {\n            // skip `dragend` events\n            if(d3.event.defaultPrevented) return;\n\n            if(buttonOpts.execute) {\n                if(buttonOpts.args2 && menuOpts.active === buttonIndex) {\n                    setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, -1);\n                    Plots.executeAPICommand(gd, buttonOpts.method, buttonOpts.args2);\n                } else {\n                    setActive(gd, menuOpts, buttonOpts, gHeader, gButton, scrollBox, buttonIndex);\n                    Plots.executeAPICommand(gd, buttonOpts.method, buttonOpts.args);\n                }\n            }\n\n            gd.emit('plotly_buttonclicked', {menu: menuOpts, button: buttonOpts, active: menuOpts.active});\n        });\n\n        button.on('mouseover', function() {\n            button.call(styleOnMouseOver);\n        });\n\n        button.on('mouseout', function() {\n            button.call(styleOnMouseOut, menuOpts);\n            buttons.call(styleButtons, menuOpts);\n        });\n    });\n\n    buttons.call(styleButtons, menuOpts);\n\n    if(isVertical) {\n        scrollBoxPosition.w = Math.max(dims.openWidth, dims.headerWidth);\n        scrollBoxPosition.h = posOpts.y - scrollBoxPosition.t;\n    } else {\n        scrollBoxPosition.w = posOpts.x - scrollBoxPosition.l;\n        scrollBoxPosition.h = Math.max(dims.openHeight, dims.headerHeight);\n    }\n\n    scrollBoxPosition.direction = menuOpts.direction;\n\n    if(scrollBox) {\n        if(buttons.size()) {\n            drawScrollBox(gd, gHeader, gButton, scrollBox, menuOpts, scrollBoxPosition);\n        } else {\n            hideScrollBox(scrollBox);\n        }\n    }\n}\n\nfunction drawScrollBox(gd, gHeader, gButton, scrollBox, menuOpts, position) {\n    // enable the scrollbox\n    var direction = menuOpts.direction;\n    var isVertical = (direction === 'up' || direction === 'down');\n    var dims = menuOpts._dims;\n\n    var active = menuOpts.active;\n    var translateX, translateY;\n    var i;\n    if(isVertical) {\n        translateY = 0;\n        for(i = 0; i < active; i++) {\n            translateY += dims.heights[i] + constants.gapButton;\n        }\n    } else {\n        translateX = 0;\n        for(i = 0; i < active; i++) {\n            translateX += dims.widths[i] + constants.gapButton;\n        }\n    }\n\n    scrollBox.enable(position, translateX, translateY);\n\n    if(scrollBox.hbar) {\n        scrollBox.hbar\n            .attr('opacity', '0')\n            .transition()\n            .attr('opacity', '1');\n    }\n\n    if(scrollBox.vbar) {\n        scrollBox.vbar\n            .attr('opacity', '0')\n            .transition()\n            .attr('opacity', '1');\n    }\n}\n\nfunction hideScrollBox(scrollBox) {\n    var hasHBar = !!scrollBox.hbar;\n    var hasVBar = !!scrollBox.vbar;\n\n    if(hasHBar) {\n        scrollBox.hbar\n            .transition()\n            .attr('opacity', '0')\n            .each('end', function() {\n                hasHBar = false;\n                if(!hasVBar) scrollBox.disable();\n            });\n    }\n\n    if(hasVBar) {\n        scrollBox.vbar\n            .transition()\n            .attr('opacity', '0')\n            .each('end', function() {\n                hasVBar = false;\n                if(!hasHBar) scrollBox.disable();\n            });\n    }\n}\n\nfunction drawItem(item, menuOpts, itemOpts, gd) {\n    item.call(drawItemRect, menuOpts)\n        .call(drawItemText, menuOpts, itemOpts, gd);\n}\n\nfunction drawItemRect(item, menuOpts) {\n    var rect = Lib.ensureSingle(item, 'rect', constants.itemRectClassName, function(s) {\n        s.attr({\n            rx: constants.rx,\n            ry: constants.ry,\n            'shape-rendering': 'crispEdges'\n        });\n    });\n\n    rect.call(Color.stroke, menuOpts.bordercolor)\n        .call(Color.fill, menuOpts.bgcolor)\n        .style('stroke-width', menuOpts.borderwidth + 'px');\n}\n\nfunction drawItemText(item, menuOpts, itemOpts, gd) {\n    var text = Lib.ensureSingle(item, 'text', constants.itemTextClassName, function(s) {\n        s.classed('user-select-none', true)\n            .attr({\n                'text-anchor': 'start',\n                'data-notex': 1\n            });\n    });\n\n    var tx = itemOpts.label;\n    var _meta = gd._fullLayout._meta;\n    if(_meta) tx = Lib.templateString(tx, _meta);\n\n    text.call(Drawing.font, menuOpts.font)\n        .text(tx)\n        .call(svgTextUtils.convertToTspans, gd);\n}\n\nfunction styleButtons(buttons, menuOpts) {\n    var active = menuOpts.active;\n\n    buttons.each(function(buttonOpts, i) {\n        var button = d3.select(this);\n\n        if(i === active && menuOpts.showactive) {\n            button.select('rect.' + constants.itemRectClassName)\n                .call(Color.fill, constants.activeColor);\n        }\n    });\n}\n\nfunction styleOnMouseOver(item) {\n    item.select('rect.' + constants.itemRectClassName)\n        .call(Color.fill, constants.hoverColor);\n}\n\nfunction styleOnMouseOut(item, menuOpts) {\n    item.select('rect.' + constants.itemRectClassName)\n        .call(Color.fill, menuOpts.bgcolor);\n}\n\n// find item dimensions (this mutates menuOpts)\nfunction findDimensions(gd, menuOpts) {\n    var dims = menuOpts._dims = {\n        width1: 0,\n        height1: 0,\n        heights: [],\n        widths: [],\n        totalWidth: 0,\n        totalHeight: 0,\n        openWidth: 0,\n        openHeight: 0,\n        lx: 0,\n        ly: 0\n    };\n\n    var fakeButtons = Drawing.tester.selectAll('g.' + constants.dropdownButtonClassName)\n        .data(Lib.filterVisible(menuOpts.buttons));\n\n    fakeButtons.enter().append('g')\n        .classed(constants.dropdownButtonClassName, true);\n\n    var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n\n    // loop over fake buttons to find width / height\n    fakeButtons.each(function(buttonOpts, i) {\n        var button = d3.select(this);\n\n        button.call(drawItem, menuOpts, buttonOpts, gd);\n\n        var text = button.select('.' + constants.itemTextClassName);\n\n        // width is given by max width of all buttons\n        var tWidth = text.node() && Drawing.bBox(text.node()).width;\n        var wEff = Math.max(tWidth + constants.textPadX, constants.minWidth);\n\n        // height is determined by item text\n        var tHeight = menuOpts.font.size * LINE_SPACING;\n        var tLines = svgTextUtils.lineCount(text);\n        var hEff = Math.max(tHeight * tLines, constants.minHeight) + constants.textOffsetY;\n\n        hEff = Math.ceil(hEff);\n        wEff = Math.ceil(wEff);\n\n        // Store per-item sizes since a row of horizontal buttons, for example,\n        // don't all need to be the same width:\n        dims.widths[i] = wEff;\n        dims.heights[i] = hEff;\n\n        // Height and width of individual element:\n        dims.height1 = Math.max(dims.height1, hEff);\n        dims.width1 = Math.max(dims.width1, wEff);\n\n        if(isVertical) {\n            dims.totalWidth = Math.max(dims.totalWidth, wEff);\n            dims.openWidth = dims.totalWidth;\n            dims.totalHeight += hEff + constants.gapButton;\n            dims.openHeight += hEff + constants.gapButton;\n        } else {\n            dims.totalWidth += wEff + constants.gapButton;\n            dims.openWidth += wEff + constants.gapButton;\n            dims.totalHeight = Math.max(dims.totalHeight, hEff);\n            dims.openHeight = dims.totalHeight;\n        }\n    });\n\n    if(isVertical) {\n        dims.totalHeight -= constants.gapButton;\n    } else {\n        dims.totalWidth -= constants.gapButton;\n    }\n\n\n    dims.headerWidth = dims.width1 + constants.arrowPadX;\n    dims.headerHeight = dims.height1;\n\n    if(menuOpts.type === 'dropdown') {\n        if(isVertical) {\n            dims.width1 += constants.arrowPadX;\n            dims.totalHeight = dims.height1;\n        } else {\n            dims.totalWidth = dims.width1;\n        }\n        dims.totalWidth += constants.arrowPadX;\n    }\n\n    fakeButtons.remove();\n\n    var paddedWidth = dims.totalWidth + menuOpts.pad.l + menuOpts.pad.r;\n    var paddedHeight = dims.totalHeight + menuOpts.pad.t + menuOpts.pad.b;\n\n    var graphSize = gd._fullLayout._size;\n    dims.lx = graphSize.l + graphSize.w * menuOpts.x;\n    dims.ly = graphSize.t + graphSize.h * (1 - menuOpts.y);\n\n    var xanchor = 'left';\n    if(Lib.isRightAnchor(menuOpts)) {\n        dims.lx -= paddedWidth;\n        xanchor = 'right';\n    }\n    if(Lib.isCenterAnchor(menuOpts)) {\n        dims.lx -= paddedWidth / 2;\n        xanchor = 'center';\n    }\n\n    var yanchor = 'top';\n    if(Lib.isBottomAnchor(menuOpts)) {\n        dims.ly -= paddedHeight;\n        yanchor = 'bottom';\n    }\n    if(Lib.isMiddleAnchor(menuOpts)) {\n        dims.ly -= paddedHeight / 2;\n        yanchor = 'middle';\n    }\n\n    dims.totalWidth = Math.ceil(dims.totalWidth);\n    dims.totalHeight = Math.ceil(dims.totalHeight);\n    dims.lx = Math.round(dims.lx);\n    dims.ly = Math.round(dims.ly);\n\n    Plots.autoMargin(gd, autoMarginId(menuOpts), {\n        x: menuOpts.x,\n        y: menuOpts.y,\n        l: paddedWidth * ({right: 1, center: 0.5}[xanchor] || 0),\n        r: paddedWidth * ({left: 1, center: 0.5}[xanchor] || 0),\n        b: paddedHeight * ({top: 1, middle: 0.5}[yanchor] || 0),\n        t: paddedHeight * ({bottom: 1, middle: 0.5}[yanchor] || 0)\n    });\n}\n\nfunction autoMarginId(menuOpts) {\n    return constants.autoMarginIdRoot + menuOpts._index;\n}\n\n// set item positions (mutates posOpts)\nfunction setItemPosition(item, menuOpts, posOpts, overrideOpts) {\n    overrideOpts = overrideOpts || {};\n    var rect = item.select('.' + constants.itemRectClassName);\n    var text = item.select('.' + constants.itemTextClassName);\n    var borderWidth = menuOpts.borderwidth;\n    var index = posOpts.index;\n    var dims = menuOpts._dims;\n\n    Drawing.setTranslate(item, borderWidth + posOpts.x, borderWidth + posOpts.y);\n\n    var isVertical = ['up', 'down'].indexOf(menuOpts.direction) !== -1;\n    var finalHeight = overrideOpts.height || (isVertical ? dims.heights[index] : dims.height1);\n\n    rect.attr({\n        x: 0,\n        y: 0,\n        width: overrideOpts.width || (isVertical ? dims.width1 : dims.widths[index]),\n        height: finalHeight\n    });\n\n    var tHeight = menuOpts.font.size * LINE_SPACING;\n    var tLines = svgTextUtils.lineCount(text);\n    var spanOffset = ((tLines - 1) * tHeight / 2);\n\n    svgTextUtils.positionText(text, constants.textOffsetX,\n        finalHeight / 2 - spanOffset + constants.textOffsetY);\n\n    if(isVertical) {\n        posOpts.y += dims.heights[index] + posOpts.yPad;\n    } else {\n        posOpts.x += dims.widths[index] + posOpts.xPad;\n    }\n\n    posOpts.index++;\n}\n\nfunction removeAllButtons(gButton, newMenuIndexAttr) {\n    gButton\n        .attr(constants.menuIndexAttrName, newMenuIndexAttr || '-1')\n        .selectAll('g.' + constants.dropdownButtonClassName).remove();\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar numConstants = require('../constants/numerical');\nvar FP_SAFE = numConstants.FP_SAFE;\nvar BADNUM = numConstants.BADNUM;\n\nvar lib = module.exports = {};\n\nlib.nestedProperty = require('./nested_property');\nlib.keyedContainer = require('./keyed_container');\nlib.relativeAttr = require('./relative_attr');\nlib.isPlainObject = require('./is_plain_object');\nlib.toLogRange = require('./to_log_range');\nlib.relinkPrivateKeys = require('./relink_private');\n\nvar arrayModule = require('./array');\nlib.isTypedArray = arrayModule.isTypedArray;\nlib.isArrayOrTypedArray = arrayModule.isArrayOrTypedArray;\nlib.isArray1D = arrayModule.isArray1D;\nlib.ensureArray = arrayModule.ensureArray;\nlib.concat = arrayModule.concat;\nlib.maxRowLength = arrayModule.maxRowLength;\nlib.minRowLength = arrayModule.minRowLength;\n\nvar modModule = require('./mod');\nlib.mod = modModule.mod;\nlib.modHalf = modModule.modHalf;\n\nvar coerceModule = require('./coerce');\nlib.valObjectMeta = coerceModule.valObjectMeta;\nlib.coerce = coerceModule.coerce;\nlib.coerce2 = coerceModule.coerce2;\nlib.coerceFont = coerceModule.coerceFont;\nlib.coerceHoverinfo = coerceModule.coerceHoverinfo;\nlib.coerceSelectionMarkerOpacity = coerceModule.coerceSelectionMarkerOpacity;\nlib.validate = coerceModule.validate;\n\nvar datesModule = require('./dates');\nlib.dateTime2ms = datesModule.dateTime2ms;\nlib.isDateTime = datesModule.isDateTime;\nlib.ms2DateTime = datesModule.ms2DateTime;\nlib.ms2DateTimeLocal = datesModule.ms2DateTimeLocal;\nlib.cleanDate = datesModule.cleanDate;\nlib.isJSDate = datesModule.isJSDate;\nlib.formatDate = datesModule.formatDate;\nlib.incrementMonth = datesModule.incrementMonth;\nlib.dateTick0 = datesModule.dateTick0;\nlib.dfltRange = datesModule.dfltRange;\nlib.findExactDates = datesModule.findExactDates;\nlib.MIN_MS = datesModule.MIN_MS;\nlib.MAX_MS = datesModule.MAX_MS;\n\nvar searchModule = require('./search');\nlib.findBin = searchModule.findBin;\nlib.sorterAsc = searchModule.sorterAsc;\nlib.sorterDes = searchModule.sorterDes;\nlib.distinctVals = searchModule.distinctVals;\nlib.roundUp = searchModule.roundUp;\nlib.sort = searchModule.sort;\nlib.findIndexOfMin = searchModule.findIndexOfMin;\n\nvar statsModule = require('./stats');\nlib.aggNums = statsModule.aggNums;\nlib.len = statsModule.len;\nlib.mean = statsModule.mean;\nlib.median = statsModule.median;\nlib.midRange = statsModule.midRange;\nlib.variance = statsModule.variance;\nlib.stdev = statsModule.stdev;\nlib.interp = statsModule.interp;\n\nvar matrixModule = require('./matrix');\nlib.init2dArray = matrixModule.init2dArray;\nlib.transposeRagged = matrixModule.transposeRagged;\nlib.dot = matrixModule.dot;\nlib.translationMatrix = matrixModule.translationMatrix;\nlib.rotationMatrix = matrixModule.rotationMatrix;\nlib.rotationXYMatrix = matrixModule.rotationXYMatrix;\nlib.apply2DTransform = matrixModule.apply2DTransform;\nlib.apply2DTransform2 = matrixModule.apply2DTransform2;\n\nvar anglesModule = require('./angles');\nlib.deg2rad = anglesModule.deg2rad;\nlib.rad2deg = anglesModule.rad2deg;\nlib.angleDelta = anglesModule.angleDelta;\nlib.angleDist = anglesModule.angleDist;\nlib.isFullCircle = anglesModule.isFullCircle;\nlib.isAngleInsideSector = anglesModule.isAngleInsideSector;\nlib.isPtInsideSector = anglesModule.isPtInsideSector;\nlib.pathArc = anglesModule.pathArc;\nlib.pathSector = anglesModule.pathSector;\nlib.pathAnnulus = anglesModule.pathAnnulus;\n\nvar anchorUtils = require('./anchor_utils');\nlib.isLeftAnchor = anchorUtils.isLeftAnchor;\nlib.isCenterAnchor = anchorUtils.isCenterAnchor;\nlib.isRightAnchor = anchorUtils.isRightAnchor;\nlib.isTopAnchor = anchorUtils.isTopAnchor;\nlib.isMiddleAnchor = anchorUtils.isMiddleAnchor;\nlib.isBottomAnchor = anchorUtils.isBottomAnchor;\n\nvar geom2dModule = require('./geometry2d');\nlib.segmentsIntersect = geom2dModule.segmentsIntersect;\nlib.segmentDistance = geom2dModule.segmentDistance;\nlib.getTextLocation = geom2dModule.getTextLocation;\nlib.clearLocationCache = geom2dModule.clearLocationCache;\nlib.getVisibleSegment = geom2dModule.getVisibleSegment;\nlib.findPointOnPath = geom2dModule.findPointOnPath;\n\nvar extendModule = require('./extend');\nlib.extendFlat = extendModule.extendFlat;\nlib.extendDeep = extendModule.extendDeep;\nlib.extendDeepAll = extendModule.extendDeepAll;\nlib.extendDeepNoArrays = extendModule.extendDeepNoArrays;\n\nvar loggersModule = require('./loggers');\nlib.log = loggersModule.log;\nlib.warn = loggersModule.warn;\nlib.error = loggersModule.error;\n\nvar regexModule = require('./regex');\nlib.counterRegex = regexModule.counter;\n\nvar throttleModule = require('./throttle');\nlib.throttle = throttleModule.throttle;\nlib.throttleDone = throttleModule.done;\nlib.clearThrottle = throttleModule.clear;\n\nvar domModule = require('./dom');\nlib.getGraphDiv = domModule.getGraphDiv;\nlib.isPlotDiv = domModule.isPlotDiv;\nlib.removeElement = domModule.removeElement;\nlib.addStyleRule = domModule.addStyleRule;\nlib.addRelatedStyleRule = domModule.addRelatedStyleRule;\nlib.deleteRelatedStyleRule = domModule.deleteRelatedStyleRule;\n\nlib.clearResponsive = require('./clear_responsive');\n\nlib.makeTraceGroups = require('./make_trace_groups');\n\nlib._ = require('./localize');\n\nlib.notifier = require('./notifier');\n\nlib.filterUnique = require('./filter_unique');\nlib.filterVisible = require('./filter_visible');\nlib.pushUnique = require('./push_unique');\n\nlib.cleanNumber = require('./clean_number');\n\nlib.ensureNumber = function ensureNumber(v) {\n    if(!isNumeric(v)) return BADNUM;\n    v = Number(v);\n    if(v < -FP_SAFE || v > FP_SAFE) return BADNUM;\n    return isNumeric(v) ? Number(v) : BADNUM;\n};\n\n/**\n * Is v a valid array index? Accepts numeric strings as well as numbers.\n *\n * @param {any} v: the value to test\n * @param {Optional[integer]} len: the array length we are indexing\n *\n * @return {bool}: v is a valid array index\n */\nlib.isIndex = function(v, len) {\n    if(len !== undefined && v >= len) return false;\n    return isNumeric(v) && (v >= 0) && (v % 1 === 0);\n};\n\nlib.noop = require('./noop');\nlib.identity = require('./identity');\n\n/**\n * create an array of length 'cnt' filled with 'v' at all indices\n *\n * @param {any} v\n * @param {number} cnt\n * @return {array}\n */\nlib.repeat = function(v, cnt) {\n    var out = new Array(cnt);\n    for(var i = 0; i < cnt; i++) {\n        out[i] = v;\n    }\n    return out;\n};\n\n/**\n * swap x and y of the same attribute in container cont\n * specify attr with a ? in place of x/y\n * you can also swap other things than x/y by providing part1 and part2\n */\nlib.swapAttrs = function(cont, attrList, part1, part2) {\n    if(!part1) part1 = 'x';\n    if(!part2) part2 = 'y';\n    for(var i = 0; i < attrList.length; i++) {\n        var attr = attrList[i];\n        var xp = lib.nestedProperty(cont, attr.replace('?', part1));\n        var yp = lib.nestedProperty(cont, attr.replace('?', part2));\n        var temp = xp.get();\n        xp.set(yp.get());\n        yp.set(temp);\n    }\n};\n\n/**\n * SVG painter's algo worked around with reinsertion\n */\nlib.raiseToTop = function raiseToTop(elem) {\n    elem.parentNode.appendChild(elem);\n};\n\n/**\n * cancel a possibly pending transition; returned selection may be used by caller\n */\nlib.cancelTransition = function(selection) {\n    return selection.transition().duration(0);\n};\n\n// constrain - restrict a number v to be between v0 and v1\nlib.constrain = function(v, v0, v1) {\n    if(v0 > v1) return Math.max(v1, Math.min(v0, v));\n    return Math.max(v0, Math.min(v1, v));\n};\n\n/**\n * do two bounding boxes from getBoundingClientRect,\n * ie {left,right,top,bottom,width,height}, overlap?\n * takes optional padding pixels\n */\nlib.bBoxIntersect = function(a, b, pad) {\n    pad = pad || 0;\n    return (a.left <= b.right + pad &&\n            b.left <= a.right + pad &&\n            a.top <= b.bottom + pad &&\n            b.top <= a.bottom + pad);\n};\n\n/*\n * simpleMap: alternative to Array.map that only\n * passes on the element and up to 2 extra args you\n * provide (but not the array index or the whole array)\n *\n * array: the array to map it to\n * func: the function to apply\n * x1, x2: optional extra args\n */\nlib.simpleMap = function(array, func, x1, x2) {\n    var len = array.length;\n    var out = new Array(len);\n    for(var i = 0; i < len; i++) out[i] = func(array[i], x1, x2);\n    return out;\n};\n\n/**\n * Random string generator\n *\n * @param {object} existing\n *     pass in strings to avoid as keys with truthy values\n * @param {int} bits\n *     bits of information in the output string, default 24\n * @param {int} base\n *     base of string representation, default 16. Should be a power of 2.\n */\nlib.randstr = function randstr(existing, bits, base, _recursion) {\n    if(!base) base = 16;\n    if(bits === undefined) bits = 24;\n    if(bits <= 0) return '0';\n\n    var digits = Math.log(Math.pow(2, bits)) / Math.log(base);\n    var res = '';\n    var i, b, x;\n\n    for(i = 2; digits === Infinity; i *= 2) {\n        digits = Math.log(Math.pow(2, bits / i)) / Math.log(base) * i;\n    }\n\n    var rem = digits - Math.floor(digits);\n\n    for(i = 0; i < Math.floor(digits); i++) {\n        x = Math.floor(Math.random() * base).toString(base);\n        res = x + res;\n    }\n\n    if(rem) {\n        b = Math.pow(base, rem);\n        x = Math.floor(Math.random() * b).toString(base);\n        res = x + res;\n    }\n\n    var parsed = parseInt(res, base);\n    if((existing && existing[res]) ||\n         (parsed !== Infinity && parsed >= Math.pow(2, bits))) {\n        if(_recursion > 10) {\n            lib.warn('randstr failed uniqueness');\n            return res;\n        }\n        return randstr(existing, bits, base, (_recursion || 0) + 1);\n    } else return res;\n};\n\nlib.OptionControl = function(opt, optname) {\n    /*\n     * An environment to contain all option setters and\n     * getters that collectively modify opts.\n     *\n     * You can call up opts from any function in new object\n     * as this.optname || this.opt\n     *\n     * See FitOpts for example of usage\n     */\n    if(!opt) opt = {};\n    if(!optname) optname = 'opt';\n\n    var self = {};\n    self.optionList = [];\n\n    self._newoption = function(optObj) {\n        optObj[optname] = opt;\n        self[optObj.name] = optObj;\n        self.optionList.push(optObj);\n    };\n\n    self['_' + optname] = opt;\n    return self;\n};\n\n/**\n * lib.smooth: smooth arrayIn by convolving with\n * a hann window with given full width at half max\n * bounce the ends in, so the output has the same length as the input\n */\nlib.smooth = function(arrayIn, FWHM) {\n    FWHM = Math.round(FWHM) || 0; // only makes sense for integers\n    if(FWHM < 2) return arrayIn;\n\n    var alen = arrayIn.length;\n    var alen2 = 2 * alen;\n    var wlen = 2 * FWHM - 1;\n    var w = new Array(wlen);\n    var arrayOut = new Array(alen);\n    var i;\n    var j;\n    var k;\n    var v;\n\n    // first make the window array\n    for(i = 0; i < wlen; i++) {\n        w[i] = (1 - Math.cos(Math.PI * (i + 1) / FWHM)) / (2 * FWHM);\n    }\n\n    // now do the convolution\n    for(i = 0; i < alen; i++) {\n        v = 0;\n        for(j = 0; j < wlen; j++) {\n            k = i + j + 1 - FWHM;\n\n            // multibounce\n            if(k < -alen) k -= alen2 * Math.round(k / alen2);\n            else if(k >= alen2) k -= alen2 * Math.floor(k / alen2);\n\n            // single bounce\n            if(k < 0) k = - 1 - k;\n            else if(k >= alen) k = alen2 - 1 - k;\n\n            v += arrayIn[k] * w[j];\n        }\n        arrayOut[i] = v;\n    }\n\n    return arrayOut;\n};\n\n/**\n * syncOrAsync: run a sequence of functions synchronously\n * as long as its returns are not promises (ie have no .then)\n * includes one argument arg to send to all functions...\n * this is mainly just to prevent us having to make wrapper functions\n * when the only purpose of the wrapper is to reference gd\n * and a final step to be executed at the end\n * TODO: if there's an error and everything is sync,\n * this doesn't happen yet because we want to make sure\n * that it gets reported\n */\nlib.syncOrAsync = function(sequence, arg, finalStep) {\n    var ret, fni;\n\n    function continueAsync() {\n        return lib.syncOrAsync(sequence, arg, finalStep);\n    }\n\n    while(sequence.length) {\n        fni = sequence.splice(0, 1)[0];\n        ret = fni(arg);\n\n        if(ret && ret.then) {\n            return ret.then(continueAsync)\n                .then(undefined, lib.promiseError);\n        }\n    }\n\n    return finalStep && finalStep(arg);\n};\n\n\n/**\n * Helper to strip trailing slash, from\n * http://stackoverflow.com/questions/6680825/return-string-without-trailing-slash\n */\nlib.stripTrailingSlash = function(str) {\n    if(str.substr(-1) === '/') return str.substr(0, str.length - 1);\n    return str;\n};\n\nlib.noneOrAll = function(containerIn, containerOut, attrList) {\n    /**\n     * some attributes come together, so if you have one of them\n     * in the input, you should copy the default values of the others\n     * to the input as well.\n     */\n    if(!containerIn) return;\n\n    var hasAny = false;\n    var hasAll = true;\n    var i;\n    var val;\n\n    for(i = 0; i < attrList.length; i++) {\n        val = containerIn[attrList[i]];\n        if(val !== undefined && val !== null) hasAny = true;\n        else hasAll = false;\n    }\n\n    if(hasAny && !hasAll) {\n        for(i = 0; i < attrList.length; i++) {\n            containerIn[attrList[i]] = containerOut[attrList[i]];\n        }\n    }\n};\n\n/** merges calcdata field (given by cdAttr) with traceAttr values\n *\n * N.B. Loop over minimum of cd.length and traceAttr.length\n * i.e. it does not try to fill in beyond traceAttr.length-1\n *\n * @param {array} traceAttr : trace attribute\n * @param {object} cd : calcdata trace\n * @param {string} cdAttr : calcdata key\n */\nlib.mergeArray = function(traceAttr, cd, cdAttr, fn) {\n    var hasFn = typeof fn === 'function';\n    if(lib.isArrayOrTypedArray(traceAttr)) {\n        var imax = Math.min(traceAttr.length, cd.length);\n        for(var i = 0; i < imax; i++) {\n            var v = traceAttr[i];\n            cd[i][cdAttr] = hasFn ? fn(v) : v;\n        }\n    }\n};\n\n// cast numbers to positive numbers, returns 0 if not greater than 0\nlib.mergeArrayCastPositive = function(traceAttr, cd, cdAttr) {\n    return lib.mergeArray(traceAttr, cd, cdAttr, function(v) {\n        var w = +v;\n        return !isFinite(w) ? 0 : w > 0 ? w : 0;\n    });\n};\n\n/** fills calcdata field (given by cdAttr) with traceAttr values\n *  or function of traceAttr values (e.g. some fallback)\n *\n * N.B. Loops over all cd items.\n *\n * @param {array} traceAttr : trace attribute\n * @param {object} cd : calcdata trace\n * @param {string} cdAttr : calcdata key\n * @param {function} [fn] : optional function to apply to each array item\n */\nlib.fillArray = function(traceAttr, cd, cdAttr, fn) {\n    fn = fn || lib.identity;\n\n    if(lib.isArrayOrTypedArray(traceAttr)) {\n        for(var i = 0; i < cd.length; i++) {\n            cd[i][cdAttr] = fn(traceAttr[i]);\n        }\n    }\n};\n\n/** Handler for trace-wide vs per-point options\n *\n * @param {object} trace : (full) trace object\n * @param {number} ptNumber : index of the point in question\n * @param {string} astr : attribute string\n * @param {function} [fn] : optional function to apply to each array item\n *\n * @return {any}\n */\nlib.castOption = function(trace, ptNumber, astr, fn) {\n    fn = fn || lib.identity;\n\n    var val = lib.nestedProperty(trace, astr).get();\n\n    if(lib.isArrayOrTypedArray(val)) {\n        if(Array.isArray(ptNumber) && lib.isArrayOrTypedArray(val[ptNumber[0]])) {\n            return fn(val[ptNumber[0]][ptNumber[1]]);\n        } else {\n            return fn(val[ptNumber]);\n        }\n    } else {\n        return val;\n    }\n};\n\n/** Extract option from calcdata item, correctly falling back to\n *  trace value if not found.\n *\n *  @param {object} calcPt : calcdata[i][j] item\n *  @param {object} trace : (full) trace object\n *  @param {string} calcKey : calcdata key\n *  @param {string} traceKey : aka trace attribute string\n *  @return {any}\n */\nlib.extractOption = function(calcPt, trace, calcKey, traceKey) {\n    if(calcKey in calcPt) return calcPt[calcKey];\n\n    // fallback to trace value,\n    //   must check if value isn't itself an array\n    //   which means the trace attribute has a corresponding\n    //   calcdata key, but its value is falsy\n    var traceVal = lib.nestedProperty(trace, traceKey).get();\n    if(!Array.isArray(traceVal)) return traceVal;\n};\n\nfunction makePtIndex2PtNumber(indexToPoints) {\n    var ptIndex2ptNumber = {};\n    for(var k in indexToPoints) {\n        var pts = indexToPoints[k];\n        for(var j = 0; j < pts.length; j++) {\n            ptIndex2ptNumber[pts[j]] = +k;\n        }\n    }\n    return ptIndex2ptNumber;\n}\n\n/** Tag selected calcdata items\n *\n * N.B. note that point 'index' corresponds to input data array index\n *  whereas 'number' is its post-transform version.\n *\n * @param {array} calcTrace\n * @param {object} trace\n *  - selectedpoints {array}\n *  - _indexToPoints {object}\n * @param {ptNumber2cdIndex} ptNumber2cdIndex (optional)\n *  optional map object for trace types that do not have 1-to-1 point number to\n *  calcdata item index correspondence (e.g. histogram)\n */\nlib.tagSelected = function(calcTrace, trace, ptNumber2cdIndex) {\n    var selectedpoints = trace.selectedpoints;\n    var indexToPoints = trace._indexToPoints;\n    var ptIndex2ptNumber;\n\n    // make pt index-to-number map object, which takes care of transformed traces\n    if(indexToPoints) {\n        ptIndex2ptNumber = makePtIndex2PtNumber(indexToPoints);\n    }\n\n    function isCdIndexValid(v) {\n        return v !== undefined && v < calcTrace.length;\n    }\n\n    for(var i = 0; i < selectedpoints.length; i++) {\n        var ptIndex = selectedpoints[i];\n\n        if(lib.isIndex(ptIndex) ||\n           (lib.isArrayOrTypedArray(ptIndex) && lib.isIndex(ptIndex[0]) && lib.isIndex(ptIndex[1]))\n        ) {\n            var ptNumber = ptIndex2ptNumber ? ptIndex2ptNumber[ptIndex] : ptIndex;\n            var cdIndex = ptNumber2cdIndex ? ptNumber2cdIndex[ptNumber] : ptNumber;\n\n            if(isCdIndexValid(cdIndex)) {\n                calcTrace[cdIndex].selected = 1;\n            }\n        }\n    }\n};\n\nlib.selIndices2selPoints = function(trace) {\n    var selectedpoints = trace.selectedpoints;\n    var indexToPoints = trace._indexToPoints;\n\n    if(indexToPoints) {\n        var ptIndex2ptNumber = makePtIndex2PtNumber(indexToPoints);\n        var out = [];\n\n        for(var i = 0; i < selectedpoints.length; i++) {\n            var ptIndex = selectedpoints[i];\n            if(lib.isIndex(ptIndex)) {\n                var ptNumber = ptIndex2ptNumber[ptIndex];\n                if(lib.isIndex(ptNumber)) {\n                    out.push(ptNumber);\n                }\n            }\n        }\n\n        return out;\n    } else {\n        return selectedpoints;\n    }\n};\n\n/** Returns target as set by 'target' transform attribute\n *\n * @param {object} trace : full trace object\n * @param {object} transformOpts : transform option object\n *  - target (string} :\n *      either an attribute string referencing an array in the trace object, or\n *      a set array.\n *\n * @return {array or false} : the target array (NOT a copy!!) or false if invalid\n */\nlib.getTargetArray = function(trace, transformOpts) {\n    var target = transformOpts.target;\n\n    if(typeof target === 'string' && target) {\n        var array = lib.nestedProperty(trace, target).get();\n        return Array.isArray(array) ? array : false;\n    } else if(Array.isArray(target)) {\n        return target;\n    }\n\n    return false;\n};\n\n/**\n * modified version of jQuery's extend to strip out private objs and functions,\n * and cut arrays down to first  or 1 elements\n * because extend-like algorithms are hella slow\n * obj2 is assumed to already be clean of these things (including no arrays)\n */\nlib.minExtend = function(obj1, obj2) {\n    var objOut = {};\n    if(typeof obj2 !== 'object') obj2 = {};\n    var arrayLen = 3;\n    var keys = Object.keys(obj1);\n    var i, k, v;\n\n    for(i = 0; i < keys.length; i++) {\n        k = keys[i];\n        v = obj1[k];\n        if(k.charAt(0) === '_' || typeof v === 'function') continue;\n        else if(k === 'module') objOut[k] = v;\n        else if(Array.isArray(v)) {\n            if(k === 'colorscale') {\n                objOut[k] = v.slice();\n            } else {\n                objOut[k] = v.slice(0, arrayLen);\n            }\n        } else if(lib.isTypedArray(v)) {\n            objOut[k] = v.subarray(0, arrayLen);\n        } else if(v && (typeof v === 'object')) objOut[k] = lib.minExtend(obj1[k], obj2[k]);\n        else objOut[k] = v;\n    }\n\n    keys = Object.keys(obj2);\n    for(i = 0; i < keys.length; i++) {\n        k = keys[i];\n        v = obj2[k];\n        if(typeof v !== 'object' || !(k in objOut) || typeof objOut[k] !== 'object') {\n            objOut[k] = v;\n        }\n    }\n\n    return objOut;\n};\n\nlib.titleCase = function(s) {\n    return s.charAt(0).toUpperCase() + s.substr(1);\n};\n\nlib.containsAny = function(s, fragments) {\n    for(var i = 0; i < fragments.length; i++) {\n        if(s.indexOf(fragments[i]) !== -1) return true;\n    }\n    return false;\n};\n\nlib.isIE = function() {\n    return typeof window.navigator.msSaveBlob !== 'undefined';\n};\n\nvar IS_IE9_OR_BELOW_REGEX = /MSIE [1-9]\\./;\nlib.isIE9orBelow = function() {\n    return lib.isIE() && IS_IE9_OR_BELOW_REGEX.test(window.navigator.userAgent);\n};\n\nvar IS_SAFARI_REGEX = /Version\\/[\\d\\.]+.*Safari/;\nlib.isSafari = function() {\n    return IS_SAFARI_REGEX.test(window.navigator.userAgent);\n};\n\n/**\n * Duck typing to recognize a d3 selection, mostly for IE9's benefit\n * because it doesn't handle instanceof like modern browsers\n */\nlib.isD3Selection = function(obj) {\n    return obj && (typeof obj.classed === 'function');\n};\n\n/**\n * Append element to DOM only if not present.\n *\n * @param {d3 selection} parent : parent selection of the element in question\n * @param {string} nodeType : node type of element to append\n * @param {string} className (optional) : class name of element in question\n * @param {fn} enterFn (optional) : optional fn applied to entering elements only\n * @return {d3 selection} selection of new layer\n *\n * Previously, we were using the following pattern:\n *\n * ```\n * var sel = parent.selectAll('.' + className)\n *     .data([0]);\n *\n * sel.enter().append(nodeType)\n *     .classed(className, true);\n *\n * return sel;\n * ```\n *\n * in numerous places in our codebase to achieve the same behavior.\n *\n * The logic below performs much better, mostly as we are using\n * `.select` instead `.selectAll` that is `querySelector` instead of\n * `querySelectorAll`.\n *\n */\nlib.ensureSingle = function(parent, nodeType, className, enterFn) {\n    var sel = parent.select(nodeType + (className ? '.' + className : ''));\n    if(sel.size()) return sel;\n\n    var layer = parent.append(nodeType);\n    if(className) layer.classed(className, true);\n    if(enterFn) layer.call(enterFn);\n\n    return layer;\n};\n\n/**\n * Same as Lib.ensureSingle, but using id as selector.\n * This version is mostly used for clipPath nodes.\n *\n * @param {d3 selection} parent : parent selection of the element in question\n * @param {string} nodeType : node type of element to append\n * @param {string} id : id of element in question\n * @param {fn} enterFn (optional) : optional fn applied to entering elements only\n * @return {d3 selection} selection of new layer\n */\nlib.ensureSingleById = function(parent, nodeType, id, enterFn) {\n    var sel = parent.select(nodeType + '#' + id);\n    if(sel.size()) return sel;\n\n    var layer = parent.append(nodeType).attr('id', id);\n    if(enterFn) layer.call(enterFn);\n\n    return layer;\n};\n\n/**\n * Converts a string path to an object.\n *\n * When given a string containing an array element, it will create a `null`\n * filled array of the given size.\n *\n * @example\n * lib.objectFromPath('nested.test[2].path', 'value');\n * // returns { nested: { test: [null, null, { path: 'value' }]}\n *\n * @param   {string}    path to nested value\n * @param   {*}         any value to be set\n *\n * @return {Object} the constructed object with a full nested path\n */\nlib.objectFromPath = function(path, value) {\n    var keys = path.split('.');\n    var tmpObj;\n    var obj = tmpObj = {};\n\n    for(var i = 0; i < keys.length; i++) {\n        var key = keys[i];\n        var el = null;\n\n        var parts = keys[i].match(/(.*)\\[([0-9]+)\\]/);\n\n        if(parts) {\n            key = parts[1];\n            el = parts[2];\n\n            tmpObj = tmpObj[key] = [];\n\n            if(i === keys.length - 1) {\n                tmpObj[el] = value;\n            } else {\n                tmpObj[el] = {};\n            }\n\n            tmpObj = tmpObj[el];\n        } else {\n            if(i === keys.length - 1) {\n                tmpObj[key] = value;\n            } else {\n                tmpObj[key] = {};\n            }\n\n            tmpObj = tmpObj[key];\n        }\n    }\n\n    return obj;\n};\n\n/**\n * Iterate through an object in-place, converting dotted properties to objects.\n *\n * Examples:\n *\n *   lib.expandObjectPaths({'nested.test.path': 'value'});\n *     => { nested: { test: {path: 'value'}}}\n *\n * It also handles array notation, e.g.:\n *\n *   lib.expandObjectPaths({'foo[1].bar': 'value'});\n *     => { foo: [null, {bar: value}] }\n *\n * It handles merges the results when two properties are specified in parallel:\n *\n *   lib.expandObjectPaths({'foo[1].bar': 10, 'foo[0].bar': 20});\n *     => { foo: [{bar: 10}, {bar: 20}] }\n *\n * It does NOT, however, merge mulitple mutliply-nested arrays::\n *\n *   lib.expandObjectPaths({'marker[1].range[1]': 5, 'marker[1].range[0]': 4})\n *     => { marker: [null, {range: 4}] }\n */\n\n// Store this to avoid recompiling regex on *every* prop since this may happen many\n// many times for animations. Could maybe be inside the function. Not sure about\n// scoping vs. recompilation tradeoff, but at least it's not just inlining it into\n// the inner loop.\nvar dottedPropertyRegex = /^([^\\[\\.]+)\\.(.+)?/;\nvar indexedPropertyRegex = /^([^\\.]+)\\[([0-9]+)\\](\\.)?(.+)?/;\n\nlib.expandObjectPaths = function(data) {\n    var match, key, prop, datum, idx, dest, trailingPath;\n    if(typeof data === 'object' && !Array.isArray(data)) {\n        for(key in data) {\n            if(data.hasOwnProperty(key)) {\n                if((match = key.match(dottedPropertyRegex))) {\n                    datum = data[key];\n                    prop = match[1];\n\n                    delete data[key];\n\n                    data[prop] = lib.extendDeepNoArrays(data[prop] || {}, lib.objectFromPath(key, lib.expandObjectPaths(datum))[prop]);\n                } else if((match = key.match(indexedPropertyRegex))) {\n                    datum = data[key];\n\n                    prop = match[1];\n                    idx = parseInt(match[2]);\n\n                    delete data[key];\n\n                    data[prop] = data[prop] || [];\n\n                    if(match[3] === '.') {\n                        // This is the case where theere are subsequent properties into which\n                        // we must recurse, e.g. transforms[0].value\n                        trailingPath = match[4];\n                        dest = data[prop][idx] = data[prop][idx] || {};\n\n                        // NB: Extend deep no arrays prevents this from working on multiple\n                        // nested properties in the same object, e.g.\n                        //\n                        // {\n                        //   foo[0].bar[1].range\n                        //   foo[0].bar[0].range\n                        // }\n                        //\n                        // In this case, the extendDeepNoArrays will overwrite one array with\n                        // the other, so that both properties *will not* be present in the\n                        // result. Fixing this would require a more intelligent tracking\n                        // of changes and merging than extendDeepNoArrays currently accomplishes.\n                        lib.extendDeepNoArrays(dest, lib.objectFromPath(trailingPath, lib.expandObjectPaths(datum)));\n                    } else {\n                        // This is the case where this property is the end of the line,\n                        // e.g. xaxis.range[0]\n                        data[prop][idx] = lib.expandObjectPaths(datum);\n                    }\n                } else {\n                    data[key] = lib.expandObjectPaths(data[key]);\n                }\n            }\n        }\n    }\n\n    return data;\n};\n\n/**\n * Converts value to string separated by the provided separators.\n *\n * @example\n * lib.numSeparate(2016, '.,');\n * // returns '2016'\n *\n * @example\n * lib.numSeparate(3000, '.,', true);\n * // returns '3,000'\n *\n * @example\n * lib.numSeparate(1234.56, '|,')\n * // returns '1,234|56'\n *\n * @param   {string|number} value       the value to be converted\n * @param   {string}    separators  string of decimal, then thousands separators\n * @param   {boolean}    separatethousands  boolean, 4-digit integers are separated if true\n *\n * @return  {string}    the value that has been separated\n */\nlib.numSeparate = function(value, separators, separatethousands) {\n    if(!separatethousands) separatethousands = false;\n\n    if(typeof separators !== 'string' || separators.length === 0) {\n        throw new Error('Separator string required for formatting!');\n    }\n\n    if(typeof value === 'number') {\n        value = String(value);\n    }\n\n    var thousandsRe = /(\\d+)(\\d{3})/;\n    var decimalSep = separators.charAt(0);\n    var thouSep = separators.charAt(1);\n\n    var x = value.split('.');\n    var x1 = x[0];\n    var x2 = x.length > 1 ? decimalSep + x[1] : '';\n\n    // Years are ignored for thousands separators\n    if(thouSep && (x.length > 1 || x1.length > 4 || separatethousands)) {\n        while(thousandsRe.test(x1)) {\n            x1 = x1.replace(thousandsRe, '$1' + thouSep + '$2');\n        }\n    }\n\n    return x1 + x2;\n};\n\nlib.TEMPLATE_STRING_REGEX = /%{([^\\s%{}:]*)([:|\\|][^}]*)?}/g;\nvar SIMPLE_PROPERTY_REGEX = /^\\w*$/;\n\n/**\n * Substitute values from an object into a string\n *\n * Examples:\n *  Lib.templateString('name: %{trace}', {trace: 'asdf'}) --> 'name: asdf'\n *  Lib.templateString('name: %{trace[0].name}', {trace: [{name: 'asdf'}]}) --> 'name: asdf'\n *\n * @param {string}  input string containing %{...} template strings\n * @param {obj}     data object containing substitution values\n *\n * @return {string} templated string\n */\nlib.templateString = function(string, obj) {\n    // Not all that useful, but cache nestedProperty instantiation\n    // just in case it speeds things up *slightly*:\n    var getterCache = {};\n\n    return string.replace(lib.TEMPLATE_STRING_REGEX, function(dummy, key) {\n        var v;\n        if(SIMPLE_PROPERTY_REGEX.test(key)) {\n            v = obj[key];\n        } else {\n            getterCache[key] = getterCache[key] || lib.nestedProperty(obj, key).get;\n            v = getterCache[key]();\n        }\n        return lib.isValidTextValue(v) ? v : '';\n    });\n};\n\nvar hovertemplateWarnings = {\n    max: 10,\n    count: 0,\n    name: 'hovertemplate'\n};\nlib.hovertemplateString = function() {\n    return templateFormatString.apply(hovertemplateWarnings, arguments);\n};\n\nvar texttemplateWarnings = {\n    max: 10,\n    count: 0,\n    name: 'texttemplate'\n};\nlib.texttemplateString = function() {\n    return templateFormatString.apply(texttemplateWarnings, arguments);\n};\n\nvar TEMPLATE_STRING_FORMAT_SEPARATOR = /^[:|\\|]/;\n/**\n * Substitute values from an object into a string and optionally formats them using d3-format,\n * or fallback to associated labels.\n *\n * Examples:\n *  Lib.hovertemplateString('name: %{trace}', {trace: 'asdf'}) --> 'name: asdf'\n *  Lib.hovertemplateString('name: %{trace[0].name}', {trace: [{name: 'asdf'}]}) --> 'name: asdf'\n *  Lib.hovertemplateString('price: %{y:$.2f}', {y: 1}) --> 'price: $1.00'\n *\n * @param {string}  input string containing %{...:...} template strings\n * @param {obj}     data object containing fallback text when no formatting is specified, ex.: {yLabel: 'formattedYValue'}\n * @param {obj}     d3 locale\n * @param {obj}     data objects containing substitution values\n *\n * @return {string} templated string\n */\nfunction templateFormatString(string, labels, d3locale) {\n    var opts = this;\n    var args = arguments;\n    if(!labels) labels = {};\n    // Not all that useful, but cache nestedProperty instantiation\n    // just in case it speeds things up *slightly*:\n    var getterCache = {};\n\n    return string.replace(lib.TEMPLATE_STRING_REGEX, function(match, key, format) {\n        var obj, value, i;\n        for(i = 3; i < args.length; i++) {\n            obj = args[i];\n            if(!obj) continue;\n            if(obj.hasOwnProperty(key)) {\n                value = obj[key];\n                break;\n            }\n\n            if(!SIMPLE_PROPERTY_REGEX.test(key)) {\n                value = getterCache[key] || lib.nestedProperty(obj, key).get();\n                if(value) getterCache[key] = value;\n            }\n            if(value !== undefined) break;\n        }\n\n        if(value === undefined && opts) {\n            if(opts.count < opts.max) {\n                lib.warn('Variable \\'' + key + '\\' in ' + opts.name + ' could not be found!');\n                value = match;\n            }\n\n            if(opts.count === opts.max) {\n                lib.warn('Too many ' + opts.name + ' warnings - additional warnings will be suppressed');\n            }\n            opts.count++;\n\n            return match;\n        }\n\n        if(format) {\n            var fmt;\n            if(format[0] === ':') {\n                fmt = d3locale ? d3locale.numberFormat : d3.format;\n                value = fmt(format.replace(TEMPLATE_STRING_FORMAT_SEPARATOR, ''))(value);\n            }\n\n            if(format[0] === '|') {\n                fmt = d3locale ? d3locale.timeFormat.utc : d3.time.format.utc;\n                var ms = lib.dateTime2ms(value);\n                value = lib.formatDate(ms, format.replace(TEMPLATE_STRING_FORMAT_SEPARATOR, ''), false, fmt);\n            }\n        } else {\n            if(labels.hasOwnProperty(key + 'Label')) value = labels[key + 'Label'];\n        }\n        return value;\n    });\n}\n\n/*\n * alphanumeric string sort, tailored for subplot IDs like scene2, scene10, x10y13 etc\n */\nvar char0 = 48;\nvar char9 = 57;\nlib.subplotSort = function(a, b) {\n    var l = Math.min(a.length, b.length) + 1;\n    var numA = 0;\n    var numB = 0;\n    for(var i = 0; i < l; i++) {\n        var charA = a.charCodeAt(i) || 0;\n        var charB = b.charCodeAt(i) || 0;\n        var isNumA = charA >= char0 && charA <= char9;\n        var isNumB = charB >= char0 && charB <= char9;\n\n        if(isNumA) numA = 10 * numA + charA - char0;\n        if(isNumB) numB = 10 * numB + charB - char0;\n\n        if(!isNumA || !isNumB) {\n            if(numA !== numB) return numA - numB;\n            if(charA !== charB) return charA - charB;\n        }\n    }\n    return numB - numA;\n};\n\n// repeatable pseudorandom generator\nvar randSeed = 2000000000;\n\nlib.seedPseudoRandom = function() {\n    randSeed = 2000000000;\n};\n\nlib.pseudoRandom = function() {\n    var lastVal = randSeed;\n    randSeed = (69069 * randSeed + 1) % 4294967296;\n    // don't let consecutive vals be too close together\n    // gets away from really trying to be random, in favor of better local uniformity\n    if(Math.abs(randSeed - lastVal) < 429496729) return lib.pseudoRandom();\n    return randSeed / 4294967296;\n};\n\n\n/** Fill hover 'pointData' container with 'correct' hover text value\n *\n * - If trace hoverinfo contains a 'text' flag and hovertext is not set,\n *   the text elements will be seen in the hover labels.\n *\n * - If trace hoverinfo contains a 'text' flag and hovertext is set,\n *   hovertext takes precedence over text\n *   i.e. the hoverinfo elements will be seen in the hover labels\n *\n *  @param {object} calcPt\n *  @param {object} trace\n *  @param {object || array} contOut (mutated here)\n */\nlib.fillText = function(calcPt, trace, contOut) {\n    var fill = Array.isArray(contOut) ?\n        function(v) { contOut.push(v); } :\n        function(v) { contOut.text = v; };\n\n    var htx = lib.extractOption(calcPt, trace, 'htx', 'hovertext');\n    if(lib.isValidTextValue(htx)) return fill(htx);\n\n    var tx = lib.extractOption(calcPt, trace, 'tx', 'text');\n    if(lib.isValidTextValue(tx)) return fill(tx);\n};\n\n// accept all truthy values and 0 (which gets cast to '0' in the hover labels)\nlib.isValidTextValue = function(v) {\n    return v || v === 0;\n};\n\n/**\n * @param {number} ratio\n * @param {number} n (number of decimal places)\n */\nlib.formatPercent = function(ratio, n) {\n    n = n || 0;\n    var str = (Math.round(100 * ratio * Math.pow(10, n)) * Math.pow(0.1, n)).toFixed(n) + '%';\n    for(var i = 0; i < n; i++) {\n        if(str.indexOf('.') !== -1) {\n            str = str.replace('0%', '%');\n            str = str.replace('.%', '%');\n        }\n    }\n    return str;\n};\n\nlib.isHidden = function(gd) {\n    var display = window.getComputedStyle(gd).display;\n    return !display || display === 'none';\n};\n\n/** Return transform text for bar bar-like rectangles and pie-like slices\n *  @param {object} transform\n *  - targetX: desired position on the x-axis\n *  - targetY: desired position on the y-axis\n *  - textX: text middle position on the x-axis\n *  - textY: text middle position on the y-axis\n *  - anchorX: (optional) text anchor position on the x-axis (computed from textX), zero for middle anchor\n *  - anchorY: (optional) text anchor position on the y-axis (computed from textY), zero for middle anchor\n *  - scale: (optional) scale applied after translate\n *  - rotate: (optional) rotation applied after scale\n *  - noCenter: when defined no extra arguments needed in rotation\n */\nlib.getTextTransform = function(transform) {\n    var noCenter = transform.noCenter;\n    var textX = transform.textX;\n    var textY = transform.textY;\n    var targetX = transform.targetX;\n    var targetY = transform.targetY;\n    var anchorX = transform.anchorX || 0;\n    var anchorY = transform.anchorY || 0;\n    var rotate = transform.rotate;\n    var scale = transform.scale;\n    if(!scale) scale = 0;\n    else if(scale > 1) scale = 1;\n\n    return (\n        'translate(' +\n            (targetX - scale * (textX + anchorX)) + ',' +\n            (targetY - scale * (textY + anchorY)) +\n        ')' +\n        (scale < 1 ?\n            'scale(' + scale + ')' : ''\n        ) +\n        (rotate ?\n            'rotate(' + rotate +\n                (noCenter ? '' : ' ' + textX + ' ' + textY) +\n            ')' : ''\n        )\n    );\n};\n\nlib.ensureUniformFontSize = function(gd, baseFont) {\n    var out = lib.extendFlat({}, baseFont);\n    out.size = Math.max(\n        baseFont.size,\n        gd._fullLayout.uniformtext.minsize || 0\n    );\n    return out;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * sanitized modulus function that always returns in the range [0, d)\n * rather than (-d, 0] if v is negative\n */\nfunction mod(v, d) {\n    var out = v % d;\n    return out < 0 ? out + d : out;\n}\n\n/**\n * sanitized modulus function that always returns in the range [-d/2, d/2]\n * rather than (-d, 0] if v is negative\n */\nfunction modHalf(v, d) {\n    return Math.abs(v) > (d / 2) ?\n        v - Math.round(v / d) * d :\n        v;\n}\n\nmodule.exports = {\n    mod: mod,\n    modHalf: modHalf\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nmodule.exports = function handleXYDefaults(traceIn, traceOut, layout, coerce) {\n    var x = coerce('x');\n    var y = coerce('y');\n    var len;\n\n    var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n    handleCalendarDefaults(traceIn, traceOut, ['x', 'y'], layout);\n\n    if(x) {\n        var xlen = Lib.minRowLength(x);\n        if(y) {\n            len = Math.min(xlen, Lib.minRowLength(y));\n        } else {\n            len = xlen;\n            coerce('y0');\n            coerce('dy');\n        }\n    } else {\n        if(!y) return 0;\n\n        len = Lib.minRowLength(y);\n        coerce('x0');\n        coerce('dx');\n    }\n\n    traceOut._length = len;\n\n    return len;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/* global MathJax:false */\n\nmodule.exports = function() {\n    if(typeof MathJax !== 'undefined') {\n        var globalConfig = (window.PlotlyConfig || {}).MathJaxConfig !== 'local';\n\n        if(globalConfig) {\n            MathJax.Hub.Config({\n                messageStyle: 'none',\n                skipStartupTypeset: true,\n                displayAlign: 'left',\n                tex2jax: {\n                    inlineMath: [['$', '$'], ['\\\\(', '\\\\)']]\n                }\n            });\n            MathJax.Hub.Configured();\n        }\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\n/**\n * aggNums() returns the result of an aggregate function applied to an array of\n * values, where non-numerical values have been tossed out.\n *\n * @param {function} f - aggregation function (e.g., Math.min)\n * @param {Number} v - initial value (continuing from previous calls)\n *      if there's no continuing value, use null for selector-type\n *      functions (max,min), or 0 for summations\n * @param {Array} a - array to aggregate (may be nested, we will recurse,\n *                    but all elements must have the same dimension)\n * @param {Number} len - maximum length of a to aggregate\n * @return {Number} - result of f applied to a starting from v\n */\nexports.aggNums = function(f, v, a, len) {\n    var i,\n        b;\n    if(!len || len > a.length) len = a.length;\n    if(!isNumeric(v)) v = false;\n    if(isArrayOrTypedArray(a[0])) {\n        b = new Array(len);\n        for(i = 0; i < len; i++) b[i] = exports.aggNums(f, v, a[i]);\n        a = b;\n    }\n\n    for(i = 0; i < len; i++) {\n        if(!isNumeric(v)) v = a[i];\n        else if(isNumeric(a[i])) v = f(+v, +a[i]);\n    }\n    return v;\n};\n\n/**\n * mean & std dev functions using aggNums, so it handles non-numerics nicely\n * even need to use aggNums instead of .length, to toss out non-numerics\n */\nexports.len = function(data) {\n    return exports.aggNums(function(a) { return a + 1; }, 0, data);\n};\n\nexports.mean = function(data, len) {\n    if(!len) len = exports.len(data);\n    return exports.aggNums(function(a, b) { return a + b; }, 0, data) / len;\n};\n\nexports.midRange = function(numArr) {\n    if(numArr === undefined || numArr.length === 0) return undefined;\n    return (exports.aggNums(Math.max, null, numArr) + exports.aggNums(Math.min, null, numArr)) / 2;\n};\n\nexports.variance = function(data, len, mean) {\n    if(!len) len = exports.len(data);\n    if(!isNumeric(mean)) mean = exports.mean(data, len);\n\n    return exports.aggNums(function(a, b) {\n        return a + Math.pow(b - mean, 2);\n    }, 0, data) / len;\n};\n\nexports.stdev = function(data, len, mean) {\n    return Math.sqrt(exports.variance(data, len, mean));\n};\n\n/**\n * median of a finite set of numbers\n * reference page: https://en.wikipedia.org/wiki/Median#Finite_set_of_numbers\n**/\nexports.median = function(data) {\n    var b = data.slice().sort();\n    return exports.interp(b, 0.5);\n};\n\n/**\n * interp() computes a percentile (quantile) for a given distribution.\n * We interpolate the distribution (to compute quantiles, we follow method #10 here:\n * http://www.amstat.org/publications/jse/v14n3/langford.html).\n * Typically the index or rank (n * arr.length) may be non-integer.\n * For reference: ends are clipped to the extreme values in the array;\n * For box plots: index you get is half a point too high (see\n * http://en.wikipedia.org/wiki/Percentile#Nearest_rank) but note that this definition\n * indexes from 1 rather than 0, so we subtract 1/2 (instead of add).\n *\n * @param {Array} arr - This array contains the values that make up the distribution.\n * @param {Number} n - Between 0 and 1, n = p/100 is such that we compute the p^th percentile.\n * For example, the 50th percentile (or median) corresponds to n = 0.5\n * @return {Number} - percentile\n */\nexports.interp = function(arr, n) {\n    if(!isNumeric(n)) throw 'n should be a finite number';\n    n = n * arr.length - 0.5;\n    if(n < 0) return arr[0];\n    if(n > arr.length - 1) return arr[arr.length - 1];\n    var frac = n % 1;\n    return frac * arr[Math.ceil(n)] + (1 - frac) * arr[Math.floor(n)];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar helpers = require('./helpers');\n\n/*\n* substantial portions of this code from FileSaver.js\n* https://github.com/eligrey/FileSaver.js\n* License: https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md\n* FileSaver.js\n* A saveAs() FileSaver implementation.\n* 1.1.20160328\n*\n* By Eli Grey, http://eligrey.com\n* License: MIT\n*   See https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md\n*/\nfunction fileSaver(url, name, format) {\n    var saveLink = document.createElement('a');\n    var canUseSaveLink = 'download' in saveLink;\n\n    var promise = new Promise(function(resolve, reject) {\n        var blob;\n        var objectUrl;\n\n        if(Lib.isIE9orBelow()) {\n            reject(new Error('IE < 10 unsupported'));\n        }\n\n        // Safari doesn't allow downloading of blob urls\n        if(Lib.isSafari()) {\n            var prefix = format === 'svg' ? ',' : ';base64,';\n            helpers.octetStream(prefix + encodeURIComponent(url));\n            return resolve(name);\n        }\n\n        // IE 10+ (native saveAs)\n        if(Lib.isIE()) {\n            // At this point we are only dealing with a decoded SVG as\n            // a data URL (since IE only supports SVG)\n            blob = helpers.createBlob(url, 'svg');\n            window.navigator.msSaveBlob(blob, name);\n            blob = null;\n            return resolve(name);\n        }\n\n        if(canUseSaveLink) {\n            blob = helpers.createBlob(url, format);\n            objectUrl = helpers.createObjectURL(blob);\n\n            saveLink.href = objectUrl;\n            saveLink.download = name;\n            document.body.appendChild(saveLink);\n            saveLink.click();\n\n            document.body.removeChild(saveLink);\n            helpers.revokeObjectURL(objectUrl);\n            blob = null;\n\n            return resolve(name);\n        }\n\n        reject(new Error('download error'));\n    });\n\n    return promise;\n}\n\n\nmodule.exports = fileSaver;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Fx = require('../fx');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar setCursor = require('../../lib/setcursor');\nvar dragElement = require('../dragelement');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar drawArrowHead = require('./draw_arrow_head');\n\n// Annotations are stored in gd.layout.annotations, an array of objects\n// index can point to one item in this array,\n//  or non-numeric to simply add a new one\n//  or -1 to modify all existing\n// opt can be the full options object, or one key (to be set to value)\n//  or undefined to simply redraw\n// if opt is blank, val can be 'add' or a full options object to add a new\n//  annotation at that point in the array, or 'remove' to delete this one\n\nmodule.exports = {\n    draw: draw,\n    drawOne: drawOne,\n    drawRaw: drawRaw\n};\n\n/*\n * draw: draw all annotations without any new modifications\n */\nfunction draw(gd) {\n    var fullLayout = gd._fullLayout;\n\n    fullLayout._infolayer.selectAll('.annotation').remove();\n\n    for(var i = 0; i < fullLayout.annotations.length; i++) {\n        if(fullLayout.annotations[i].visible) {\n            drawOne(gd, i);\n        }\n    }\n\n    return Plots.previousPromises(gd);\n}\n\n/*\n * drawOne: draw a single cartesian or paper-ref annotation, potentially with modifications\n *\n * index (int): the annotation to draw\n */\nfunction drawOne(gd, index) {\n    var fullLayout = gd._fullLayout;\n    var options = fullLayout.annotations[index] || {};\n    var xa = Axes.getFromId(gd, options.xref);\n    var ya = Axes.getFromId(gd, options.yref);\n\n    if(xa) xa.setScale();\n    if(ya) ya.setScale();\n\n    drawRaw(gd, options, index, false, xa, ya);\n}\n\n/**\n * drawRaw: draw a single annotation, potentially with modifications\n *\n * @param {DOM element} gd\n * @param {object} options : this annotation's fullLayout options\n * @param {integer} index : index in 'annotations' container of the annotation to draw\n * @param {string} subplotId : id of the annotation's subplot\n *  - use false for 2d (i.e. cartesian or paper-ref) annotations\n * @param {object | undefined} xa : full x-axis object to compute subplot pos-to-px\n * @param {object | undefined} ya : ... y-axis\n */\nfunction drawRaw(gd, options, index, subplotId, xa, ya) {\n    var fullLayout = gd._fullLayout;\n    var gs = gd._fullLayout._size;\n    var edits = gd._context.edits;\n\n    var className, containerStr;\n\n    if(subplotId) {\n        className = 'annotation-' + subplotId;\n        containerStr = subplotId + '.annotations';\n    } else {\n        className = 'annotation';\n        containerStr = 'annotations';\n    }\n\n    var editHelpers = arrayEditor(gd.layout, containerStr, options);\n    var modifyBase = editHelpers.modifyBase;\n    var modifyItem = editHelpers.modifyItem;\n    var getUpdateObj = editHelpers.getUpdateObj;\n\n    // remove the existing annotation if there is one\n    fullLayout._infolayer\n        .selectAll('.' + className + '[data-index=\"' + index + '\"]')\n        .remove();\n\n    var annClipID = 'clip' + fullLayout._uid + '_ann' + index;\n\n    // this annotation is gone - quit now after deleting it\n    // TODO: use d3 idioms instead of deleting and redrawing every time\n    if(!options._input || options.visible === false) {\n        d3.selectAll('#' + annClipID).remove();\n        return;\n    }\n\n    // calculated pixel positions\n    // x & y each will get text, head, and tail as appropriate\n    var annPosPx = {x: {}, y: {}};\n    var textangle = +options.textangle || 0;\n\n    // create the components\n    // made a single group to contain all, so opacity can work right\n    // with border/arrow together this could handle a whole bunch of\n    // cleanup at this point, but works for now\n    var annGroup = fullLayout._infolayer.append('g')\n        .classed(className, true)\n        .attr('data-index', String(index))\n        .style('opacity', options.opacity);\n\n    // another group for text+background so that they can rotate together\n    var annTextGroup = annGroup.append('g')\n        .classed('annotation-text-g', true);\n\n    var editTextPosition = edits[options.showarrow ? 'annotationTail' : 'annotationPosition'];\n    var textEvents = options.captureevents || edits.annotationText || editTextPosition;\n\n    function makeEventData(initialEvent) {\n        var eventData = {\n            index: index,\n            annotation: options._input,\n            fullAnnotation: options,\n            event: initialEvent\n        };\n        if(subplotId) {\n            eventData.subplotId = subplotId;\n        }\n        return eventData;\n    }\n\n    var annTextGroupInner = annTextGroup.append('g')\n        .style('pointer-events', textEvents ? 'all' : null)\n        .call(setCursor, 'pointer')\n        .on('click', function() {\n            gd._dragging = false;\n            gd.emit('plotly_clickannotation', makeEventData(d3.event));\n        });\n\n    if(options.hovertext) {\n        annTextGroupInner\n        .on('mouseover', function() {\n            var hoverOptions = options.hoverlabel;\n            var hoverFont = hoverOptions.font;\n            var bBox = this.getBoundingClientRect();\n            var bBoxRef = gd.getBoundingClientRect();\n\n            Fx.loneHover({\n                x0: bBox.left - bBoxRef.left,\n                x1: bBox.right - bBoxRef.left,\n                y: (bBox.top + bBox.bottom) / 2 - bBoxRef.top,\n                text: options.hovertext,\n                color: hoverOptions.bgcolor,\n                borderColor: hoverOptions.bordercolor,\n                fontFamily: hoverFont.family,\n                fontSize: hoverFont.size,\n                fontColor: hoverFont.color\n            }, {\n                container: fullLayout._hoverlayer.node(),\n                outerContainer: fullLayout._paper.node(),\n                gd: gd\n            });\n        })\n        .on('mouseout', function() {\n            Fx.loneUnhover(fullLayout._hoverlayer.node());\n        });\n    }\n\n    var borderwidth = options.borderwidth;\n    var borderpad = options.borderpad;\n    var borderfull = borderwidth + borderpad;\n\n    var annTextBG = annTextGroupInner.append('rect')\n        .attr('class', 'bg')\n        .style('stroke-width', borderwidth + 'px')\n        .call(Color.stroke, options.bordercolor)\n        .call(Color.fill, options.bgcolor);\n\n    var isSizeConstrained = options.width || options.height;\n\n    var annTextClip = fullLayout._topclips\n        .selectAll('#' + annClipID)\n        .data(isSizeConstrained ? [0] : []);\n\n    annTextClip.enter().append('clipPath')\n        .classed('annclip', true)\n        .attr('id', annClipID)\n      .append('rect');\n    annTextClip.exit().remove();\n\n    var font = options.font;\n\n    var text = fullLayout._meta ?\n        Lib.templateString(options.text, fullLayout._meta) :\n        options.text;\n\n    var annText = annTextGroupInner.append('text')\n        .classed('annotation-text', true)\n        .text(text);\n\n    function textLayout(s) {\n        s.call(Drawing.font, font)\n        .attr({\n            'text-anchor': {\n                left: 'start',\n                right: 'end'\n            }[options.align] || 'middle'\n        });\n\n        svgTextUtils.convertToTspans(s, gd, drawGraphicalElements);\n        return s;\n    }\n\n    function drawGraphicalElements() {\n        // if the text has *only* a link, make the whole box into a link\n        var anchor3 = annText.selectAll('a');\n        if(anchor3.size() === 1 && anchor3.text() === annText.text()) {\n            var wholeLink = annTextGroupInner.insert('a', ':first-child').attr({\n                'xlink:xlink:href': anchor3.attr('xlink:href'),\n                'xlink:xlink:show': anchor3.attr('xlink:show')\n            })\n            .style({cursor: 'pointer'});\n\n            wholeLink.node().appendChild(annTextBG.node());\n        }\n\n        var mathjaxGroup = annTextGroupInner.select('.annotation-text-math-group');\n        var hasMathjax = !mathjaxGroup.empty();\n        var anntextBB = Drawing.bBox(\n                (hasMathjax ? mathjaxGroup : annText).node());\n        var textWidth = anntextBB.width;\n        var textHeight = anntextBB.height;\n        var annWidth = options.width || textWidth;\n        var annHeight = options.height || textHeight;\n        var outerWidth = Math.round(annWidth + 2 * borderfull);\n        var outerHeight = Math.round(annHeight + 2 * borderfull);\n\n        function shiftFraction(v, anchor) {\n            if(anchor === 'auto') {\n                if(v < 1 / 3) anchor = 'left';\n                else if(v > 2 / 3) anchor = 'right';\n                else anchor = 'center';\n            }\n            return {\n                center: 0,\n                middle: 0,\n                left: 0.5,\n                bottom: -0.5,\n                right: -0.5,\n                top: 0.5\n            }[anchor];\n        }\n\n        var annotationIsOffscreen = false;\n        var letters = ['x', 'y'];\n\n        for(var i = 0; i < letters.length; i++) {\n            var axLetter = letters[i];\n            var axRef = options[axLetter + 'ref'] || axLetter;\n            var tailRef = options['a' + axLetter + 'ref'];\n            var ax = {x: xa, y: ya}[axLetter];\n            var dimAngle = (textangle + (axLetter === 'x' ? 0 : -90)) * Math.PI / 180;\n            // note that these two can be either positive or negative\n            var annSizeFromWidth = outerWidth * Math.cos(dimAngle);\n            var annSizeFromHeight = outerHeight * Math.sin(dimAngle);\n            // but this one is the positive total size\n            var annSize = Math.abs(annSizeFromWidth) + Math.abs(annSizeFromHeight);\n            var anchor = options[axLetter + 'anchor'];\n            var overallShift = options[axLetter + 'shift'] * (axLetter === 'x' ? 1 : -1);\n            var posPx = annPosPx[axLetter];\n            var basePx;\n            var textPadShift;\n            var alignPosition;\n            var autoAlignFraction;\n            var textShift;\n\n            /*\n             * calculate the *primary* pixel position\n             * which is the arrowhead if there is one,\n             * otherwise the text anchor point\n             */\n            if(ax) {\n                // check if annotation is off screen, to bypass DOM manipulations\n                var posFraction = ax.r2fraction(options[axLetter]);\n                if(posFraction < 0 || posFraction > 1) {\n                    if(tailRef === axRef) {\n                        posFraction = ax.r2fraction(options['a' + axLetter]);\n                        if(posFraction < 0 || posFraction > 1) {\n                            annotationIsOffscreen = true;\n                        }\n                    } else {\n                        annotationIsOffscreen = true;\n                    }\n                }\n                basePx = ax._offset + ax.r2p(options[axLetter]);\n                autoAlignFraction = 0.5;\n            } else {\n                if(axLetter === 'x') {\n                    alignPosition = options[axLetter];\n                    basePx = gs.l + gs.w * alignPosition;\n                } else {\n                    alignPosition = 1 - options[axLetter];\n                    basePx = gs.t + gs.h * alignPosition;\n                }\n                autoAlignFraction = options.showarrow ? 0.5 : alignPosition;\n            }\n\n            // now translate this into pixel positions of head, tail, and text\n            // as well as paddings for autorange\n            if(options.showarrow) {\n                posPx.head = basePx;\n\n                var arrowLength = options['a' + axLetter];\n\n                // with an arrow, the text rotates around the anchor point\n                textShift = annSizeFromWidth * shiftFraction(0.5, options.xanchor) -\n                    annSizeFromHeight * shiftFraction(0.5, options.yanchor);\n\n                if(tailRef === axRef) {\n                    posPx.tail = ax._offset + ax.r2p(arrowLength);\n                    // tail is data-referenced: autorange pads the text in px from the tail\n                    textPadShift = textShift;\n                } else {\n                    posPx.tail = basePx + arrowLength;\n                    // tail is specified in px from head, so autorange also pads vs head\n                    textPadShift = textShift + arrowLength;\n                }\n\n                posPx.text = posPx.tail + textShift;\n\n                // constrain pixel/paper referenced so the draggers are at least\n                // partially visible\n                var maxPx = fullLayout[(axLetter === 'x') ? 'width' : 'height'];\n                if(axRef === 'paper') {\n                    posPx.head = Lib.constrain(posPx.head, 1, maxPx - 1);\n                }\n                if(tailRef === 'pixel') {\n                    var shiftPlus = -Math.max(posPx.tail - 3, posPx.text);\n                    var shiftMinus = Math.min(posPx.tail + 3, posPx.text) - maxPx;\n                    if(shiftPlus > 0) {\n                        posPx.tail += shiftPlus;\n                        posPx.text += shiftPlus;\n                    } else if(shiftMinus > 0) {\n                        posPx.tail -= shiftMinus;\n                        posPx.text -= shiftMinus;\n                    }\n                }\n\n                posPx.tail += overallShift;\n                posPx.head += overallShift;\n            } else {\n                // with no arrow, the text rotates and *then* we put the anchor\n                // relative to the new bounding box\n                textShift = annSize * shiftFraction(autoAlignFraction, anchor);\n                textPadShift = textShift;\n                posPx.text = basePx + textShift;\n            }\n\n            posPx.text += overallShift;\n            textShift += overallShift;\n            textPadShift += overallShift;\n\n            // padplus/minus are used by autorange\n            options['_' + axLetter + 'padplus'] = (annSize / 2) + textPadShift;\n            options['_' + axLetter + 'padminus'] = (annSize / 2) - textPadShift;\n\n            // size/shift are used during dragging\n            options['_' + axLetter + 'size'] = annSize;\n            options['_' + axLetter + 'shift'] = textShift;\n        }\n\n        if(annotationIsOffscreen) {\n            annTextGroupInner.remove();\n            return;\n        }\n\n        var xShift = 0;\n        var yShift = 0;\n\n        if(options.align !== 'left') {\n            xShift = (annWidth - textWidth) * (options.align === 'center' ? 0.5 : 1);\n        }\n        if(options.valign !== 'top') {\n            yShift = (annHeight - textHeight) * (options.valign === 'middle' ? 0.5 : 1);\n        }\n\n        if(hasMathjax) {\n            mathjaxGroup.select('svg').attr({\n                x: borderfull + xShift - 1,\n                y: borderfull + yShift\n            })\n            .call(Drawing.setClipUrl, isSizeConstrained ? annClipID : null, gd);\n        } else {\n            var texty = borderfull + yShift - anntextBB.top;\n            var textx = borderfull + xShift - anntextBB.left;\n\n            annText.call(svgTextUtils.positionText, textx, texty)\n                .call(Drawing.setClipUrl, isSizeConstrained ? annClipID : null, gd);\n        }\n\n        annTextClip.select('rect').call(Drawing.setRect, borderfull, borderfull,\n            annWidth, annHeight);\n\n        annTextBG.call(Drawing.setRect, borderwidth / 2, borderwidth / 2,\n            outerWidth - borderwidth, outerHeight - borderwidth);\n\n        annTextGroupInner.call(Drawing.setTranslate,\n            Math.round(annPosPx.x.text - outerWidth / 2),\n            Math.round(annPosPx.y.text - outerHeight / 2));\n\n        /*\n         * rotate text and background\n         * we already calculated the text center position *as rotated*\n         * because we needed that for autoranging anyway, so now whether\n         * we have an arrow or not, we rotate about the text center.\n         */\n        annTextGroup.attr({transform: 'rotate(' + textangle + ',' +\n                            annPosPx.x.text + ',' + annPosPx.y.text + ')'});\n\n        /*\n         * add the arrow\n         * uses options[arrowwidth,arrowcolor,arrowhead] for styling\n         * dx and dy are normally zero, but when you are dragging the textbox\n         * while the head stays put, dx and dy are the pixel offsets\n         */\n        var drawArrow = function(dx, dy) {\n            annGroup\n                .selectAll('.annotation-arrow-g')\n                .remove();\n\n            var headX = annPosPx.x.head;\n            var headY = annPosPx.y.head;\n            var tailX = annPosPx.x.tail + dx;\n            var tailY = annPosPx.y.tail + dy;\n            var textX = annPosPx.x.text + dx;\n            var textY = annPosPx.y.text + dy;\n\n            // find the edge of the text box, where we'll start the arrow:\n            // create transform matrix to rotate the text box corners\n            var transform = Lib.rotationXYMatrix(textangle, textX, textY);\n            var applyTransform = Lib.apply2DTransform(transform);\n            var applyTransform2 = Lib.apply2DTransform2(transform);\n\n            // calculate and transform bounding box\n            var width = +annTextBG.attr('width');\n            var height = +annTextBG.attr('height');\n            var xLeft = textX - 0.5 * width;\n            var xRight = xLeft + width;\n            var yTop = textY - 0.5 * height;\n            var yBottom = yTop + height;\n            var edges = [\n                [xLeft, yTop, xLeft, yBottom],\n                [xLeft, yBottom, xRight, yBottom],\n                [xRight, yBottom, xRight, yTop],\n                [xRight, yTop, xLeft, yTop]\n            ].map(applyTransform2);\n\n            // Remove the line if it ends inside the box.  Use ray\n            // casting for rotated boxes: see which edges intersect a\n            // line from the arrowhead to far away and reduce with xor\n            // to get the parity of the number of intersections.\n            if(edges.reduce(function(a, x) {\n                return a ^\n                    !!Lib.segmentsIntersect(headX, headY, headX + 1e6, headY + 1e6,\n                            x[0], x[1], x[2], x[3]);\n            }, false)) {\n                // no line or arrow - so quit drawArrow now\n                return;\n            }\n\n            edges.forEach(function(x) {\n                var p = Lib.segmentsIntersect(tailX, tailY, headX, headY,\n                            x[0], x[1], x[2], x[3]);\n                if(p) {\n                    tailX = p.x;\n                    tailY = p.y;\n                }\n            });\n\n            var strokewidth = options.arrowwidth;\n            var arrowColor = options.arrowcolor;\n            var arrowSide = options.arrowside;\n\n            var arrowGroup = annGroup.append('g')\n                .style({opacity: Color.opacity(arrowColor)})\n                .classed('annotation-arrow-g', true);\n\n            var arrow = arrowGroup.append('path')\n                .attr('d', 'M' + tailX + ',' + tailY + 'L' + headX + ',' + headY)\n                .style('stroke-width', strokewidth + 'px')\n                .call(Color.stroke, Color.rgb(arrowColor));\n\n            drawArrowHead(arrow, arrowSide, options);\n\n            // the arrow dragger is a small square right at the head, then a line to the tail,\n            // all expanded by a stroke width of 6px plus the arrow line width\n            if(edits.annotationPosition && arrow.node().parentNode && !subplotId) {\n                var arrowDragHeadX = headX;\n                var arrowDragHeadY = headY;\n                if(options.standoff) {\n                    var arrowLength = Math.sqrt(Math.pow(headX - tailX, 2) + Math.pow(headY - tailY, 2));\n                    arrowDragHeadX += options.standoff * (tailX - headX) / arrowLength;\n                    arrowDragHeadY += options.standoff * (tailY - headY) / arrowLength;\n                }\n                var arrowDrag = arrowGroup.append('path')\n                    .classed('annotation-arrow', true)\n                    .classed('anndrag', true)\n                    .classed('cursor-move', true)\n                    .attr({\n                        d: 'M3,3H-3V-3H3ZM0,0L' + (tailX - arrowDragHeadX) + ',' + (tailY - arrowDragHeadY),\n                        transform: 'translate(' + arrowDragHeadX + ',' + arrowDragHeadY + ')'\n                    })\n                    .style('stroke-width', (strokewidth + 6) + 'px')\n                    .call(Color.stroke, 'rgba(0,0,0,0)')\n                    .call(Color.fill, 'rgba(0,0,0,0)');\n\n                var annx0, anny0;\n\n                // dragger for the arrow & head: translates the whole thing\n                // (head/tail/text) all together\n                dragElement.init({\n                    element: arrowDrag.node(),\n                    gd: gd,\n                    prepFn: function() {\n                        var pos = Drawing.getTranslate(annTextGroupInner);\n\n                        annx0 = pos.x;\n                        anny0 = pos.y;\n                        if(xa && xa.autorange) {\n                            modifyBase(xa._name + '.autorange', true);\n                        }\n                        if(ya && ya.autorange) {\n                            modifyBase(ya._name + '.autorange', true);\n                        }\n                    },\n                    moveFn: function(dx, dy) {\n                        var annxy0 = applyTransform(annx0, anny0);\n                        var xcenter = annxy0[0] + dx;\n                        var ycenter = annxy0[1] + dy;\n                        annTextGroupInner.call(Drawing.setTranslate, xcenter, ycenter);\n\n                        modifyItem('x', xa ?\n                            xa.p2r(xa.r2p(options.x) + dx) :\n                            (options.x + (dx / gs.w)));\n                        modifyItem('y', ya ?\n                            ya.p2r(ya.r2p(options.y) + dy) :\n                            (options.y - (dy / gs.h)));\n\n                        if(options.axref === options.xref) {\n                            modifyItem('ax', xa.p2r(xa.r2p(options.ax) + dx));\n                        }\n\n                        if(options.ayref === options.yref) {\n                            modifyItem('ay', ya.p2r(ya.r2p(options.ay) + dy));\n                        }\n\n                        arrowGroup.attr('transform', 'translate(' + dx + ',' + dy + ')');\n                        annTextGroup.attr({\n                            transform: 'rotate(' + textangle + ',' +\n                                   xcenter + ',' + ycenter + ')'\n                        });\n                    },\n                    doneFn: function() {\n                        Registry.call('_guiRelayout', gd, getUpdateObj());\n                        var notesBox = document.querySelector('.js-notes-box-panel');\n                        if(notesBox) notesBox.redraw(notesBox.selectedObj);\n                    }\n                });\n            }\n        };\n\n        if(options.showarrow) drawArrow(0, 0);\n\n        // user dragging the annotation (text, not arrow)\n        if(editTextPosition) {\n            var baseTextTransform;\n\n            // dragger for the textbox: if there's an arrow, just drag the\n            // textbox and tail, leave the head untouched\n            dragElement.init({\n                element: annTextGroupInner.node(),\n                gd: gd,\n                prepFn: function() {\n                    baseTextTransform = annTextGroup.attr('transform');\n                },\n                moveFn: function(dx, dy) {\n                    var csr = 'pointer';\n                    if(options.showarrow) {\n                        if(options.axref === options.xref) {\n                            modifyItem('ax', xa.p2r(xa.r2p(options.ax) + dx));\n                        } else {\n                            modifyItem('ax', options.ax + dx);\n                        }\n\n                        if(options.ayref === options.yref) {\n                            modifyItem('ay', ya.p2r(ya.r2p(options.ay) + dy));\n                        } else {\n                            modifyItem('ay', options.ay + dy);\n                        }\n\n                        drawArrow(dx, dy);\n                    } else if(!subplotId) {\n                        var xUpdate, yUpdate;\n                        if(xa) {\n                            xUpdate = xa.p2r(xa.r2p(options.x) + dx);\n                        } else {\n                            var widthFraction = options._xsize / gs.w;\n                            var xLeft = options.x + (options._xshift - options.xshift) / gs.w - widthFraction / 2;\n\n                            xUpdate = dragElement.align(xLeft + dx / gs.w,\n                                widthFraction, 0, 1, options.xanchor);\n                        }\n\n                        if(ya) {\n                            yUpdate = ya.p2r(ya.r2p(options.y) + dy);\n                        } else {\n                            var heightFraction = options._ysize / gs.h;\n                            var yBottom = options.y - (options._yshift + options.yshift) / gs.h - heightFraction / 2;\n\n                            yUpdate = dragElement.align(yBottom - dy / gs.h,\n                                heightFraction, 0, 1, options.yanchor);\n                        }\n                        modifyItem('x', xUpdate);\n                        modifyItem('y', yUpdate);\n                        if(!xa || !ya) {\n                            csr = dragElement.getCursor(\n                                xa ? 0.5 : xUpdate,\n                                ya ? 0.5 : yUpdate,\n                                options.xanchor, options.yanchor\n                            );\n                        }\n                    } else return;\n\n                    annTextGroup.attr({\n                        transform: 'translate(' + dx + ',' + dy + ')' + baseTextTransform\n                    });\n\n                    setCursor(annTextGroupInner, csr);\n                },\n                clickFn: function(_, initialEvent) {\n                    if(options.captureevents) {\n                        gd.emit('plotly_clickannotation', makeEventData(initialEvent));\n                    }\n                },\n                doneFn: function() {\n                    setCursor(annTextGroupInner);\n                    Registry.call('_guiRelayout', gd, getUpdateObj());\n                    var notesBox = document.querySelector('.js-notes-box-panel');\n                    if(notesBox) notesBox.redraw(notesBox.selectedObj);\n                }\n            });\n        }\n    }\n\n    if(edits.annotationText) {\n        annText.call(svgTextUtils.makeEditable, {delegate: annTextGroupInner, gd: gd})\n            .call(textLayout)\n            .on('edit', function(_text) {\n                options.text = _text;\n\n                this.call(textLayout);\n\n                modifyItem('text', _text);\n\n                if(xa && xa.autorange) {\n                    modifyBase(xa._name + '.autorange', true);\n                }\n                if(ya && ya.autorange) {\n                    modifyBase(ya._name + '.autorange', true);\n                }\n\n                Registry.call('_guiRelayout', gd, getUpdateObj());\n            });\n    } else annText.call(textLayout);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Lib = require('../../lib');\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Events = require('../../lib/events');\nvar dragElement = require('../dragelement');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar handleClick = require('./handle_click');\n\nvar constants = require('./constants');\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar getLegendData = require('./get_legend_data');\nvar style = require('./style');\nvar helpers = require('./helpers');\n\nmodule.exports = function draw(gd, opts) {\n    var fullLayout = gd._fullLayout;\n    var clipId = 'legend' + fullLayout._uid;\n    var layer;\n\n    // Check whether this is the main legend (ie. called without any opts)\n    if(!opts) {\n        opts = fullLayout.legend || {};\n        opts._main = true;\n        layer = fullLayout._infolayer;\n    } else {\n        layer = opts.layer;\n        clipId += '-hover';\n    }\n\n    if(!layer) return;\n\n    if(!gd._legendMouseDownTime) gd._legendMouseDownTime = 0;\n\n    var legendData;\n    if(opts._main) {\n        if(!gd.calcdata) return;\n        legendData = fullLayout.showlegend && getLegendData(gd.calcdata, opts);\n    } else {\n        if(!opts.entries) return;\n        legendData = getLegendData(opts.entries, opts);\n    }\n\n    var hiddenSlices = fullLayout.hiddenlabels || [];\n\n    if(opts._main && (!fullLayout.showlegend || !legendData.length)) {\n        layer.selectAll('.legend').remove();\n        fullLayout._topdefs.select('#' + clipId).remove();\n        return Plots.autoMargin(gd, 'legend');\n    }\n\n    var legend = Lib.ensureSingle(layer, 'g', 'legend', function(s) {\n        if(opts._main) s.attr('pointer-events', 'all');\n    });\n\n    var clipPath = Lib.ensureSingleById(fullLayout._topdefs, 'clipPath', clipId, function(s) {\n        s.append('rect');\n    });\n\n    var bg = Lib.ensureSingle(legend, 'rect', 'bg', function(s) {\n        s.attr('shape-rendering', 'crispEdges');\n    });\n    bg.call(Color.stroke, opts.bordercolor)\n        .call(Color.fill, opts.bgcolor)\n        .style('stroke-width', opts.borderwidth + 'px');\n\n    var scrollBox = Lib.ensureSingle(legend, 'g', 'scrollbox');\n\n    var title = opts.title;\n    opts._titleWidth = 0;\n    opts._titleHeight = 0;\n    if(title.text) {\n        var titleEl = Lib.ensureSingle(scrollBox, 'text', 'legendtitletext');\n        titleEl.attr('text-anchor', 'start')\n            .classed('user-select-none', true)\n            .call(Drawing.font, title.font)\n            .text(title.text);\n\n        textLayout(titleEl, scrollBox, gd, opts); // handle mathjax or multi-line text and compute title height\n    }\n\n    var scrollBar = Lib.ensureSingle(legend, 'rect', 'scrollbar', function(s) {\n        s.attr(constants.scrollBarEnterAttrs)\n         .call(Color.fill, constants.scrollBarColor);\n    });\n\n    var groups = scrollBox.selectAll('g.groups').data(legendData);\n    groups.enter().append('g').attr('class', 'groups');\n    groups.exit().remove();\n\n    var traces = groups.selectAll('g.traces').data(Lib.identity);\n    traces.enter().append('g').attr('class', 'traces');\n    traces.exit().remove();\n\n    traces.style('opacity', function(d) {\n        var trace = d[0].trace;\n        if(Registry.traceIs(trace, 'pie-like')) {\n            return hiddenSlices.indexOf(d[0].label) !== -1 ? 0.5 : 1;\n        } else {\n            return trace.visible === 'legendonly' ? 0.5 : 1;\n        }\n    })\n    .each(function() { d3.select(this).call(drawTexts, gd, opts); })\n    .call(style, gd, opts)\n    .each(function() { if(opts._main) d3.select(this).call(setupTraceToggle, gd); });\n\n    Lib.syncOrAsync([\n        Plots.previousPromises,\n        function() { return computeLegendDimensions(gd, groups, traces, opts); },\n        function() {\n            // IF expandMargin return a Promise (which is truthy),\n            // we're under a doAutoMargin redraw, so we don't have to\n            // draw the remaining pieces below\n            if(opts._main && expandMargin(gd)) return;\n\n            var gs = fullLayout._size;\n            var bw = opts.borderwidth;\n\n            var lx = gs.l + gs.w * opts.x - FROM_TL[getXanchor(opts)] * opts._width;\n            var ly = gs.t + gs.h * (1 - opts.y) - FROM_TL[getYanchor(opts)] * opts._effHeight;\n\n            if(opts._main && fullLayout.margin.autoexpand) {\n                var lx0 = lx;\n                var ly0 = ly;\n\n                lx = Lib.constrain(lx, 0, fullLayout.width - opts._width);\n                ly = Lib.constrain(ly, 0, fullLayout.height - opts._effHeight);\n\n                if(lx !== lx0) {\n                    Lib.log('Constrain legend.x to make legend fit inside graph');\n                }\n                if(ly !== ly0) {\n                    Lib.log('Constrain legend.y to make legend fit inside graph');\n                }\n            }\n\n            // Set size and position of all the elements that make up a legend:\n            // legend, background and border, scroll box and scroll bar as well as title\n            if(opts._main) Drawing.setTranslate(legend, lx, ly);\n\n            // to be safe, remove previous listeners\n            scrollBar.on('.drag', null);\n            legend.on('wheel', null);\n\n            if(!opts._main || opts._height <= opts._maxHeight || gd._context.staticPlot) {\n                // if scrollbar should not be shown.\n                var height = opts._effHeight;\n\n                // if not the main legend, let it be its full size\n                if(!opts._main) height = opts._height;\n\n                bg.attr({\n                    width: opts._width - bw,\n                    height: height - bw,\n                    x: bw / 2,\n                    y: bw / 2\n                });\n\n                Drawing.setTranslate(scrollBox, 0, 0);\n\n                clipPath.select('rect').attr({\n                    width: opts._width - 2 * bw,\n                    height: height - 2 * bw,\n                    x: bw,\n                    y: bw\n                });\n\n                Drawing.setClipUrl(scrollBox, clipId, gd);\n\n                Drawing.setRect(scrollBar, 0, 0, 0, 0);\n                delete opts._scrollY;\n            } else {\n                var scrollBarHeight = Math.max(constants.scrollBarMinHeight,\n                    opts._effHeight * opts._effHeight / opts._height);\n                var scrollBarYMax = opts._effHeight -\n                    scrollBarHeight -\n                    2 * constants.scrollBarMargin;\n                var scrollBoxYMax = opts._height - opts._effHeight;\n                var scrollRatio = scrollBarYMax / scrollBoxYMax;\n\n                var scrollBoxY = Math.min(opts._scrollY || 0, scrollBoxYMax);\n\n                // increase the background and clip-path width\n                // by the scrollbar width and margin\n                bg.attr({\n                    width: opts._width -\n                        2 * bw +\n                        constants.scrollBarWidth +\n                        constants.scrollBarMargin,\n                    height: opts._effHeight - bw,\n                    x: bw / 2,\n                    y: bw / 2\n                });\n\n                clipPath.select('rect').attr({\n                    width: opts._width -\n                        2 * bw +\n                        constants.scrollBarWidth +\n                        constants.scrollBarMargin,\n                    height: opts._effHeight - 2 * bw,\n                    x: bw,\n                    y: bw + scrollBoxY\n                });\n\n                Drawing.setClipUrl(scrollBox, clipId, gd);\n\n                scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n\n                // scroll legend by mousewheel or touchpad swipe up/down\n                legend.on('wheel', function() {\n                    scrollBoxY = Lib.constrain(\n                        opts._scrollY +\n                            ((d3.event.deltaY / scrollBarYMax) * scrollBoxYMax),\n                        0, scrollBoxYMax);\n                    scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n                    if(scrollBoxY !== 0 && scrollBoxY !== scrollBoxYMax) {\n                        d3.event.preventDefault();\n                    }\n                });\n\n                var eventY0, eventY1, scrollBoxY0;\n\n                var getScrollBarDragY = function(scrollBoxY0, eventY0, eventY1) {\n                    var y = ((eventY1 - eventY0) / scrollRatio) + scrollBoxY0;\n                    return Lib.constrain(y, 0, scrollBoxYMax);\n                };\n\n                var getNaturalDragY = function(scrollBoxY0, eventY0, eventY1) {\n                    var y = ((eventY0 - eventY1) / scrollRatio) + scrollBoxY0;\n                    return Lib.constrain(y, 0, scrollBoxYMax);\n                };\n\n                // scroll legend by dragging scrollBAR\n                var scrollBarDrag = d3.behavior.drag()\n                .on('dragstart', function() {\n                    var e = d3.event.sourceEvent;\n                    if(e.type === 'touchstart') {\n                        eventY0 = e.changedTouches[0].clientY;\n                    } else {\n                        eventY0 = e.clientY;\n                    }\n                    scrollBoxY0 = scrollBoxY;\n                })\n                .on('drag', function() {\n                    var e = d3.event.sourceEvent;\n                    if(e.buttons === 2 || e.ctrlKey) return;\n                    if(e.type === 'touchmove') {\n                        eventY1 = e.changedTouches[0].clientY;\n                    } else {\n                        eventY1 = e.clientY;\n                    }\n                    scrollBoxY = getScrollBarDragY(scrollBoxY0, eventY0, eventY1);\n                    scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n                });\n                scrollBar.call(scrollBarDrag);\n\n                // scroll legend by touch-dragging scrollBOX\n                var scrollBoxTouchDrag = d3.behavior.drag()\n                .on('dragstart', function() {\n                    var e = d3.event.sourceEvent;\n                    if(e.type === 'touchstart') {\n                        eventY0 = e.changedTouches[0].clientY;\n                        scrollBoxY0 = scrollBoxY;\n                    }\n                })\n                .on('drag', function() {\n                    var e = d3.event.sourceEvent;\n                    if(e.type === 'touchmove') {\n                        eventY1 = e.changedTouches[0].clientY;\n                        scrollBoxY = getNaturalDragY(scrollBoxY0, eventY0, eventY1);\n                        scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio);\n                    }\n                });\n                scrollBox.call(scrollBoxTouchDrag);\n            }\n\n            function scrollHandler(scrollBoxY, scrollBarHeight, scrollRatio) {\n                opts._scrollY = gd._fullLayout.legend._scrollY = scrollBoxY;\n                Drawing.setTranslate(scrollBox, 0, -scrollBoxY);\n\n                Drawing.setRect(\n                    scrollBar,\n                    opts._width,\n                    constants.scrollBarMargin + scrollBoxY * scrollRatio,\n                    constants.scrollBarWidth,\n                    scrollBarHeight\n                );\n                clipPath.select('rect').attr('y', bw + scrollBoxY);\n            }\n\n            if(gd._context.edits.legendPosition) {\n                var xf, yf, x0, y0;\n\n                legend.classed('cursor-move', true);\n\n                dragElement.init({\n                    element: legend.node(),\n                    gd: gd,\n                    prepFn: function() {\n                        var transform = Drawing.getTranslate(legend);\n                        x0 = transform.x;\n                        y0 = transform.y;\n                    },\n                    moveFn: function(dx, dy) {\n                        var newX = x0 + dx;\n                        var newY = y0 + dy;\n\n                        Drawing.setTranslate(legend, newX, newY);\n\n                        xf = dragElement.align(newX, 0, gs.l, gs.l + gs.w, opts.xanchor);\n                        yf = dragElement.align(newY, 0, gs.t + gs.h, gs.t, opts.yanchor);\n                    },\n                    doneFn: function() {\n                        if(xf !== undefined && yf !== undefined) {\n                            Registry.call('_guiRelayout', gd, {'legend.x': xf, 'legend.y': yf});\n                        }\n                    },\n                    clickFn: function(numClicks, e) {\n                        var clickedTrace = layer.selectAll('g.traces').filter(function() {\n                            var bbox = this.getBoundingClientRect();\n                            return (\n                                e.clientX >= bbox.left && e.clientX <= bbox.right &&\n                                e.clientY >= bbox.top && e.clientY <= bbox.bottom\n                            );\n                        });\n                        if(clickedTrace.size() > 0) {\n                            clickOrDoubleClick(gd, legend, clickedTrace, numClicks, e);\n                        }\n                    }\n                });\n            }\n        }], gd);\n};\n\nfunction clickOrDoubleClick(gd, legend, legendItem, numClicks, evt) {\n    var trace = legendItem.data()[0][0].trace;\n    var evtData = {\n        event: evt,\n        node: legendItem.node(),\n        curveNumber: trace.index,\n        expandedIndex: trace._expandedIndex,\n        data: gd.data,\n        layout: gd.layout,\n        frames: gd._transitionData._frames,\n        config: gd._context,\n        fullData: gd._fullData,\n        fullLayout: gd._fullLayout\n    };\n\n    if(trace._group) {\n        evtData.group = trace._group;\n    }\n    if(Registry.traceIs(trace, 'pie-like')) {\n        evtData.label = legendItem.datum()[0].label;\n    }\n\n    var clickVal = Events.triggerHandler(gd, 'plotly_legendclick', evtData);\n    if(clickVal === false) return;\n\n    if(numClicks === 1) {\n        legend._clickTimeout = setTimeout(function() {\n            handleClick(legendItem, gd, numClicks);\n        }, gd._context.doubleClickDelay);\n    } else if(numClicks === 2) {\n        if(legend._clickTimeout) clearTimeout(legend._clickTimeout);\n        gd._legendMouseDownTime = 0;\n\n        var dblClickVal = Events.triggerHandler(gd, 'plotly_legenddoubleclick', evtData);\n        if(dblClickVal !== false) handleClick(legendItem, gd, numClicks);\n    }\n}\n\nfunction drawTexts(g, gd, opts) {\n    var legendItem = g.data()[0][0];\n    var trace = legendItem.trace;\n    var isPieLike = Registry.traceIs(trace, 'pie-like');\n    var traceIndex = trace.index;\n    var isEditable = opts._main && gd._context.edits.legendText && !isPieLike;\n    var maxNameLength = opts._maxNameLength;\n\n    var name;\n    if(!opts.entries) {\n        name = isPieLike ? legendItem.label : trace.name;\n        if(trace._meta) {\n            name = Lib.templateString(name, trace._meta);\n        }\n    } else {\n        name = legendItem.text;\n    }\n\n    var textEl = Lib.ensureSingle(g, 'text', 'legendtext');\n\n    textEl.attr('text-anchor', 'start')\n        .classed('user-select-none', true)\n        .call(Drawing.font, opts.font)\n        .text(isEditable ? ensureLength(name, maxNameLength) : name);\n\n    svgTextUtils.positionText(textEl, constants.textGap, 0);\n\n    if(isEditable) {\n        textEl.call(svgTextUtils.makeEditable, {gd: gd, text: name})\n            .call(textLayout, g, gd, opts)\n            .on('edit', function(newName) {\n                this.text(ensureLength(newName, maxNameLength))\n                    .call(textLayout, g, gd, opts);\n\n                var fullInput = legendItem.trace._fullInput || {};\n                var update = {};\n\n                if(Registry.hasTransform(fullInput, 'groupby')) {\n                    var groupbyIndices = Registry.getTransformIndices(fullInput, 'groupby');\n                    var index = groupbyIndices[groupbyIndices.length - 1];\n\n                    var kcont = Lib.keyedContainer(fullInput, 'transforms[' + index + '].styles', 'target', 'value.name');\n\n                    kcont.set(legendItem.trace._group, newName);\n\n                    update = kcont.constructUpdate();\n                } else {\n                    update.name = newName;\n                }\n\n                return Registry.call('_guiRestyle', gd, update, traceIndex);\n            });\n    } else {\n        textLayout(textEl, g, gd, opts);\n    }\n}\n\n/*\n * Make sure we have a reasonably clickable region.\n * If this string is missing or very short, pad it with spaces out to at least\n * 4 characters, up to the max length of other labels, on the assumption that\n * most characters are wider than spaces so a string of spaces will usually be\n * no wider than the real labels.\n */\nfunction ensureLength(str, maxLength) {\n    var targetLength = Math.max(4, maxLength);\n    if(str && str.trim().length >= targetLength / 2) return str;\n    str = str || '';\n    for(var i = targetLength - str.length; i > 0; i--) str += ' ';\n    return str;\n}\n\nfunction setupTraceToggle(g, gd) {\n    var doubleClickDelay = gd._context.doubleClickDelay;\n    var newMouseDownTime;\n    var numClicks = 1;\n\n    var traceToggle = Lib.ensureSingle(g, 'rect', 'legendtoggle', function(s) {\n        s.style('cursor', 'pointer')\n            .attr('pointer-events', 'all')\n            .call(Color.fill, 'rgba(0,0,0,0)');\n    });\n\n    traceToggle.on('mousedown', function() {\n        newMouseDownTime = (new Date()).getTime();\n        if(newMouseDownTime - gd._legendMouseDownTime < doubleClickDelay) {\n            // in a click train\n            numClicks += 1;\n        } else {\n            // new click train\n            numClicks = 1;\n            gd._legendMouseDownTime = newMouseDownTime;\n        }\n    });\n    traceToggle.on('mouseup', function() {\n        if(gd._dragged || gd._editing) return;\n        var legend = gd._fullLayout.legend;\n\n        if((new Date()).getTime() - gd._legendMouseDownTime > doubleClickDelay) {\n            numClicks = Math.max(numClicks - 1, 1);\n        }\n\n        clickOrDoubleClick(gd, legend, g, numClicks, d3.event);\n    });\n}\n\nfunction textLayout(s, g, gd, opts) {\n    if(!opts._main) s.attr('data-notex', true); // do not process MathJax if not main\n    svgTextUtils.convertToTspans(s, gd, function() {\n        computeTextDimensions(g, gd, opts);\n    });\n}\n\nfunction computeTextDimensions(g, gd, opts) {\n    var legendItem = g.data()[0][0];\n    if(opts._main && legendItem && !legendItem.trace.showlegend) {\n        g.remove();\n        return;\n    }\n\n    var mathjaxGroup = g.select('g[class*=math-group]');\n    var mathjaxNode = mathjaxGroup.node();\n    if(!opts) opts = gd._fullLayout.legend;\n    var bw = opts.borderwidth;\n    var lineHeight = (legendItem ? opts : opts.title).font.size * LINE_SPACING;\n    var height, width;\n\n    if(mathjaxNode) {\n        var mathjaxBB = Drawing.bBox(mathjaxNode);\n\n        height = mathjaxBB.height;\n        width = mathjaxBB.width;\n\n        if(legendItem) {\n            Drawing.setTranslate(mathjaxGroup, 0, height * 0.25);\n        } else { // case of title\n            Drawing.setTranslate(mathjaxGroup, bw, height * 0.75 + bw);\n        }\n    } else {\n        var textEl = g.select(legendItem ?\n            '.legendtext' : '.legendtitletext'\n        );\n        var textLines = svgTextUtils.lineCount(textEl);\n        var textNode = textEl.node();\n\n        height = lineHeight * textLines;\n        width = textNode ? Drawing.bBox(textNode).width : 0;\n\n        // approximation to height offset to center the font\n        // to avoid getBoundingClientRect\n        var textY = lineHeight * ((textLines - 1) / 2 - 0.3);\n        if(legendItem) {\n            svgTextUtils.positionText(textEl, constants.textGap, -textY);\n        } else { // case of title\n            svgTextUtils.positionText(textEl, constants.titlePad + bw, lineHeight + bw);\n        }\n    }\n\n    if(legendItem) {\n        legendItem.lineHeight = lineHeight;\n        legendItem.height = Math.max(height, 16) + 3;\n        legendItem.width = width;\n    } else { // case of title\n        opts._titleWidth = width;\n        opts._titleHeight = height;\n    }\n}\n\nfunction getTitleSize(opts) {\n    var w = 0;\n    var h = 0;\n\n    var side = opts.title.side;\n    if(side) {\n        if(side.indexOf('left') !== -1) {\n            w = opts._titleWidth;\n        }\n        if(side.indexOf('top') !== -1) {\n            h = opts._titleHeight;\n        }\n    }\n\n    return [w, h];\n}\n\n/*\n * Computes in fullLayout.legend:\n *\n *  - _height: legend height including items past scrollbox height\n *  - _maxHeight: maximum legend height before scrollbox is required\n *  - _effHeight: legend height w/ or w/o scrollbox\n *\n *  - _width: legend width\n *  - _maxWidth (for orientation:h only): maximum width before starting new row\n */\nfunction computeLegendDimensions(gd, groups, traces, opts) {\n    var fullLayout = gd._fullLayout;\n    if(!opts) opts = fullLayout.legend;\n    var gs = fullLayout._size;\n\n    var isVertical = helpers.isVertical(opts);\n    var isGrouped = helpers.isGrouped(opts);\n\n    var bw = opts.borderwidth;\n    var bw2 = 2 * bw;\n    var textGap = constants.textGap;\n    var itemGap = constants.itemGap;\n    var endPad = 2 * (bw + itemGap);\n\n    var yanchor = getYanchor(opts);\n    var isBelowPlotArea = opts.y < 0 || (opts.y === 0 && yanchor === 'top');\n    var isAbovePlotArea = opts.y > 1 || (opts.y === 1 && yanchor === 'bottom');\n\n    // - if below/above plot area, give it the maximum potential margin-push value\n    // - otherwise, extend the height of the plot area\n    opts._maxHeight = Math.max(\n        (isBelowPlotArea || isAbovePlotArea) ? fullLayout.height / 2 : gs.h,\n        30\n    );\n\n    var toggleRectWidth = 0;\n    opts._width = 0;\n    opts._height = 0;\n    var titleSize = getTitleSize(opts);\n\n    if(isVertical) {\n        traces.each(function(d) {\n            var h = d[0].height;\n            Drawing.setTranslate(this,\n                bw + titleSize[0],\n                bw + titleSize[1] + opts._height + h / 2 + itemGap\n            );\n            opts._height += h;\n            opts._width = Math.max(opts._width, d[0].width);\n        });\n\n        toggleRectWidth = textGap + opts._width;\n        opts._width += itemGap + textGap + bw2;\n        opts._height += endPad;\n\n        if(isGrouped) {\n            groups.each(function(d, i) {\n                Drawing.setTranslate(this, 0, i * opts.tracegroupgap);\n            });\n            opts._height += (opts._lgroupsLength - 1) * opts.tracegroupgap;\n        }\n    } else {\n        var xanchor = getXanchor(opts);\n        var isLeftOfPlotArea = opts.x < 0 || (opts.x === 0 && xanchor === 'right');\n        var isRightOfPlotArea = opts.x > 1 || (opts.x === 1 && xanchor === 'left');\n        var isBeyondPlotAreaY = isAbovePlotArea || isBelowPlotArea;\n        var hw = fullLayout.width / 2;\n\n        // - if placed within x-margins, extend the width of the plot area\n        // - else if below/above plot area and anchored in the margin, extend to opposite margin,\n        // - otherwise give it the maximum potential margin-push value\n        opts._maxWidth = Math.max(\n            isLeftOfPlotArea ? ((isBeyondPlotAreaY && xanchor === 'left') ? gs.l + gs.w : hw) :\n            isRightOfPlotArea ? ((isBeyondPlotAreaY && xanchor === 'right') ? gs.r + gs.w : hw) :\n            gs.w,\n        2 * textGap);\n        var maxItemWidth = 0;\n        var combinedItemWidth = 0;\n        traces.each(function(d) {\n            var w = d[0].width + textGap;\n            maxItemWidth = Math.max(maxItemWidth, w);\n            combinedItemWidth += w;\n        });\n\n        toggleRectWidth = null;\n        var maxRowWidth = 0;\n\n        if(isGrouped) {\n            var maxGroupHeightInRow = 0;\n            var groupOffsetX = 0;\n            var groupOffsetY = 0;\n            groups.each(function() {\n                var maxWidthInGroup = 0;\n                var offsetY = 0;\n                d3.select(this).selectAll('g.traces').each(function(d) {\n                    var h = d[0].height;\n                    Drawing.setTranslate(this,\n                        titleSize[0],\n                        titleSize[1] + bw + itemGap + h / 2 + offsetY\n                    );\n                    offsetY += h;\n                    maxWidthInGroup = Math.max(maxWidthInGroup, textGap + d[0].width);\n                });\n                maxGroupHeightInRow = Math.max(maxGroupHeightInRow, offsetY);\n\n                var next = maxWidthInGroup + itemGap;\n\n                if((next + bw + groupOffsetX) > opts._maxWidth) {\n                    maxRowWidth = Math.max(maxRowWidth, groupOffsetX);\n                    groupOffsetX = 0;\n                    groupOffsetY += maxGroupHeightInRow + opts.tracegroupgap;\n                    maxGroupHeightInRow = offsetY;\n                }\n\n                Drawing.setTranslate(this, groupOffsetX, groupOffsetY);\n\n                groupOffsetX += next;\n            });\n\n            opts._width = Math.max(maxRowWidth, groupOffsetX) + bw;\n            opts._height = groupOffsetY + maxGroupHeightInRow + endPad;\n        } else {\n            var nTraces = traces.size();\n            var oneRowLegend = (combinedItemWidth + bw2 + (nTraces - 1) * itemGap) < opts._maxWidth;\n\n            var maxItemHeightInRow = 0;\n            var offsetX = 0;\n            var offsetY = 0;\n            var rowWidth = 0;\n            traces.each(function(d) {\n                var h = d[0].height;\n                var w = textGap + d[0].width;\n                var next = (oneRowLegend ? w : maxItemWidth) + itemGap;\n\n                if((next + bw + offsetX) > opts._maxWidth) {\n                    maxRowWidth = Math.max(maxRowWidth, rowWidth);\n                    offsetX = 0;\n                    offsetY += maxItemHeightInRow;\n                    opts._height += maxItemHeightInRow;\n                    maxItemHeightInRow = 0;\n                }\n\n                Drawing.setTranslate(this,\n                    titleSize[0] + bw + offsetX,\n                    titleSize[1] + bw + offsetY + h / 2 + itemGap\n                );\n\n                rowWidth = offsetX + w + itemGap;\n                offsetX += next;\n                maxItemHeightInRow = Math.max(maxItemHeightInRow, h);\n            });\n\n            if(oneRowLegend) {\n                opts._width = offsetX + bw2;\n                opts._height = maxItemHeightInRow + endPad;\n            } else {\n                opts._width = Math.max(maxRowWidth, rowWidth) + bw2;\n                opts._height += maxItemHeightInRow + endPad;\n            }\n        }\n    }\n\n    opts._width = Math.ceil(\n        Math.max(\n            opts._width + titleSize[0],\n            opts._titleWidth + 2 * (bw + constants.titlePad)\n        )\n    );\n\n    opts._height = Math.ceil(\n        Math.max(\n            opts._height + titleSize[1],\n            opts._titleHeight + 2 * (bw + constants.itemGap)\n        )\n    );\n\n    opts._effHeight = Math.min(opts._height, opts._maxHeight);\n\n    var edits = gd._context.edits;\n    var isEditable = edits.legendText || edits.legendPosition;\n    traces.each(function(d) {\n        var traceToggle = d3.select(this).select('.legendtoggle');\n        var h = d[0].height;\n        var w = isEditable ? textGap : (toggleRectWidth || (textGap + d[0].width));\n        if(!isVertical) w += itemGap / 2;\n        Drawing.setRect(traceToggle, 0, -h / 2, w, h);\n    });\n}\n\nfunction expandMargin(gd) {\n    var fullLayout = gd._fullLayout;\n    var opts = fullLayout.legend;\n    var xanchor = getXanchor(opts);\n    var yanchor = getYanchor(opts);\n\n    return Plots.autoMargin(gd, 'legend', {\n        x: opts.x,\n        y: opts.y,\n        l: opts._width * (FROM_TL[xanchor]),\n        r: opts._width * (FROM_BR[xanchor]),\n        b: opts._effHeight * (FROM_BR[yanchor]),\n        t: opts._effHeight * (FROM_TL[yanchor])\n    });\n}\n\nfunction getXanchor(opts) {\n    return Lib.isRightAnchor(opts) ? 'right' :\n        Lib.isCenterAnchor(opts) ? 'center' :\n        'left';\n}\n\nfunction getYanchor(opts) {\n    return Lib.isBottomAnchor(opts) ? 'bottom' :\n        Lib.isMiddleAnchor(opts) ? 'middle' :\n        'top';\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar numConstants = require('../../constants/numerical');\nvar oneYear = numConstants.ONEAVGYEAR;\nvar oneMonth = numConstants.ONEAVGMONTH;\nvar oneDay = numConstants.ONEDAY;\nvar oneHour = numConstants.ONEHOUR;\nvar oneMin = numConstants.ONEMIN;\nvar oneSec = numConstants.ONESEC;\nvar tickIncrement = require('../../plots/cartesian/axes').tickIncrement;\n\n\n/*\n * make a function that will find rounded bin edges\n * @param {number} leftGap: how far from the left edge of any bin is the closest data value?\n * @param {number} rightGap: how far from the right edge of any bin is the closest data value?\n * @param {Array[number]} binEdges: the actual edge values used in binning\n * @param {object} pa: the position axis\n * @param {string} calendar: the data calendar\n *\n * @return {function(v, isRightEdge)}:\n *   find the start (isRightEdge is falsy) or end (truthy) label value for a bin edge `v`\n */\nmodule.exports = function getBinSpanLabelRound(leftGap, rightGap, binEdges, pa, calendar) {\n    // the rounding digit is the largest digit that changes in *all* of 4 regions:\n    // - inside the rightGap before binEdges[0] (shifted 10% to the left)\n    // - inside the leftGap after binEdges[0] (expanded by 10% of rightGap on each end)\n    // - same for binEdges[1]\n    var dv0 = -1.1 * rightGap;\n    var dv1 = -0.1 * rightGap;\n    var dv2 = leftGap - dv1;\n    var edge0 = binEdges[0];\n    var edge1 = binEdges[1];\n    var leftDigit = Math.min(\n        biggestDigitChanged(edge0 + dv1, edge0 + dv2, pa, calendar),\n        biggestDigitChanged(edge1 + dv1, edge1 + dv2, pa, calendar)\n    );\n    var rightDigit = Math.min(\n        biggestDigitChanged(edge0 + dv0, edge0 + dv1, pa, calendar),\n        biggestDigitChanged(edge1 + dv0, edge1 + dv1, pa, calendar)\n    );\n\n    // normally we try to make the label for the right edge different from\n    // the left edge label, so it's unambiguous which bin gets data on the edge.\n    // but if this results in more than 3 extra digits (or for dates, more than\n    // 2 fields ie hr&min or min&sec, which is 3600x), it'll be more clutter than\n    // useful so keep the label cleaner instead\n    var digit, disambiguateEdges;\n    if(leftDigit > rightDigit && rightDigit < Math.abs(edge1 - edge0) / 4000) {\n        digit = leftDigit;\n        disambiguateEdges = false;\n    } else {\n        digit = Math.min(leftDigit, rightDigit);\n        disambiguateEdges = true;\n    }\n\n    if(pa.type === 'date' && digit > oneDay) {\n        var dashExclude = (digit === oneYear) ? 1 : 6;\n        var increment = (digit === oneYear) ? 'M12' : 'M1';\n\n        return function(v, isRightEdge) {\n            var dateStr = pa.c2d(v, oneYear, calendar);\n            var dashPos = dateStr.indexOf('-', dashExclude);\n            if(dashPos > 0) dateStr = dateStr.substr(0, dashPos);\n            var roundedV = pa.d2c(dateStr, 0, calendar);\n\n            if(roundedV < v) {\n                var nextV = tickIncrement(roundedV, increment, false, calendar);\n                if((roundedV + nextV) / 2 < v + leftGap) roundedV = nextV;\n            }\n\n            if(isRightEdge && disambiguateEdges) {\n                return tickIncrement(roundedV, increment, true, calendar);\n            }\n\n            return roundedV;\n        };\n    }\n\n    return function(v, isRightEdge) {\n        var roundedV = digit * Math.round(v / digit);\n        // if we rounded down and we could round up and still be < leftGap\n        // (or what leftGap values round to), do that\n        if(roundedV + (digit / 10) < v && roundedV + (digit * 0.9) < v + leftGap) {\n            roundedV += digit;\n        }\n        // finally for the right edge back off one digit - but only if we can do that\n        // and not clip off any data that's potentially in the bin\n        if(isRightEdge && disambiguateEdges) {\n            roundedV -= digit;\n        }\n        return roundedV;\n    };\n};\n\n/*\n * Find the largest digit that changes within a (calcdata) region [v1, v2]\n * if dates, \"digit\" means date/time part when it's bigger than a second\n * returns the unit value to round to this digit, eg 0.01 to round to hundredths, or\n * 100 to round to hundreds. returns oneMonth or oneYear for month or year rounding,\n * so that Math.min will work, rather than 'M1' and 'M12'\n */\nfunction biggestDigitChanged(v1, v2, pa, calendar) {\n    // are we crossing zero? can't say anything.\n    // in principle this doesn't apply to dates but turns out this doesn't matter.\n    if(v1 * v2 <= 0) return Infinity;\n\n    var dv = Math.abs(v2 - v1);\n    var isDate = pa.type === 'date';\n    var digit = biggestGuaranteedDigitChanged(dv, isDate);\n    // see if a larger digit also changed\n    for(var i = 0; i < 10; i++) {\n        // numbers: next digit needs to be >10x but <100x then gets rounded down.\n        // dates: next digit can be as much as 60x (then rounded down)\n        var nextDigit = biggestGuaranteedDigitChanged(digit * 80, isDate);\n        // if we get to years, the chain stops\n        if(digit === nextDigit) break;\n        if(didDigitChange(nextDigit, v1, v2, isDate, pa, calendar)) digit = nextDigit;\n        else break;\n    }\n    return digit;\n}\n\n/*\n * Find the largest digit that *definitely* changes in a region [v, v + dv] for any v\n * for nonuniform date regions (months/years) pick the largest\n */\nfunction biggestGuaranteedDigitChanged(dv, isDate) {\n    if(isDate && dv > oneSec) {\n        // this is supposed to be the biggest *guaranteed* change\n        // so compare to the longest month and year across any calendar,\n        // and we'll iterate back up later\n        // note: does not support rounding larger than one year. We could add\n        // that if anyone wants it, but seems unusual and not strictly necessary.\n        if(dv > oneDay) {\n            if(dv > oneYear * 1.1) return oneYear;\n            if(dv > oneMonth * 1.1) return oneMonth;\n            return oneDay;\n        }\n\n        if(dv > oneHour) return oneHour;\n        if(dv > oneMin) return oneMin;\n        return oneSec;\n    }\n    return Math.pow(10, Math.floor(Math.log(dv) / Math.LN10));\n}\n\nfunction didDigitChange(digit, v1, v2, isDate, pa, calendar) {\n    if(isDate && digit > oneDay) {\n        var dateParts1 = dateParts(v1, pa, calendar);\n        var dateParts2 = dateParts(v2, pa, calendar);\n        var parti = (digit === oneYear) ? 0 : 1;\n        return dateParts1[parti] !== dateParts2[parti];\n    }\n    return Math.floor(v2 / digit) - Math.floor(v1 / digit) > 0.1;\n}\n\nfunction dateParts(v, pa, calendar) {\n    var parts = pa.c2d(v, oneYear, calendar).split('-');\n    if(parts[0] === '') {\n        parts.unshift();\n        parts[0] = '-' + parts[0];\n    }\n    return parts;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nfunction findCategories(ax, opts) {\n    var dataAttr = opts.dataAttr || ax._id.charAt(0);\n    var lookup = {};\n    var axData;\n    var i, j;\n\n    if(opts.axData) {\n        // non-x/y case\n        axData = opts.axData;\n    } else {\n        // x/y case\n        axData = [];\n        for(i = 0; i < opts.data.length; i++) {\n            var trace = opts.data[i];\n            if(trace[dataAttr + 'axis'] === ax._id) {\n                axData.push(trace);\n            }\n        }\n    }\n\n    for(i = 0; i < axData.length; i++) {\n        var vals = axData[i][dataAttr];\n        for(j = 0; j < vals.length; j++) {\n            var v = vals[j];\n            if(v !== null && v !== undefined) {\n                lookup[v] = 1;\n            }\n        }\n    }\n\n    return Object.keys(lookup);\n}\n\n/**\n * Fills in category* default and initial categories.\n *\n * @param {object} containerIn : input axis object\n * @param {object} containerOut : full axis object\n * @param {function} coerce : Lib.coerce fn wrapper\n * @param {object} opts :\n *   - data {array} : (full) data trace\n * OR\n *   - axData {array} : (full) data associated with axis being coerced here\n *   - dataAttr {string} : attribute name corresponding to coordinate array\n */\nmodule.exports = function handleCategoryOrderDefaults(containerIn, containerOut, coerce, opts) {\n    if(containerOut.type !== 'category') return;\n\n    var arrayIn = containerIn.categoryarray;\n    var isValidArray = (Array.isArray(arrayIn) && arrayIn.length > 0);\n\n    // override default 'categoryorder' value when non-empty array is supplied\n    var orderDefault;\n    if(isValidArray) orderDefault = 'array';\n\n    var order = coerce('categoryorder', orderDefault);\n    var array;\n\n    // coerce 'categoryarray' only in array order case\n    if(order === 'array') {\n        array = coerce('categoryarray');\n    }\n\n    // cannot set 'categoryorder' to 'array' with an invalid 'categoryarray'\n    if(!isValidArray && order === 'array') {\n        order = containerOut.categoryorder = 'trace';\n    }\n\n    // set up things for makeCalcdata\n    if(order === 'trace') {\n        containerOut._initialCategories = [];\n    } else if(order === 'array') {\n        containerOut._initialCategories = array.slice();\n    } else {\n        array = findCategories(containerOut, opts).sort();\n        if(order === 'category ascending') {\n            containerOut._initialCategories = array;\n        } else if(order === 'category descending') {\n            containerOut._initialCategories = array.reverse();\n        }\n    }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n// common to 'scatter' and 'scatterternary'\nmodule.exports = function handleLineShapeDefaults(traceIn, traceOut, coerce) {\n    var shape = coerce('line.shape');\n    if(shape === 'spline') coerce('line.smoothing');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar padAttrs = require('../../plots/pad_attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar buttonsAttrs = templatedArray('button', {\n    visible: {\n        valType: 'boolean',\n        role: 'info',\n        description: 'Determines whether or not this button is visible.'\n    },\n    method: {\n        valType: 'enumerated',\n        values: ['restyle', 'relayout', 'animate', 'update', 'skip'],\n        dflt: 'restyle',\n        role: 'info',\n        description: [\n            'Sets the Plotly method to be called on click.',\n            'If the `skip` method is used, the API updatemenu will function as normal',\n            'but will perform no API calls and will not bind automatically to state',\n            'updates. This may be used to create a component interface and attach to',\n            'updatemenu events manually via JavaScript.'\n        ].join(' ')\n    },\n    args: {\n        valType: 'info_array',\n        role: 'info',\n        freeLength: true,\n        items: [\n            {valType: 'any'},\n            {valType: 'any'},\n            {valType: 'any'}\n        ],\n        description: [\n            'Sets the arguments values to be passed to the Plotly',\n            'method set in `method` on click.'\n        ].join(' ')\n    },\n    args2: {\n        valType: 'info_array',\n        role: 'info',\n        freeLength: true,\n        items: [\n            {valType: 'any'},\n            {valType: 'any'},\n            {valType: 'any'}\n        ],\n        description: [\n            'Sets a 2nd set of `args`,',\n            'these arguments values are passed to the Plotly',\n            'method set in `method` when clicking this button while in the active state.',\n            'Use this to create toggle buttons.'\n        ].join(' ')\n    },\n    label: {\n        valType: 'string',\n        role: 'info',\n        dflt: '',\n        description: 'Sets the text label to appear on the button.'\n    },\n    execute: {\n        valType: 'boolean',\n        role: 'info',\n        dflt: true,\n        description: [\n            'When true, the API method is executed. When false, all other behaviors are the same',\n            'and command execution is skipped. This may be useful when hooking into, for example,',\n            'the `plotly_buttonclicked` method and executing the API command manually without losing',\n            'the benefit of the updatemenu automatically binding to the state of the plot through the',\n            'specification of `method` and `args`.'\n        ].join(' ')\n    }\n});\n\nmodule.exports = overrideAll(templatedArray('updatemenu', {\n    _arrayAttrRegexps: [/^updatemenus\\[(0|[1-9][0-9]+)\\]\\.buttons/],\n\n    visible: {\n        valType: 'boolean',\n        role: 'info',\n        description: [\n            'Determines whether or not the update menu is visible.'\n        ].join(' ')\n    },\n\n    type: {\n        valType: 'enumerated',\n        values: ['dropdown', 'buttons'],\n        dflt: 'dropdown',\n        role: 'info',\n        description: [\n            'Determines whether the buttons are accessible via a dropdown menu',\n            'or whether the buttons are stacked horizontally or vertically'\n        ].join(' ')\n    },\n\n    direction: {\n        valType: 'enumerated',\n        values: ['left', 'right', 'up', 'down'],\n        dflt: 'down',\n        role: 'info',\n        description: [\n            'Determines the direction in which the buttons are laid out, whether',\n            'in a dropdown menu or a row/column of buttons. For `left` and `up`,',\n            'the buttons will still appear in left-to-right or top-to-bottom order',\n            'respectively.'\n        ].join(' ')\n    },\n\n    active: {\n        valType: 'integer',\n        role: 'info',\n        min: -1,\n        dflt: 0,\n        description: [\n            'Determines which button (by index starting from 0) is',\n            'considered active.'\n        ].join(' ')\n    },\n\n    showactive: {\n        valType: 'boolean',\n        role: 'info',\n        dflt: true,\n        description: 'Highlights active dropdown item or active button if true.'\n    },\n\n    buttons: buttonsAttrs,\n\n    x: {\n        valType: 'number',\n        min: -2,\n        max: 3,\n        dflt: -0.05,\n        role: 'style',\n        description: 'Sets the x position (in normalized coordinates) of the update menu.'\n    },\n    xanchor: {\n        valType: 'enumerated',\n        values: ['auto', 'left', 'center', 'right'],\n        dflt: 'right',\n        role: 'info',\n        description: [\n            'Sets the update menu\\'s horizontal position anchor.',\n            'This anchor binds the `x` position to the *left*, *center*',\n            'or *right* of the range selector.'\n        ].join(' ')\n    },\n    y: {\n        valType: 'number',\n        min: -2,\n        max: 3,\n        dflt: 1,\n        role: 'style',\n        description: 'Sets the y position (in normalized coordinates) of the update menu.'\n    },\n    yanchor: {\n        valType: 'enumerated',\n        values: ['auto', 'top', 'middle', 'bottom'],\n        dflt: 'top',\n        role: 'info',\n        description: [\n            'Sets the update menu\\'s vertical position anchor',\n            'This anchor binds the `y` position to the *top*, *middle*',\n            'or *bottom* of the range selector.'\n        ].join(' ')\n    },\n\n    pad: extendFlat(padAttrs({editType: 'arraydraw'}), {\n        description: 'Sets the padding around the buttons or dropdown menu.'\n    }),\n\n    font: fontAttrs({\n        description: 'Sets the font of the update menu button text.'\n    }),\n\n    bgcolor: {\n        valType: 'color',\n        role: 'style',\n        description: 'Sets the background color of the update menu buttons.'\n    },\n    bordercolor: {\n        valType: 'color',\n        dflt: colorAttrs.borderLine,\n        role: 'style',\n        description: 'Sets the color of the border enclosing the update menu.'\n    },\n    borderwidth: {\n        valType: 'number',\n        min: 0,\n        dflt: 1,\n        role: 'style',\n        editType: 'arraydraw',\n        description: 'Sets the width (in px) of the border enclosing the update menu.'\n    }\n}), 'arraydraw', 'from-root');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * Creates a set of padding attributes.\n *\n * @param {object} opts\n *   @param {string} editType:\n *     the editType for all pieces of this padding definition\n *\n * @return {object} attributes object containing {t, r, b, l} as specified\n */\nmodule.exports = function(opts) {\n    var editType = opts.editType;\n    return {\n        t: {\n            valType: 'number',\n            dflt: 0,\n            role: 'style',\n            editType: editType,\n            description: 'The amount of padding (in px) along the top of the component.'\n        },\n        r: {\n            valType: 'number',\n            dflt: 0,\n            role: 'style',\n            editType: editType,\n            description: 'The amount of padding (in px) on the right side of the component.'\n        },\n        b: {\n            valType: 'number',\n            dflt: 0,\n            role: 'style',\n            editType: editType,\n            description: 'The amount of padding (in px) along the bottom of the component.'\n        },\n        l: {\n            valType: 'number',\n            dflt: 0,\n            role: 'style',\n            editType: editType,\n            description: 'The amount of padding (in px) on the left side of the component.'\n        },\n        editType: editType\n    };\n};\n","'use strict';\n\nvar Lib = require('../src/lib');\nvar rules = {\n    \"X,X div\": \"direction:ltr;font-family:'Open Sans', verdana, arial, sans-serif;margin:0;padding:0;\",\n    \"X input,X button\": \"font-family:'Open Sans', verdana, arial, sans-serif;\",\n    \"X input:focus,X button:focus\": \"outline:none;\",\n    \"X a\": \"text-decoration:none;\",\n    \"X a:hover\": \"text-decoration:none;\",\n    \"X .crisp\": \"shape-rendering:crispEdges;\",\n    \"X .user-select-none\": \"-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;\",\n    \"X svg\": \"overflow:hidden;\",\n    \"X svg a\": \"fill:#447adb;\",\n    \"X svg a:hover\": \"fill:#3c6dc5;\",\n    \"X .main-svg\": \"position:absolute;top:0;left:0;pointer-events:none;\",\n    \"X .main-svg .draglayer\": \"pointer-events:all;\",\n    \"X .cursor-default\": \"cursor:default;\",\n    \"X .cursor-pointer\": \"cursor:pointer;\",\n    \"X .cursor-crosshair\": \"cursor:crosshair;\",\n    \"X .cursor-move\": \"cursor:move;\",\n    \"X .cursor-col-resize\": \"cursor:col-resize;\",\n    \"X .cursor-row-resize\": \"cursor:row-resize;\",\n    \"X .cursor-ns-resize\": \"cursor:ns-resize;\",\n    \"X .cursor-ew-resize\": \"cursor:ew-resize;\",\n    \"X .cursor-sw-resize\": \"cursor:sw-resize;\",\n    \"X .cursor-s-resize\": \"cursor:s-resize;\",\n    \"X .cursor-se-resize\": \"cursor:se-resize;\",\n    \"X .cursor-w-resize\": \"cursor:w-resize;\",\n    \"X .cursor-e-resize\": \"cursor:e-resize;\",\n    \"X .cursor-nw-resize\": \"cursor:nw-resize;\",\n    \"X .cursor-n-resize\": \"cursor:n-resize;\",\n    \"X .cursor-ne-resize\": \"cursor:ne-resize;\",\n    \"X .cursor-grab\": \"cursor:-webkit-grab;cursor:grab;\",\n    \"X .modebar\": \"position:absolute;top:2px;right:2px;\",\n    \"X .ease-bg\": \"-webkit-transition:background-color 0.3s ease 0s;-moz-transition:background-color 0.3s ease 0s;-ms-transition:background-color 0.3s ease 0s;-o-transition:background-color 0.3s ease 0s;transition:background-color 0.3s ease 0s;\",\n    \"X .modebar--hover>:not(.watermark)\": \"opacity:0;-webkit-transition:opacity 0.3s ease 0s;-moz-transition:opacity 0.3s ease 0s;-ms-transition:opacity 0.3s ease 0s;-o-transition:opacity 0.3s ease 0s;transition:opacity 0.3s ease 0s;\",\n    \"X:hover .modebar--hover .modebar-group\": \"opacity:1;\",\n    \"X .modebar-group\": \"float:left;display:inline-block;box-sizing:border-box;padding-left:8px;position:relative;vertical-align:middle;white-space:nowrap;\",\n    \"X .modebar-btn\": \"position:relative;font-size:16px;padding:3px 4px;height:22px;cursor:pointer;line-height:normal;box-sizing:border-box;\",\n    \"X .modebar-btn svg\": \"position:relative;top:2px;\",\n    \"X .modebar.vertical\": \"display:flex;flex-direction:column;flex-wrap:wrap;align-content:flex-end;max-height:100%;\",\n    \"X .modebar.vertical svg\": \"top:-1px;\",\n    \"X .modebar.vertical .modebar-group\": \"display:block;float:none;padding-left:0px;padding-bottom:8px;\",\n    \"X .modebar.vertical .modebar-group .modebar-btn\": \"display:block;text-align:center;\",\n    \"X [data-title]:before,X [data-title]:after\": \"position:absolute;-webkit-transform:translate3d(0, 0, 0);-moz-transform:translate3d(0, 0, 0);-ms-transform:translate3d(0, 0, 0);-o-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0);display:none;opacity:0;z-index:1001;pointer-events:none;top:110%;right:50%;\",\n    \"X [data-title]:hover:before,X [data-title]:hover:after\": \"display:block;opacity:1;\",\n    \"X [data-title]:before\": \"content:'';position:absolute;background:transparent;border:6px solid transparent;z-index:1002;margin-top:-12px;border-bottom-color:#69738a;margin-right:-6px;\",\n    \"X [data-title]:after\": \"content:attr(data-title);background:#69738a;color:white;padding:8px 10px;font-size:12px;line-height:12px;white-space:nowrap;margin-right:-18px;border-radius:2px;\",\n    \"X .vertical [data-title]:before,X .vertical [data-title]:after\": \"top:0%;right:200%;\",\n    \"X .vertical [data-title]:before\": \"border:6px solid transparent;border-left-color:#69738a;margin-top:8px;margin-right:-30px;\",\n    \"X .select-outline\": \"fill:none;stroke-width:1;shape-rendering:crispEdges;\",\n    \"X .select-outline-1\": \"stroke:white;\",\n    \"X .select-outline-2\": \"stroke:black;stroke-dasharray:2px 2px;\",\n    Y: \"font-family:'Open Sans';position:fixed;top:50px;right:20px;z-index:10000;font-size:10pt;max-width:180px;\",\n    \"Y p\": \"margin:0;\",\n    \"Y .notifier-note\": \"min-width:180px;max-width:250px;border:1px solid #fff;z-index:3000;margin:0;background-color:#8c97af;background-color:rgba(140,151,175,0.9);color:#fff;padding:10px;overflow-wrap:break-word;word-wrap:break-word;-ms-hyphens:auto;-webkit-hyphens:auto;hyphens:auto;\",\n    \"Y .notifier-close\": \"color:#fff;opacity:0.8;float:right;padding:0 5px;background:none;border:none;font-size:20px;font-weight:bold;line-height:20px;\",\n    \"Y .notifier-close:hover\": \"color:#444;text-decoration:none;cursor:pointer;\"\n};\n\nfor(var selector in rules) {\n    var fullSelector = selector.replace(/^,/,' ,')\n        .replace(/X/g, '.js-plotly-plot .plotly')\n        .replace(/Y/g, '.plotly-notifier');\n    Lib.addStyleRule(fullSelector, rules[selector]);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar buttonAttrs = templatedArray('button', {\n    visible: {\n        valType: 'boolean',\n        role: 'info',\n        dflt: true,\n        editType: 'plot',\n        description: 'Determines whether or not this button is visible.'\n    },\n    step: {\n        valType: 'enumerated',\n        role: 'info',\n        values: ['month', 'year', 'day', 'hour', 'minute', 'second', 'all'],\n        dflt: 'month',\n        editType: 'plot',\n        description: [\n            'The unit of measurement that the `count` value will set the range by.'\n        ].join(' ')\n    },\n    stepmode: {\n        valType: 'enumerated',\n        role: 'info',\n        values: ['backward', 'todate'],\n        dflt: 'backward',\n        editType: 'plot',\n        description: [\n            'Sets the range update mode.',\n            'If *backward*, the range update shifts the start of range',\n            'back *count* times *step* milliseconds.',\n            'If *todate*, the range update shifts the start of range',\n            'back to the first timestamp from *count* times',\n            '*step* milliseconds back.',\n            'For example, with `step` set to *year* and `count` set to *1*',\n            'the range update shifts the start of the range back to',\n            'January 01 of the current year.',\n            'Month and year *todate* are currently available only',\n            'for the built-in (Gregorian) calendar.'\n        ].join(' ')\n    },\n    count: {\n        valType: 'number',\n        role: 'info',\n        min: 0,\n        dflt: 1,\n        editType: 'plot',\n        description: [\n            'Sets the number of steps to take to update the range.',\n            'Use with `step` to specify the update interval.'\n        ].join(' ')\n    },\n    label: {\n        valType: 'string',\n        role: 'info',\n        editType: 'plot',\n        description: 'Sets the text label to appear on the button.'\n    },\n    editType: 'plot',\n    description: [\n        'Sets the specifications for each buttons.',\n        'By default, a range selector comes with no buttons.'\n    ].join(' ')\n});\n\nmodule.exports = {\n    visible: {\n        valType: 'boolean',\n        role: 'info',\n        editType: 'plot',\n        description: [\n            'Determines whether or not this range selector is visible.',\n            'Note that range selectors are only available for x axes of',\n            '`type` set to or auto-typed to *date*.'\n        ].join(' ')\n    },\n\n    buttons: buttonAttrs,\n\n    x: {\n        valType: 'number',\n        min: -2,\n        max: 3,\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the x position (in normalized coordinates) of the range selector.'\n    },\n    xanchor: {\n        valType: 'enumerated',\n        values: ['auto', 'left', 'center', 'right'],\n        dflt: 'left',\n        role: 'info',\n        editType: 'plot',\n        description: [\n            'Sets the range selector\\'s horizontal position anchor.',\n            'This anchor binds the `x` position to the *left*, *center*',\n            'or *right* of the range selector.'\n        ].join(' ')\n    },\n    y: {\n        valType: 'number',\n        min: -2,\n        max: 3,\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the y position (in normalized coordinates) of the range selector.'\n    },\n    yanchor: {\n        valType: 'enumerated',\n        values: ['auto', 'top', 'middle', 'bottom'],\n        dflt: 'bottom',\n        role: 'info',\n        editType: 'plot',\n        description: [\n            'Sets the range selector\\'s vertical position anchor',\n            'This anchor binds the `y` position to the *top*, *middle*',\n            'or *bottom* of the range selector.'\n        ].join(' ')\n    },\n\n    font: fontAttrs({\n        editType: 'plot',\n        description: 'Sets the font of the range selector button text.'\n    }),\n\n    bgcolor: {\n        valType: 'color',\n        dflt: colorAttrs.lightLine,\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the background color of the range selector buttons.'\n    },\n    activecolor: {\n        valType: 'color',\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the background color of the active range selector button.'\n    },\n    bordercolor: {\n        valType: 'color',\n        dflt: colorAttrs.defaultLine,\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the color of the border enclosing the range selector.'\n    },\n    borderwidth: {\n        valType: 'number',\n        min: 0,\n        dflt: 0,\n        role: 'style',\n        editType: 'plot',\n        description: 'Sets the width (in px) of the border enclosing the range selector.'\n    },\n    editType: 'plot'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar extractOpts = require('../colorscale/helpers').extractOpts;\n\nvar subTypes = require('../../traces/scatter/subtypes');\nvar stylePie = require('../../traces/pie/style_one');\nvar pieCastOption = require('../../traces/pie/helpers').castOption;\n\nvar CST_MARKER_SIZE = 12;\nvar CST_LINE_WIDTH = 5;\nvar CST_MARKER_LINE_WIDTH = 2;\nvar MAX_LINE_WIDTH = 10;\nvar MAX_MARKER_LINE_WIDTH = 5;\n\nmodule.exports = function style(s, gd, legend) {\n    var fullLayout = gd._fullLayout;\n    if(!legend) legend = fullLayout.legend;\n    var constantItemSizing = legend.itemsizing === 'constant';\n\n    var boundLineWidth = function(mlw, cont, max, cst) {\n        var v;\n        if(mlw + 1) {\n            v = mlw;\n        } else if(cont && cont.width > 0) {\n            v = cont.width;\n        } else {\n            return 0;\n        }\n        return constantItemSizing ? cst : Math.min(v, max);\n    };\n\n    s.each(function(d) {\n        var traceGroup = d3.select(this);\n\n        var layers = Lib.ensureSingle(traceGroup, 'g', 'layers');\n        layers.style('opacity', d[0].trace.opacity);\n\n        var valign = legend.valign;\n        var lineHeight = d[0].lineHeight;\n        var height = d[0].height;\n\n        if(valign === 'middle' || !lineHeight || !height) {\n            layers.attr('transform', null);\n        } else {\n            var factor = {top: 1, bottom: -1}[valign];\n            var markerOffsetY = factor * (0.5 * (lineHeight - height + 3));\n            layers.attr('transform', 'translate(0,' + markerOffsetY + ')');\n        }\n\n        var fill = layers\n            .selectAll('g.legendfill')\n                .data([d]);\n        fill.enter().append('g')\n            .classed('legendfill', true);\n\n        var line = layers\n            .selectAll('g.legendlines')\n                .data([d]);\n        line.enter().append('g')\n            .classed('legendlines', true);\n\n        var symbol = layers\n            .selectAll('g.legendsymbols')\n                .data([d]);\n        symbol.enter().append('g')\n            .classed('legendsymbols', true);\n\n        symbol.selectAll('g.legendpoints')\n            .data([d])\n          .enter().append('g')\n            .classed('legendpoints', true);\n    })\n    .each(styleSpatial)\n    .each(styleWaterfalls)\n    .each(styleFunnels)\n    .each(styleBars)\n    .each(styleBoxes)\n    .each(styleFunnelareas)\n    .each(stylePies)\n    .each(styleLines)\n    .each(stylePoints)\n    .each(styleCandles)\n    .each(styleOHLC);\n\n    function styleLines(d) {\n        var d0 = d[0];\n        var trace = d0.trace;\n        var showFill = trace.visible && trace.fill && trace.fill !== 'none';\n        var showLine = subTypes.hasLines(trace);\n        var contours = trace.contours;\n        var showGradientLine = false;\n        var showGradientFill = false;\n        var dMod, tMod;\n\n        var cOpts = extractOpts(trace);\n        var colorscale = cOpts.colorscale;\n        var reversescale = cOpts.reversescale;\n\n        var fillGradient = function(s) {\n            if(s.size()) {\n                var gradientID = 'legendfill-' + trace.uid;\n                Drawing.gradient(s, gd, gradientID,\n                    getGradientDirection(reversescale),\n                    colorscale, 'fill');\n            }\n        };\n\n        var lineGradient = function(s) {\n            if(s.size()) {\n                var gradientID = 'legendline-' + trace.uid;\n                Drawing.lineGroupStyle(s);\n                Drawing.gradient(s, gd, gradientID,\n                    getGradientDirection(reversescale),\n                    colorscale, 'stroke');\n            }\n        };\n\n        if(contours) {\n            var coloring = contours.coloring;\n\n            if(coloring === 'lines') {\n                showGradientLine = true;\n            } else {\n                showLine = coloring === 'none' || coloring === 'heatmap' || contours.showlines;\n            }\n\n            if(contours.type === 'constraint') {\n                showFill = contours._operation !== '=';\n            } else if(coloring === 'fill' || coloring === 'heatmap') {\n                showGradientFill = true;\n            }\n        }\n\n        // with fill and no markers or text, move the line and fill up a bit\n        // so it's more centered\n        var markersOrText = subTypes.hasMarkers(trace) || subTypes.hasText(trace);\n        var anyFill = showFill || showGradientFill;\n        var anyLine = showLine || showGradientLine;\n        var pathStart = (markersOrText || !anyFill) ? 'M5,0' :\n            // with a line leave it slightly below center, to leave room for the\n            // line thickness and because the line is usually more prominent\n            anyLine ? 'M5,-2' : 'M5,-3';\n\n        var this3 = d3.select(this);\n\n        var fill = this3.select('.legendfill').selectAll('path')\n            .data(showFill || showGradientFill ? [d] : []);\n        fill.enter().append('path').classed('js-fill', true);\n        fill.exit().remove();\n        fill.attr('d', pathStart + 'h30v6h-30z')\n            .call(showFill ? Drawing.fillGroupStyle : fillGradient);\n\n        if(showLine || showGradientLine) {\n            var lw = boundLineWidth(undefined, trace.line, MAX_LINE_WIDTH, CST_LINE_WIDTH);\n            tMod = Lib.minExtend(trace, {line: {width: lw}});\n            dMod = [Lib.minExtend(d0, {trace: tMod})];\n        }\n\n        var line = this3.select('.legendlines').selectAll('path')\n            .data(showLine || showGradientLine ? [dMod] : []);\n        line.enter().append('path').classed('js-line', true);\n        line.exit().remove();\n\n        // this is ugly... but you can't apply a gradient to a perfectly\n        // horizontal or vertical line. Presumably because then\n        // the system doesn't know how to scale vertical variation, even\n        // though there *is* no vertical variation in this case.\n        // so add an invisibly small angle to the line\n        // This issue (and workaround) exist across (Mac) Chrome, FF, and Safari\n        line.attr('d', pathStart + (showGradientLine ? 'l30,0.0001' : 'h30'))\n            .call(showLine ? Drawing.lineGroupStyle : lineGradient);\n    }\n\n    function stylePoints(d) {\n        var d0 = d[0];\n        var trace = d0.trace;\n        var showMarkers = subTypes.hasMarkers(trace);\n        var showText = subTypes.hasText(trace);\n        var showLines = subTypes.hasLines(trace);\n        var dMod, tMod;\n\n        // 'scatter3d' don't use gd.calcdata,\n        // use d0.trace to infer arrayOk attributes\n\n        function boundVal(attrIn, arrayToValFn, bounds, cst) {\n            var valIn = Lib.nestedProperty(trace, attrIn).get();\n            var valToBound = (Lib.isArrayOrTypedArray(valIn) && arrayToValFn) ?\n                arrayToValFn(valIn) :\n                valIn;\n\n            if(constantItemSizing && valToBound && cst !== undefined) {\n                valToBound = cst;\n            }\n\n            if(bounds) {\n                if(valToBound < bounds[0]) return bounds[0];\n                else if(valToBound > bounds[1]) return bounds[1];\n            }\n            return valToBound;\n        }\n\n        function pickFirst(array) {\n            if(d0._distinct && d0.index && array[d0.index]) return array[d0.index];\n            return array[0];\n        }\n\n        // constrain text, markers, etc so they'll fit on the legend\n        if(showMarkers || showText || showLines) {\n            var dEdit = {};\n            var tEdit = {};\n\n            if(showMarkers) {\n                dEdit.mc = boundVal('marker.color', pickFirst);\n                dEdit.mx = boundVal('marker.symbol', pickFirst);\n                dEdit.mo = boundVal('marker.opacity', Lib.mean, [0.2, 1]);\n                dEdit.mlc = boundVal('marker.line.color', pickFirst);\n                dEdit.mlw = boundVal('marker.line.width', Lib.mean, [0, 5], CST_MARKER_LINE_WIDTH);\n                tEdit.marker = {\n                    sizeref: 1,\n                    sizemin: 1,\n                    sizemode: 'diameter'\n                };\n\n                var ms = boundVal('marker.size', Lib.mean, [2, 16], CST_MARKER_SIZE);\n                dEdit.ms = ms;\n                tEdit.marker.size = ms;\n            }\n\n            if(showLines) {\n                tEdit.line = {\n                    width: boundVal('line.width', pickFirst, [0, 10], CST_LINE_WIDTH)\n                };\n            }\n\n            if(showText) {\n                dEdit.tx = 'Aa';\n                dEdit.tp = boundVal('textposition', pickFirst);\n                dEdit.ts = 10;\n                dEdit.tc = boundVal('textfont.color', pickFirst);\n                dEdit.tf = boundVal('textfont.family', pickFirst);\n            }\n\n            dMod = [Lib.minExtend(d0, dEdit)];\n            tMod = Lib.minExtend(trace, tEdit);\n\n            // always show legend items in base state\n            tMod.selectedpoints = null;\n\n            // never show texttemplate\n            tMod.texttemplate = null;\n        }\n\n        var ptgroup = d3.select(this).select('g.legendpoints');\n\n        var pts = ptgroup.selectAll('path.scatterpts')\n            .data(showMarkers ? dMod : []);\n        // make sure marker is on the bottom, in case it enters after text\n        pts.enter().insert('path', ':first-child')\n            .classed('scatterpts', true)\n            .attr('transform', 'translate(20,0)');\n        pts.exit().remove();\n        pts.call(Drawing.pointStyle, tMod, gd);\n\n        // 'mrc' is set in pointStyle and used in textPointStyle:\n        // constrain it here\n        if(showMarkers) dMod[0].mrc = 3;\n\n        var txt = ptgroup.selectAll('g.pointtext')\n            .data(showText ? dMod : []);\n        txt.enter()\n            .append('g').classed('pointtext', true)\n                .append('text').attr('transform', 'translate(20,0)');\n        txt.exit().remove();\n        txt.selectAll('text').call(Drawing.textPointStyle, tMod, gd);\n    }\n\n    function styleWaterfalls(d) {\n        var trace = d[0].trace;\n        var isWaterfall = trace.type === 'waterfall';\n\n        if(d[0]._distinct && isWaterfall) {\n            var cont = d[0].trace[d[0].dir].marker;\n            d[0].mc = cont.color;\n            d[0].mlw = cont.line.width;\n            d[0].mlc = cont.line.color;\n            return styleBarLike(d, this, 'waterfall');\n        }\n\n        var ptsData = [];\n        if(trace.visible && isWaterfall) {\n            ptsData = d[0].hasTotals ?\n                [['increasing', 'M-6,-6V6H0Z'], ['totals', 'M6,6H0L-6,-6H-0Z'], ['decreasing', 'M6,6V-6H0Z']] :\n                [['increasing', 'M-6,-6V6H6Z'], ['decreasing', 'M6,6V-6H-6Z']];\n        }\n\n        var pts = d3.select(this).select('g.legendpoints')\n            .selectAll('path.legendwaterfall')\n            .data(ptsData);\n        pts.enter().append('path').classed('legendwaterfall', true)\n            .attr('transform', 'translate(20,0)')\n            .style('stroke-miterlimit', 1);\n        pts.exit().remove();\n\n        pts.each(function(dd) {\n            var pt = d3.select(this);\n            var cont = trace[dd[0]].marker;\n            var lw = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n            pt.attr('d', dd[1])\n                .style('stroke-width', lw + 'px')\n                .call(Color.fill, cont.color);\n\n            if(lw) {\n                pt.call(Color.stroke, cont.line.color);\n            }\n        });\n    }\n\n    function styleBars(d) {\n        styleBarLike(d, this);\n    }\n\n    function styleFunnels(d) {\n        styleBarLike(d, this, 'funnel');\n    }\n\n    function styleBarLike(d, lThis, desiredType) {\n        var trace = d[0].trace;\n        var marker = trace.marker || {};\n        var markerLine = marker.line || {};\n\n        var isVisible = (!desiredType) ? Registry.traceIs(trace, 'bar') :\n            (trace.visible && trace.type === desiredType);\n\n        var barpath = d3.select(lThis).select('g.legendpoints')\n            .selectAll('path.legend' + desiredType)\n            .data(isVisible ? [d] : []);\n        barpath.enter().append('path').classed('legend' + desiredType, true)\n            .attr('d', 'M6,6H-6V-6H6Z')\n            .attr('transform', 'translate(20,0)');\n        barpath.exit().remove();\n\n        barpath.each(function(d) {\n            var p = d3.select(this);\n            var d0 = d[0];\n            var w = boundLineWidth(d0.mlw, marker.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n            p.style('stroke-width', w + 'px')\n                .call(Color.fill, d0.mc || marker.color);\n\n            if(w) Color.stroke(p, d0.mlc || markerLine.color);\n        });\n    }\n\n    function styleBoxes(d) {\n        var trace = d[0].trace;\n\n        var pts = d3.select(this).select('g.legendpoints')\n            .selectAll('path.legendbox')\n            .data(trace.visible && Registry.traceIs(trace, 'box-violin') ? [d] : []);\n        pts.enter().append('path').classed('legendbox', true)\n            // if we want the median bar, prepend M6,0H-6\n            .attr('d', 'M6,6H-6V-6H6Z')\n            .attr('transform', 'translate(20,0)');\n        pts.exit().remove();\n\n        pts.each(function() {\n            var p = d3.select(this);\n\n            if((trace.boxpoints === 'all' || trace.points === 'all') &&\n                Color.opacity(trace.fillcolor) === 0 && Color.opacity((trace.line || {}).color) === 0\n            ) {\n                var tMod = Lib.minExtend(trace, {\n                    marker: {\n                        size: constantItemSizing ? CST_MARKER_SIZE : Lib.constrain(trace.marker.size, 2, 16),\n                        sizeref: 1,\n                        sizemin: 1,\n                        sizemode: 'diameter'\n                    }\n                });\n                pts.call(Drawing.pointStyle, tMod, gd);\n            } else {\n                var w = boundLineWidth(undefined, trace.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n                p.style('stroke-width', w + 'px')\n                    .call(Color.fill, trace.fillcolor);\n\n                if(w) Color.stroke(p, trace.line.color);\n            }\n        });\n    }\n\n    function styleCandles(d) {\n        var trace = d[0].trace;\n\n        var pts = d3.select(this).select('g.legendpoints')\n            .selectAll('path.legendcandle')\n            .data(trace.visible && trace.type === 'candlestick' ? [d, d] : []);\n        pts.enter().append('path').classed('legendcandle', true)\n            .attr('d', function(_, i) {\n                if(i) return 'M-15,0H-8M-8,6V-6H8Z'; // increasing\n                return 'M15,0H8M8,-6V6H-8Z'; // decreasing\n            })\n            .attr('transform', 'translate(20,0)')\n            .style('stroke-miterlimit', 1);\n        pts.exit().remove();\n\n        pts.each(function(_, i) {\n            var p = d3.select(this);\n            var cont = trace[i ? 'increasing' : 'decreasing'];\n            var w = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n            p.style('stroke-width', w + 'px')\n                .call(Color.fill, cont.fillcolor);\n\n            if(w) Color.stroke(p, cont.line.color);\n        });\n    }\n\n    function styleOHLC(d) {\n        var trace = d[0].trace;\n\n        var pts = d3.select(this).select('g.legendpoints')\n            .selectAll('path.legendohlc')\n            .data(trace.visible && trace.type === 'ohlc' ? [d, d] : []);\n        pts.enter().append('path').classed('legendohlc', true)\n            .attr('d', function(_, i) {\n                if(i) return 'M-15,0H0M-8,-6V0'; // increasing\n                return 'M15,0H0M8,6V0'; // decreasing\n            })\n            .attr('transform', 'translate(20,0)')\n            .style('stroke-miterlimit', 1);\n        pts.exit().remove();\n\n        pts.each(function(_, i) {\n            var p = d3.select(this);\n            var cont = trace[i ? 'increasing' : 'decreasing'];\n            var w = boundLineWidth(undefined, cont.line, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n            p.style('fill', 'none')\n                .call(Drawing.dashLine, cont.line.dash, w);\n\n            if(w) Color.stroke(p, cont.line.color);\n        });\n    }\n\n    function stylePies(d) {\n        stylePieLike(d, this, 'pie');\n    }\n\n    function styleFunnelareas(d) {\n        stylePieLike(d, this, 'funnelarea');\n    }\n\n    function stylePieLike(d, lThis, desiredType) {\n        var d0 = d[0];\n        var trace = d0.trace;\n\n        var isVisible = (!desiredType) ? Registry.traceIs(trace, desiredType) :\n            (trace.visible && trace.type === desiredType);\n\n        var pts = d3.select(lThis).select('g.legendpoints')\n            .selectAll('path.legend' + desiredType)\n            .data(isVisible ? [d] : []);\n        pts.enter().append('path').classed('legend' + desiredType, true)\n            .attr('d', 'M6,6H-6V-6H6Z')\n            .attr('transform', 'translate(20,0)');\n        pts.exit().remove();\n\n        if(pts.size()) {\n            var cont = (trace.marker || {}).line;\n            var lw = boundLineWidth(pieCastOption(cont.width, d0.pts), cont, MAX_MARKER_LINE_WIDTH, CST_MARKER_LINE_WIDTH);\n\n            var tMod = Lib.minExtend(trace, {marker: {line: {width: lw}}});\n            // since minExtend do not slice more than 3 items we need to patch line.color here\n            tMod.marker.line.color = cont.color;\n\n            var d0Mod = Lib.minExtend(d0, {trace: tMod});\n\n            stylePie(pts, d0Mod, tMod);\n        }\n    }\n\n    function styleSpatial(d) { // i.e. maninly traces having z and colorscale\n        var trace = d[0].trace;\n\n        var useGradient;\n        var ptsData = [];\n        if(trace.visible) {\n            switch(trace.type) {\n                case 'histogram2d' :\n                case 'heatmap' :\n                    ptsData = [\n                        ['M-15,-2V4H15V-2Z'] // similar to contour\n                    ];\n                    useGradient = true;\n                    break;\n                case 'choropleth' :\n                case 'choroplethmapbox' :\n                    ptsData = [\n                        ['M-6,-6V6H6V-6Z']\n                    ];\n                    useGradient = true;\n                    break;\n                case 'densitymapbox' :\n                    ptsData = [\n                        ['M-6,0 a6,6 0 1,0 12,0 a 6,6 0 1,0 -12,0']\n                    ];\n                    useGradient = 'radial';\n                    break;\n                case 'cone' :\n                    ptsData = [\n                        ['M-6,2 A2,2 0 0,0 -6,6 V6L6,4Z'],\n                        ['M-6,-6 A2,2 0 0,0 -6,-2 L6,-4Z'],\n                        ['M-6,-2 A2,2 0 0,0 -6,2 L6,0Z']\n                    ];\n                    useGradient = false;\n                    break;\n                case 'streamtube' :\n                    ptsData = [\n                        ['M-6,2 A2,2 0 0,0 -6,6 H6 A2,2 0 0,1 6,2 Z'],\n                        ['M-6,-6 A2,2 0 0,0 -6,-2 H6 A2,2 0 0,1 6,-6 Z'],\n                        ['M-6,-2 A2,2 0 0,0 -6,2 H6 A2,2 0 0,1 6,-2 Z']\n                    ];\n                    useGradient = false;\n                    break;\n                case 'surface' :\n                    ptsData = [\n                        ['M-6,-6 A2,3 0 0,0 -6,0 H6 A2,3 0 0,1 6,-6 Z'],\n                        ['M-6,1 A2,3 0 0,1 -6,6 H6 A2,3 0 0,0 6,0 Z']\n                    ];\n                    useGradient = true;\n                    break;\n                case 'mesh3d' :\n                    ptsData = [\n                        ['M-6,6H0L-6,-6Z'],\n                        ['M6,6H0L6,-6Z'],\n                        ['M-6,-6H6L0,6Z']\n                    ];\n                    useGradient = false;\n                    break;\n                case 'volume' :\n                    ptsData = [\n                        ['M-6,6H0L-6,-6Z'],\n                        ['M6,6H0L6,-6Z'],\n                        ['M-6,-6H6L0,6Z']\n                    ];\n                    useGradient = true;\n                    break;\n                case 'isosurface':\n                    ptsData = [\n                        ['M-6,6H0L-6,-6Z'],\n                        ['M6,6H0L6,-6Z'],\n                        ['M-6,-6 A12,24 0 0,0 6,-6 L0,6Z']\n                    ];\n                    useGradient = false;\n                    break;\n            }\n        }\n\n        var pts = d3.select(this).select('g.legendpoints')\n            .selectAll('path.legend3dandfriends')\n            .data(ptsData);\n        pts.enter().append('path').classed('legend3dandfriends', true)\n            .attr('transform', 'translate(20,0)')\n            .style('stroke-miterlimit', 1);\n        pts.exit().remove();\n\n        pts.each(function(dd, i) {\n            var pt = d3.select(this);\n\n            var cOpts = extractOpts(trace);\n            var colorscale = cOpts.colorscale;\n            var reversescale = cOpts.reversescale;\n            var fillGradient = function(s) {\n                if(s.size()) {\n                    var gradientID = 'legendfill-' + trace.uid;\n                    Drawing.gradient(s, gd, gradientID,\n                        getGradientDirection(reversescale, useGradient === 'radial'),\n                        colorscale, 'fill');\n                }\n            };\n\n            var fillColor;\n            if(!colorscale) {\n                var color = trace.vertexcolor || trace.facecolor || trace.color;\n                fillColor = Lib.isArrayOrTypedArray(color) ? (color[i] || color[0]) : color;\n            } else {\n                if(!useGradient) {\n                    var len = colorscale.length;\n                    fillColor =\n                        i === 0 ? colorscale[reversescale ? len - 1 : 0][1] : // minimum\n                        i === 1 ? colorscale[reversescale ? 0 : len - 1][1] : // maximum\n                            colorscale[Math.floor((len - 1) / 2)][1]; // middle\n                }\n            }\n\n            pt.attr('d', dd[0]);\n            if(fillColor) {\n                pt.call(Color.fill, fillColor);\n            } else {\n                pt.call(fillGradient);\n            }\n        });\n    }\n};\n\nfunction getGradientDirection(reversescale, isRadial) {\n    var str = isRadial ? 'radial' : 'horizontal';\n    return str + (reversescale ? '' : 'reversed');\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Plots = require('../plots');\nvar Drawing = require('../../components/drawing');\n\nvar getModuleCalcData = require('../get_data').getModuleCalcData;\nvar axisIds = require('./axis_ids');\nvar constants = require('./constants');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nvar ensureSingle = Lib.ensureSingle;\n\nfunction ensureSingleAndAddDatum(parent, nodeType, className) {\n    return Lib.ensureSingle(parent, nodeType, className, function(s) {\n        s.datum(className);\n    });\n}\n\nexports.name = 'cartesian';\n\nexports.attr = ['xaxis', 'yaxis'];\n\nexports.idRoot = ['x', 'y'];\n\nexports.idRegex = constants.idRegex;\n\nexports.attrRegex = constants.attrRegex;\n\nexports.attributes = require('./attributes');\n\nexports.layoutAttributes = require('./layout_attributes');\n\nexports.supplyLayoutDefaults = require('./layout_defaults');\n\nexports.transitionAxes = require('./transition_axes');\n\nexports.finalizeSubplots = function(layoutIn, layoutOut) {\n    var subplots = layoutOut._subplots;\n    var xList = subplots.xaxis;\n    var yList = subplots.yaxis;\n    var spSVG = subplots.cartesian;\n    var spAll = spSVG.concat(subplots.gl2d || []);\n    var allX = {};\n    var allY = {};\n    var i, xi, yi;\n\n    for(i = 0; i < spAll.length; i++) {\n        var parts = spAll[i].split('y');\n        allX[parts[0]] = 1;\n        allY['y' + parts[1]] = 1;\n    }\n\n    // check for x axes with no subplot, and make one from the anchor of that x axis\n    for(i = 0; i < xList.length; i++) {\n        xi = xList[i];\n        if(!allX[xi]) {\n            yi = (layoutIn[axisIds.id2name(xi)] || {}).anchor;\n            if(!constants.idRegex.y.test(yi)) yi = 'y';\n            spSVG.push(xi + yi);\n            spAll.push(xi + yi);\n\n            if(!allY[yi]) {\n                allY[yi] = 1;\n                Lib.pushUnique(yList, yi);\n            }\n        }\n    }\n\n    // same for y axes with no subplot\n    for(i = 0; i < yList.length; i++) {\n        yi = yList[i];\n        if(!allY[yi]) {\n            xi = (layoutIn[axisIds.id2name(yi)] || {}).anchor;\n            if(!constants.idRegex.x.test(xi)) xi = 'x';\n            spSVG.push(xi + yi);\n            spAll.push(xi + yi);\n\n            if(!allX[xi]) {\n                allX[xi] = 1;\n                Lib.pushUnique(xList, xi);\n            }\n        }\n    }\n\n    // finally, if we've gotten here we're supposed to show cartesian...\n    // so if there are NO subplots at all, make one from the first\n    // x & y axes in the input layout\n    if(!spAll.length) {\n        xi = '';\n        yi = '';\n        for(var ki in layoutIn) {\n            if(constants.attrRegex.test(ki)) {\n                var axLetter = ki.charAt(0);\n                if(axLetter === 'x') {\n                    if(!xi || (+ki.substr(5) < +xi.substr(5))) {\n                        xi = ki;\n                    }\n                } else if(!yi || (+ki.substr(5) < +yi.substr(5))) {\n                    yi = ki;\n                }\n            }\n        }\n        xi = xi ? axisIds.name2id(xi) : 'x';\n        yi = yi ? axisIds.name2id(yi) : 'y';\n        xList.push(xi);\n        yList.push(yi);\n        spSVG.push(xi + yi);\n    }\n};\n\n/**\n * Cartesian.plot\n *\n * @param {DOM div | object} gd\n * @param {array (optional)} traces\n *  array of traces indices to plot\n *  if undefined, plots all cartesian traces,\n * @param {object} (optional) transitionOpts\n *  transition option object\n * @param {function} (optional) makeOnCompleteCallback\n *  transition make callback function from Plots.transition\n */\nexports.plot = function(gd, traces, transitionOpts, makeOnCompleteCallback) {\n    var fullLayout = gd._fullLayout;\n    var subplots = fullLayout._subplots.cartesian;\n    var calcdata = gd.calcdata;\n    var i;\n\n    if(!Array.isArray(traces)) {\n        // If traces is not provided, then it's a complete replot and missing\n        // traces are removed\n        traces = [];\n        for(i = 0; i < calcdata.length; i++) traces.push(i);\n    }\n\n    for(i = 0; i < subplots.length; i++) {\n        var subplot = subplots[i];\n        var subplotInfo = fullLayout._plots[subplot];\n\n        // Get all calcdata for this subplot:\n        var cdSubplot = [];\n        var pcd;\n\n        for(var j = 0; j < calcdata.length; j++) {\n            var cd = calcdata[j];\n            var trace = cd[0].trace;\n\n            // Skip trace if whitelist provided and it's not whitelisted:\n            // if (Array.isArray(traces) && traces.indexOf(i) === -1) continue;\n            if(trace.xaxis + trace.yaxis === subplot) {\n                // XXX: Should trace carpet dependencies. Only replot all carpet plots if the carpet\n                // axis has actually changed:\n                //\n                // If this trace is specifically requested, add it to the list:\n                if(traces.indexOf(trace.index) !== -1 || trace.carpet) {\n                    // Okay, so example: traces 0, 1, and 2 have fill = tonext. You animate\n                    // traces 0 and 2. Trace 1 also needs to be updated, otherwise its fill\n                    // is outdated. So this retroactively adds the previous trace if the\n                    // traces are interdependent.\n                    if(\n                        pcd &&\n                        pcd[0].trace.xaxis + pcd[0].trace.yaxis === subplot &&\n                        ['tonextx', 'tonexty', 'tonext'].indexOf(trace.fill) !== -1 &&\n                        cdSubplot.indexOf(pcd) === -1\n                    ) {\n                        cdSubplot.push(pcd);\n                    }\n\n                    cdSubplot.push(cd);\n                }\n\n                // Track the previous trace on this subplot for the retroactive-add step\n                // above:\n                pcd = cd;\n            }\n        }\n\n        plotOne(gd, subplotInfo, cdSubplot, transitionOpts, makeOnCompleteCallback);\n    }\n};\n\nfunction plotOne(gd, plotinfo, cdSubplot, transitionOpts, makeOnCompleteCallback) {\n    var traceLayerClasses = constants.traceLayerClasses;\n    var fullLayout = gd._fullLayout;\n    var modules = fullLayout._modules;\n    var _module, cdModuleAndOthers, cdModule;\n\n    var layerData = [];\n    var zoomScaleQueryParts = [];\n\n    for(var i = 0; i < modules.length; i++) {\n        _module = modules[i];\n        var name = _module.name;\n        var categories = Registry.modules[name].categories;\n\n        if(categories.svg) {\n            var className = (_module.layerName || name + 'layer');\n            var plotMethod = _module.plot;\n\n            // plot all visible traces of this type on this subplot at once\n            cdModuleAndOthers = getModuleCalcData(cdSubplot, plotMethod);\n            cdModule = cdModuleAndOthers[0];\n            // don't need to search the found traces again - in fact we need to NOT\n            // so that if two modules share the same plotter we don't double-plot\n            cdSubplot = cdModuleAndOthers[1];\n\n            if(cdModule.length) {\n                layerData.push({\n                    i: traceLayerClasses.indexOf(className),\n                    className: className,\n                    plotMethod: plotMethod,\n                    cdModule: cdModule\n                });\n            }\n\n            if(categories.zoomScale) {\n                zoomScaleQueryParts.push('.' + className);\n            }\n        }\n    }\n\n    layerData.sort(function(a, b) { return a.i - b.i; });\n\n    var layers = plotinfo.plot.selectAll('g.mlayer')\n        .data(layerData, function(d) { return d.className; });\n\n    layers.enter().append('g')\n        .attr('class', function(d) { return d.className; })\n        .classed('mlayer', true)\n        .classed('rangeplot', plotinfo.isRangePlot);\n\n    layers.exit().remove();\n\n    layers.order();\n\n    layers.each(function(d) {\n        var sel = d3.select(this);\n        var className = d.className;\n\n        d.plotMethod(\n            gd, plotinfo, d.cdModule, sel,\n            transitionOpts, makeOnCompleteCallback\n        );\n\n        // layers that allow `cliponaxis: false`\n        if(constants.clipOnAxisFalseQuery.indexOf('.' + className) === -1) {\n            Drawing.setClipUrl(sel, plotinfo.layerClipId, gd);\n        }\n    });\n\n    // call Scattergl.plot separately\n    if(fullLayout._has('scattergl')) {\n        _module = Registry.getModule('scattergl');\n        cdModule = getModuleCalcData(cdSubplot, _module)[0];\n        _module.plot(gd, plotinfo, cdModule);\n    }\n\n    // stash \"hot\" selections for faster interaction on drag and scroll\n    if(!gd._context.staticPlot) {\n        if(plotinfo._hasClipOnAxisFalse) {\n            plotinfo.clipOnAxisFalseTraces = plotinfo.plot\n                .selectAll(constants.clipOnAxisFalseQuery.join(','))\n                .selectAll('.trace');\n        }\n\n        if(zoomScaleQueryParts.length) {\n            var traces = plotinfo.plot\n                .selectAll(zoomScaleQueryParts.join(','))\n                .selectAll('.trace');\n\n            plotinfo.zoomScalePts = traces.selectAll('path.point');\n            plotinfo.zoomScaleTxt = traces.selectAll('.textpoint');\n        }\n    }\n}\n\nexports.clean = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n    var oldPlots = oldFullLayout._plots || {};\n    var newPlots = newFullLayout._plots || {};\n    var oldSubplotList = oldFullLayout._subplots || {};\n    var plotinfo;\n    var i, k;\n\n    // when going from a large splom graph to something else,\n    // we need to clear  so that the new cartesian subplot\n    // can have the correct layer ordering\n    if(oldFullLayout._hasOnlyLargeSploms && !newFullLayout._hasOnlyLargeSploms) {\n        for(k in oldPlots) {\n            plotinfo = oldPlots[k];\n            if(plotinfo.plotgroup) plotinfo.plotgroup.remove();\n        }\n    }\n\n    var hadGl = (oldFullLayout._has && oldFullLayout._has('gl'));\n    var hasGl = (newFullLayout._has && newFullLayout._has('gl'));\n\n    if(hadGl && !hasGl) {\n        for(k in oldPlots) {\n            plotinfo = oldPlots[k];\n            if(plotinfo._scene) plotinfo._scene.destroy();\n        }\n    }\n\n    // delete any titles we don't need anymore\n    // check if axis list has changed, and if so clear old titles\n    if(oldSubplotList.xaxis && oldSubplotList.yaxis) {\n        var oldAxIDs = axisIds.listIds({_fullLayout: oldFullLayout});\n        for(i = 0; i < oldAxIDs.length; i++) {\n            var oldAxId = oldAxIDs[i];\n            if(!newFullLayout[axisIds.id2name(oldAxId)]) {\n                oldFullLayout._infolayer.selectAll('.g-' + oldAxId + 'title').remove();\n            }\n        }\n    }\n\n    var hadCartesian = (oldFullLayout._has && oldFullLayout._has('cartesian'));\n    var hasCartesian = (newFullLayout._has && newFullLayout._has('cartesian'));\n\n    if(hadCartesian && !hasCartesian) {\n        // if we've gotten rid of all cartesian traces, remove all the subplot svg items\n\n        purgeSubplotLayers(oldFullLayout._cartesianlayer.selectAll('.subplot'), oldFullLayout);\n        oldFullLayout._defs.selectAll('.axesclip').remove();\n        delete oldFullLayout._axisConstraintGroups;\n    } else if(oldSubplotList.cartesian) {\n        // otherwise look for subplots we need to remove\n\n        for(i = 0; i < oldSubplotList.cartesian.length; i++) {\n            var oldSubplotId = oldSubplotList.cartesian[i];\n            if(!newPlots[oldSubplotId]) {\n                var selector = '.' + oldSubplotId + ',.' + oldSubplotId + '-x,.' + oldSubplotId + '-y';\n                oldFullLayout._cartesianlayer.selectAll(selector).remove();\n                removeSubplotExtras(oldSubplotId, oldFullLayout);\n            }\n        }\n    }\n};\n\nexports.drawFramework = function(gd) {\n    var fullLayout = gd._fullLayout;\n    var subplotData = makeSubplotData(gd);\n\n    var subplotLayers = fullLayout._cartesianlayer.selectAll('.subplot')\n        .data(subplotData, String);\n\n    subplotLayers.enter().append('g')\n        .attr('class', function(d) { return 'subplot ' + d[0]; });\n\n    subplotLayers.order();\n\n    subplotLayers.exit()\n        .call(purgeSubplotLayers, fullLayout);\n\n    subplotLayers.each(function(d) {\n        var id = d[0];\n        var plotinfo = fullLayout._plots[id];\n\n        plotinfo.plotgroup = d3.select(this);\n        makeSubplotLayer(gd, plotinfo);\n\n        // make separate drag layers for each subplot,\n        // but append them to paper rather than the plot groups,\n        // so they end up on top of the rest\n        plotinfo.draglayer = ensureSingle(fullLayout._draggers, 'g', id);\n    });\n};\n\nexports.rangePlot = function(gd, plotinfo, cdSubplot) {\n    makeSubplotLayer(gd, plotinfo);\n    plotOne(gd, plotinfo, cdSubplot);\n    Plots.style(gd);\n};\n\nfunction makeSubplotData(gd) {\n    var fullLayout = gd._fullLayout;\n    var ids = fullLayout._subplots.cartesian;\n    var len = ids.length;\n    var i, j, id, plotinfo, xa, ya;\n\n    // split 'regular' and 'overlaying' subplots\n    var regulars = [];\n    var overlays = [];\n\n    for(i = 0; i < len; i++) {\n        id = ids[i];\n        plotinfo = fullLayout._plots[id];\n        xa = plotinfo.xaxis;\n        ya = plotinfo.yaxis;\n\n        var xa2 = xa._mainAxis;\n        var ya2 = ya._mainAxis;\n        var mainplot = xa2._id + ya2._id;\n        var mainplotinfo = fullLayout._plots[mainplot];\n        plotinfo.overlays = [];\n\n        if(mainplot !== id && mainplotinfo) {\n            plotinfo.mainplot = mainplot;\n            plotinfo.mainplotinfo = mainplotinfo;\n            overlays.push(id);\n        } else {\n            plotinfo.mainplot = undefined;\n            plotinfo.mainPlotinfo = undefined;\n            regulars.push(id);\n        }\n    }\n\n    // fill in list of overlaying subplots in 'main plot'\n    for(i = 0; i < overlays.length; i++) {\n        id = overlays[i];\n        plotinfo = fullLayout._plots[id];\n        plotinfo.mainplotinfo.overlays.push(plotinfo);\n    }\n\n    // put 'regular' subplot data before 'overlaying'\n    var subplotIds = regulars.concat(overlays);\n    var subplotData = new Array(len);\n\n    for(i = 0; i < len; i++) {\n        id = subplotIds[i];\n        plotinfo = fullLayout._plots[id];\n        xa = plotinfo.xaxis;\n        ya = plotinfo.yaxis;\n\n        // use info about axis layer and overlaying pattern\n        // to clean what need to be cleaned up in exit selection\n        var d = [id, xa.layer, ya.layer, xa.overlaying || '', ya.overlaying || ''];\n        for(j = 0; j < plotinfo.overlays.length; j++) {\n            d.push(plotinfo.overlays[j].id);\n        }\n        subplotData[i] = d;\n    }\n\n    return subplotData;\n}\n\nfunction makeSubplotLayer(gd, plotinfo) {\n    var plotgroup = plotinfo.plotgroup;\n    var id = plotinfo.id;\n    var xLayer = constants.layerValue2layerClass[plotinfo.xaxis.layer];\n    var yLayer = constants.layerValue2layerClass[plotinfo.yaxis.layer];\n    var hasOnlyLargeSploms = gd._fullLayout._hasOnlyLargeSploms;\n\n    if(!plotinfo.mainplot) {\n        if(hasOnlyLargeSploms) {\n            // TODO could do even better\n            // - we don't need plot (but we would have to mock it in lsInner\n            //   and other places\n            // - we don't (x|y)lines and (x|y)axislayer for most subplots\n            //   usually just the bottom x and left y axes.\n            plotinfo.xlines = ensureSingle(plotgroup, 'path', 'xlines-above');\n            plotinfo.ylines = ensureSingle(plotgroup, 'path', 'ylines-above');\n            plotinfo.xaxislayer = ensureSingle(plotgroup, 'g', 'xaxislayer-above');\n            plotinfo.yaxislayer = ensureSingle(plotgroup, 'g', 'yaxislayer-above');\n        } else {\n            var backLayer = ensureSingle(plotgroup, 'g', 'layer-subplot');\n            plotinfo.shapelayer = ensureSingle(backLayer, 'g', 'shapelayer');\n            plotinfo.imagelayer = ensureSingle(backLayer, 'g', 'imagelayer');\n\n            plotinfo.gridlayer = ensureSingle(plotgroup, 'g', 'gridlayer');\n            plotinfo.zerolinelayer = ensureSingle(plotgroup, 'g', 'zerolinelayer');\n\n            ensureSingle(plotgroup, 'path', 'xlines-below');\n            ensureSingle(plotgroup, 'path', 'ylines-below');\n            plotinfo.overlinesBelow = ensureSingle(plotgroup, 'g', 'overlines-below');\n\n            ensureSingle(plotgroup, 'g', 'xaxislayer-below');\n            ensureSingle(plotgroup, 'g', 'yaxislayer-below');\n            plotinfo.overaxesBelow = ensureSingle(plotgroup, 'g', 'overaxes-below');\n\n            plotinfo.plot = ensureSingle(plotgroup, 'g', 'plot');\n            plotinfo.overplot = ensureSingle(plotgroup, 'g', 'overplot');\n\n            plotinfo.xlines = ensureSingle(plotgroup, 'path', 'xlines-above');\n            plotinfo.ylines = ensureSingle(plotgroup, 'path', 'ylines-above');\n            plotinfo.overlinesAbove = ensureSingle(plotgroup, 'g', 'overlines-above');\n\n            ensureSingle(plotgroup, 'g', 'xaxislayer-above');\n            ensureSingle(plotgroup, 'g', 'yaxislayer-above');\n            plotinfo.overaxesAbove = ensureSingle(plotgroup, 'g', 'overaxes-above');\n\n            // set refs to correct layers as determined by 'axis.layer'\n            plotinfo.xlines = plotgroup.select('.xlines-' + xLayer);\n            plotinfo.ylines = plotgroup.select('.ylines-' + yLayer);\n            plotinfo.xaxislayer = plotgroup.select('.xaxislayer-' + xLayer);\n            plotinfo.yaxislayer = plotgroup.select('.yaxislayer-' + yLayer);\n        }\n    } else {\n        var mainplotinfo = plotinfo.mainplotinfo;\n        var mainplotgroup = mainplotinfo.plotgroup;\n        var xId = id + '-x';\n        var yId = id + '-y';\n\n        // now make the components of overlaid subplots\n        // overlays don't have backgrounds, and append all\n        // their other components to the corresponding\n        // extra groups of their main plots.\n\n        plotinfo.gridlayer = mainplotinfo.gridlayer;\n        plotinfo.zerolinelayer = mainplotinfo.zerolinelayer;\n\n        ensureSingle(mainplotinfo.overlinesBelow, 'path', xId);\n        ensureSingle(mainplotinfo.overlinesBelow, 'path', yId);\n        ensureSingle(mainplotinfo.overaxesBelow, 'g', xId);\n        ensureSingle(mainplotinfo.overaxesBelow, 'g', yId);\n\n        plotinfo.plot = ensureSingle(mainplotinfo.overplot, 'g', id);\n\n        ensureSingle(mainplotinfo.overlinesAbove, 'path', xId);\n        ensureSingle(mainplotinfo.overlinesAbove, 'path', yId);\n        ensureSingle(mainplotinfo.overaxesAbove, 'g', xId);\n        ensureSingle(mainplotinfo.overaxesAbove, 'g', yId);\n\n        // set refs to correct layers as determined by 'abovetraces'\n        plotinfo.xlines = mainplotgroup.select('.overlines-' + xLayer).select('.' + xId);\n        plotinfo.ylines = mainplotgroup.select('.overlines-' + yLayer).select('.' + yId);\n        plotinfo.xaxislayer = mainplotgroup.select('.overaxes-' + xLayer).select('.' + xId);\n        plotinfo.yaxislayer = mainplotgroup.select('.overaxes-' + yLayer).select('.' + yId);\n    }\n\n    // common attributes for all subplots, overlays or not\n\n    if(!hasOnlyLargeSploms) {\n        ensureSingleAndAddDatum(plotinfo.gridlayer, 'g', plotinfo.xaxis._id);\n        ensureSingleAndAddDatum(plotinfo.gridlayer, 'g', plotinfo.yaxis._id);\n        plotinfo.gridlayer.selectAll('g')\n            .map(function(d) { return d[0]; })\n            .sort(axisIds.idSort);\n    }\n\n    plotinfo.xlines\n        .style('fill', 'none')\n        .classed('crisp', true);\n\n    plotinfo.ylines\n        .style('fill', 'none')\n        .classed('crisp', true);\n}\n\nfunction purgeSubplotLayers(layers, fullLayout) {\n    if(!layers) return;\n\n    var overlayIdsToRemove = {};\n\n    layers.each(function(d) {\n        var id = d[0];\n        var plotgroup = d3.select(this);\n\n        plotgroup.remove();\n        removeSubplotExtras(id, fullLayout);\n        overlayIdsToRemove[id] = true;\n\n        // do not remove individual axis s here\n        // as other subplots may need them\n    });\n\n    // must remove overlaid subplot trace layers 'manually'\n\n    for(var k in fullLayout._plots) {\n        var subplotInfo = fullLayout._plots[k];\n        var overlays = subplotInfo.overlays || [];\n\n        for(var j = 0; j < overlays.length; j++) {\n            var overlayInfo = overlays[j];\n\n            if(overlayIdsToRemove[overlayInfo.id]) {\n                overlayInfo.plot.selectAll('.trace').remove();\n            }\n        }\n    }\n}\n\nfunction removeSubplotExtras(subplotId, fullLayout) {\n    fullLayout._draggers.selectAll('g.' + subplotId).remove();\n    fullLayout._defs.select('#clip' + fullLayout._uid + subplotId + 'plot').remove();\n}\n\nexports.toSVG = function(gd) {\n    var imageRoot = gd._fullLayout._glimages;\n    var root = d3.select(gd).selectAll('.svg-container');\n    var canvases = root.filter(function(d, i) {return i === root.size() - 1;})\n        .selectAll('.gl-canvas-context, .gl-canvas-focus');\n\n    function canvasToImage() {\n        var canvas = this;\n        var imageData = canvas.toDataURL('image/png');\n        var image = imageRoot.append('svg:image');\n\n        image.attr({\n            xmlns: xmlnsNamespaces.svg,\n            'xlink:href': imageData,\n            preserveAspectRatio: 'none',\n            x: 0,\n            y: 0,\n            width: canvas.width,\n            height: canvas.height\n        });\n    }\n\n    canvases.each(canvasToImage);\n};\n\nexports.updateFx = require('./graph_interact').updateFx;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n    /**\n     * Standardize all missing data in calcdata to use undefined\n     * never null or NaN.\n     * That way we can use !==undefined, or !== BADNUM,\n     * to test for real data\n     */\n    BADNUM: undefined,\n\n    /*\n     * Limit certain operations to well below floating point max value\n     * to avoid glitches: Make sure that even when you multiply it by the\n     * number of pixels on a giant screen it still works\n     */\n    FP_SAFE: Number.MAX_VALUE / 10000,\n\n    /*\n     * conversion of date units to milliseconds\n     * year and month constants are marked \"AVG\"\n     * to remind us that not all years and months\n     * have the same length\n     */\n    ONEAVGYEAR: 31557600000, // 365.25 days\n    ONEAVGMONTH: 2629800000, // 1/12 of ONEAVGYEAR\n    ONEDAY: 86400000,\n    ONEHOUR: 3600000,\n    ONEMIN: 60000,\n    ONESEC: 1000,\n\n    /*\n     * For fast conversion btwn world calendars and epoch ms, the Julian Day Number\n     * of the unix epoch. From calendars.instance().newDate(1970, 1, 1).toJD()\n     */\n    EPOCHJD: 2440587.5,\n\n    /*\n     * Are two values nearly equal? Compare to 1PPM\n     */\n    ALMOST_EQUAL: 1 - 1e-6,\n\n    /*\n     * If we're asked to clip a non-positive log value, how far off-screen\n     * do we put it?\n     */\n    LOG_CLIP: 10,\n\n    /*\n     * not a number, but for displaying numbers: the \"minus sign\" symbol is\n     * wider than the regular ascii dash \"-\"\n     */\n    MINUS_SIGN: '\\u2212'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function handleHoverModeDefaults(layoutIn, layoutOut, fullData) {\n    function coerce(attr, dflt) {\n        // don't coerce if it is already coerced in other place e.g. in cartesian defaults\n        if(layoutOut[attr] !== undefined) return layoutOut[attr];\n\n        return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n    }\n\n    var clickmode = coerce('clickmode');\n\n    var hovermodeDflt;\n    if(layoutOut._has('cartesian')) {\n        if(clickmode.indexOf('select') > -1) {\n            hovermodeDflt = 'closest';\n        } else {\n            // flag for 'horizontal' plots:\n            // determines the state of the mode bar 'compare' hovermode button\n            layoutOut._isHoriz = isHoriz(fullData, layoutOut);\n            hovermodeDflt = layoutOut._isHoriz ? 'y' : 'x';\n        }\n    } else hovermodeDflt = 'closest';\n\n    return coerce('hovermode', hovermodeDflt);\n};\n\nfunction isHoriz(fullData, fullLayout) {\n    var stackOpts = fullLayout._scatterStackOpts || {};\n\n    for(var i = 0; i < fullData.length; i++) {\n        var trace = fullData[i];\n        var subplot = trace.xaxis + trace.yaxis;\n        var subplotStackOpts = stackOpts[subplot] || {};\n        var groupOpts = subplotStackOpts[trace.stackgroup] || {};\n\n        if(trace.orientation !== 'h' && groupOpts.orientation !== 'h') {\n            return false;\n        }\n    }\n\n    return true;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\nvar Plots = require('../../plots/plots');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Titles = require('../../components/titles');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\n\nvar axAttrs = require('./layout_attributes');\nvar cleanTicks = require('./clean_ticks');\n\nvar constants = require('../../constants/numerical');\nvar ONEAVGYEAR = constants.ONEAVGYEAR;\nvar ONEAVGMONTH = constants.ONEAVGMONTH;\nvar ONEDAY = constants.ONEDAY;\nvar ONEHOUR = constants.ONEHOUR;\nvar ONEMIN = constants.ONEMIN;\nvar ONESEC = constants.ONESEC;\nvar MINUS_SIGN = constants.MINUS_SIGN;\nvar BADNUM = constants.BADNUM;\n\nvar alignmentConstants = require('../../constants/alignment');\nvar MID_SHIFT = alignmentConstants.MID_SHIFT;\nvar CAP_SHIFT = alignmentConstants.CAP_SHIFT;\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar OPPOSITE_SIDE = alignmentConstants.OPPOSITE_SIDE;\n\nvar axes = module.exports = {};\n\naxes.setConvert = require('./set_convert');\nvar autoType = require('./axis_autotype');\n\nvar axisIds = require('./axis_ids');\naxes.id2name = axisIds.id2name;\naxes.name2id = axisIds.name2id;\naxes.cleanId = axisIds.cleanId;\naxes.list = axisIds.list;\naxes.listIds = axisIds.listIds;\naxes.getFromId = axisIds.getFromId;\naxes.getFromTrace = axisIds.getFromTrace;\n\nvar autorange = require('./autorange');\naxes.getAutoRange = autorange.getAutoRange;\naxes.findExtremes = autorange.findExtremes;\n\n/*\n * find the list of possible axes to reference with an xref or yref attribute\n * and coerce it to that list\n *\n * attr: the attribute we're generating a reference for. Should end in 'x' or 'y'\n *     but can be prefixed, like 'ax' for annotation's arrow x\n * dflt: the default to coerce to, or blank to use the first axis (falling back on\n *     extraOption if there is no axis)\n * extraOption: aside from existing axes with this letter, what non-axis value is allowed?\n *     Only required if it's different from `dflt`\n */\naxes.coerceRef = function(containerIn, containerOut, gd, attr, dflt, extraOption) {\n    var axLetter = attr.charAt(attr.length - 1);\n    var axlist = gd._fullLayout._subplots[axLetter + 'axis'];\n    var refAttr = attr + 'ref';\n    var attrDef = {};\n\n    if(!dflt) dflt = axlist[0] || extraOption;\n    if(!extraOption) extraOption = dflt;\n\n    // data-ref annotations are not supported in gl2d yet\n\n    attrDef[refAttr] = {\n        valType: 'enumerated',\n        values: axlist.concat(extraOption ? [extraOption] : []),\n        dflt: dflt\n    };\n\n    // xref, yref\n    return Lib.coerce(containerIn, containerOut, attrDef, refAttr);\n};\n\n/*\n * coerce position attributes (range-type) that can be either on axes or absolute\n * (paper or pixel) referenced. The biggest complication here is that we don't know\n * before looking at the axis whether the value must be a number or not (it may be\n * a date string), so we can't use the regular valType='number' machinery\n *\n * axRef (string): the axis this position is referenced to, or:\n *     paper: fraction of the plot area\n *     pixel: pixels relative to some starting position\n * attr (string): the attribute in containerOut we are coercing\n * dflt (number): the default position, as a fraction or pixels. If the attribute\n *     is to be axis-referenced, this will be converted to an axis data value\n *\n * Also cleans the values, since the attribute definition itself has to say\n * valType: 'any' to handle date axes. This allows us to accept:\n * - for category axes: category names, and convert them here into serial numbers.\n *   Note that this will NOT work for axis range endpoints, because we don't know\n *   the category list yet (it's set by ax.makeCalcdata during calc)\n *   but it works for component (note, shape, images) positions.\n * - for date axes: JS Dates or milliseconds, and convert to date strings\n * - for other types: coerce them to numbers\n */\naxes.coercePosition = function(containerOut, gd, coerce, axRef, attr, dflt) {\n    var cleanPos, pos;\n\n    if(axRef === 'paper' || axRef === 'pixel') {\n        cleanPos = Lib.ensureNumber;\n        pos = coerce(attr, dflt);\n    } else {\n        var ax = axes.getFromId(gd, axRef);\n        dflt = ax.fraction2r(dflt);\n        pos = coerce(attr, dflt);\n        cleanPos = ax.cleanPos;\n    }\n\n    containerOut[attr] = cleanPos(pos);\n};\n\naxes.cleanPosition = function(pos, gd, axRef) {\n    var cleanPos = (axRef === 'paper' || axRef === 'pixel') ?\n        Lib.ensureNumber :\n        axes.getFromId(gd, axRef).cleanPos;\n\n    return cleanPos(pos);\n};\n\naxes.redrawComponents = function(gd, axIds) {\n    axIds = axIds ? axIds : axes.listIds(gd);\n\n    var fullLayout = gd._fullLayout;\n\n    function _redrawOneComp(moduleName, methodName, stashName, shortCircuit) {\n        var method = Registry.getComponentMethod(moduleName, methodName);\n        var stash = {};\n\n        for(var i = 0; i < axIds.length; i++) {\n            var ax = fullLayout[axes.id2name(axIds[i])];\n            var indices = ax[stashName];\n\n            for(var j = 0; j < indices.length; j++) {\n                var ind = indices[j];\n\n                if(!stash[ind]) {\n                    method(gd, ind);\n                    stash[ind] = 1;\n                    // once is enough for images (which doesn't use the `i` arg anyway)\n                    if(shortCircuit) return;\n                }\n            }\n        }\n    }\n\n    // annotations and shapes 'draw' method is slow,\n    // use the finer-grained 'drawOne' method instead\n    _redrawOneComp('annotations', 'drawOne', '_annIndices');\n    _redrawOneComp('shapes', 'drawOne', '_shapeIndices');\n    _redrawOneComp('images', 'draw', '_imgIndices', true);\n};\n\nvar getDataConversions = axes.getDataConversions = function(gd, trace, target, targetArray) {\n    var ax;\n\n    // If target points to an axis, use the type we already have for that\n    // axis to find the data type. Otherwise use the values to autotype.\n    var d2cTarget = (target === 'x' || target === 'y' || target === 'z') ?\n        target :\n        targetArray;\n\n    // In the case of an array target, make a mock data array\n    // and call supplyDefaults to the data type and\n    // setup the data-to-calc method.\n    if(Array.isArray(d2cTarget)) {\n        ax = {\n            type: autoType(targetArray),\n            _categories: []\n        };\n        axes.setConvert(ax);\n\n        // build up ax._categories (usually done during ax.makeCalcdata()\n        if(ax.type === 'category') {\n            for(var i = 0; i < targetArray.length; i++) {\n                ax.d2c(targetArray[i]);\n            }\n        }\n        // TODO what to do for transforms?\n    } else {\n        ax = axes.getFromTrace(gd, trace, d2cTarget);\n    }\n\n    // if 'target' has corresponding axis\n    // -> use setConvert method\n    if(ax) return {d2c: ax.d2c, c2d: ax.c2d};\n\n    // special case for 'ids'\n    // -> cast to String\n    if(d2cTarget === 'ids') return {d2c: toString, c2d: toString};\n\n    // otherwise (e.g. numeric-array of 'marker.color' or 'marker.size')\n    // -> cast to Number\n\n    return {d2c: toNum, c2d: toNum};\n};\n\nfunction toNum(v) { return +v; }\nfunction toString(v) { return String(v); }\n\naxes.getDataToCoordFunc = function(gd, trace, target, targetArray) {\n    return getDataConversions(gd, trace, target, targetArray).d2c;\n};\n\n// get counteraxis letter for this axis (name or id)\n// this can also be used as the id for default counter axis\naxes.counterLetter = function(id) {\n    var axLetter = id.charAt(0);\n    if(axLetter === 'x') return 'y';\n    if(axLetter === 'y') return 'x';\n};\n\n// incorporate a new minimum difference and first tick into\n// forced\n// note that _forceTick0 is linearized, so needs to be turned into\n// a range value for setting tick0\naxes.minDtick = function(ax, newDiff, newFirst, allow) {\n    // doesn't make sense to do forced min dTick on log or category axes,\n    // and the plot itself may decide to cancel (ie non-grouped bars)\n    if(['log', 'category', 'multicategory'].indexOf(ax.type) !== -1 || !allow) {\n        ax._minDtick = 0;\n    } else if(ax._minDtick === undefined) {\n        // undefined means there's nothing there yet\n\n        ax._minDtick = newDiff;\n        ax._forceTick0 = newFirst;\n    } else if(ax._minDtick) {\n        if((ax._minDtick / newDiff + 1e-6) % 1 < 2e-6 &&\n            // existing minDtick is an integer multiple of newDiff\n            // (within rounding err)\n            // and forceTick0 can be shifted to newFirst\n\n                (((newFirst - ax._forceTick0) / newDiff % 1) +\n                    1.000001) % 1 < 2e-6) {\n            ax._minDtick = newDiff;\n            ax._forceTick0 = newFirst;\n        } else if((newDiff / ax._minDtick + 1e-6) % 1 > 2e-6 ||\n            // if the converse is true (newDiff is a multiple of minDtick and\n            // newFirst can be shifted to forceTick0) then do nothing - same\n            // forcing stands. Otherwise, cancel forced minimum\n\n                (((newFirst - ax._forceTick0) / ax._minDtick % 1) +\n                    1.000001) % 1 > 2e-6) {\n            ax._minDtick = 0;\n        }\n    }\n};\n\n// save a copy of the initial axis ranges in fullLayout\n// use them in mode bar and dblclick events\naxes.saveRangeInitial = function(gd, overwrite) {\n    var axList = axes.list(gd, '', true);\n    var hasOneAxisChanged = false;\n\n    for(var i = 0; i < axList.length; i++) {\n        var ax = axList[i];\n        var isNew = (ax._rangeInitial === undefined);\n        var hasChanged = isNew || !(\n            ax.range[0] === ax._rangeInitial[0] &&\n            ax.range[1] === ax._rangeInitial[1]\n        );\n\n        if((isNew && ax.autorange === false) || (overwrite && hasChanged)) {\n            ax._rangeInitial = ax.range.slice();\n            hasOneAxisChanged = true;\n        }\n    }\n\n    return hasOneAxisChanged;\n};\n\n// save a copy of the initial spike visibility\naxes.saveShowSpikeInitial = function(gd, overwrite) {\n    var axList = axes.list(gd, '', true);\n    var hasOneAxisChanged = false;\n    var allSpikesEnabled = 'on';\n\n    for(var i = 0; i < axList.length; i++) {\n        var ax = axList[i];\n        var isNew = (ax._showSpikeInitial === undefined);\n        var hasChanged = isNew || !(ax.showspikes === ax._showspikes);\n\n        if(isNew || (overwrite && hasChanged)) {\n            ax._showSpikeInitial = ax.showspikes;\n            hasOneAxisChanged = true;\n        }\n\n        if(allSpikesEnabled === 'on' && !ax.showspikes) {\n            allSpikesEnabled = 'off';\n        }\n    }\n    gd._fullLayout._cartesianSpikesEnabled = allSpikesEnabled;\n    return hasOneAxisChanged;\n};\n\naxes.autoBin = function(data, ax, nbins, is2d, calendar, size) {\n    var dataMin = Lib.aggNums(Math.min, null, data);\n    var dataMax = Lib.aggNums(Math.max, null, data);\n\n    if(ax.type === 'category' || ax.type === 'multicategory') {\n        return {\n            start: dataMin - 0.5,\n            end: dataMax + 0.5,\n            size: Math.max(1, Math.round(size) || 1),\n            _dataSpan: dataMax - dataMin,\n        };\n    }\n\n    if(!calendar) calendar = ax.calendar;\n\n    // piggyback off tick code to make \"nice\" bin sizes and edges\n    var dummyAx;\n    if(ax.type === 'log') {\n        dummyAx = {\n            type: 'linear',\n            range: [dataMin, dataMax]\n        };\n    } else {\n        dummyAx = {\n            type: ax.type,\n            range: Lib.simpleMap([dataMin, dataMax], ax.c2r, 0, calendar),\n            calendar: calendar\n        };\n    }\n    axes.setConvert(dummyAx);\n\n    size = size && cleanTicks.dtick(size, dummyAx.type);\n\n    if(size) {\n        dummyAx.dtick = size;\n        dummyAx.tick0 = cleanTicks.tick0(undefined, dummyAx.type, calendar);\n    } else {\n        var size0;\n        if(nbins) size0 = ((dataMax - dataMin) / nbins);\n        else {\n            // totally auto: scale off std deviation so the highest bin is\n            // somewhat taller than the total number of bins, but don't let\n            // the size get smaller than the 'nice' rounded down minimum\n            // difference between values\n            var distinctData = Lib.distinctVals(data);\n            var msexp = Math.pow(10, Math.floor(\n                Math.log(distinctData.minDiff) / Math.LN10));\n            var minSize = msexp * Lib.roundUp(\n                distinctData.minDiff / msexp, [0.9, 1.9, 4.9, 9.9], true);\n            size0 = Math.max(minSize, 2 * Lib.stdev(data) /\n                Math.pow(data.length, is2d ? 0.25 : 0.4));\n\n            // fallback if ax.d2c output BADNUMs\n            // e.g. when user try to plot categorical bins\n            // on a layout.xaxis.type: 'linear'\n            if(!isNumeric(size0)) size0 = 1;\n        }\n\n        axes.autoTicks(dummyAx, size0);\n    }\n\n    var finalSize = dummyAx.dtick;\n    var binStart = axes.tickIncrement(\n            axes.tickFirst(dummyAx), finalSize, 'reverse', calendar);\n    var binEnd, bincount;\n\n    // check for too many data points right at the edges of bins\n    // (>50% within 1% of bin edges) or all data points integral\n    // and offset the bins accordingly\n    if(typeof finalSize === 'number') {\n        binStart = autoShiftNumericBins(binStart, data, dummyAx, dataMin, dataMax);\n\n        bincount = 1 + Math.floor((dataMax - binStart) / finalSize);\n        binEnd = binStart + bincount * finalSize;\n    } else {\n        // month ticks - should be the only nonlinear kind we have at this point.\n        // dtick (as supplied by axes.autoTick) only has nonlinear values on\n        // date and log axes, but even if you display a histogram on a log axis\n        // we bin it on a linear axis (which one could argue against, but that's\n        // a separate issue)\n        if(dummyAx.dtick.charAt(0) === 'M') {\n            binStart = autoShiftMonthBins(binStart, data, finalSize, dataMin, calendar);\n        }\n\n        // calculate the endpoint for nonlinear ticks - you have to\n        // just increment until you're done\n        binEnd = binStart;\n        bincount = 0;\n        while(binEnd <= dataMax) {\n            binEnd = axes.tickIncrement(binEnd, finalSize, false, calendar);\n            bincount++;\n        }\n    }\n\n    return {\n        start: ax.c2r(binStart, 0, calendar),\n        end: ax.c2r(binEnd, 0, calendar),\n        size: finalSize,\n        _dataSpan: dataMax - dataMin\n    };\n};\n\n\nfunction autoShiftNumericBins(binStart, data, ax, dataMin, dataMax) {\n    var edgecount = 0;\n    var midcount = 0;\n    var intcount = 0;\n    var blankCount = 0;\n\n    function nearEdge(v) {\n        // is a value within 1% of a bin edge?\n        return (1 + (v - binStart) * 100 / ax.dtick) % 100 < 2;\n    }\n\n    for(var i = 0; i < data.length; i++) {\n        if(data[i] % 1 === 0) intcount++;\n        else if(!isNumeric(data[i])) blankCount++;\n\n        if(nearEdge(data[i])) edgecount++;\n        if(nearEdge(data[i] + ax.dtick / 2)) midcount++;\n    }\n    var dataCount = data.length - blankCount;\n\n    if(intcount === dataCount && ax.type !== 'date') {\n        if(ax.dtick < 1) {\n            // all integers: if bin size is <1, it's because\n            // that was specifically requested (large nbins)\n            // so respect that... but center the bins containing\n            // integers on those integers\n\n            binStart = dataMin - 0.5 * ax.dtick;\n        } else {\n            // otherwise start half an integer down regardless of\n            // the bin size, just enough to clear up endpoint\n            // ambiguity about which integers are in which bins.\n\n            binStart -= 0.5;\n            if(binStart + ax.dtick < dataMin) binStart += ax.dtick;\n        }\n    } else if(midcount < dataCount * 0.1) {\n        if(edgecount > dataCount * 0.3 ||\n                nearEdge(dataMin) || nearEdge(dataMax)) {\n            // lots of points at the edge, not many in the middle\n            // shift half a bin\n            var binshift = ax.dtick / 2;\n            binStart += (binStart + binshift < dataMin) ? binshift : -binshift;\n        }\n    }\n    return binStart;\n}\n\n\nfunction autoShiftMonthBins(binStart, data, dtick, dataMin, calendar) {\n    var stats = Lib.findExactDates(data, calendar);\n    // number of data points that needs to be an exact value\n    // to shift that increment to (near) the bin center\n    var threshold = 0.8;\n\n    if(stats.exactDays > threshold) {\n        var numMonths = Number(dtick.substr(1));\n\n        if((stats.exactYears > threshold) && (numMonths % 12 === 0)) {\n            // The exact middle of a non-leap-year is 1.5 days into July\n            // so if we start the bins here, all but leap years will\n            // get hover-labeled as exact years.\n            binStart = axes.tickIncrement(binStart, 'M6', 'reverse') + ONEDAY * 1.5;\n        } else if(stats.exactMonths > threshold) {\n            // Months are not as clean, but if we shift half the *longest*\n            // month (31/2 days) then 31-day months will get labeled exactly\n            // and shorter months will get labeled with the correct month\n            // but shifted 12-36 hours into it.\n            binStart = axes.tickIncrement(binStart, 'M1', 'reverse') + ONEDAY * 15.5;\n        } else {\n            // Shifting half a day is exact, but since these are month bins it\n            // will always give a somewhat odd-looking label, until we do something\n            // smarter like showing the bin boundaries (or the bounds of the actual\n            // data in each bin)\n            binStart -= ONEDAY / 2;\n        }\n        var nextBinStart = axes.tickIncrement(binStart, dtick);\n\n        if(nextBinStart <= dataMin) return nextBinStart;\n    }\n    return binStart;\n}\n\n// ----------------------------------------------------\n// Ticks and grids\n// ----------------------------------------------------\n\n// ensure we have tick0, dtick, and tick rounding calculated\naxes.prepTicks = function(ax) {\n    var rng = Lib.simpleMap(ax.range, ax.r2l);\n\n    // calculate max number of (auto) ticks to display based on plot size\n    if(ax.tickmode === 'auto' || !ax.dtick) {\n        var nt = ax.nticks;\n        var minPx;\n\n        if(!nt) {\n            if(ax.type === 'category' || ax.type === 'multicategory') {\n                minPx = ax.tickfont ? (ax.tickfont.size || 12) * 1.2 : 15;\n                nt = ax._length / minPx;\n            } else {\n                minPx = ax._id.charAt(0) === 'y' ? 40 : 80;\n                nt = Lib.constrain(ax._length / minPx, 4, 9) + 1;\n            }\n\n            // radial axes span half their domain,\n            // multiply nticks value by two to get correct number of auto ticks.\n            if(ax._name === 'radialaxis') nt *= 2;\n        }\n\n        // add a couple of extra digits for filling in ticks when we\n        // have explicit tickvals without tick text\n        if(ax.tickmode === 'array') nt *= 100;\n\n\n        ax._roughDTick = (Math.abs(rng[1] - rng[0]) - (ax._lBreaks || 0)) / nt;\n        axes.autoTicks(ax, ax._roughDTick);\n\n        // check for a forced minimum dtick\n        if(ax._minDtick > 0 && ax.dtick < ax._minDtick * 2) {\n            ax.dtick = ax._minDtick;\n            ax.tick0 = ax.l2r(ax._forceTick0);\n        }\n    }\n\n    // check for missing tick0\n    if(!ax.tick0) {\n        ax.tick0 = (ax.type === 'date') ? '2000-01-01' : 0;\n    }\n\n    // ensure we don't try to make ticks below our minimum precision\n    // see https://github.com/plotly/plotly.js/issues/2892\n    if(ax.type === 'date' && ax.dtick < 0.1) ax.dtick = 0.1;\n\n    // now figure out rounding of tick values\n    autoTickRound(ax);\n};\n\n// calculate the ticks: text, values, positioning\n// if ticks are set to automatic, determine the right values (tick0,dtick)\n// in any case, set tickround to # of digits to round tick labels to,\n// or codes to this effect for log and date scales\naxes.calcTicks = function calcTicks(ax) {\n    axes.prepTicks(ax);\n    var rng = Lib.simpleMap(ax.range, ax.r2l);\n\n    // now that we've figured out the auto values for formatting\n    // in case we're missing some ticktext, we can break out for array ticks\n    if(ax.tickmode === 'array') return arrayTicks(ax);\n\n    // find the first tick\n    ax._tmin = axes.tickFirst(ax);\n\n    // add a tiny bit so we get ticks which may have rounded out\n    var startTick = rng[0] * 1.0001 - rng[1] * 0.0001;\n    var endTick = rng[1] * 1.0001 - rng[0] * 0.0001;\n    // check for reversed axis\n    var axrev = (rng[1] < rng[0]);\n\n    // No visible ticks? Quit.\n    // I've only seen this on category axes with all categories off the edge.\n    if((ax._tmin < startTick) !== axrev) return [];\n\n    // return the full set of tick vals\n    if(ax.type === 'category' || ax.type === 'multicategory') {\n        endTick = (axrev) ? Math.max(-0.5, endTick) :\n            Math.min(ax._categories.length - 0.5, endTick);\n    }\n\n    var isDLog = (ax.type === 'log') && !(isNumeric(ax.dtick) || ax.dtick.charAt(0) === 'L');\n\n    var tickVals;\n    function generateTicks() {\n        var xPrevious = null;\n        var maxTicks = Math.max(1000, ax._length || 0);\n        tickVals = [];\n        for(var x = ax._tmin;\n                (axrev) ? (x >= endTick) : (x <= endTick);\n                x = axes.tickIncrement(x, ax.dtick, axrev, ax.calendar)) {\n            // prevent infinite loops - no more than one tick per pixel,\n            // and make sure each value is different from the previous\n            if(tickVals.length > maxTicks || x === xPrevious) break;\n            xPrevious = x;\n\n            var minor = false;\n            if(isDLog && (x !== (x | 0))) {\n                minor = true;\n            }\n\n            tickVals.push({\n                minor: minor,\n                value: x\n            });\n        }\n    }\n\n    generateTicks();\n\n    if(ax.rangebreaks) {\n        // replace ticks inside breaks that would get a tick\n        if(ax.tickmode === 'auto') {\n            for(var t = 0; t < tickVals.length; t++) {\n                var value = tickVals[t].value;\n                if(ax.maskBreaks(value) === BADNUM) {\n                    // find which break we are in\n                    for(var k = 0; k < ax._rangebreaks.length; k++) {\n                        var brk = ax._rangebreaks[k];\n                        if(value >= brk.min && value < brk.max) {\n                            tickVals[t].value = brk.max; // replace with break end\n                            break;\n                        }\n                    }\n                }\n            }\n        }\n\n        // reduce ticks\n        var len = tickVals.length;\n        if(len > 2) {\n            var tf2 = 2 * (ax.tickfont ? ax.tickfont.size : 12);\n\n            var newTickVals = [];\n            var prevPos;\n\n            var dir = axrev ? 1 : -1;\n            var first = axrev ? 0 : len - 1;\n            var last = axrev ? len - 1 : 0;\n            for(var q = first; dir * q <= dir * last; q += dir) { // apply reverse loop to pick greater values in breaks first\n                var pos = ax.c2p(tickVals[q].value);\n\n                if(prevPos === undefined || Math.abs(pos - prevPos) > tf2) {\n                    prevPos = pos;\n                    newTickVals.push(tickVals[q]);\n                }\n            }\n            tickVals = newTickVals.reverse();\n        }\n    }\n\n    // If same angle over a full circle, the last tick vals is a duplicate.\n    // TODO must do something similar for angular date axes.\n    if(isAngular(ax) && Math.abs(rng[1] - rng[0]) === 360) {\n        tickVals.pop();\n    }\n\n    // save the last tick as well as first, so we can\n    // show the exponent only on the last one\n    ax._tmax = (tickVals[tickVals.length - 1] || {}).value;\n\n    // for showing the rest of a date when the main tick label is only the\n    // latter part: ax._prevDateHead holds what we showed most recently.\n    // Start with it cleared and mark that we're in calcTicks (ie calculating a\n    // whole string of these so we should care what the previous date head was!)\n    ax._prevDateHead = '';\n    ax._inCalcTicks = true;\n\n    var ticksOut = new Array(tickVals.length);\n    for(var i = 0; i < tickVals.length; i++) {\n        var _minor = tickVals[i].minor;\n        var _value = tickVals[i].value;\n\n        ticksOut[i] = axes.tickText(\n            ax,\n            _value,\n            false, // hover\n            _minor // noSuffixPrefix\n        );\n    }\n\n    ax._inCalcTicks = false;\n\n    return ticksOut;\n};\n\nfunction arrayTicks(ax) {\n    var vals = ax.tickvals;\n    var text = ax.ticktext;\n    var ticksOut = new Array(vals.length);\n    var rng = Lib.simpleMap(ax.range, ax.r2l);\n    var r0expanded = rng[0] * 1.0001 - rng[1] * 0.0001;\n    var r1expanded = rng[1] * 1.0001 - rng[0] * 0.0001;\n    var tickMin = Math.min(r0expanded, r1expanded);\n    var tickMax = Math.max(r0expanded, r1expanded);\n    var j = 0;\n\n    // without a text array, just format the given values as any other ticks\n    // except with more precision to the numbers\n    if(!Array.isArray(text)) text = [];\n\n    // make sure showing ticks doesn't accidentally add new categories\n    // TODO multicategory, if we allow ticktext / tickvals\n    var tickVal2l = ax.type === 'category' ? ax.d2l_noadd : ax.d2l;\n\n    // array ticks on log axes always show the full number\n    // (if no explicit ticktext overrides it)\n    if(ax.type === 'log' && String(ax.dtick).charAt(0) !== 'L') {\n        ax.dtick = 'L' + Math.pow(10, Math.floor(Math.min(ax.range[0], ax.range[1])) - 1);\n    }\n\n    for(var i = 0; i < vals.length; i++) {\n        var vali = tickVal2l(vals[i]);\n        if(vali > tickMin && vali < tickMax) {\n            if(text[i] === undefined) ticksOut[j] = axes.tickText(ax, vali);\n            else ticksOut[j] = tickTextObj(ax, vali, String(text[i]));\n            j++;\n        }\n    }\n\n    if(j < vals.length) ticksOut.splice(j, vals.length - j);\n\n    if(ax.rangebreaks) {\n        // remove ticks falling inside rangebreaks\n        ticksOut = ticksOut.filter(function(d) {\n            return ax.maskBreaks(d.x) !== BADNUM;\n        });\n    }\n\n    return ticksOut;\n}\n\nvar roundBase10 = [2, 5, 10];\nvar roundBase24 = [1, 2, 3, 6, 12];\nvar roundBase60 = [1, 2, 5, 10, 15, 30];\n// 2&3 day ticks are weird, but need something btwn 1&7\nvar roundDays = [1, 2, 3, 7, 14];\n// approx. tick positions for log axes, showing all (1) and just 1, 2, 5 (2)\n// these don't have to be exact, just close enough to round to the right value\nvar roundLog1 = [-0.046, 0, 0.301, 0.477, 0.602, 0.699, 0.778, 0.845, 0.903, 0.954, 1];\nvar roundLog2 = [-0.301, 0, 0.301, 0.699, 1];\n// N.B. `thetaunit; 'radians' angular axes must be converted to degrees\nvar roundAngles = [15, 30, 45, 90, 180];\n\nfunction roundDTick(roughDTick, base, roundingSet) {\n    return base * Lib.roundUp(roughDTick / base, roundingSet);\n}\n\n// autoTicks: calculate best guess at pleasant ticks for this axis\n// inputs:\n//      ax - an axis object\n//      roughDTick - rough tick spacing (to be turned into a nice round number)\n// outputs (into ax):\n//   tick0: starting point for ticks (not necessarily on the graph)\n//      usually 0 for numeric (=10^0=1 for log) or jan 1, 2000 for dates\n//   dtick: the actual, nice round tick spacing, usually a little larger than roughDTick\n//      if the ticks are spaced linearly (linear scale, categories,\n//          log with only full powers, date ticks < month),\n//          this will just be a number\n//      months: M#\n//      years: M# where # is 12*number of years\n//      log with linear ticks: L# where # is the linear tick spacing\n//      log showing powers plus some intermediates:\n//          D1 shows all digits, D2 shows 2 and 5\naxes.autoTicks = function(ax, roughDTick) {\n    var base;\n\n    function getBase(v) {\n        return Math.pow(v, Math.floor(Math.log(roughDTick) / Math.LN10));\n    }\n\n    if(ax.type === 'date') {\n        ax.tick0 = Lib.dateTick0(ax.calendar);\n        // the criteria below are all based on the rough spacing we calculate\n        // being > half of the final unit - so precalculate twice the rough val\n        var roughX2 = 2 * roughDTick;\n\n        if(roughX2 > ONEAVGYEAR) {\n            roughDTick /= ONEAVGYEAR;\n            base = getBase(10);\n            ax.dtick = 'M' + (12 * roundDTick(roughDTick, base, roundBase10));\n        } else if(roughX2 > ONEAVGMONTH) {\n            roughDTick /= ONEAVGMONTH;\n            ax.dtick = 'M' + roundDTick(roughDTick, 1, roundBase24);\n        } else if(roughX2 > ONEDAY) {\n            ax.dtick = roundDTick(roughDTick, ONEDAY, ax._hasDayOfWeekBreaks ? [1, 7, 14] : roundDays);\n\n            // get week ticks on sunday\n            // this will also move the base tick off 2000-01-01 if dtick is\n            // 2 or 3 days... but that's a weird enough case that we'll ignore it.\n            ax.tick0 = Lib.dateTick0(ax.calendar, true);\n        } else if(roughX2 > ONEHOUR) {\n            ax.dtick = roundDTick(roughDTick, ONEHOUR, roundBase24);\n        } else if(roughX2 > ONEMIN) {\n            ax.dtick = roundDTick(roughDTick, ONEMIN, roundBase60);\n        } else if(roughX2 > ONESEC) {\n            ax.dtick = roundDTick(roughDTick, ONESEC, roundBase60);\n        } else {\n            // milliseconds\n            base = getBase(10);\n            ax.dtick = roundDTick(roughDTick, base, roundBase10);\n        }\n    } else if(ax.type === 'log') {\n        ax.tick0 = 0;\n        var rng = Lib.simpleMap(ax.range, ax.r2l);\n\n        if(roughDTick > 0.7) {\n            // only show powers of 10\n            ax.dtick = Math.ceil(roughDTick);\n        } else if(Math.abs(rng[1] - rng[0]) < 1) {\n            // span is less than one power of 10\n            var nt = 1.5 * Math.abs((rng[1] - rng[0]) / roughDTick);\n\n            // ticks on a linear scale, labeled fully\n            roughDTick = Math.abs(Math.pow(10, rng[1]) -\n                Math.pow(10, rng[0])) / nt;\n            base = getBase(10);\n            ax.dtick = 'L' + roundDTick(roughDTick, base, roundBase10);\n        } else {\n            // include intermediates between powers of 10,\n            // labeled with small digits\n            // ax.dtick = \"D2\" (show 2 and 5) or \"D1\" (show all digits)\n            ax.dtick = (roughDTick > 0.3) ? 'D2' : 'D1';\n        }\n    } else if(ax.type === 'category' || ax.type === 'multicategory') {\n        ax.tick0 = 0;\n        ax.dtick = Math.ceil(Math.max(roughDTick, 1));\n    } else if(isAngular(ax)) {\n        ax.tick0 = 0;\n        base = 1;\n        ax.dtick = roundDTick(roughDTick, base, roundAngles);\n    } else {\n        // auto ticks always start at 0\n        ax.tick0 = 0;\n        base = getBase(10);\n        ax.dtick = roundDTick(roughDTick, base, roundBase10);\n    }\n\n    // prevent infinite loops\n    if(ax.dtick === 0) ax.dtick = 1;\n\n    // TODO: this is from log axis histograms with autorange off\n    if(!isNumeric(ax.dtick) && typeof ax.dtick !== 'string') {\n        var olddtick = ax.dtick;\n        ax.dtick = 1;\n        throw 'ax.dtick error: ' + String(olddtick);\n    }\n};\n\n// after dtick is already known, find tickround = precision\n// to display in tick labels\n//   for numeric ticks, integer # digits after . to round to\n//   for date ticks, the last date part to show (y,m,d,H,M,S)\n//      or an integer # digits past seconds\nfunction autoTickRound(ax) {\n    var dtick = ax.dtick;\n\n    ax._tickexponent = 0;\n    if(!isNumeric(dtick) && typeof dtick !== 'string') {\n        dtick = 1;\n    }\n\n    if(ax.type === 'category' || ax.type === 'multicategory') {\n        ax._tickround = null;\n    }\n    if(ax.type === 'date') {\n        // If tick0 is unusual, give tickround a bit more information\n        // not necessarily *all* the information in tick0 though, if it's really odd\n        // minimal string length for tick0: 'd' is 10, 'M' is 16, 'S' is 19\n        // take off a leading minus (year < 0) and i (intercalary month) so length is consistent\n        var tick0ms = ax.r2l(ax.tick0);\n        var tick0str = ax.l2r(tick0ms).replace(/(^-|i)/g, '');\n        var tick0len = tick0str.length;\n\n        if(String(dtick).charAt(0) === 'M') {\n            // any tick0 more specific than a year: alway show the full date\n            if(tick0len > 10 || tick0str.substr(5) !== '01-01') ax._tickround = 'd';\n            // show the month unless ticks are full multiples of a year\n            else ax._tickround = (+(dtick.substr(1)) % 12 === 0) ? 'y' : 'm';\n        } else if((dtick >= ONEDAY && tick0len <= 10) || (dtick >= ONEDAY * 15)) ax._tickround = 'd';\n        else if((dtick >= ONEMIN && tick0len <= 16) || (dtick >= ONEHOUR)) ax._tickround = 'M';\n        else if((dtick >= ONESEC && tick0len <= 19) || (dtick >= ONEMIN)) ax._tickround = 'S';\n        else {\n            // tickround is a number of digits of fractional seconds\n            // of any two adjacent ticks, at least one will have the maximum fractional digits\n            // of all possible ticks - so take the max. length of tick0 and the next one\n            var tick1len = ax.l2r(tick0ms + dtick).replace(/^-/, '').length;\n            ax._tickround = Math.max(tick0len, tick1len) - 20;\n\n            // We shouldn't get here... but in case there's a situation I'm\n            // not thinking of where tick0str and tick1str are identical or\n            // something, fall back on maximum precision\n            if(ax._tickround < 0) ax._tickround = 4;\n        }\n    } else if(isNumeric(dtick) || dtick.charAt(0) === 'L') {\n        // linear or log (except D1, D2)\n        var rng = ax.range.map(ax.r2d || Number);\n        if(!isNumeric(dtick)) dtick = Number(dtick.substr(1));\n        // 2 digits past largest digit of dtick\n        ax._tickround = 2 - Math.floor(Math.log(dtick) / Math.LN10 + 0.01);\n\n        var maxend = Math.max(Math.abs(rng[0]), Math.abs(rng[1]));\n        var rangeexp = Math.floor(Math.log(maxend) / Math.LN10 + 0.01);\n        if(Math.abs(rangeexp) > 3) {\n            if(isSIFormat(ax.exponentformat) && !beyondSI(rangeexp)) {\n                ax._tickexponent = 3 * Math.round((rangeexp - 1) / 3);\n            } else ax._tickexponent = rangeexp;\n        }\n    } else {\n        // D1 or D2 (log)\n        ax._tickround = null;\n    }\n}\n\n// months and years don't have constant millisecond values\n// (but a year is always 12 months so we only need months)\n// log-scale ticks are also not consistently spaced, except\n// for pure powers of 10\n// numeric ticks always have constant differences, other datetime ticks\n// can all be calculated as constant number of milliseconds\naxes.tickIncrement = function(x, dtick, axrev, calendar) {\n    var axSign = axrev ? -1 : 1;\n\n    // includes linear, all dates smaller than month, and pure 10^n in log\n    if(isNumeric(dtick)) return x + axSign * dtick;\n\n    // everything else is a string, one character plus a number\n    var tType = dtick.charAt(0);\n    var dtSigned = axSign * Number(dtick.substr(1));\n\n    // Dates: months (or years - see Lib.incrementMonth)\n    if(tType === 'M') return Lib.incrementMonth(x, dtSigned, calendar);\n\n    // Log scales: Linear, Digits\n    else if(tType === 'L') return Math.log(Math.pow(10, x) + dtSigned) / Math.LN10;\n\n    // log10 of 2,5,10, or all digits (logs just have to be\n    // close enough to round)\n    else if(tType === 'D') {\n        var tickset = (dtick === 'D2') ? roundLog2 : roundLog1;\n        var x2 = x + axSign * 0.01;\n        var frac = Lib.roundUp(Lib.mod(x2, 1), tickset, axrev);\n\n        return Math.floor(x2) +\n            Math.log(d3.round(Math.pow(10, frac), 1)) / Math.LN10;\n    } else throw 'unrecognized dtick ' + String(dtick);\n};\n\n// calculate the first tick on an axis\naxes.tickFirst = function(ax) {\n    var r2l = ax.r2l || Number;\n    var rng = Lib.simpleMap(ax.range, r2l);\n    var axrev = rng[1] < rng[0];\n    var sRound = axrev ? Math.floor : Math.ceil;\n    // add a tiny extra bit to make sure we get ticks\n    // that may have been rounded out\n    var r0 = rng[0] * 1.0001 - rng[1] * 0.0001;\n    var dtick = ax.dtick;\n    var tick0 = r2l(ax.tick0);\n\n    if(isNumeric(dtick)) {\n        var tmin = sRound((r0 - tick0) / dtick) * dtick + tick0;\n\n        // make sure no ticks outside the category list\n        if(ax.type === 'category' || ax.type === 'multicategory') {\n            tmin = Lib.constrain(tmin, 0, ax._categories.length - 1);\n        }\n        return tmin;\n    }\n\n    var tType = dtick.charAt(0);\n    var dtNum = Number(dtick.substr(1));\n\n    // Dates: months (or years)\n    if(tType === 'M') {\n        var cnt = 0;\n        var t0 = tick0;\n        var t1, mult, newDTick;\n\n        // This algorithm should work for *any* nonlinear (but close to linear!)\n        // tick spacing. Limit to 10 iterations, for gregorian months it's normally <=3.\n        while(cnt < 10) {\n            t1 = axes.tickIncrement(t0, dtick, axrev, ax.calendar);\n            if((t1 - r0) * (t0 - r0) <= 0) {\n                // t1 and t0 are on opposite sides of r0! we've succeeded!\n                if(axrev) return Math.min(t0, t1);\n                return Math.max(t0, t1);\n            }\n            mult = (r0 - ((t0 + t1) / 2)) / (t1 - t0);\n            newDTick = tType + ((Math.abs(Math.round(mult)) || 1) * dtNum);\n            t0 = axes.tickIncrement(t0, newDTick, mult < 0 ? !axrev : axrev, ax.calendar);\n            cnt++;\n        }\n        Lib.error('tickFirst did not converge', ax);\n        return t0;\n    } else if(tType === 'L') {\n        // Log scales: Linear, Digits\n\n        return Math.log(sRound(\n            (Math.pow(10, r0) - tick0) / dtNum) * dtNum + tick0) / Math.LN10;\n    } else if(tType === 'D') {\n        var tickset = (dtick === 'D2') ? roundLog2 : roundLog1;\n        var frac = Lib.roundUp(Lib.mod(r0, 1), tickset, axrev);\n\n        return Math.floor(r0) +\n            Math.log(d3.round(Math.pow(10, frac), 1)) / Math.LN10;\n    } else throw 'unrecognized dtick ' + String(dtick);\n};\n\n// draw the text for one tick.\n// px,py are the location on gd.paper\n// prefix is there so the x axis ticks can be dropped a line\n// ax is the axis layout, x is the tick value\n// hover is a (truthy) flag for whether to show numbers with a bit\n// more precision for hovertext\naxes.tickText = function(ax, x, hover, noSuffixPrefix) {\n    var out = tickTextObj(ax, x);\n    var arrayMode = ax.tickmode === 'array';\n    var extraPrecision = hover || arrayMode;\n    var axType = ax.type;\n    // TODO multicategory, if we allow ticktext / tickvals\n    var tickVal2l = axType === 'category' ? ax.d2l_noadd : ax.d2l;\n    var i;\n\n    if(arrayMode && Array.isArray(ax.ticktext)) {\n        var rng = Lib.simpleMap(ax.range, ax.r2l);\n        var minDiff = (Math.abs(rng[1] - rng[0]) - (ax._lBreaks || 0)) / 10000;\n\n        for(i = 0; i < ax.ticktext.length; i++) {\n            if(Math.abs(x - tickVal2l(ax.tickvals[i])) < minDiff) break;\n        }\n        if(i < ax.ticktext.length) {\n            out.text = String(ax.ticktext[i]);\n            return out;\n        }\n    }\n\n    function isHidden(showAttr) {\n        if(showAttr === undefined) return true;\n        if(hover) return showAttr === 'none';\n\n        var firstOrLast = {\n            first: ax._tmin,\n            last: ax._tmax\n        }[showAttr];\n\n        return showAttr !== 'all' && x !== firstOrLast;\n    }\n\n    var hideexp = hover ?\n        'never' :\n        ax.exponentformat !== 'none' && isHidden(ax.showexponent) ? 'hide' : '';\n\n    if(axType === 'date') formatDate(ax, out, hover, extraPrecision);\n    else if(axType === 'log') formatLog(ax, out, hover, extraPrecision, hideexp);\n    else if(axType === 'category') formatCategory(ax, out);\n    else if(axType === 'multicategory') formatMultiCategory(ax, out, hover);\n    else if(isAngular(ax)) formatAngle(ax, out, hover, extraPrecision, hideexp);\n    else formatLinear(ax, out, hover, extraPrecision, hideexp);\n\n    // add prefix and suffix\n    if(!noSuffixPrefix) {\n        if(ax.tickprefix && !isHidden(ax.showtickprefix)) out.text = ax.tickprefix + out.text;\n        if(ax.ticksuffix && !isHidden(ax.showticksuffix)) out.text += ax.ticksuffix;\n    }\n\n    // Setup ticks and grid lines boundaries\n    // at 1/2 a 'category' to the left/bottom\n    if(ax.tickson === 'boundaries' || ax.showdividers) {\n        var inbounds = function(v) {\n            var p = ax.l2p(v);\n            return p >= 0 && p <= ax._length ? v : null;\n        };\n\n        out.xbnd = [\n            inbounds(out.x - 0.5),\n            inbounds(out.x + ax.dtick - 0.5)\n        ];\n    }\n\n    return out;\n};\n\n/**\n * create text for a hover label on this axis, with special handling of\n * log axes (where negative values can't be displayed but can appear in hover text)\n *\n * @param {object} ax: the axis to format text for\n * @param {number} val: calcdata value to format\n * @param {Optional(number)} val2: a second value to display\n *\n * @returns {string} `val` formatted as a string appropriate to this axis, or\n *     `val` and `val2` as a range (ie ' - ') if `val2` is provided and\n *     it's different from `val`.\n */\naxes.hoverLabelText = function(ax, val, val2) {\n    if(val2 !== BADNUM && val2 !== val) {\n        return axes.hoverLabelText(ax, val) + ' - ' + axes.hoverLabelText(ax, val2);\n    }\n\n    var logOffScale = (ax.type === 'log' && val <= 0);\n    var tx = axes.tickText(ax, ax.c2l(logOffScale ? -val : val), 'hover').text;\n\n    if(logOffScale) {\n        return val === 0 ? '0' : MINUS_SIGN + tx;\n    }\n\n    // TODO: should we do something special if the axis calendar and\n    // the data calendar are different? Somehow display both dates with\n    // their system names? Right now it will just display in the axis calendar\n    // but users could add the other one as text.\n    return tx;\n};\n\nfunction tickTextObj(ax, x, text) {\n    var tf = ax.tickfont || {};\n\n    return {\n        x: x,\n        dx: 0,\n        dy: 0,\n        text: text || '',\n        fontSize: tf.size,\n        font: tf.family,\n        fontColor: tf.color\n    };\n}\n\nfunction formatDate(ax, out, hover, extraPrecision) {\n    var tr = ax._tickround;\n    var fmt = (hover && ax.hoverformat) || axes.getTickFormat(ax);\n\n    if(extraPrecision) {\n        // second or sub-second precision: extra always shows max digits.\n        // for other fields, extra precision just adds one field.\n        if(isNumeric(tr)) tr = 4;\n        else tr = {y: 'm', m: 'd', d: 'M', M: 'S', S: 4}[tr];\n    }\n\n    var dateStr = Lib.formatDate(out.x, fmt, tr, ax._dateFormat, ax.calendar, ax._extraFormat);\n    var headStr;\n\n    var splitIndex = dateStr.indexOf('\\n');\n    if(splitIndex !== -1) {\n        headStr = dateStr.substr(splitIndex + 1);\n        dateStr = dateStr.substr(0, splitIndex);\n    }\n\n    if(extraPrecision) {\n        // if extraPrecision led to trailing zeros, strip them off\n        // actually, this can lead to removing even more zeros than\n        // in the original rounding, but that's fine because in these\n        // contexts uniformity is not so important (if there's even\n        // anything to be uniform with!)\n\n        // can we remove the whole time part?\n        if(dateStr === '00:00:00' || dateStr === '00:00') {\n            dateStr = headStr;\n            headStr = '';\n        } else if(dateStr.length === 8) {\n            // strip off seconds if they're zero (zero fractional seconds\n            // are already omitted)\n            // but we never remove minutes and leave just hours\n            dateStr = dateStr.replace(/:00$/, '');\n        }\n    }\n\n    if(headStr) {\n        if(hover) {\n            // hover puts it all on one line, so headPart works best up front\n            // except for year headPart: turn this into \"Jan 1, 2000\" etc.\n            if(tr === 'd') dateStr += ', ' + headStr;\n            else dateStr = headStr + (dateStr ? ', ' + dateStr : '');\n        } else if(!ax._inCalcTicks || (headStr !== ax._prevDateHead)) {\n            dateStr += '
' + headStr;\n ax._prevDateHead = headStr;\n }\n }\n\n out.text = dateStr;\n}\n\nfunction formatLog(ax, out, hover, extraPrecision, hideexp) {\n var dtick = ax.dtick;\n var x = out.x;\n var tickformat = ax.tickformat;\n var dtChar0 = typeof dtick === 'string' && dtick.charAt(0);\n\n if(hideexp === 'never') {\n // If this is a hover label, then we must *never* hide the exponent\n // for the sake of display, which could give the wrong value by\n // potentially many orders of magnitude. If hideexp was 'never', then\n // it's now succeeded by preventing the other condition from automating\n // this choice. Thus we can unset it so that the axis formatting takes\n // precedence.\n hideexp = '';\n }\n\n if(extraPrecision && (dtChar0 !== 'L')) {\n dtick = 'L3';\n dtChar0 = 'L';\n }\n\n if(tickformat || (dtChar0 === 'L')) {\n out.text = numFormat(Math.pow(10, x), ax, hideexp, extraPrecision);\n } else if(isNumeric(dtick) || ((dtChar0 === 'D') && (Lib.mod(x + 0.01, 1) < 0.1))) {\n var p = Math.round(x);\n var absP = Math.abs(p);\n var exponentFormat = ax.exponentformat;\n if(exponentFormat === 'power' || (isSIFormat(exponentFormat) && beyondSI(p))) {\n if(p === 0) out.text = 1;\n else if(p === 1) out.text = '10';\n else out.text = '10' + (p > 1 ? '' : MINUS_SIGN) + absP + '';\n\n out.fontSize *= 1.25;\n } else if((exponentFormat === 'e' || exponentFormat === 'E') && absP > 2) {\n out.text = '1' + exponentFormat + (p > 0 ? '+' : MINUS_SIGN) + absP;\n } else {\n out.text = numFormat(Math.pow(10, x), ax, '', 'fakehover');\n if(dtick === 'D1' && ax._id.charAt(0) === 'y') {\n out.dy -= out.fontSize / 6;\n }\n }\n } else if(dtChar0 === 'D') {\n out.text = String(Math.round(Math.pow(10, Lib.mod(x, 1))));\n out.fontSize *= 0.75;\n } else throw 'unrecognized dtick ' + String(dtick);\n\n // if 9's are printed on log scale, move the 10's away a bit\n if(ax.dtick === 'D1') {\n var firstChar = String(out.text).charAt(0);\n if(firstChar === '0' || firstChar === '1') {\n if(ax._id.charAt(0) === 'y') {\n out.dx -= out.fontSize / 4;\n } else {\n out.dy += out.fontSize / 2;\n out.dx += (ax.range[1] > ax.range[0] ? 1 : -1) *\n out.fontSize * (x < 0 ? 0.5 : 0.25);\n }\n }\n }\n}\n\nfunction formatCategory(ax, out) {\n var tt = ax._categories[Math.round(out.x)];\n if(tt === undefined) tt = '';\n out.text = String(tt);\n}\n\nfunction formatMultiCategory(ax, out, hover) {\n var v = Math.round(out.x);\n var cats = ax._categories[v] || [];\n var tt = cats[1] === undefined ? '' : String(cats[1]);\n var tt2 = cats[0] === undefined ? '' : String(cats[0]);\n\n if(hover) {\n // TODO is this what we want?\n out.text = tt2 + ' - ' + tt;\n } else {\n // setup for secondary labels\n out.text = tt;\n out.text2 = tt2;\n }\n}\n\nfunction formatLinear(ax, out, hover, extraPrecision, hideexp) {\n if(hideexp === 'never') {\n // If this is a hover label, then we must *never* hide the exponent\n // for the sake of display, which could give the wrong value by\n // potentially many orders of magnitude. If hideexp was 'never', then\n // it's now succeeded by preventing the other condition from automating\n // this choice. Thus we can unset it so that the axis formatting takes\n // precedence.\n hideexp = '';\n } else if(ax.showexponent === 'all' && Math.abs(out.x / ax.dtick) < 1e-6) {\n // don't add an exponent to zero if we're showing all exponents\n // so the only reason you'd show an exponent on zero is if it's the\n // ONLY tick to get an exponent (first or last)\n hideexp = 'hide';\n }\n out.text = numFormat(out.x, ax, hideexp, extraPrecision);\n}\n\nfunction formatAngle(ax, out, hover, extraPrecision, hideexp) {\n if(ax.thetaunit === 'radians' && !hover) {\n var num = out.x / 180;\n\n if(num === 0) {\n out.text = '0';\n } else {\n var frac = num2frac(num);\n\n if(frac[1] >= 100) {\n out.text = numFormat(Lib.deg2rad(out.x), ax, hideexp, extraPrecision);\n } else {\n var isNeg = out.x < 0;\n\n if(frac[1] === 1) {\n if(frac[0] === 1) out.text = 'π';\n else out.text = frac[0] + 'π';\n } else {\n out.text = [\n '', frac[0], '',\n '⁄',\n '', frac[1], '',\n 'π'\n ].join('');\n }\n\n if(isNeg) out.text = MINUS_SIGN + out.text;\n }\n }\n } else {\n out.text = numFormat(out.x, ax, hideexp, extraPrecision);\n }\n}\n\n// inspired by\n// https://github.com/yisibl/num2fraction/blob/master/index.js\nfunction num2frac(num) {\n function almostEq(a, b) {\n return Math.abs(a - b) <= 1e-6;\n }\n\n function findGCD(a, b) {\n return almostEq(b, 0) ? a : findGCD(b, a % b);\n }\n\n function findPrecision(n) {\n var e = 1;\n while(!almostEq(Math.round(n * e) / e, n)) {\n e *= 10;\n }\n return e;\n }\n\n var precision = findPrecision(num);\n var number = num * precision;\n var gcd = Math.abs(findGCD(number, precision));\n\n return [\n // numerator\n Math.round(number / gcd),\n // denominator\n Math.round(precision / gcd)\n ];\n}\n\n// format a number (tick value) according to the axis settings\n// new, more reliable procedure than d3.round or similar:\n// add half the rounding increment, then stringify and truncate\n// also automatically switch to sci. notation\nvar SIPREFIXES = ['f', 'p', 'n', 'μ', 'm', '', 'k', 'M', 'G', 'T'];\n\nfunction isSIFormat(exponentFormat) {\n return exponentFormat === 'SI' || exponentFormat === 'B';\n}\n\n// are we beyond the range of common SI prefixes?\n// 10^-16 -> 1x10^-16\n// 10^-15 -> 1f\n// ...\n// 10^14 -> 100T\n// 10^15 -> 1x10^15\n// 10^16 -> 1x10^16\nfunction beyondSI(exponent) {\n return exponent > 14 || exponent < -15;\n}\n\nfunction numFormat(v, ax, fmtoverride, hover) {\n var isNeg = v < 0;\n // max number of digits past decimal point to show\n var tickRound = ax._tickround;\n var exponentFormat = fmtoverride || ax.exponentformat || 'B';\n var exponent = ax._tickexponent;\n var tickformat = axes.getTickFormat(ax);\n var separatethousands = ax.separatethousands;\n\n // special case for hover: set exponent just for this value, and\n // add a couple more digits of precision over tick labels\n if(hover) {\n // make a dummy axis obj to get the auto rounding and exponent\n var ah = {\n exponentformat: exponentFormat,\n dtick: ax.showexponent === 'none' ? ax.dtick :\n (isNumeric(v) ? Math.abs(v) || 1 : 1),\n // if not showing any exponents, don't change the exponent\n // from what we calculate\n range: ax.showexponent === 'none' ? ax.range.map(ax.r2d) : [0, v || 1]\n };\n autoTickRound(ah);\n tickRound = (Number(ah._tickround) || 0) + 4;\n exponent = ah._tickexponent;\n if(ax.hoverformat) tickformat = ax.hoverformat;\n }\n\n if(tickformat) return ax._numFormat(tickformat)(v).replace(/-/g, MINUS_SIGN);\n\n // 'epsilon' - rounding increment\n var e = Math.pow(10, -tickRound) / 2;\n\n // exponentFormat codes:\n // 'e' (1.2e+6, default)\n // 'E' (1.2E+6)\n // 'SI' (1.2M)\n // 'B' (same as SI except 10^9=B not G)\n // 'none' (1200000)\n // 'power' (1.2x10^6)\n // 'hide' (1.2, use 3rd argument=='hide' to eg\n // only show exponent on last tick)\n if(exponentFormat === 'none') exponent = 0;\n\n // take the sign out, put it back manually at the end\n // - makes cases easier\n v = Math.abs(v);\n if(v < e) {\n // 0 is just 0, but may get exponent if it's the last tick\n v = '0';\n isNeg = false;\n } else {\n v += e;\n // take out a common exponent, if any\n if(exponent) {\n v *= Math.pow(10, -exponent);\n tickRound += exponent;\n }\n // round the mantissa\n if(tickRound === 0) v = String(Math.floor(v));\n else if(tickRound < 0) {\n v = String(Math.round(v));\n v = v.substr(0, v.length + tickRound);\n for(var i = tickRound; i < 0; i++) v += '0';\n } else {\n v = String(v);\n var dp = v.indexOf('.') + 1;\n if(dp) v = v.substr(0, dp + tickRound).replace(/\\.?0+$/, '');\n }\n // insert appropriate decimal point and thousands separator\n v = Lib.numSeparate(v, ax._separators, separatethousands);\n }\n\n // add exponent\n if(exponent && exponentFormat !== 'hide') {\n if(isSIFormat(exponentFormat) && beyondSI(exponent)) exponentFormat = 'power';\n\n var signedExponent;\n if(exponent < 0) signedExponent = MINUS_SIGN + -exponent;\n else if(exponentFormat !== 'power') signedExponent = '+' + exponent;\n else signedExponent = String(exponent);\n\n if(exponentFormat === 'e' || exponentFormat === 'E') {\n v += exponentFormat + signedExponent;\n } else if(exponentFormat === 'power') {\n v += '×10' + signedExponent + '';\n } else if(exponentFormat === 'B' && exponent === 9) {\n v += 'B';\n } else if(isSIFormat(exponentFormat)) {\n v += SIPREFIXES[exponent / 3 + 5];\n }\n }\n\n // put sign back in and return\n // replace standard minus character (which is technically a hyphen)\n // with a true minus sign\n if(isNeg) return MINUS_SIGN + v;\n return v;\n}\n\naxes.getTickFormat = function(ax) {\n var i;\n\n function convertToMs(dtick) {\n return typeof dtick !== 'string' ? dtick : Number(dtick.replace('M', '')) * ONEAVGMONTH;\n }\n\n function compareLogTicks(left, right) {\n var priority = ['L', 'D'];\n if(typeof left === typeof right) {\n if(typeof left === 'number') {\n return left - right;\n } else {\n var leftPriority = priority.indexOf(left.charAt(0));\n var rightPriority = priority.indexOf(right.charAt(0));\n if(leftPriority === rightPriority) {\n return Number(left.replace(/(L|D)/g, '')) - Number(right.replace(/(L|D)/g, ''));\n } else {\n return leftPriority - rightPriority;\n }\n }\n } else {\n return typeof left === 'number' ? 1 : -1;\n }\n }\n\n function isProperStop(dtick, range, convert) {\n var convertFn = convert || function(x) { return x;};\n var leftDtick = range[0];\n var rightDtick = range[1];\n return ((!leftDtick && typeof leftDtick !== 'number') || convertFn(leftDtick) <= convertFn(dtick)) &&\n ((!rightDtick && typeof rightDtick !== 'number') || convertFn(rightDtick) >= convertFn(dtick));\n }\n\n function isProperLogStop(dtick, range) {\n var isLeftDtickNull = range[0] === null;\n var isRightDtickNull = range[1] === null;\n var isDtickInRangeLeft = compareLogTicks(dtick, range[0]) >= 0;\n var isDtickInRangeRight = compareLogTicks(dtick, range[1]) <= 0;\n return (isLeftDtickNull || isDtickInRangeLeft) && (isRightDtickNull || isDtickInRangeRight);\n }\n\n var tickstop, stopi;\n if(ax.tickformatstops && ax.tickformatstops.length > 0) {\n switch(ax.type) {\n case 'date':\n case 'linear': {\n for(i = 0; i < ax.tickformatstops.length; i++) {\n stopi = ax.tickformatstops[i];\n if(stopi.enabled && isProperStop(ax.dtick, stopi.dtickrange, convertToMs)) {\n tickstop = stopi;\n break;\n }\n }\n break;\n }\n case 'log': {\n for(i = 0; i < ax.tickformatstops.length; i++) {\n stopi = ax.tickformatstops[i];\n if(stopi.enabled && isProperLogStop(ax.dtick, stopi.dtickrange)) {\n tickstop = stopi;\n break;\n }\n }\n break;\n }\n default:\n }\n }\n return tickstop ? tickstop.value : ax.tickformat;\n};\n\n// getSubplots - extract all subplot IDs we need\n// as an array of items like 'xy', 'x2y', 'x2y2'...\n// sorted by x (x,x2,x3...) then y\n// optionally restrict to only subplots containing axis object ax\n//\n// NOTE: this is currently only used OUTSIDE plotly.js (toolpanel, webapp)\n// ideally we get rid of it there (or just copy this there) and remove it here\naxes.getSubplots = function(gd, ax) {\n var subplotObj = gd._fullLayout._subplots;\n var allSubplots = subplotObj.cartesian.concat(subplotObj.gl2d || []);\n\n var out = ax ? axes.findSubplotsWithAxis(allSubplots, ax) : allSubplots;\n\n out.sort(function(a, b) {\n var aParts = a.substr(1).split('y');\n var bParts = b.substr(1).split('y');\n\n if(aParts[0] === bParts[0]) return +aParts[1] - +bParts[1];\n return +aParts[0] - +bParts[0];\n });\n\n return out;\n};\n\n// find all subplots with axis 'ax'\n// NOTE: this is only used in axes.getSubplots (only used outside plotly.js) and\n// gl2d/convert (where it restricts axis subplots to only those with gl2d)\naxes.findSubplotsWithAxis = function(subplots, ax) {\n var axMatch = new RegExp(\n (ax._id.charAt(0) === 'x') ? ('^' + ax._id + 'y') : (ax._id + '$')\n );\n var subplotsWithAx = [];\n\n for(var i = 0; i < subplots.length; i++) {\n var sp = subplots[i];\n if(axMatch.test(sp)) subplotsWithAx.push(sp);\n }\n\n return subplotsWithAx;\n};\n\n// makeClipPaths: prepare clipPaths for all single axes and all possible xy pairings\naxes.makeClipPaths = function(gd) {\n var fullLayout = gd._fullLayout;\n\n // for more info: https://github.com/plotly/plotly.js/issues/2595\n if(fullLayout._hasOnlyLargeSploms) return;\n\n var fullWidth = {_offset: 0, _length: fullLayout.width, _id: ''};\n var fullHeight = {_offset: 0, _length: fullLayout.height, _id: ''};\n var xaList = axes.list(gd, 'x', true);\n var yaList = axes.list(gd, 'y', true);\n var clipList = [];\n var i, j;\n\n for(i = 0; i < xaList.length; i++) {\n clipList.push({x: xaList[i], y: fullHeight});\n for(j = 0; j < yaList.length; j++) {\n if(i === 0) clipList.push({x: fullWidth, y: yaList[j]});\n clipList.push({x: xaList[i], y: yaList[j]});\n }\n }\n\n // selectors don't work right with camelCase tags,\n // have to use class instead\n // https://groups.google.com/forum/#!topic/d3-js/6EpAzQ2gU9I\n var axClips = fullLayout._clips.selectAll('.axesclip')\n .data(clipList, function(d) { return d.x._id + d.y._id; });\n\n axClips.enter().append('clipPath')\n .classed('axesclip', true)\n .attr('id', function(d) { return 'clip' + fullLayout._uid + d.x._id + d.y._id; })\n .append('rect');\n\n axClips.exit().remove();\n\n axClips.each(function(d) {\n d3.select(this).select('rect').attr({\n x: d.x._offset || 0,\n y: d.y._offset || 0,\n width: d.x._length || 1,\n height: d.y._length || 1\n });\n });\n};\n\n/**\n * Main multi-axis drawing routine!\n *\n * @param {DOM element} gd : graph div\n * @param {string or array of strings} arg : polymorphic argument\n * @param {object} opts:\n * - @param {boolean} skipTitle : optional flag to skip axis title draw/update\n *\n * Signature 1: Axes.draw(gd, 'redraw')\n * use this to clear and redraw all axes on graph\n *\n * Signature 2: Axes.draw(gd, '')\n * use this to draw all axes on graph w/o the selectAll().remove()\n * of the 'redraw' signature\n *\n * Signature 3: Axes.draw(gd, [axId, axId2, ...])\n * where the items are axis id string,\n * use this to update multiple axes in one call\n *\n * N.B draw updates:\n * - ax._r (stored range for use by zoom/pan)\n * - ax._rl (stored linearized range for use by zoom/pan)\n */\naxes.draw = function(gd, arg, opts) {\n var fullLayout = gd._fullLayout;\n\n if(arg === 'redraw') {\n fullLayout._paper.selectAll('g.subplot').each(function(d) {\n var id = d[0];\n var plotinfo = fullLayout._plots[id];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'tick').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'tick').remove();\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'tick2').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'tick2').remove();\n plotinfo.xaxislayer.selectAll('.' + xa._id + 'divider').remove();\n plotinfo.yaxislayer.selectAll('.' + ya._id + 'divider').remove();\n\n if(plotinfo.gridlayer) plotinfo.gridlayer.selectAll('path').remove();\n if(plotinfo.zerolinelayer) plotinfo.zerolinelayer.selectAll('path').remove();\n\n fullLayout._infolayer.select('.g-' + xa._id + 'title').remove();\n fullLayout._infolayer.select('.g-' + ya._id + 'title').remove();\n });\n }\n\n var axList = (!arg || arg === 'redraw') ? axes.listIds(gd) : arg;\n\n return Lib.syncOrAsync(axList.map(function(axId) {\n return function() {\n if(!axId) return;\n\n var ax = axes.getFromId(gd, axId);\n var axDone = axes.drawOne(gd, ax, opts);\n\n ax._r = ax.range.slice();\n ax._rl = Lib.simpleMap(ax._r, ax.r2l);\n\n return axDone;\n };\n }));\n};\n\n/**\n * Draw one cartesian axis\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * @param {object} opts\n * - @param {boolean} skipTitle (set to true to skip axis title draw call)\n *\n * Depends on:\n * - ax._mainSubplot (from linkSubplots)\n * - ax._mainAxis\n * - ax._anchorAxis\n * - ax._subplotsWith\n * - ax._counterDomainMin, ax._counterDomainMax (optionally, from linkSubplots)\n * - ax._tickAngles (on redraw only, old value relinked during supplyDefaults)\n * - ax._mainLinePosition (from lsInner)\n * - ax._mainMirrorPosition\n * - ax._linepositions\n *\n * Fills in:\n * - ax._vals:\n * - ax._gridVals:\n * - ax._selections:\n * - ax._tickAngles:\n * - ax._depth (when required only):\n * - and calls ax.setScale\n */\naxes.drawOne = function(gd, ax, opts) {\n opts = opts || {};\n\n var i, sp, plotinfo;\n\n ax.setScale();\n\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var counterLetter = axes.counterLetter(axId);\n var mainPlotinfo = fullLayout._plots[ax._mainSubplot];\n\n // this happens when updating matched group with 'missing' axes\n if(!mainPlotinfo) return;\n\n var mainAxLayer = mainPlotinfo[axLetter + 'axislayer'];\n var mainLinePosition = ax._mainLinePosition;\n var mainMirrorPosition = ax._mainMirrorPosition;\n\n var vals = ax._vals = axes.calcTicks(ax);\n\n // Add a couple of axis properties that should cause us to recreate\n // elements. Used in d3 data function.\n var axInfo = [ax.mirror, mainLinePosition, mainMirrorPosition].join('_');\n for(i = 0; i < vals.length; i++) {\n vals[i].axInfo = axInfo;\n }\n\n // stash selections to avoid DOM queries e.g.\n // - stash tickLabels selection, so that drawTitle can use it to scoot title\n ax._selections = {};\n // stash tick angle (including the computed 'auto' values) per tick-label class\n // linkup 'previous' tick angles on redraws\n if(ax._tickAngles) ax._prevTickAngles = ax._tickAngles;\n ax._tickAngles = {};\n // measure [in px] between axis position and outward-most part of bounding box\n // (touching either the tick label or ticks)\n // depth can be expansive to compute, so we only do so when required\n ax._depth = null;\n\n // calcLabelLevelBbox can be expensive,\n // so make sure to not call it twice during the same Axes.drawOne call\n // by stashing label-level bounding boxes per tick-label class\n var llbboxes = {};\n function getLabelLevelBbox(suffix) {\n var cls = axId + (suffix || 'tick');\n if(!llbboxes[cls]) llbboxes[cls] = calcLabelLevelBbox(ax, cls);\n return llbboxes[cls];\n }\n\n if(!ax.visible) return;\n\n var transFn = axes.makeTransFn(ax);\n var tickVals;\n // We remove zero lines, grid lines, and inside ticks if they're within 1px of the end\n // The key case here is removing zero lines when the axis bound is zero\n var valsClipped;\n\n if(ax.tickson === 'boundaries') {\n var boundaryVals = getBoundaryVals(ax, vals);\n valsClipped = axes.clipEnds(ax, boundaryVals);\n tickVals = ax.ticks === 'inside' ? valsClipped : boundaryVals;\n } else {\n valsClipped = axes.clipEnds(ax, vals);\n tickVals = ax.ticks === 'inside' ? valsClipped : vals;\n }\n\n var gridVals = ax._gridVals = valsClipped;\n var dividerVals = getDividerVals(ax, vals);\n\n if(!fullLayout._hasOnlyLargeSploms) {\n var subplotsWithAx = ax._subplotsWith;\n\n // keep track of which subplots (by main counter axis) we've already\n // drawn grids for, so we don't overdraw overlaying subplots\n var finishedGrids = {};\n\n for(i = 0; i < subplotsWithAx.length; i++) {\n sp = subplotsWithAx[i];\n plotinfo = fullLayout._plots[sp];\n\n var counterAxis = plotinfo[counterLetter + 'axis'];\n var mainCounterID = counterAxis._mainAxis._id;\n if(finishedGrids[mainCounterID]) continue;\n finishedGrids[mainCounterID] = 1;\n\n var gridPath = axLetter === 'x' ?\n 'M0,' + counterAxis._offset + 'v' + counterAxis._length :\n 'M' + counterAxis._offset + ',0h' + counterAxis._length;\n\n axes.drawGrid(gd, ax, {\n vals: gridVals,\n counterAxis: counterAxis,\n layer: plotinfo.gridlayer.select('.' + axId),\n path: gridPath,\n transFn: transFn\n });\n axes.drawZeroLine(gd, ax, {\n counterAxis: counterAxis,\n layer: plotinfo.zerolinelayer,\n path: gridPath,\n transFn: transFn\n });\n }\n }\n\n var tickSigns = axes.getTickSigns(ax);\n var tickSubplots = [];\n\n if(ax.ticks) {\n var mainTickPath = axes.makeTickPath(ax, mainLinePosition, tickSigns[2]);\n var mirrorTickPath;\n var fullTickPath;\n if(ax._anchorAxis && ax.mirror && ax.mirror !== true) {\n mirrorTickPath = axes.makeTickPath(ax, mainMirrorPosition, tickSigns[3]);\n fullTickPath = mainTickPath + mirrorTickPath;\n } else {\n mirrorTickPath = '';\n fullTickPath = mainTickPath;\n }\n\n var tickPath;\n if(ax.showdividers && ax.ticks === 'outside' && ax.tickson === 'boundaries') {\n var dividerLookup = {};\n for(i = 0; i < dividerVals.length; i++) {\n dividerLookup[dividerVals[i].x] = 1;\n }\n tickPath = function(d) {\n return dividerLookup[d.x] ? mirrorTickPath : fullTickPath;\n };\n } else {\n tickPath = fullTickPath;\n }\n\n axes.drawTicks(gd, ax, {\n vals: tickVals,\n layer: mainAxLayer,\n path: tickPath,\n transFn: transFn\n });\n\n if(ax.mirror === 'allticks') {\n tickSubplots = Object.keys(ax._linepositions || {});\n }\n }\n\n for(i = 0; i < tickSubplots.length; i++) {\n sp = tickSubplots[i];\n plotinfo = fullLayout._plots[sp];\n // [bottom or left, top or right], free and main are handled above\n var linepositions = ax._linepositions[sp] || [];\n var spTickPath = axes.makeTickPath(ax, linepositions[0], tickSigns[0]) +\n axes.makeTickPath(ax, linepositions[1], tickSigns[1]);\n\n axes.drawTicks(gd, ax, {\n vals: tickVals,\n layer: plotinfo[axLetter + 'axislayer'],\n path: spTickPath,\n transFn: transFn\n });\n }\n\n var seq = [];\n\n // tick labels - for now just the main labels.\n // TODO: mirror labels, esp for subplots\n\n seq.push(function() {\n return axes.drawLabels(gd, ax, {\n vals: vals,\n layer: mainAxLayer,\n transFn: transFn,\n labelFns: axes.makeLabelFns(ax, mainLinePosition)\n });\n });\n\n if(ax.type === 'multicategory') {\n var pad = {x: 2, y: 10}[axLetter];\n\n seq.push(function() {\n var bboxKey = {x: 'height', y: 'width'}[axLetter];\n var standoff = getLabelLevelBbox()[bboxKey] + pad +\n (ax._tickAngles[axId + 'tick'] ? ax.tickfont.size * LINE_SPACING : 0);\n\n return axes.drawLabels(gd, ax, {\n vals: getSecondaryLabelVals(ax, vals),\n layer: mainAxLayer,\n cls: axId + 'tick2',\n repositionOnUpdate: true,\n secondary: true,\n transFn: transFn,\n labelFns: axes.makeLabelFns(ax, mainLinePosition + standoff * tickSigns[4])\n });\n });\n\n seq.push(function() {\n ax._depth = tickSigns[4] * (getLabelLevelBbox('tick2')[ax.side] - mainLinePosition);\n\n return drawDividers(gd, ax, {\n vals: dividerVals,\n layer: mainAxLayer,\n path: axes.makeTickPath(ax, mainLinePosition, tickSigns[4], ax._depth),\n transFn: transFn\n });\n });\n } else if(ax.title.hasOwnProperty('standoff')) {\n seq.push(function() {\n ax._depth = tickSigns[4] * (getLabelLevelBbox()[ax.side] - mainLinePosition);\n });\n }\n\n var hasRangeSlider = Registry.getComponentMethod('rangeslider', 'isVisible')(ax);\n\n seq.push(function() {\n var s = ax.side.charAt(0);\n var sMirror = OPPOSITE_SIDE[ax.side].charAt(0);\n var pos = axes.getPxPosition(gd, ax);\n var outsideTickLen = ax.ticks === 'outside' ? ax.ticklen : 0;\n var llbbox;\n\n var push;\n var mirrorPush;\n var rangeSliderPush;\n\n if(ax.automargin || hasRangeSlider) {\n if(ax.type === 'multicategory') {\n llbbox = getLabelLevelBbox('tick2');\n } else {\n llbbox = getLabelLevelBbox();\n if(axLetter === 'x' && s === 'b') {\n ax._depth = Math.max(llbbox.width > 0 ? llbbox.bottom - pos : 0, outsideTickLen);\n }\n }\n }\n\n if(ax.automargin) {\n push = {x: 0, y: 0, r: 0, l: 0, t: 0, b: 0};\n var domainIndices = [0, 1];\n\n if(axLetter === 'x') {\n if(s === 'b') {\n push[s] = ax._depth;\n } else {\n push[s] = ax._depth = Math.max(llbbox.width > 0 ? pos - llbbox.top : 0, outsideTickLen);\n domainIndices.reverse();\n }\n\n if(llbbox.width > 0) {\n var rExtra = llbbox.right - (ax._offset + ax._length);\n if(rExtra > 0) {\n push.xr = 1;\n push.r = rExtra;\n }\n var lExtra = ax._offset - llbbox.left;\n if(lExtra > 0) {\n push.xl = 0;\n push.l = lExtra;\n }\n }\n } else {\n if(s === 'l') {\n push[s] = ax._depth = Math.max(llbbox.height > 0 ? pos - llbbox.left : 0, outsideTickLen);\n } else {\n push[s] = ax._depth = Math.max(llbbox.height > 0 ? llbbox.right - pos : 0, outsideTickLen);\n domainIndices.reverse();\n }\n\n if(llbbox.height > 0) {\n var bExtra = llbbox.bottom - (ax._offset + ax._length);\n if(bExtra > 0) {\n push.yb = 0;\n push.b = bExtra;\n }\n var tExtra = ax._offset - llbbox.top;\n if(tExtra > 0) {\n push.yt = 1;\n push.t = tExtra;\n }\n }\n }\n\n push[counterLetter] = ax.anchor === 'free' ?\n ax.position :\n ax._anchorAxis.domain[domainIndices[0]];\n\n if(ax.title.text !== fullLayout._dfltTitle[axLetter]) {\n push[s] += approxTitleDepth(ax) + (ax.title.standoff || 0);\n }\n\n if(ax.mirror && ax.anchor !== 'free') {\n mirrorPush = {x: 0, y: 0, r: 0, l: 0, t: 0, b: 0};\n\n mirrorPush[sMirror] = ax.linewidth;\n if(ax.mirror && ax.mirror !== true) mirrorPush[sMirror] += outsideTickLen;\n\n if(ax.mirror === true || ax.mirror === 'ticks') {\n mirrorPush[counterLetter] = ax._anchorAxis.domain[domainIndices[1]];\n } else if(ax.mirror === 'all' || ax.mirror === 'allticks') {\n mirrorPush[counterLetter] = [ax._counterDomainMin, ax._counterDomainMax][domainIndices[1]];\n }\n }\n }\n\n if(hasRangeSlider) {\n rangeSliderPush = Registry.getComponentMethod('rangeslider', 'autoMarginOpts')(gd, ax);\n }\n\n Plots.autoMargin(gd, axAutoMarginID(ax), push);\n Plots.autoMargin(gd, axMirrorAutoMarginID(ax), mirrorPush);\n Plots.autoMargin(gd, rangeSliderAutoMarginID(ax), rangeSliderPush);\n });\n\n if(!opts.skipTitle &&\n !(hasRangeSlider && ax.side === 'bottom')\n ) {\n seq.push(function() { return drawTitle(gd, ax); });\n }\n\n return Lib.syncOrAsync(seq);\n};\n\nfunction getBoundaryVals(ax, vals) {\n var out = [];\n var i;\n\n // boundaryVals are never used for labels;\n // no need to worry about the other tickTextObj keys\n var _push = function(d, bndIndex) {\n var xb = d.xbnd[bndIndex];\n if(xb !== null) {\n out.push(Lib.extendFlat({}, d, {x: xb}));\n }\n };\n\n if(vals.length) {\n for(i = 0; i < vals.length; i++) {\n _push(vals[i], 0);\n }\n _push(vals[i - 1], 1);\n }\n\n return out;\n}\n\nfunction getSecondaryLabelVals(ax, vals) {\n var out = [];\n var lookup = {};\n\n for(var i = 0; i < vals.length; i++) {\n var d = vals[i];\n if(lookup[d.text2]) {\n lookup[d.text2].push(d.x);\n } else {\n lookup[d.text2] = [d.x];\n }\n }\n\n for(var k in lookup) {\n out.push(tickTextObj(ax, Lib.interp(lookup[k], 0.5), k));\n }\n\n return out;\n}\n\nfunction getDividerVals(ax, vals) {\n var out = [];\n var i, current;\n\n // never used for labels;\n // no need to worry about the other tickTextObj keys\n var _push = function(d, bndIndex) {\n var xb = d.xbnd[bndIndex];\n if(xb !== null) {\n out.push(Lib.extendFlat({}, d, {x: xb}));\n }\n };\n\n if(ax.showdividers && vals.length) {\n for(i = 0; i < vals.length; i++) {\n var d = vals[i];\n if(d.text2 !== current) {\n _push(d, 0);\n }\n current = d.text2;\n }\n _push(vals[i - 1], 1);\n }\n\n return out;\n}\n\nfunction calcLabelLevelBbox(ax, cls) {\n var top, bottom;\n var left, right;\n\n if(ax._selections[cls].size()) {\n top = Infinity;\n bottom = -Infinity;\n left = Infinity;\n right = -Infinity;\n ax._selections[cls].each(function() {\n var thisLabel = selectTickLabel(this);\n // Use parent node , to make Drawing.bBox\n // retrieve a bbox computed with transform info\n //\n // To improve perf, it would be nice to use `thisLabel.node()`\n // (like in fixLabelOverlaps) instead and use Axes.getPxPosition\n // together with the makeLabelFns outputs and `tickangle`\n // to compute one bbox per (tick value x tick style)\n var bb = Drawing.bBox(thisLabel.node().parentNode);\n top = Math.min(top, bb.top);\n bottom = Math.max(bottom, bb.bottom);\n left = Math.min(left, bb.left);\n right = Math.max(right, bb.right);\n });\n } else {\n top = 0;\n bottom = 0;\n left = 0;\n right = 0;\n }\n\n return {\n top: top,\n bottom: bottom,\n left: left,\n right: right,\n height: bottom - top,\n width: right - left\n };\n}\n\n/**\n * Which direction do the 'ax.side' values, and free ticks go?\n *\n * @param {object} ax (full) axis object\n * - {string} _id (starting with 'x' or 'y')\n * - {string} side\n * - {string} ticks\n * @return {array} all entries are either -1 or 1\n * - [0]: sign for top/right ticks (i.e. negative SVG direction)\n * - [1]: sign for bottom/left ticks (i.e. positive SVG direction)\n * - [2]: sign for ticks corresponding to 'ax.side'\n * - [3]: sign for ticks mirroring 'ax.side'\n * - [4]: sign of arrow starting at axis pointing towards margin\n */\naxes.getTickSigns = function(ax) {\n var axLetter = ax._id.charAt(0);\n var sideOpposite = {x: 'top', y: 'right'}[axLetter];\n var main = ax.side === sideOpposite ? 1 : -1;\n var out = [-1, 1, main, -main];\n // then we flip if outside XOR y axis\n if((ax.ticks !== 'inside') === (axLetter === 'x')) {\n out = out.map(function(v) { return -v; });\n }\n // independent of `ticks`; do not flip this one\n if(ax.side) {\n out.push({l: -1, t: -1, r: 1, b: 1}[ax.side.charAt(0)]);\n }\n return out;\n};\n\n/**\n * Make axis translate transform function\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {number} _offset\n * - {fn} l2p\n * @return {fn} function of calcTicks items\n */\naxes.makeTransFn = function(ax) {\n var axLetter = ax._id.charAt(0);\n var offset = ax._offset;\n return axLetter === 'x' ?\n function(d) { return 'translate(' + (offset + ax.l2p(d.x)) + ',0)'; } :\n function(d) { return 'translate(0,' + (offset + ax.l2p(d.x)) + ')'; };\n};\n\n/**\n * Make axis tick path string\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {number} ticklen\n * - {number} linewidth\n * @param {number} shift along direction of ticklen\n * @param {1 or -1} sgn tick sign\n * @param {number (optional)} len tick length\n * @return {string}\n */\naxes.makeTickPath = function(ax, shift, sgn, len) {\n len = len !== undefined ? len : ax.ticklen;\n\n var axLetter = ax._id.charAt(0);\n var pad = (ax.linewidth || 1) / 2;\n\n return axLetter === 'x' ?\n 'M0,' + (shift + pad * sgn) + 'v' + (len * sgn) :\n 'M' + (shift + pad * sgn) + ',0h' + (len * sgn);\n};\n\n/**\n * Make axis tick label x, y and anchor functions\n *\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} ticks\n * - {number} ticklen\n * - {string} side\n * - {number} linewidth\n * - {number} tickfont.size\n * - {boolean} showline\n * @param {number} shift\n * @param {number} angle [in degrees] ...\n * @return {object}\n * - {fn} xFn\n * - {fn} yFn\n * - {fn} anchorFn\n * - {fn} heightFn\n * - {number} labelStandoff (gap parallel to ticks)\n * - {number} labelShift (gap perpendicular to ticks)\n */\naxes.makeLabelFns = function(ax, shift, angle) {\n var axLetter = ax._id.charAt(0);\n var ticksOnOutsideLabels = ax.tickson !== 'boundaries' && ax.ticks === 'outside';\n\n var labelStandoff = 0;\n var labelShift = 0;\n\n if(ticksOnOutsideLabels) {\n labelStandoff += ax.ticklen;\n }\n if(angle && ax.ticks === 'outside') {\n var rad = Lib.deg2rad(angle);\n labelStandoff = ax.ticklen * Math.cos(rad) + 1;\n labelShift = ax.ticklen * Math.sin(rad);\n }\n if(ax.showticklabels && (ticksOnOutsideLabels || ax.showline)) {\n labelStandoff += 0.2 * ax.tickfont.size;\n }\n labelStandoff += (ax.linewidth || 1) / 2;\n\n var out = {\n labelStandoff: labelStandoff,\n labelShift: labelShift\n };\n\n var x0, y0, ff, flipIt;\n\n if(axLetter === 'x') {\n flipIt = ax.side === 'bottom' ? 1 : -1;\n x0 = labelShift * flipIt;\n y0 = shift + labelStandoff * flipIt;\n ff = ax.side === 'bottom' ? 1 : -0.2;\n\n out.xFn = function(d) { return d.dx + x0; };\n out.yFn = function(d) { return d.dy + y0 + d.fontSize * ff; };\n out.anchorFn = function(d, a) {\n if(!isNumeric(a) || a === 0 || a === 180) {\n return 'middle';\n }\n return (a * flipIt < 0) ? 'end' : 'start';\n };\n out.heightFn = function(d, a, h) {\n return (a < -60 || a > 60) ? -0.5 * h :\n ax.side === 'top' ? -h :\n 0;\n };\n } else if(axLetter === 'y') {\n flipIt = ax.side === 'right' ? 1 : -1;\n x0 = labelStandoff;\n y0 = -labelShift * flipIt;\n ff = Math.abs(ax.tickangle) === 90 ? 0.5 : 0;\n\n out.xFn = function(d) { return d.dx + shift + (x0 + d.fontSize * ff) * flipIt; };\n out.yFn = function(d) { return d.dy + y0 + d.fontSize * MID_SHIFT; };\n out.anchorFn = function(d, a) {\n if(isNumeric(a) && Math.abs(a) === 90) {\n return 'middle';\n }\n return ax.side === 'right' ? 'start' : 'end';\n };\n out.heightFn = function(d, a, h) {\n a *= ax.side === 'left' ? 1 : -1;\n return a < -30 ? -h :\n a < 30 ? -0.5 * h :\n 0;\n };\n }\n\n return out;\n};\n\nfunction tickDataFn(d) {\n return [d.text, d.x, d.axInfo, d.font, d.fontSize, d.fontColor].join('_');\n}\n\n/**\n * Draw axis ticks\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} ticks\n * - {number} linewidth\n * - {string} tickcolor\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawTicks = function(gd, ax, opts) {\n opts = opts || {};\n\n var cls = ax._id + 'tick';\n\n var ticks = opts.layer.selectAll('path.' + cls)\n .data(ax.ticks ? opts.vals : [], tickDataFn);\n\n ticks.exit().remove();\n\n ticks.enter().append('path')\n .classed(cls, 1)\n .classed('ticks', 1)\n .classed('crisp', opts.crisp !== false)\n .call(Color.stroke, ax.tickcolor)\n .style('stroke-width', Drawing.crispRound(gd, ax.tickwidth, 1) + 'px')\n .attr('d', opts.path);\n\n ticks.attr('transform', opts.transFn);\n};\n\n/**\n * Draw axis grid\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} showgrid\n * - {string} gridcolor\n * - {string} gridwidth\n * - {boolean} zeroline\n * - {string} type\n * - {string} dtick\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {object} counterAxis (full axis object corresponding to counter axis)\n * optional - only required if this axis supports zero lines\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawGrid = function(gd, ax, opts) {\n opts = opts || {};\n\n var cls = ax._id + 'grid';\n var vals = opts.vals;\n var counterAx = opts.counterAxis;\n if(ax.showgrid === false) {\n vals = [];\n } else if(counterAx && axes.shouldShowZeroLine(gd, ax, counterAx)) {\n var isArrayMode = ax.tickmode === 'array';\n for(var i = 0; i < vals.length; i++) {\n var xi = vals[i].x;\n if(isArrayMode ? !xi : (Math.abs(xi) < ax.dtick / 100)) {\n vals = vals.slice(0, i).concat(vals.slice(i + 1));\n // In array mode you can in principle have multiple\n // ticks at 0, so test them all. Otherwise once we found\n // one we can stop.\n if(isArrayMode) i--;\n else break;\n }\n }\n }\n\n var grid = opts.layer.selectAll('path.' + cls)\n .data(vals, tickDataFn);\n\n grid.exit().remove();\n\n grid.enter().append('path')\n .classed(cls, 1)\n .classed('crisp', opts.crisp !== false);\n\n ax._gw = Drawing.crispRound(gd, ax.gridwidth, 1);\n\n grid.attr('transform', opts.transFn)\n .attr('d', opts.path)\n .call(Color.stroke, ax.gridcolor || '#ddd')\n .style('stroke-width', ax._gw + 'px');\n\n if(typeof opts.path === 'function') grid.attr('d', opts.path);\n};\n\n/**\n * Draw axis zero-line\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} zeroline\n * - {number} zerolinewidth\n * - {string} zerolinecolor\n * - {number (optional)} _gridWidthCrispRound\n * @param {object} opts\n * - {d3 selection} layer\n * - {object} counterAxis (full axis object corresponding to counter axis)\n * - {string or fn} path\n * - {fn} transFn\n * - {boolean} crisp (set to false to unset crisp-edge SVG rendering)\n */\naxes.drawZeroLine = function(gd, ax, opts) {\n opts = opts || opts;\n\n var cls = ax._id + 'zl';\n var show = axes.shouldShowZeroLine(gd, ax, opts.counterAxis);\n\n var zl = opts.layer.selectAll('path.' + cls)\n .data(show ? [{x: 0, id: ax._id}] : []);\n\n zl.exit().remove();\n\n zl.enter().append('path')\n .classed(cls, 1)\n .classed('zl', 1)\n .classed('crisp', opts.crisp !== false)\n .each(function() {\n // use the fact that only one element can enter to trigger a sort.\n // If several zerolines enter at the same time we will sort once per,\n // but generally this should be a minimal overhead.\n opts.layer.selectAll('path').sort(function(da, db) {\n return axisIds.idSort(da.id, db.id);\n });\n });\n\n zl.attr('transform', opts.transFn)\n .attr('d', opts.path)\n .call(Color.stroke, ax.zerolinecolor || Color.defaultLine)\n .style('stroke-width', Drawing.crispRound(gd, ax.zerolinewidth, ax._gw || 1) + 'px');\n};\n\n/**\n * Draw axis tick labels\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {boolean} showticklabels\n * - {number} tickangle\n * - {object (optional)} _selections\n * - {object} (optional)} _tickAngles\n * - {object} (optional)} _prevTickAngles\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {string (optional)} cls (node className)\n * - {boolean} repositionOnUpdate (set to true to reposition update selection)\n * - {boolean} secondary\n * - {fn} transFn\n * - {object} labelFns\n * + {fn} xFn\n * + {fn} yFn\n * + {fn} anchorFn\n * + {fn} heightFn\n */\naxes.drawLabels = function(gd, ax, opts) {\n opts = opts || {};\n\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var cls = opts.cls || axId + 'tick';\n var vals = opts.vals;\n var labelFns = opts.labelFns;\n var tickAngle = opts.secondary ? 0 : ax.tickangle;\n var prevAngle = (ax._prevTickAngles || {})[cls];\n\n var tickLabels = opts.layer.selectAll('g.' + cls)\n .data(ax.showticklabels ? vals : [], tickDataFn);\n\n var labelsReady = [];\n\n tickLabels.enter().append('g')\n .classed(cls, 1)\n .append('text')\n // only so tex has predictable alignment that we can\n // alter later\n .attr('text-anchor', 'middle')\n .each(function(d) {\n var thisLabel = d3.select(this);\n var newPromise = gd._promises.length;\n\n thisLabel\n .call(svgTextUtils.positionText, labelFns.xFn(d), labelFns.yFn(d))\n .call(Drawing.font, d.font, d.fontSize, d.fontColor)\n .text(d.text)\n .call(svgTextUtils.convertToTspans, gd);\n\n if(gd._promises[newPromise]) {\n // if we have an async label, we'll deal with that\n // all here so take it out of gd._promises and\n // instead position the label and promise this in\n // labelsReady\n labelsReady.push(gd._promises.pop().then(function() {\n positionLabels(thisLabel, tickAngle);\n }));\n } else {\n // sync label: just position it now.\n positionLabels(thisLabel, tickAngle);\n }\n });\n\n tickLabels.exit().remove();\n\n if(opts.repositionOnUpdate) {\n tickLabels.each(function(d) {\n d3.select(this).select('text')\n .call(svgTextUtils.positionText, labelFns.xFn(d), labelFns.yFn(d));\n });\n }\n\n function positionLabels(s, angle) {\n s.each(function(d) {\n var thisLabel = d3.select(this);\n var mathjaxGroup = thisLabel.select('.text-math-group');\n var anchor = labelFns.anchorFn(d, angle);\n\n var transform = opts.transFn.call(thisLabel.node(), d) +\n ((isNumeric(angle) && +angle !== 0) ?\n (' rotate(' + angle + ',' + labelFns.xFn(d) + ',' +\n (labelFns.yFn(d) - d.fontSize / 2) + ')') :\n '');\n\n // how much to shift a multi-line label to center it vertically.\n var nLines = svgTextUtils.lineCount(thisLabel);\n var lineHeight = LINE_SPACING * d.fontSize;\n var anchorHeight = labelFns.heightFn(d, isNumeric(angle) ? +angle : 0, (nLines - 1) * lineHeight);\n\n if(anchorHeight) {\n transform += ' translate(0, ' + anchorHeight + ')';\n }\n\n if(mathjaxGroup.empty()) {\n thisLabel.select('text').attr({\n transform: transform,\n 'text-anchor': anchor\n });\n } else {\n var mjWidth = Drawing.bBox(mathjaxGroup.node()).width;\n var mjShift = mjWidth * {end: -0.5, start: 0.5}[anchor];\n mathjaxGroup.attr('transform', transform + (mjShift ? 'translate(' + mjShift + ',0)' : ''));\n }\n });\n }\n\n // make sure all labels are correctly positioned at their base angle\n // the positionLabels call above is only for newly drawn labels.\n // do this without waiting, using the last calculated angle to\n // minimize flicker, then do it again when we know all labels are\n // there, putting back the prescribed angle to check for overlaps.\n positionLabels(tickLabels, (prevAngle + 1) ? prevAngle : tickAngle);\n\n function allLabelsReady() {\n return labelsReady.length && Promise.all(labelsReady);\n }\n\n var autoangle = null;\n\n function fixLabelOverlaps() {\n positionLabels(tickLabels, tickAngle);\n\n // check for auto-angling if x labels overlap\n // don't auto-angle at all for log axes with\n // base and digit format\n if(vals.length && axLetter === 'x' && !isNumeric(tickAngle) &&\n (ax.type !== 'log' || String(ax.dtick).charAt(0) !== 'D')\n ) {\n autoangle = 0;\n\n var maxFontSize = 0;\n var lbbArray = [];\n var i;\n\n tickLabels.each(function(d) {\n maxFontSize = Math.max(maxFontSize, d.fontSize);\n\n var x = ax.l2p(d.x);\n var thisLabel = selectTickLabel(this);\n var bb = Drawing.bBox(thisLabel.node());\n\n lbbArray.push({\n // ignore about y, just deal with x overlaps\n top: 0,\n bottom: 10,\n height: 10,\n left: x - bb.width / 2,\n // impose a 2px gap\n right: x + bb.width / 2 + 2,\n width: bb.width + 2\n });\n });\n\n if((ax.tickson === 'boundaries' || ax.showdividers) && !opts.secondary) {\n var gap = 2;\n if(ax.ticks) gap += ax.tickwidth / 2;\n\n // TODO should secondary labels also fall into this fix-overlap regime?\n\n for(i = 0; i < lbbArray.length; i++) {\n var xbnd = vals[i].xbnd;\n var lbb = lbbArray[i];\n if(\n (xbnd[0] !== null && (lbb.left - ax.l2p(xbnd[0])) < gap) ||\n (xbnd[1] !== null && (ax.l2p(xbnd[1]) - lbb.right) < gap)\n ) {\n autoangle = 90;\n break;\n }\n }\n } else {\n var vLen = vals.length;\n var tickSpacing = Math.abs((vals[vLen - 1].x - vals[0].x) * ax._m) / (vLen - 1);\n var rotate90 = (tickSpacing < maxFontSize * 2.5) || ax.type === 'multicategory';\n\n // any overlap at all - set 30 degrees or 90 degrees\n for(i = 0; i < lbbArray.length - 1; i++) {\n if(Lib.bBoxIntersect(lbbArray[i], lbbArray[i + 1])) {\n autoangle = rotate90 ? 90 : 30;\n break;\n }\n }\n }\n\n if(autoangle) {\n positionLabels(tickLabels, autoangle);\n }\n }\n }\n\n if(ax._selections) {\n ax._selections[cls] = tickLabels;\n }\n\n var seq = [allLabelsReady];\n\n // N.B. during auto-margin redraws, if the axis fixed its label overlaps\n // by rotating 90 degrees, do not attempt to re-fix its label overlaps\n // as this can lead to infinite redraw loops!\n if(ax.automargin && fullLayout._redrawFromAutoMarginCount && prevAngle === 90) {\n autoangle = 90;\n seq.push(function() {\n positionLabels(tickLabels, prevAngle);\n });\n } else {\n seq.push(fixLabelOverlaps);\n }\n\n // save current tick angle for future redraws\n if(ax._tickAngles) {\n seq.push(function() {\n ax._tickAngles[cls] = autoangle === null ?\n (isNumeric(tickAngle) ? tickAngle : 0) :\n autoangle;\n });\n }\n\n var done = Lib.syncOrAsync(seq);\n if(done && done.then) gd._promises.push(done);\n return done;\n};\n\n/**\n * Draw axis dividers\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} showdividers\n * - {number} dividerwidth\n * - {string} dividercolor\n * @param {object} opts\n * - {array of object} vals (calcTicks output-like)\n * - {d3 selection} layer\n * - {fn} path\n * - {fn} transFn\n */\nfunction drawDividers(gd, ax, opts) {\n var cls = ax._id + 'divider';\n var vals = opts.vals;\n\n var dividers = opts.layer.selectAll('path.' + cls)\n .data(vals, tickDataFn);\n\n dividers.exit().remove();\n\n dividers.enter().insert('path', ':first-child')\n .classed(cls, 1)\n .classed('crisp', 1)\n .call(Color.stroke, ax.dividercolor)\n .style('stroke-width', Drawing.crispRound(gd, ax.dividerwidth, 1) + 'px');\n\n dividers\n .attr('transform', opts.transFn)\n .attr('d', opts.path);\n}\n\n/**\n * Get axis position in px, that is the distance for the graph's\n * top (left) edge for x (y) axes.\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} side\n * if anchored:\n * - {object} _anchorAxis\n * Otherwise:\n * - {number} position\n * @return {number}\n */\naxes.getPxPosition = function(gd, ax) {\n var gs = gd._fullLayout._size;\n var axLetter = ax._id.charAt(0);\n var side = ax.side;\n var anchorAxis;\n\n if(ax.anchor !== 'free') {\n anchorAxis = ax._anchorAxis;\n } else if(axLetter === 'x') {\n anchorAxis = {\n _offset: gs.t + (1 - (ax.position || 0)) * gs.h,\n _length: 0\n };\n } else if(axLetter === 'y') {\n anchorAxis = {\n _offset: gs.l + (ax.position || 0) * gs.w,\n _length: 0\n };\n }\n\n if(side === 'top' || side === 'left') {\n return anchorAxis._offset;\n } else if(side === 'bottom' || side === 'right') {\n return anchorAxis._offset + anchorAxis._length;\n }\n};\n\n/**\n * Approximate axis title depth (w/o computing its bounding box)\n *\n * @param {object} ax (full) axis object\n * - {string} title.text\n * - {number} title.font.size\n * - {number} title.standoff\n * @return {number} (in px)\n */\nfunction approxTitleDepth(ax) {\n var fontSize = ax.title.font.size;\n var extraLines = (ax.title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n if(ax.title.hasOwnProperty('standoff')) {\n return extraLines ?\n fontSize * (CAP_SHIFT + (extraLines * LINE_SPACING)) :\n fontSize * CAP_SHIFT;\n } else {\n return extraLines ?\n fontSize * (extraLines + 1) * LINE_SPACING :\n fontSize;\n }\n}\n\n/**\n * Draw axis title, compute default standoff if necessary\n *\n * @param {DOM element} gd\n * @param {object} ax (full) axis object\n * - {string} _id\n * - {string} _name\n * - {string} side\n * - {number} title.font.size\n * - {object} _selections\n *\n * - {number} _depth\n * - {number} title.standoff\n * OR\n * - {number} linewidth\n * - {boolean} showticklabels\n */\nfunction drawTitle(gd, ax) {\n var fullLayout = gd._fullLayout;\n var axId = ax._id;\n var axLetter = axId.charAt(0);\n var fontSize = ax.title.font.size;\n\n var titleStandoff;\n\n if(ax.title.hasOwnProperty('standoff')) {\n titleStandoff = ax._depth + ax.title.standoff + approxTitleDepth(ax);\n } else {\n if(ax.type === 'multicategory') {\n titleStandoff = ax._depth;\n } else {\n var offsetBase = 1.5;\n titleStandoff = 10 + fontSize * offsetBase + (ax.linewidth ? ax.linewidth - 1 : 0);\n }\n\n if(axLetter === 'x') {\n titleStandoff += ax.side === 'top' ?\n fontSize * (ax.showticklabels ? 1 : 0) :\n fontSize * (ax.showticklabels ? 1.5 : 0.5);\n } else {\n titleStandoff += ax.side === 'right' ?\n fontSize * (ax.showticklabels ? 1 : 0.5) :\n fontSize * (ax.showticklabels ? 0.5 : 0);\n }\n }\n\n var pos = axes.getPxPosition(gd, ax);\n var transform, x, y;\n\n if(axLetter === 'x') {\n x = ax._offset + ax._length / 2;\n y = (ax.side === 'top') ? pos - titleStandoff : pos + titleStandoff;\n } else {\n y = ax._offset + ax._length / 2;\n x = (ax.side === 'right') ? pos + titleStandoff : pos - titleStandoff;\n transform = {rotate: '-90', offset: 0};\n }\n\n var avoid;\n\n if(ax.type !== 'multicategory') {\n var tickLabels = ax._selections[ax._id + 'tick'];\n\n avoid = {\n selection: tickLabels,\n side: ax.side\n };\n\n if(tickLabels && tickLabels.node() && tickLabels.node().parentNode) {\n var translation = Drawing.getTranslate(tickLabels.node().parentNode);\n avoid.offsetLeft = translation.x;\n avoid.offsetTop = translation.y;\n }\n\n if(ax.title.hasOwnProperty('standoff')) {\n avoid.pad = 0;\n }\n }\n\n return Titles.draw(gd, axId + 'title', {\n propContainer: ax,\n propName: ax._name + '.title.text',\n placeholder: fullLayout._dfltTitle[axLetter],\n avoid: avoid,\n transform: transform,\n attributes: {x: x, y: y, 'text-anchor': 'middle'}\n });\n}\n\naxes.shouldShowZeroLine = function(gd, ax, counterAxis) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n return (\n (rng[0] * rng[1] <= 0) &&\n ax.zeroline &&\n (ax.type === 'linear' || ax.type === '-') &&\n !(ax.rangebreaks && ax.maskBreaks(0) === BADNUM) &&\n (\n clipEnds(ax, 0) ||\n !anyCounterAxLineAtZero(gd, ax, counterAxis, rng) ||\n hasBarsOrFill(gd, ax)\n )\n );\n};\n\naxes.clipEnds = function(ax, vals) {\n return vals.filter(function(d) { return clipEnds(ax, d.x); });\n};\n\nfunction clipEnds(ax, l) {\n var p = ax.l2p(l);\n return (p > 1 && p < ax._length - 1);\n}\n\nfunction anyCounterAxLineAtZero(gd, ax, counterAxis, rng) {\n var mainCounterAxis = counterAxis._mainAxis;\n if(!mainCounterAxis) return;\n\n var fullLayout = gd._fullLayout;\n var axLetter = ax._id.charAt(0);\n var counterLetter = axes.counterLetter(ax._id);\n\n var zeroPosition = ax._offset + (\n ((Math.abs(rng[0]) < Math.abs(rng[1])) === (axLetter === 'x')) ?\n 0 : ax._length\n );\n\n function lineNearZero(ax2) {\n if(!ax2.showline || !ax2.linewidth) return false;\n var tolerance = Math.max((ax2.linewidth + ax.zerolinewidth) / 2, 1);\n\n function closeEnough(pos2) {\n return typeof pos2 === 'number' && Math.abs(pos2 - zeroPosition) < tolerance;\n }\n\n if(closeEnough(ax2._mainLinePosition) || closeEnough(ax2._mainMirrorPosition)) {\n return true;\n }\n var linePositions = ax2._linepositions || {};\n for(var k in linePositions) {\n if(closeEnough(linePositions[k][0]) || closeEnough(linePositions[k][1])) {\n return true;\n }\n }\n }\n\n var plotinfo = fullLayout._plots[counterAxis._mainSubplot];\n if(!(plotinfo.mainplotinfo || plotinfo).overlays.length) {\n return lineNearZero(counterAxis, zeroPosition);\n }\n\n var counterLetterAxes = axes.list(gd, counterLetter);\n for(var i = 0; i < counterLetterAxes.length; i++) {\n var counterAxis2 = counterLetterAxes[i];\n if(\n counterAxis2._mainAxis === mainCounterAxis &&\n lineNearZero(counterAxis2, zeroPosition)\n ) {\n return true;\n }\n }\n}\n\nfunction hasBarsOrFill(gd, ax) {\n var fullData = gd._fullData;\n var subplot = ax._mainSubplot;\n var axLetter = ax._id.charAt(0);\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible === true && (trace.xaxis + trace.yaxis) === subplot) {\n if(\n Registry.traceIs(trace, 'bar-like') &&\n trace.orientation === {x: 'h', y: 'v'}[axLetter]\n ) return true;\n\n if(\n trace.fill &&\n trace.fill.charAt(trace.fill.length - 1) === axLetter\n ) return true;\n }\n }\n return false;\n}\n\nfunction selectTickLabel(gTick) {\n var s = d3.select(gTick);\n var mj = s.select('.text-math-group');\n return mj.empty() ? s.select('text') : mj;\n}\n\n/**\n * Find all margin pushers for 2D axes and reserve them for later use\n * Both label and rangeslider automargin calculations happen later so\n * we need to explicitly allow their ids in order to not delete them.\n *\n * TODO: can we pull the actual automargin calls forward to avoid this hack?\n * We're probably also doing multiple redraws in this case, would be faster\n * if we can just do the whole calculation ahead of time and draw once.\n */\naxes.allowAutoMargin = function(gd) {\n var axList = axes.list(gd, '', true);\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n if(ax.automargin) {\n Plots.allowAutoMargin(gd, axAutoMarginID(ax));\n if(ax.mirror) {\n Plots.allowAutoMargin(gd, axMirrorAutoMarginID(ax));\n }\n }\n if(Registry.getComponentMethod('rangeslider', 'isVisible')(ax)) {\n Plots.allowAutoMargin(gd, rangeSliderAutoMarginID(ax));\n }\n }\n};\n\nfunction axAutoMarginID(ax) { return ax._id + '.automargin'; }\nfunction axMirrorAutoMarginID(ax) { return axAutoMarginID(ax) + '.mirror'; }\nfunction rangeSliderAutoMarginID(ax) { return ax._id + '.rangeslider'; }\n\n// swap all the presentation attributes of the axes showing these traces\naxes.swap = function(gd, traces) {\n var axGroups = makeAxisGroups(gd, traces);\n\n for(var i = 0; i < axGroups.length; i++) {\n swapAxisGroup(gd, axGroups[i].x, axGroups[i].y);\n }\n};\n\nfunction makeAxisGroups(gd, traces) {\n var groups = [];\n var i, j;\n\n for(i = 0; i < traces.length; i++) {\n var groupsi = [];\n var xi = gd._fullData[traces[i]].xaxis;\n var yi = gd._fullData[traces[i]].yaxis;\n if(!xi || !yi) continue; // not a 2D cartesian trace?\n\n for(j = 0; j < groups.length; j++) {\n if(groups[j].x.indexOf(xi) !== -1 || groups[j].y.indexOf(yi) !== -1) {\n groupsi.push(j);\n }\n }\n\n if(!groupsi.length) {\n groups.push({x: [xi], y: [yi]});\n continue;\n }\n\n var group0 = groups[groupsi[0]];\n var groupj;\n\n if(groupsi.length > 1) {\n for(j = 1; j < groupsi.length; j++) {\n groupj = groups[groupsi[j]];\n mergeAxisGroups(group0.x, groupj.x);\n mergeAxisGroups(group0.y, groupj.y);\n }\n }\n mergeAxisGroups(group0.x, [xi]);\n mergeAxisGroups(group0.y, [yi]);\n }\n\n return groups;\n}\n\nfunction mergeAxisGroups(intoSet, fromSet) {\n for(var i = 0; i < fromSet.length; i++) {\n if(intoSet.indexOf(fromSet[i]) === -1) intoSet.push(fromSet[i]);\n }\n}\n\nfunction swapAxisGroup(gd, xIds, yIds) {\n var xFullAxes = [];\n var yFullAxes = [];\n var layout = gd.layout;\n var i, j;\n\n for(i = 0; i < xIds.length; i++) xFullAxes.push(axes.getFromId(gd, xIds[i]));\n for(i = 0; i < yIds.length; i++) yFullAxes.push(axes.getFromId(gd, yIds[i]));\n\n var allAxKeys = Object.keys(axAttrs);\n\n var noSwapAttrs = [\n 'anchor', 'domain', 'overlaying', 'position', 'side', 'tickangle', 'editType'\n ];\n var numericTypes = ['linear', 'log'];\n\n for(i = 0; i < allAxKeys.length; i++) {\n var keyi = allAxKeys[i];\n var xVal = xFullAxes[0][keyi];\n var yVal = yFullAxes[0][keyi];\n var allEqual = true;\n var coerceLinearX = false;\n var coerceLinearY = false;\n if(keyi.charAt(0) === '_' || typeof xVal === 'function' ||\n noSwapAttrs.indexOf(keyi) !== -1) {\n continue;\n }\n for(j = 1; j < xFullAxes.length && allEqual; j++) {\n var xVali = xFullAxes[j][keyi];\n if(keyi === 'type' && numericTypes.indexOf(xVal) !== -1 &&\n numericTypes.indexOf(xVali) !== -1 && xVal !== xVali) {\n // type is special - if we find a mixture of linear and log,\n // coerce them all to linear on flipping\n coerceLinearX = true;\n } else if(xVali !== xVal) allEqual = false;\n }\n for(j = 1; j < yFullAxes.length && allEqual; j++) {\n var yVali = yFullAxes[j][keyi];\n if(keyi === 'type' && numericTypes.indexOf(yVal) !== -1 &&\n numericTypes.indexOf(yVali) !== -1 && yVal !== yVali) {\n // type is special - if we find a mixture of linear and log,\n // coerce them all to linear on flipping\n coerceLinearY = true;\n } else if(yFullAxes[j][keyi] !== yVal) allEqual = false;\n }\n if(allEqual) {\n if(coerceLinearX) layout[xFullAxes[0]._name].type = 'linear';\n if(coerceLinearY) layout[yFullAxes[0]._name].type = 'linear';\n swapAxisAttrs(layout, keyi, xFullAxes, yFullAxes, gd._fullLayout._dfltTitle);\n }\n }\n\n // now swap x&y for any annotations anchored to these x & y\n for(i = 0; i < gd._fullLayout.annotations.length; i++) {\n var ann = gd._fullLayout.annotations[i];\n if(xIds.indexOf(ann.xref) !== -1 &&\n yIds.indexOf(ann.yref) !== -1) {\n Lib.swapAttrs(layout.annotations[i], ['?']);\n }\n }\n}\n\nfunction swapAxisAttrs(layout, key, xFullAxes, yFullAxes, dfltTitle) {\n // in case the value is the default for either axis,\n // look at the first axis in each list and see if\n // this key's value is undefined\n var np = Lib.nestedProperty;\n var xVal = np(layout[xFullAxes[0]._name], key).get();\n var yVal = np(layout[yFullAxes[0]._name], key).get();\n var i;\n\n if(key === 'title') {\n // special handling of placeholder titles\n if(xVal && xVal.text === dfltTitle.x) {\n xVal.text = dfltTitle.y;\n }\n if(yVal && yVal.text === dfltTitle.y) {\n yVal.text = dfltTitle.x;\n }\n }\n\n for(i = 0; i < xFullAxes.length; i++) {\n np(layout, xFullAxes[i]._name + '.' + key).set(yVal);\n }\n for(i = 0; i < yFullAxes.length; i++) {\n np(layout, yFullAxes[i]._name + '.' + key).set(xVal);\n }\n}\n\nfunction isAngular(ax) {\n return ax._id === 'angularaxis';\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar constants = require('./constants');\n\nmodule.exports = {\n moduleType: 'component',\n name: constants.name,\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Color = require('../../components/color');\nvar castOption = require('./helpers').castOption;\n\nmodule.exports = function styleOne(s, pt, trace) {\n var line = trace.marker.line;\n var lineColor = castOption(line.color, pt.pts) || Color.defaultLine;\n var lineWidth = castOption(line.width, pt.pts) || 0;\n\n s.style('stroke-width', lineWidth)\n .call(Color.fill, pt.color)\n .call(Color.stroke, lineColor);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'annotations3d',\n\n schema: {\n subplots: {\n scene: {annotations: require('./attributes')}\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n includeBasePlot: includeGL3D,\n\n convert: require('./convert'),\n draw: require('./draw')\n};\n\nfunction includeGL3D(layoutIn, layoutOut) {\n var GL3D = Registry.subplotsRegistry.gl3d;\n if(!GL3D) return;\n\n var attrRegex = GL3D.attrRegex;\n\n var keys = Object.keys(layoutIn);\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n if(attrRegex.test(k) && (layoutIn[k].annotations || []).length) {\n Lib.pushUnique(layoutOut._basePlotModules, GL3D);\n Lib.pushUnique(layoutOut._subplots.gl3d, k);\n }\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n/**\n * Determine the position anchor property of x/y xanchor/yanchor components.\n *\n * - values < 1/3 align the low side at that fraction,\n * - values [1/3, 2/3] align the center at that fraction,\n * - values > 2/3 align the right at that fraction.\n */\n\n\nexports.isLeftAnchor = function isLeftAnchor(opts) {\n return (\n opts.xanchor === 'left' ||\n (opts.xanchor === 'auto' && opts.x <= 1 / 3)\n );\n};\n\nexports.isCenterAnchor = function isCenterAnchor(opts) {\n return (\n opts.xanchor === 'center' ||\n (opts.xanchor === 'auto' && opts.x > 1 / 3 && opts.x < 2 / 3)\n );\n};\n\nexports.isRightAnchor = function isRightAnchor(opts) {\n return (\n opts.xanchor === 'right' ||\n (opts.xanchor === 'auto' && opts.x >= 2 / 3)\n );\n};\n\nexports.isTopAnchor = function isTopAnchor(opts) {\n return (\n opts.yanchor === 'top' ||\n (opts.yanchor === 'auto' && opts.y >= 2 / 3)\n );\n};\n\nexports.isMiddleAnchor = function isMiddleAnchor(opts) {\n return (\n opts.yanchor === 'middle' ||\n (opts.yanchor === 'auto' && opts.y > 1 / 3 && opts.y < 2 / 3)\n );\n};\n\nexports.isBottomAnchor = function isBottomAnchor(opts) {\n return (\n opts.yanchor === 'bottom' ||\n (opts.yanchor === 'auto' && opts.y <= 1 / 3)\n );\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar Lib = require('../../lib');\n\nfunction resizeText(gd, gTrace, traceType) {\n var fullLayout = gd._fullLayout;\n var minSize = fullLayout['_' + traceType + 'Text_minsize'];\n if(minSize) {\n var shouldHide = fullLayout.uniformtext.mode === 'hide';\n\n var selector;\n switch(traceType) {\n case 'funnelarea' :\n case 'pie' :\n case 'sunburst' :\n selector = 'g.slice';\n break;\n case 'treemap' :\n selector = 'g.slice, g.pathbar';\n break;\n default :\n selector = 'g.points > g.point';\n }\n\n gTrace.selectAll(selector).each(function(d) {\n var transform = d.transform;\n if(transform) {\n transform.scale = (shouldHide && transform.hide) ? 0 : minSize / transform.fontSize;\n\n var el = d3.select(this).select('text');\n el.attr('transform', Lib.getTextTransform(transform));\n }\n });\n }\n}\n\nfunction recordMinTextSize(\n traceType, // in\n transform, // inout\n fullLayout // inout\n) {\n if(fullLayout.uniformtext.mode) {\n var minKey = getMinKey(traceType);\n var minSize = fullLayout.uniformtext.minsize;\n var size = transform.scale * transform.fontSize;\n\n transform.hide = size < minSize;\n\n fullLayout[minKey] = fullLayout[minKey] || Infinity;\n if(!transform.hide) {\n fullLayout[minKey] = Math.min(\n fullLayout[minKey],\n Math.max(size, minSize)\n );\n }\n }\n}\n\nfunction clearMinTextSize(\n traceType, // in\n fullLayout // inout\n) {\n var minKey = getMinKey(traceType);\n fullLayout[minKey] = undefined;\n}\n\nfunction getMinKey(traceType) {\n return '_' + traceType + 'Text_minsize';\n}\n\nmodule.exports = {\n recordMinTextSize: recordMinTextSize,\n clearMinTextSize: clearMinTextSize,\n resizeText: resizeText\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar handleTickValueDefaults = require('../../plots/cartesian/tick_value_defaults');\nvar handleTickMarkDefaults = require('../../plots/cartesian/tick_mark_defaults');\nvar handleTickLabelDefaults = require('../../plots/cartesian/tick_label_defaults');\n\nvar attributes = require('./attributes');\n\nmodule.exports = function colorbarDefaults(containerIn, containerOut, layout) {\n var colorbarOut = Template.newContainer(containerOut, 'colorbar');\n var colorbarIn = containerIn.colorbar || {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(colorbarIn, colorbarOut, attributes, attr, dflt);\n }\n\n var thicknessmode = coerce('thicknessmode');\n coerce('thickness', (thicknessmode === 'fraction') ?\n 30 / (layout.width - layout.margin.l - layout.margin.r) :\n 30\n );\n\n var lenmode = coerce('lenmode');\n coerce('len', (lenmode === 'fraction') ?\n 1 :\n layout.height - layout.margin.t - layout.margin.b\n );\n\n coerce('x');\n coerce('xanchor');\n coerce('xpad');\n coerce('y');\n coerce('yanchor');\n coerce('ypad');\n Lib.noneOrAll(colorbarIn, colorbarOut, ['x', 'y']);\n\n coerce('outlinecolor');\n coerce('outlinewidth');\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('bgcolor');\n\n handleTickValueDefaults(colorbarIn, colorbarOut, coerce, 'linear');\n\n var opts = {outerTicks: false, font: layout.font};\n handleTickLabelDefaults(colorbarIn, colorbarOut, coerce, 'linear', opts);\n handleTickMarkDefaults(colorbarIn, colorbarOut, coerce, 'linear', opts);\n\n coerce('title.text', layout._dfltTitle.colorbar);\n Lib.coerceFont(coerce, 'title.font', layout.font);\n coerce('title.side');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar loggers = require('./loggers');\n\n/**\n * Allow referencing a graph DOM element either directly\n * or by its id string\n *\n * @param {HTMLDivElement|string} gd: a graph element or its id\n *\n * @returns {HTMLDivElement} the DOM element of the graph\n */\nfunction getGraphDiv(gd) {\n var gdElement;\n\n if(typeof gd === 'string') {\n gdElement = document.getElementById(gd);\n\n if(gdElement === null) {\n throw new Error('No DOM element with id \\'' + gd + '\\' exists on the page.');\n }\n\n return gdElement;\n } else if(gd === null || gd === undefined) {\n throw new Error('DOM element provided is null or undefined');\n }\n\n // otherwise assume that gd is a DOM element\n return gd;\n}\n\nfunction isPlotDiv(el) {\n var el3 = d3.select(el);\n return el3.node() instanceof HTMLElement &&\n el3.size() &&\n el3.classed('js-plotly-plot');\n}\n\nfunction removeElement(el) {\n var elParent = el && el.parentNode;\n if(elParent) elParent.removeChild(el);\n}\n\n/**\n * for dynamically adding style rules\n * makes one stylesheet that contains all rules added\n * by all calls to this function\n */\nfunction addStyleRule(selector, styleString) {\n addRelatedStyleRule('global', selector, styleString);\n}\n\n/**\n * for dynamically adding style rules\n * to a stylesheet uniquely identified by a uid\n */\nfunction addRelatedStyleRule(uid, selector, styleString) {\n var id = 'plotly.js-style-' + uid;\n var style = document.getElementById(id);\n if(!style) {\n style = document.createElement('style');\n style.setAttribute('id', id);\n // WebKit hack :(\n style.appendChild(document.createTextNode(''));\n document.head.appendChild(style);\n }\n var styleSheet = style.sheet;\n\n if(styleSheet.insertRule) {\n styleSheet.insertRule(selector + '{' + styleString + '}', 0);\n } else if(styleSheet.addRule) {\n styleSheet.addRule(selector, styleString, 0);\n } else loggers.warn('addStyleRule failed');\n}\n\n/**\n * to remove from the page a stylesheet identified by a given uid\n */\nfunction deleteRelatedStyleRule(uid) {\n var id = 'plotly.js-style-' + uid;\n var style = document.getElementById(id);\n if(style) removeElement(style);\n}\n\nmodule.exports = {\n getGraphDiv: getGraphDiv,\n isPlotDiv: isPlotDiv,\n removeElement: removeElement,\n addStyleRule: addStyleRule,\n addRelatedStyleRule: addRelatedStyleRule,\n deleteRelatedStyleRule: deleteRelatedStyleRule\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar maxRowLength = require('../../lib').maxRowLength;\n\n/* Return a list of empty points in 2D array z\n * each empty point z[i][j] gives an array [i, j, neighborCount]\n * neighborCount is the count of 4 nearest neighbors that DO exist\n * this is to give us an order of points to evaluate for interpolation.\n * if no neighbors exist, we iteratively look for neighbors that HAVE\n * neighbors, and add a fractional neighborCount\n */\nmodule.exports = function findEmpties(z) {\n var empties = [];\n var neighborHash = {};\n var noNeighborList = [];\n var nextRow = z[0];\n var row = [];\n var blank = [0, 0, 0];\n var rowLength = maxRowLength(z);\n var prevRow;\n var i;\n var j;\n var thisPt;\n var p;\n var neighborCount;\n var newNeighborHash;\n var foundNewNeighbors;\n\n for(i = 0; i < z.length; i++) {\n prevRow = row;\n row = nextRow;\n nextRow = z[i + 1] || [];\n for(j = 0; j < rowLength; j++) {\n if(row[j] === undefined) {\n neighborCount = (row[j - 1] !== undefined ? 1 : 0) +\n (row[j + 1] !== undefined ? 1 : 0) +\n (prevRow[j] !== undefined ? 1 : 0) +\n (nextRow[j] !== undefined ? 1 : 0);\n\n if(neighborCount) {\n // for this purpose, don't count off-the-edge points\n // as undefined neighbors\n if(i === 0) neighborCount++;\n if(j === 0) neighborCount++;\n if(i === z.length - 1) neighborCount++;\n if(j === row.length - 1) neighborCount++;\n\n // if all neighbors that could exist do, we don't\n // need this for finding farther neighbors\n if(neighborCount < 4) {\n neighborHash[[i, j]] = [i, j, neighborCount];\n }\n\n empties.push([i, j, neighborCount]);\n } else noNeighborList.push([i, j]);\n }\n }\n }\n\n while(noNeighborList.length) {\n newNeighborHash = {};\n foundNewNeighbors = false;\n\n // look for cells that now have neighbors but didn't before\n for(p = noNeighborList.length - 1; p >= 0; p--) {\n thisPt = noNeighborList[p];\n i = thisPt[0];\n j = thisPt[1];\n\n neighborCount = ((neighborHash[[i - 1, j]] || blank)[2] +\n (neighborHash[[i + 1, j]] || blank)[2] +\n (neighborHash[[i, j - 1]] || blank)[2] +\n (neighborHash[[i, j + 1]] || blank)[2]) / 20;\n\n if(neighborCount) {\n newNeighborHash[thisPt] = [i, j, neighborCount];\n noNeighborList.splice(p, 1);\n foundNewNeighbors = true;\n }\n }\n\n if(!foundNewNeighbors) {\n throw 'findEmpties iterated with no new neighbors';\n }\n\n // put these new cells into the main neighbor list\n for(thisPt in newNeighborHash) {\n neighborHash[thisPt] = newNeighborHash[thisPt];\n empties.push(newNeighborHash[thisPt]);\n }\n }\n\n // sort the full list in descending order of neighbor count\n return empties.sort(function(a, b) { return b[2] - a[2]; });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n/* global jQuery:false */\n\nvar EventEmitter = require('events').EventEmitter;\n\nvar Events = {\n\n init: function(plotObj) {\n /*\n * If we have already instantiated an emitter for this plot\n * return early.\n */\n if(plotObj._ev instanceof EventEmitter) return plotObj;\n\n var ev = new EventEmitter();\n var internalEv = new EventEmitter();\n\n /*\n * Assign to plot._ev while we still live in a land\n * where plot is a DOM element with stuff attached to it.\n * In the future we can make plot the event emitter itself.\n */\n plotObj._ev = ev;\n\n /*\n * Create a second event handler that will manage events *internally*.\n * This allows parts of plotly to respond to thing like relayout without\n * having to use the user-facing event handler. They cannot peacefully\n * coexist on the same handler because a user invoking\n * plotObj.removeAllListeners() would detach internal events, breaking\n * plotly.\n */\n plotObj._internalEv = internalEv;\n\n /*\n * Assign bound methods from the ev to the plot object. These methods\n * will reference the 'this' of plot._ev even though they are methods\n * of plot. This will keep the event machinery away from the plot object\n * which currently is often a DOM element but presents an API that will\n * continue to function when plot becomes an emitter. Not all EventEmitter\n * methods have been bound to `plot` as some do not currently add value to\n * the Plotly event API.\n */\n plotObj.on = ev.on.bind(ev);\n plotObj.once = ev.once.bind(ev);\n plotObj.removeListener = ev.removeListener.bind(ev);\n plotObj.removeAllListeners = ev.removeAllListeners.bind(ev);\n\n /*\n * Create functions for managing internal events. These are *only* triggered\n * by the mirroring of external events via the emit function.\n */\n plotObj._internalOn = internalEv.on.bind(internalEv);\n plotObj._internalOnce = internalEv.once.bind(internalEv);\n plotObj._removeInternalListener = internalEv.removeListener.bind(internalEv);\n plotObj._removeAllInternalListeners = internalEv.removeAllListeners.bind(internalEv);\n\n /*\n * We must wrap emit to continue to support JQuery events. The idea\n * is to check to see if the user is using JQuery events, if they are\n * we emit JQuery events to trigger user handlers as well as the EventEmitter\n * events.\n */\n plotObj.emit = function(event, data) {\n if(typeof jQuery !== 'undefined') {\n jQuery(plotObj).trigger(event, data);\n }\n\n ev.emit(event, data);\n internalEv.emit(event, data);\n };\n\n return plotObj;\n },\n\n /*\n * This function behaves like jQuery's triggerHandler. It calls\n * all handlers for a particular event and returns the return value\n * of the LAST handler. This function also triggers jQuery's\n * triggerHandler for backwards compatibility.\n */\n triggerHandler: function(plotObj, event, data) {\n var jQueryHandlerValue;\n var nodeEventHandlerValue;\n\n /*\n * If jQuery exists run all its handlers for this event and\n * collect the return value of the LAST handler function\n */\n if(typeof jQuery !== 'undefined') {\n jQueryHandlerValue = jQuery(plotObj).triggerHandler(event, data);\n }\n\n /*\n * Now run all the node style event handlers\n */\n var ev = plotObj._ev;\n if(!ev) return jQueryHandlerValue;\n\n var handlers = ev._events[event];\n if(!handlers) return jQueryHandlerValue;\n\n // making sure 'this' is the EventEmitter instance\n function apply(handler) {\n // The 'once' case, we can't just call handler() as we need\n // the return value here. So,\n // - remove handler\n // - call listener and grab return value!\n // - stash 'fired' key to not call handler twice\n if(handler.listener) {\n ev.removeListener(event, handler.listener);\n if(!handler.fired) {\n handler.fired = true;\n return handler.listener.apply(ev, [data]);\n }\n } else {\n return handler.apply(ev, [data]);\n }\n }\n\n // handlers can be function or an array of functions\n handlers = Array.isArray(handlers) ? handlers : [handlers];\n\n var i;\n for(i = 0; i < handlers.length - 1; i++) {\n apply(handlers[i]);\n }\n // now call the final handler and collect its value\n nodeEventHandlerValue = apply(handlers[i]);\n\n /*\n * Return either the jQuery handler value if it exists or the\n * nodeEventHandler value. jQuery event value supersedes nodejs\n * events for backwards compatibility reasons.\n */\n return jQueryHandlerValue !== undefined ?\n jQueryHandlerValue :\n nodeEventHandlerValue;\n },\n\n purge: function(plotObj) {\n delete plotObj._ev;\n delete plotObj.on;\n delete plotObj.once;\n delete plotObj.removeListener;\n delete plotObj.removeAllListeners;\n delete plotObj.emit;\n\n delete plotObj._ev;\n delete plotObj._internalEv;\n delete plotObj._internalOn;\n delete plotObj._internalOnce;\n delete plotObj._removeInternalListener;\n delete plotObj._removeAllInternalListeners;\n\n return plotObj;\n }\n\n};\n\nmodule.exports = Events;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar attrs = require('./attributes');\nvar oppAxisAttrs = require('./oppaxis_attributes');\nvar helpers = require('./helpers');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'rangeslider',\n\n schema: {\n subplots: {\n xaxis: {\n rangeslider: Lib.extendFlat({}, attrs, {\n yaxis: oppAxisAttrs\n })\n }\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n calcAutorange: require('./calc_autorange'),\n draw: require('./draw'),\n isVisible: helpers.isVisible,\n makeData: helpers.makeData,\n autoMarginOpts: helpers.autoMarginOpts\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar id2name = require('./axis_ids').id2name;\nvar scaleZoom = require('./scale_zoom');\nvar makePadFn = require('./autorange').makePadFn;\nvar concatExtremes = require('./autorange').concatExtremes;\n\nvar ALMOST_EQUAL = require('../../constants/numerical').ALMOST_EQUAL;\nvar FROM_BL = require('../../constants/alignment').FROM_BL;\n\nexports.handleConstraintDefaults = function(containerIn, containerOut, coerce, opts) {\n var allAxisIds = opts.allAxisIds;\n var layoutOut = opts.layoutOut;\n var scaleanchorDflt = opts.scaleanchorDflt;\n var constrainDflt = opts.constrainDflt;\n var constraintGroups = layoutOut._axisConstraintGroups;\n var matchGroups = layoutOut._axisMatchGroups;\n var axId = containerOut._id;\n var axLetter = axId.charAt(0);\n var splomStash = ((layoutOut._splomAxes || {})[axLetter] || {})[axId] || {};\n var thisID = containerOut._id;\n var letter = thisID.charAt(0);\n\n // coerce the constraint mechanics even if this axis has no scaleanchor\n // because it may be the anchor of another axis.\n var constrain = coerce('constrain', constrainDflt);\n Lib.coerce(containerIn, containerOut, {\n constraintoward: {\n valType: 'enumerated',\n values: letter === 'x' ? ['left', 'center', 'right'] : ['bottom', 'middle', 'top'],\n dflt: letter === 'x' ? 'center' : 'middle'\n }\n }, 'constraintoward');\n\n var matches, matchOpts;\n\n if((containerIn.matches || splomStash.matches) && !containerOut.fixedrange) {\n matchOpts = getConstraintOpts(matchGroups, thisID, allAxisIds, layoutOut);\n matches = Lib.coerce(containerIn, containerOut, {\n matches: {\n valType: 'enumerated',\n values: matchOpts.linkableAxes || [],\n dflt: splomStash.matches\n }\n }, 'matches');\n }\n\n // 'matches' wins over 'scaleanchor' (for now)\n var scaleanchor, scaleOpts;\n\n if(!matches &&\n !(containerOut.fixedrange && constrain !== 'domain') &&\n (containerIn.scaleanchor || scaleanchorDflt)\n ) {\n scaleOpts = getConstraintOpts(constraintGroups, thisID, allAxisIds, layoutOut, constrain);\n scaleanchor = Lib.coerce(containerIn, containerOut, {\n scaleanchor: {\n valType: 'enumerated',\n values: scaleOpts.linkableAxes || []\n }\n }, 'scaleanchor', scaleanchorDflt);\n }\n\n if(matches) {\n delete containerOut.constrain;\n updateConstraintGroups(matchGroups, matchOpts.thisGroup, thisID, matches, 1);\n } else if(allAxisIds.indexOf(containerIn.matches) !== -1) {\n Lib.warn('ignored ' + containerOut._name + '.matches: \"' +\n containerIn.matches + '\" to avoid either an infinite loop ' +\n 'or because the target axis has fixed range.');\n }\n\n if(scaleanchor) {\n var scaleratio = coerce('scaleratio');\n\n // TODO: I suppose I could do attribute.min: Number.MIN_VALUE to avoid zero,\n // but that seems hacky. Better way to say \"must be a positive number\"?\n // Of course if you use several super-tiny values you could eventually\n // force a product of these to zero and all hell would break loose...\n // Likewise with super-huge values.\n if(!scaleratio) scaleratio = containerOut.scaleratio = 1;\n\n updateConstraintGroups(constraintGroups, scaleOpts.thisGroup, thisID, scaleanchor, scaleratio);\n } else if(allAxisIds.indexOf(containerIn.scaleanchor) !== -1) {\n Lib.warn('ignored ' + containerOut._name + '.scaleanchor: \"' +\n containerIn.scaleanchor + '\" to avoid either an infinite loop ' +\n 'and possibly inconsistent scaleratios, or because the target ' +\n 'axis has fixed range or this axis declares a *matches* constraint.');\n }\n};\n\n// If this axis is already part of a constraint group, we can't\n// scaleanchor any other axis in that group, or we'd make a loop.\n// Filter allAxisIds to enforce this, also matching axis types.\nfunction getConstraintOpts(groups, thisID, allAxisIds, layoutOut, constrain) {\n var doesNotConstrainRange = constrain !== 'range';\n var thisType = layoutOut[id2name(thisID)].type;\n var i, j, idj, axj;\n\n var linkableAxes = [];\n for(j = 0; j < allAxisIds.length; j++) {\n idj = allAxisIds[j];\n if(idj === thisID) continue;\n\n axj = layoutOut[id2name(idj)];\n if(axj.type === thisType) {\n if(!axj.fixedrange) {\n linkableAxes.push(idj);\n } else if(doesNotConstrainRange && axj.anchor) {\n // allow domain constraints on subplots where\n // BOTH axes have fixedrange:true and constrain:domain\n var counterAxj = layoutOut[id2name(axj.anchor)];\n if(counterAxj.fixedrange) {\n linkableAxes.push(idj);\n }\n }\n }\n }\n\n for(i = 0; i < groups.length; i++) {\n if(groups[i][thisID]) {\n var thisGroup = groups[i];\n\n var linkableAxesNoLoops = [];\n for(j = 0; j < linkableAxes.length; j++) {\n idj = linkableAxes[j];\n if(!thisGroup[idj]) linkableAxesNoLoops.push(idj);\n }\n return {linkableAxes: linkableAxesNoLoops, thisGroup: thisGroup};\n }\n }\n\n return {linkableAxes: linkableAxes, thisGroup: null};\n}\n\n/*\n * Add this axis to the axis constraint groups, which is the collection\n * of axes that are all constrained together on scale.\n *\n * constraintGroups: a list of objects. each object is\n * {axis_id: scale_within_group}, where scale_within_group is\n * only important relative to the rest of the group, and defines\n * the relative scales between all axes in the group\n *\n * thisGroup: the group the current axis is already in\n * thisID: the id if the current axis\n * scaleanchor: the id of the axis to scale it with\n * scaleratio: the ratio of this axis to the scaleanchor axis\n */\nfunction updateConstraintGroups(constraintGroups, thisGroup, thisID, scaleanchor, scaleratio) {\n var i, j, groupi, keyj, thisGroupIndex;\n\n if(thisGroup === null) {\n thisGroup = {};\n thisGroup[thisID] = 1;\n thisGroupIndex = constraintGroups.length;\n constraintGroups.push(thisGroup);\n } else {\n thisGroupIndex = constraintGroups.indexOf(thisGroup);\n }\n\n var thisGroupKeys = Object.keys(thisGroup);\n\n // we know that this axis isn't in any other groups, but we don't know\n // about the scaleanchor axis. If it is, we need to merge the groups.\n for(i = 0; i < constraintGroups.length; i++) {\n groupi = constraintGroups[i];\n if(i !== thisGroupIndex && groupi[scaleanchor]) {\n var baseScale = groupi[scaleanchor];\n for(j = 0; j < thisGroupKeys.length; j++) {\n keyj = thisGroupKeys[j];\n groupi[keyj] = baseScale * scaleratio * thisGroup[keyj];\n }\n constraintGroups.splice(thisGroupIndex, 1);\n return;\n }\n }\n\n // otherwise, we insert the new scaleanchor axis as the base scale (1)\n // in its group, and scale the rest of the group to it\n if(scaleratio !== 1) {\n for(j = 0; j < thisGroupKeys.length; j++) {\n thisGroup[thisGroupKeys[j]] *= scaleratio;\n }\n }\n thisGroup[scaleanchor] = 1;\n}\n\nexports.enforce = function enforce(gd) {\n var fullLayout = gd._fullLayout;\n var constraintGroups = fullLayout._axisConstraintGroups || [];\n\n var i, j, axisID, ax, normScale, mode, factor;\n\n for(i = 0; i < constraintGroups.length; i++) {\n var group = constraintGroups[i];\n var axisIDs = Object.keys(group);\n\n var minScale = Infinity;\n var maxScale = 0;\n // mostly matchScale will be the same as minScale\n // ie we expand axis ranges to encompass *everything*\n // that's currently in any of their ranges, but during\n // autorange of a subset of axes we will ignore other\n // axes for this purpose.\n var matchScale = Infinity;\n var normScales = {};\n var axes = {};\n var hasAnyDomainConstraint = false;\n\n // find the (normalized) scale of each axis in the group\n for(j = 0; j < axisIDs.length; j++) {\n axisID = axisIDs[j];\n axes[axisID] = ax = fullLayout[id2name(axisID)];\n\n if(ax._inputDomain) ax.domain = ax._inputDomain.slice();\n else ax._inputDomain = ax.domain.slice();\n\n if(!ax._inputRange) ax._inputRange = ax.range.slice();\n\n // set axis scale here so we can use _m rather than\n // having to calculate it from length and range\n ax.setScale();\n\n // abs: inverted scales still satisfy the constraint\n normScales[axisID] = normScale = Math.abs(ax._m) / group[axisID];\n minScale = Math.min(minScale, normScale);\n if(ax.constrain === 'domain' || !ax._constraintShrinkable) {\n matchScale = Math.min(matchScale, normScale);\n }\n\n // this has served its purpose, so remove it\n delete ax._constraintShrinkable;\n maxScale = Math.max(maxScale, normScale);\n\n if(ax.constrain === 'domain') hasAnyDomainConstraint = true;\n }\n\n // Do we have a constraint mismatch? Give a small buffer for rounding errors\n if(minScale > ALMOST_EQUAL * maxScale && !hasAnyDomainConstraint) continue;\n\n // now increase any ranges we need to until all normalized scales are equal\n for(j = 0; j < axisIDs.length; j++) {\n axisID = axisIDs[j];\n normScale = normScales[axisID];\n ax = axes[axisID];\n mode = ax.constrain;\n\n // even if the scale didn't change, if we're shrinking domain\n // we need to recalculate in case `constraintoward` changed\n if(normScale !== matchScale || mode === 'domain') {\n factor = normScale / matchScale;\n\n if(mode === 'range') {\n scaleZoom(ax, factor);\n } else {\n // mode === 'domain'\n\n var inputDomain = ax._inputDomain;\n var domainShrunk = (ax.domain[1] - ax.domain[0]) /\n (inputDomain[1] - inputDomain[0]);\n var rangeShrunk = (ax.r2l(ax.range[1]) - ax.r2l(ax.range[0])) /\n (ax.r2l(ax._inputRange[1]) - ax.r2l(ax._inputRange[0]));\n\n factor /= domainShrunk;\n\n if(factor * rangeShrunk < 1) {\n // we've asked to magnify the axis more than we can just by\n // enlarging the domain - so we need to constrict range\n ax.domain = ax._input.domain = inputDomain.slice();\n scaleZoom(ax, factor);\n continue;\n }\n\n if(rangeShrunk < 1) {\n // the range has previously been constricted by ^^, but we've\n // switched to the domain-constricted regime, so reset range\n ax.range = ax._input.range = ax._inputRange.slice();\n factor *= rangeShrunk;\n }\n\n if(ax.autorange) {\n /*\n * range & factor may need to change because range was\n * calculated for the larger scaling, so some pixel\n * paddings may get cut off when we reduce the domain.\n *\n * This is easier than the regular autorange calculation\n * because we already know the scaling `m`, but we still\n * need to cut out impossible constraints (like\n * annotations with super-long arrows). That's what\n * outerMin/Max are for - if the expansion was going to\n * go beyond the original domain, it must be impossible\n */\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n var rangeCenter = (rl0 + rl1) / 2;\n var rangeMin = rangeCenter;\n var rangeMax = rangeCenter;\n var halfRange = Math.abs(rl1 - rangeCenter);\n // extra tiny bit for rounding errors, in case we actually\n // *are* expanding to the full domain\n var outerMin = rangeCenter - halfRange * factor * 1.0001;\n var outerMax = rangeCenter + halfRange * factor * 1.0001;\n var getPad = makePadFn(ax);\n\n updateDomain(ax, factor);\n var m = Math.abs(ax._m);\n var extremes = concatExtremes(gd, ax);\n var minArray = extremes.min;\n var maxArray = extremes.max;\n var newVal;\n var k;\n\n for(k = 0; k < minArray.length; k++) {\n newVal = minArray[k].val - getPad(minArray[k]) / m;\n if(newVal > outerMin && newVal < rangeMin) {\n rangeMin = newVal;\n }\n }\n\n for(k = 0; k < maxArray.length; k++) {\n newVal = maxArray[k].val + getPad(maxArray[k]) / m;\n if(newVal < outerMax && newVal > rangeMax) {\n rangeMax = newVal;\n }\n }\n\n var domainExpand = (rangeMax - rangeMin) / (2 * halfRange);\n factor /= domainExpand;\n\n rangeMin = ax.l2r(rangeMin);\n rangeMax = ax.l2r(rangeMax);\n ax.range = ax._input.range = (rl0 < rl1) ?\n [rangeMin, rangeMax] : [rangeMax, rangeMin];\n }\n\n updateDomain(ax, factor);\n }\n }\n }\n }\n};\n\n// For use before autoranging, check if this axis was previously constrained\n// by domain but no longer is\nexports.clean = function clean(gd, ax) {\n if(ax._inputDomain) {\n var isConstrained = false;\n var axId = ax._id;\n var constraintGroups = gd._fullLayout._axisConstraintGroups;\n for(var j = 0; j < constraintGroups.length; j++) {\n if(constraintGroups[j][axId]) {\n isConstrained = true;\n break;\n }\n }\n if(!isConstrained || ax.constrain !== 'domain') {\n ax._input.domain = ax.domain = ax._inputDomain;\n delete ax._inputDomain;\n }\n }\n};\n\nfunction updateDomain(ax, factor) {\n var inputDomain = ax._inputDomain;\n var centerFraction = FROM_BL[ax.constraintoward];\n var center = inputDomain[0] + (inputDomain[1] - inputDomain[0]) * centerFraction;\n\n ax.domain = ax._input.domain = [\n center + (inputDomain[0] - center) / factor,\n center + (inputDomain[1] - center) / factor\n ];\n ax.setScale();\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n/* eslint-disable new-cap */\n\n'use strict';\n\nvar d3 = require('d3');\nvar Lib = require('../../../lib');\nvar Color = require('../../../components/color');\n\nvar micropolar = require('./micropolar');\nvar UndoManager = require('./undo_manager');\nvar extendDeepAll = Lib.extendDeepAll;\n\nvar manager = module.exports = {};\n\nmanager.framework = function(_gd) {\n var config, previousConfigClone, plot, convertedInput, container;\n var undoManager = new UndoManager();\n\n function exports(_inputConfig, _container) {\n if(_container) container = _container;\n d3.select(d3.select(container).node().parentNode).selectAll('.svg-container>*:not(.chart-root)').remove();\n\n config = (!config) ?\n _inputConfig :\n extendDeepAll(config, _inputConfig);\n\n if(!plot) plot = micropolar.Axis();\n convertedInput = micropolar.adapter.plotly().convert(config);\n plot.config(convertedInput).render(container);\n _gd.data = config.data;\n _gd.layout = config.layout;\n manager.fillLayout(_gd);\n return config;\n }\n exports.isPolar = true;\n exports.svg = function() { return plot.svg(); };\n exports.getConfig = function() { return config; };\n exports.getLiveConfig = function() {\n return micropolar.adapter.plotly().convert(plot.getLiveConfig(), true);\n };\n exports.getLiveScales = function() { return {t: plot.angularScale(), r: plot.radialScale()}; };\n exports.setUndoPoint = function() {\n var that = this;\n var configClone = micropolar.util.cloneJson(config);\n (function(_configClone, _previousConfigClone) {\n undoManager.add({\n undo: function() {\n if(_previousConfigClone) that(_previousConfigClone);\n },\n redo: function() {\n that(_configClone);\n }\n });\n })(configClone, previousConfigClone);\n previousConfigClone = micropolar.util.cloneJson(configClone);\n };\n exports.undo = function() { undoManager.undo(); };\n exports.redo = function() { undoManager.redo(); };\n return exports;\n};\n\nmanager.fillLayout = function(_gd) {\n var container = d3.select(_gd).selectAll('.plot-container');\n var paperDiv = container.selectAll('.svg-container');\n var paper = _gd.framework && _gd.framework.svg && _gd.framework.svg();\n var dflts = {\n width: 800,\n height: 600,\n paper_bgcolor: Color.background,\n _container: container,\n _paperdiv: paperDiv,\n _paper: paper\n };\n\n _gd._fullLayout = extendDeepAll(dflts, _gd.layout);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar name = 'images';\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n var opts = {\n name: name,\n handleItemDefaults: imageDefaults\n };\n\n handleArrayContainerDefaults(layoutIn, layoutOut, opts);\n};\n\n\nfunction imageDefaults(imageIn, imageOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(imageIn, imageOut, attributes, attr, dflt);\n }\n\n var source = coerce('source');\n var visible = coerce('visible', !!source);\n\n if(!visible) return imageOut;\n\n coerce('layer');\n coerce('xanchor');\n coerce('yanchor');\n coerce('sizex');\n coerce('sizey');\n coerce('sizing');\n coerce('opacity');\n\n var gdMock = { _fullLayout: fullLayout };\n var axLetters = ['x', 'y'];\n\n for(var i = 0; i < 2; i++) {\n // 'paper' is the fallback axref\n var axLetter = axLetters[i];\n var axRef = Axes.coerceRef(imageIn, imageOut, gdMock, axLetter, 'paper');\n\n if(axRef !== 'paper') {\n var ax = Axes.getFromId(gdMock, axRef);\n ax._imgIndices.push(imageOut._index);\n }\n\n Axes.coercePosition(imageOut, gdMock, coerce, axRef, axLetter, 0);\n }\n\n return imageOut;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar tinycolor = require('tinycolor2');\nvar supportsPassive = require('has-passive-events');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Fx = require('../../components/fx');\nvar Axes = require('./axes');\nvar setCursor = require('../../lib/setcursor');\nvar dragElement = require('../../components/dragelement');\nvar FROM_TL = require('../../constants/alignment').FROM_TL;\nvar clearGlCanvases = require('../../lib/clear_gl_canvases');\nvar redrawReglTraces = require('../../plot_api/subroutines').redrawReglTraces;\n\nvar Plots = require('../plots');\n\nvar getFromId = require('./axis_ids').getFromId;\nvar prepSelect = require('./select').prepSelect;\nvar clearSelect = require('./select').clearSelect;\nvar selectOnClick = require('./select').selectOnClick;\nvar scaleZoom = require('./scale_zoom');\n\nvar constants = require('./constants');\nvar MINDRAG = constants.MINDRAG;\nvar MINZOOM = constants.MINZOOM;\n\n// flag for showing \"doubleclick to zoom out\" only at the beginning\nvar SHOWZOOMOUTTIP = true;\n\n// dragBox: create an element to drag one or more axis ends\n// inputs:\n// plotinfo - which subplot are we making dragboxes on?\n// x,y,w,h - left, top, width, height of the box\n// ns - how does this drag the vertical axis?\n// 'n' - top only\n// 's' - bottom only\n// 'ns' - top and bottom together, difference unchanged\n// ew - same for horizontal axis\nfunction makeDragBox(gd, plotinfo, x, y, w, h, ns, ew) {\n // mouseDown stores ms of first mousedown event in the last\n // `gd._context.doubleClickDelay` ms on the drag bars\n // numClicks stores how many mousedowns have been seen\n // within `gd._context.doubleClickDelay` so we can check for click or doubleclick events\n // dragged stores whether a drag has occurred, so we don't have to\n // redraw unnecessarily, ie if no move bigger than MINDRAG or MINZOOM px\n var zoomlayer = gd._fullLayout._zoomlayer;\n var isMainDrag = (ns + ew === 'nsew');\n var singleEnd = (ns + ew).length === 1;\n\n // main subplot x and y (i.e. found in plotinfo - the main ones)\n var xa0, ya0;\n // {ax._id: ax} hash objects\n var xaHash, yaHash;\n // xaHash/yaHash values (arrays)\n var xaxes, yaxes;\n // main axis offsets\n var xs, ys;\n // main axis lengths\n var pw, ph;\n // contains keys 'xaHash', 'yaHash', 'xaxes', and 'yaxes'\n // which are the x/y {ax._id: ax} hash objects and their values\n // for linked axis relative to this subplot\n var links;\n // similar to `links` but for matching axes\n var matches;\n // set to ew/ns val when active, set to '' when inactive\n var xActive, yActive;\n // are all axes in this subplot are fixed?\n var allFixedRanges;\n // do we need to edit x/y ranges?\n var editX, editY;\n // graph-wide optimization flags\n var hasScatterGl, hasSplom, hasSVG;\n // collected changes to be made to the plot by relayout at the end\n var updates;\n\n function recomputeAxisLists() {\n xa0 = plotinfo.xaxis;\n ya0 = plotinfo.yaxis;\n pw = xa0._length;\n ph = ya0._length;\n xs = xa0._offset;\n ys = ya0._offset;\n\n xaHash = {};\n xaHash[xa0._id] = xa0;\n yaHash = {};\n yaHash[ya0._id] = ya0;\n\n // if we're dragging two axes at once, also drag overlays\n if(ns && ew) {\n var overlays = plotinfo.overlays;\n for(var i = 0; i < overlays.length; i++) {\n var xa = overlays[i].xaxis;\n xaHash[xa._id] = xa;\n var ya = overlays[i].yaxis;\n yaHash[ya._id] = ya;\n }\n }\n\n xaxes = hashValues(xaHash);\n yaxes = hashValues(yaHash);\n xActive = isDirectionActive(xaxes, ew);\n yActive = isDirectionActive(yaxes, ns);\n allFixedRanges = !yActive && !xActive;\n\n links = calcLinks(gd, gd._fullLayout._axisConstraintGroups, xaHash, yaHash);\n matches = calcLinks(gd, gd._fullLayout._axisMatchGroups, xaHash, yaHash);\n editX = ew || links.isSubplotConstrained || matches.isSubplotConstrained;\n editY = ns || links.isSubplotConstrained || matches.isSubplotConstrained;\n\n var fullLayout = gd._fullLayout;\n hasScatterGl = fullLayout._has('scattergl');\n hasSplom = fullLayout._has('splom');\n hasSVG = fullLayout._has('svg');\n }\n\n recomputeAxisLists();\n\n var cursor = getDragCursor(yActive + xActive, gd._fullLayout.dragmode, isMainDrag);\n var dragger = makeRectDragger(plotinfo, ns + ew + 'drag', cursor, x, y, w, h);\n\n // still need to make the element if the axes are disabled\n // but nuke its events (except for maindrag which needs them for hover)\n // and stop there\n if(allFixedRanges && !isMainDrag) {\n dragger.onmousedown = null;\n dragger.style.pointerEvents = 'none';\n return dragger;\n }\n\n var dragOptions = {\n element: dragger,\n gd: gd,\n plotinfo: plotinfo\n };\n\n dragOptions.prepFn = function(e, startX, startY) {\n var dragModePrev = dragOptions.dragmode;\n var dragModeNow = gd._fullLayout.dragmode;\n if(dragModeNow !== dragModePrev) {\n dragOptions.dragmode = dragModeNow;\n }\n\n recomputeAxisLists();\n\n if(!allFixedRanges) {\n if(isMainDrag) {\n // main dragger handles all drag modes, and changes\n // to pan (or to zoom if it already is pan) on shift\n if(e.shiftKey) {\n if(dragModeNow === 'pan') dragModeNow = 'zoom';\n else if(!isSelectOrLasso(dragModeNow)) dragModeNow = 'pan';\n } else if(e.ctrlKey) {\n dragModeNow = 'pan';\n }\n } else {\n // all other draggers just pan\n dragModeNow = 'pan';\n }\n }\n\n if(dragModeNow === 'lasso') dragOptions.minDrag = 1;\n else dragOptions.minDrag = undefined;\n\n if(isSelectOrLasso(dragModeNow)) {\n dragOptions.xaxes = xaxes;\n dragOptions.yaxes = yaxes;\n // this attaches moveFn, clickFn, doneFn on dragOptions\n prepSelect(e, startX, startY, dragOptions, dragModeNow);\n } else {\n dragOptions.clickFn = clickFn;\n if(isSelectOrLasso(dragModePrev)) {\n // TODO Fix potential bug\n // Note: clearing / resetting selection state only happens, when user\n // triggers at least one interaction in pan/zoom mode. Otherwise, the\n // select/lasso outlines are deleted (in plots.js.cleanPlot) but the selection\n // cache isn't cleared. So when the user switches back to select/lasso and\n // 'adds to a selection' with Shift, the \"old\", seemingly removed outlines\n // are redrawn again because the selection cache still holds their coordinates.\n // However, this isn't easily solved, since plots.js would need\n // to have a reference to the dragOptions object (which holds the\n // selection cache).\n clearAndResetSelect();\n }\n\n if(!allFixedRanges) {\n if(dragModeNow === 'zoom') {\n dragOptions.moveFn = zoomMove;\n dragOptions.doneFn = zoomDone;\n\n // zoomMove takes care of the threshold, but we need to\n // minimize this so that constrained zoom boxes will flip\n // orientation at the right place\n dragOptions.minDrag = 1;\n\n zoomPrep(e, startX, startY);\n } else if(dragModeNow === 'pan') {\n dragOptions.moveFn = plotDrag;\n dragOptions.doneFn = dragTail;\n }\n }\n }\n\n gd._fullLayout._redrag = function() {\n var dragDataNow = gd._dragdata;\n\n if(dragDataNow && dragDataNow.element === dragger) {\n var dragModeNow = gd._fullLayout.dragmode;\n\n if(!isSelectOrLasso(dragModeNow)) {\n recomputeAxisLists();\n updateSubplots([0, 0, pw, ph]);\n dragOptions.moveFn(dragDataNow.dx, dragDataNow.dy);\n }\n\n // TODO should we try to \"re-select\" under select/lasso modes?\n // probably best to wait for https://github.com/plotly/plotly.js/issues/1851\n }\n };\n };\n\n function clearAndResetSelect() {\n // clear selection polygon cache (if any)\n dragOptions.plotinfo.selection = false;\n // clear selection outlines\n clearSelect(gd);\n }\n\n function clickFn(numClicks, evt) {\n var clickmode = gd._fullLayout.clickmode;\n\n removeZoombox(gd);\n\n if(numClicks === 2 && !singleEnd) doubleClick();\n\n if(isMainDrag) {\n if(clickmode.indexOf('select') > -1) {\n selectOnClick(evt, gd, xaxes, yaxes, plotinfo.id, dragOptions);\n }\n\n if(clickmode.indexOf('event') > -1) {\n Fx.click(gd, evt, plotinfo.id);\n }\n } else if(numClicks === 1 && singleEnd) {\n var ax = ns ? ya0 : xa0;\n var end = (ns === 's' || ew === 'w') ? 0 : 1;\n var attrStr = ax._name + '.range[' + end + ']';\n var initialText = getEndText(ax, end);\n var hAlign = 'left';\n var vAlign = 'middle';\n\n if(ax.fixedrange) return;\n\n if(ns) {\n vAlign = (ns === 'n') ? 'top' : 'bottom';\n if(ax.side === 'right') hAlign = 'right';\n } else if(ew === 'e') hAlign = 'right';\n\n if(gd._context.showAxisRangeEntryBoxes) {\n d3.select(dragger)\n .call(svgTextUtils.makeEditable, {\n gd: gd,\n immediate: true,\n background: gd._fullLayout.paper_bgcolor,\n text: String(initialText),\n fill: ax.tickfont ? ax.tickfont.color : '#444',\n horizontalAlign: hAlign,\n verticalAlign: vAlign\n })\n .on('edit', function(text) {\n var v = ax.d2r(text);\n if(v !== undefined) {\n Registry.call('_guiRelayout', gd, attrStr, v);\n }\n });\n }\n }\n }\n\n dragElement.init(dragOptions);\n\n // x/y px position at start of drag\n var x0, y0;\n // bbox object of the zoombox\n var box;\n // luminance of bg behind zoombox\n var lum;\n // zoombox path outline\n var path0;\n // is zoombox dimmed (during drag)\n var dimmed;\n // 'x'-only, 'y' or 'xy' zooming\n var zoomMode;\n // zoombox d3 selection\n var zb;\n // zoombox corner d3 selection\n var corners;\n // zoom takes over minDrag, so it also has to take over gd._dragged\n var zoomDragged;\n\n function zoomPrep(e, startX, startY) {\n var dragBBox = dragger.getBoundingClientRect();\n x0 = startX - dragBBox.left;\n y0 = startY - dragBBox.top;\n box = {l: x0, r: x0, w: 0, t: y0, b: y0, h: 0};\n lum = gd._hmpixcount ?\n (gd._hmlumcount / gd._hmpixcount) :\n tinycolor(gd._fullLayout.plot_bgcolor).getLuminance();\n path0 = 'M0,0H' + pw + 'V' + ph + 'H0V0';\n dimmed = false;\n zoomMode = 'xy';\n zoomDragged = false;\n zb = makeZoombox(zoomlayer, lum, xs, ys, path0);\n corners = makeCorners(zoomlayer, xs, ys);\n }\n\n function zoomMove(dx0, dy0) {\n if(gd._transitioningWithDuration) {\n return false;\n }\n\n var x1 = Math.max(0, Math.min(pw, dx0 + x0));\n var y1 = Math.max(0, Math.min(ph, dy0 + y0));\n var dx = Math.abs(x1 - x0);\n var dy = Math.abs(y1 - y0);\n\n box.l = Math.min(x0, x1);\n box.r = Math.max(x0, x1);\n box.t = Math.min(y0, y1);\n box.b = Math.max(y0, y1);\n\n function noZoom() {\n zoomMode = '';\n box.r = box.l;\n box.t = box.b;\n corners.attr('d', 'M0,0Z');\n }\n\n if(links.isSubplotConstrained) {\n if(dx > MINZOOM || dy > MINZOOM) {\n zoomMode = 'xy';\n if(dx / pw > dy / ph) {\n dy = dx * ph / pw;\n if(y0 > y1) box.t = y0 - dy;\n else box.b = y0 + dy;\n } else {\n dx = dy * pw / ph;\n if(x0 > x1) box.l = x0 - dx;\n else box.r = x0 + dx;\n }\n corners.attr('d', xyCorners(box));\n } else {\n noZoom();\n }\n } else if(matches.isSubplotConstrained) {\n if(dx > MINZOOM || dy > MINZOOM) {\n zoomMode = 'xy';\n\n var r0 = Math.min(box.l / pw, (ph - box.b) / ph);\n var r1 = Math.max(box.r / pw, (ph - box.t) / ph);\n\n box.l = r0 * pw;\n box.r = r1 * pw;\n box.b = (1 - r0) * ph;\n box.t = (1 - r1) * ph;\n corners.attr('d', xyCorners(box));\n } else {\n noZoom();\n }\n } else if(!yActive || dy < Math.min(Math.max(dx * 0.6, MINDRAG), MINZOOM)) {\n // look for small drags in one direction or the other,\n // and only drag the other axis\n\n if(dx < MINDRAG || !xActive) {\n noZoom();\n } else {\n box.t = 0;\n box.b = ph;\n zoomMode = 'x';\n corners.attr('d', xCorners(box, y0));\n }\n } else if(!xActive || dx < Math.min(dy * 0.6, MINZOOM)) {\n box.l = 0;\n box.r = pw;\n zoomMode = 'y';\n corners.attr('d', yCorners(box, x0));\n } else {\n zoomMode = 'xy';\n corners.attr('d', xyCorners(box));\n }\n box.w = box.r - box.l;\n box.h = box.b - box.t;\n\n if(zoomMode) zoomDragged = true;\n gd._dragged = zoomDragged;\n\n updateZoombox(zb, corners, box, path0, dimmed, lum);\n computeZoomUpdates();\n gd.emit('plotly_relayouting', updates);\n dimmed = true;\n }\n\n function computeZoomUpdates() {\n updates = {};\n\n // TODO: edit linked axes in zoomAxRanges and in dragTail\n if(zoomMode === 'xy' || zoomMode === 'x') {\n zoomAxRanges(xaxes, box.l / pw, box.r / pw, updates, links.xaxes);\n updateMatchedAxRange('x', updates);\n }\n if(zoomMode === 'xy' || zoomMode === 'y') {\n zoomAxRanges(yaxes, (ph - box.b) / ph, (ph - box.t) / ph, updates, links.yaxes);\n updateMatchedAxRange('y', updates);\n }\n }\n\n function zoomDone() {\n computeZoomUpdates();\n removeZoombox(gd);\n dragTail();\n showDoubleClickNotifier(gd);\n }\n\n // scroll zoom, on all draggers except corners\n var scrollViewBox = [0, 0, pw, ph];\n // wait a little after scrolling before redrawing\n var redrawTimer = null;\n var REDRAWDELAY = constants.REDRAWDELAY;\n var mainplot = plotinfo.mainplot ? gd._fullLayout._plots[plotinfo.mainplot] : plotinfo;\n\n function zoomWheel(e) {\n // deactivate mousewheel scrolling on embedded graphs\n // devs can override this with layout._enablescrollzoom,\n // but _ ensures this setting won't leave their page\n if(!gd._context._scrollZoom.cartesian && !gd._fullLayout._enablescrollzoom) {\n return;\n }\n\n clearAndResetSelect();\n\n // If a transition is in progress, then disable any behavior:\n if(gd._transitioningWithDuration) {\n e.preventDefault();\n e.stopPropagation();\n return;\n }\n\n recomputeAxisLists();\n\n clearTimeout(redrawTimer);\n\n var wheelDelta = -e.deltaY;\n if(!isFinite(wheelDelta)) wheelDelta = e.wheelDelta / 10;\n if(!isFinite(wheelDelta)) {\n Lib.log('Did not find wheel motion attributes: ', e);\n return;\n }\n\n var zoom = Math.exp(-Math.min(Math.max(wheelDelta, -20), 20) / 200);\n var gbb = mainplot.draglayer.select('.nsewdrag').node().getBoundingClientRect();\n var xfrac = (e.clientX - gbb.left) / gbb.width;\n var yfrac = (gbb.bottom - e.clientY) / gbb.height;\n var i;\n\n function zoomWheelOneAxis(ax, centerFraction, zoom) {\n if(ax.fixedrange) return;\n\n var axRange = Lib.simpleMap(ax.range, ax.r2l);\n var v0 = axRange[0] + (axRange[1] - axRange[0]) * centerFraction;\n function doZoom(v) { return ax.l2r(v0 + (v - v0) * zoom); }\n ax.range = axRange.map(doZoom);\n }\n\n if(editX) {\n // if we're only zooming this axis because of constraints,\n // zoom it about the center\n if(!ew) xfrac = 0.5;\n\n for(i = 0; i < xaxes.length; i++) {\n zoomWheelOneAxis(xaxes[i], xfrac, zoom);\n }\n updateMatchedAxRange('x');\n\n scrollViewBox[2] *= zoom;\n scrollViewBox[0] += scrollViewBox[2] * xfrac * (1 / zoom - 1);\n }\n if(editY) {\n if(!ns) yfrac = 0.5;\n\n for(i = 0; i < yaxes.length; i++) {\n zoomWheelOneAxis(yaxes[i], yfrac, zoom);\n }\n updateMatchedAxRange('y');\n\n scrollViewBox[3] *= zoom;\n scrollViewBox[1] += scrollViewBox[3] * (1 - yfrac) * (1 / zoom - 1);\n }\n\n // viewbox redraw at first\n updateSubplots(scrollViewBox);\n ticksAndAnnotations();\n\n gd.emit('plotly_relayouting', updates);\n\n // then replot after a delay to make sure\n // no more scrolling is coming\n redrawTimer = setTimeout(function() {\n scrollViewBox = [0, 0, pw, ph];\n dragTail();\n }, REDRAWDELAY);\n\n e.preventDefault();\n return;\n }\n\n // everything but the corners gets wheel zoom\n if(ns.length * ew.length !== 1) {\n attachWheelEventHandler(dragger, zoomWheel);\n }\n\n // plotDrag: move the plot in response to a drag\n function plotDrag(dx, dy) {\n // If a transition is in progress, then disable any behavior:\n if(gd._transitioningWithDuration) {\n return;\n }\n\n // prevent axis drawing from monkeying with margins until we're done\n gd._fullLayout._replotting = true;\n\n if(xActive === 'ew' || yActive === 'ns') {\n if(xActive) {\n dragAxList(xaxes, dx);\n updateMatchedAxRange('x');\n }\n if(yActive) {\n dragAxList(yaxes, dy);\n updateMatchedAxRange('y');\n }\n updateSubplots([xActive ? -dx : 0, yActive ? -dy : 0, pw, ph]);\n ticksAndAnnotations();\n gd.emit('plotly_relayouting', updates);\n return;\n }\n\n // dz: set a new value for one end (0 or 1) of an axis array axArray,\n // and return a pixel shift for that end for the viewbox\n // based on pixel drag distance d\n // TODO: this makes (generally non-fatal) errors when you get\n // near floating point limits\n function dz(axArray, end, d) {\n var otherEnd = 1 - end;\n var movedAx;\n var newLinearizedEnd;\n for(var i = 0; i < axArray.length; i++) {\n var axi = axArray[i];\n if(axi.fixedrange) continue;\n movedAx = axi;\n newLinearizedEnd = axi._rl[otherEnd] +\n (axi._rl[end] - axi._rl[otherEnd]) / dZoom(d / axi._length);\n var newEnd = axi.l2r(newLinearizedEnd);\n\n // if l2r comes back false or undefined, it means we've dragged off\n // the end of valid ranges - so stop.\n if(newEnd !== false && newEnd !== undefined) axi.range[end] = newEnd;\n }\n return movedAx._length * (movedAx._rl[end] - newLinearizedEnd) /\n (movedAx._rl[end] - movedAx._rl[otherEnd]);\n }\n\n if(links.isSubplotConstrained && xActive && yActive) {\n // dragging a corner of a constrained subplot:\n // respect the fixed corner, but harmonize dx and dy\n var dxySign = ((xActive === 'w') === (yActive === 'n')) ? 1 : -1;\n var dxyFraction = (dx / pw + dxySign * dy / ph) / 2;\n dx = dxyFraction * pw;\n dy = dxySign * dxyFraction * ph;\n }\n\n if(xActive === 'w') dx = dz(xaxes, 0, dx);\n else if(xActive === 'e') dx = dz(xaxes, 1, -dx);\n else if(!xActive) dx = 0;\n\n if(yActive === 'n') dy = dz(yaxes, 1, dy);\n else if(yActive === 's') dy = dz(yaxes, 0, -dy);\n else if(!yActive) dy = 0;\n\n var xStart = (xActive === 'w') ? dx : 0;\n var yStart = (yActive === 'n') ? dy : 0;\n\n if(links.isSubplotConstrained) {\n var i;\n if(!xActive && yActive.length === 1) {\n // dragging one end of the y axis of a constrained subplot\n // scale the other axis the same about its middle\n for(i = 0; i < xaxes.length; i++) {\n xaxes[i].range = xaxes[i]._r.slice();\n scaleZoom(xaxes[i], 1 - dy / ph);\n }\n dx = dy * pw / ph;\n xStart = dx / 2;\n }\n if(!yActive && xActive.length === 1) {\n for(i = 0; i < yaxes.length; i++) {\n yaxes[i].range = yaxes[i]._r.slice();\n scaleZoom(yaxes[i], 1 - dx / pw);\n }\n dy = dx * ph / pw;\n yStart = dy / 2;\n }\n }\n\n updateMatchedAxRange('x');\n updateMatchedAxRange('y');\n updateSubplots([xStart, yStart, pw - dx, ph - dy]);\n ticksAndAnnotations();\n gd.emit('plotly_relayouting', updates);\n }\n\n function updateMatchedAxRange(axLetter, out) {\n var matchedAxes = matches.isSubplotConstrained ?\n {x: yaxes, y: xaxes}[axLetter] :\n matches[axLetter + 'axes'];\n\n var constrainedAxes = matches.isSubplotConstrained ?\n {x: xaxes, y: yaxes}[axLetter] :\n [];\n\n for(var i = 0; i < matchedAxes.length; i++) {\n var ax = matchedAxes[i];\n var axId = ax._id;\n var axId2 = matches.xLinks[axId] || matches.yLinks[axId];\n var ax2 = constrainedAxes[0] || xaHash[axId2] || yaHash[axId2];\n\n if(ax2) {\n if(out) {\n // zoombox case - don't mutate 'range', just add keys in 'updates'\n out[ax._name + '.range[0]'] = out[ax2._name + '.range[0]'];\n out[ax._name + '.range[1]'] = out[ax2._name + '.range[1]'];\n } else {\n ax.range = ax2.range.slice();\n }\n }\n }\n }\n\n // Draw ticks and annotations (and other components) when ranges change.\n // Also records the ranges that have changed for use by update at the end.\n function ticksAndAnnotations() {\n var activeAxIds = [];\n var i;\n\n function pushActiveAxIds(axList) {\n for(i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) activeAxIds.push(axList[i]._id);\n }\n }\n\n if(editX) {\n pushActiveAxIds(xaxes);\n pushActiveAxIds(links.xaxes);\n pushActiveAxIds(matches.xaxes);\n }\n if(editY) {\n pushActiveAxIds(yaxes);\n pushActiveAxIds(links.yaxes);\n pushActiveAxIds(matches.yaxes);\n }\n\n updates = {};\n for(i = 0; i < activeAxIds.length; i++) {\n var axId = activeAxIds[i];\n var ax = getFromId(gd, axId);\n Axes.drawOne(gd, ax, {skipTitle: true});\n updates[ax._name + '.range[0]'] = ax.range[0];\n updates[ax._name + '.range[1]'] = ax.range[1];\n }\n\n Axes.redrawComponents(gd, activeAxIds);\n }\n\n function doubleClick() {\n if(gd._transitioningWithDuration) return;\n\n var doubleClickConfig = gd._context.doubleClick;\n\n var axList = [];\n if(xActive) axList = axList.concat(xaxes);\n if(yActive) axList = axList.concat(yaxes);\n if(matches.xaxes) axList = axList.concat(matches.xaxes);\n if(matches.yaxes) axList = axList.concat(matches.yaxes);\n\n var attrs = {};\n var ax, i, rangeInitial;\n\n // For reset+autosize mode:\n // If *any* of the main axes is not at its initial range\n // (or autoranged, if we have no initial range, to match the logic in\n // doubleClickConfig === 'reset' below), we reset.\n // If they are *all* at their initial ranges, then we autosize.\n if(doubleClickConfig === 'reset+autosize') {\n doubleClickConfig = 'autosize';\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n if((ax._rangeInitial && (\n ax.range[0] !== ax._rangeInitial[0] ||\n ax.range[1] !== ax._rangeInitial[1]\n )) ||\n (!ax._rangeInitial && !ax.autorange)\n ) {\n doubleClickConfig = 'reset';\n break;\n }\n }\n }\n\n if(doubleClickConfig === 'autosize') {\n // don't set the linked axes here, so relayout marks them as shrinkable\n // and we autosize just to the requested axis/axes\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n if(!ax.fixedrange) attrs[ax._name + '.autorange'] = true;\n }\n } else if(doubleClickConfig === 'reset') {\n // when we're resetting, reset all linked axes too, so we get back\n // to the fully-auto-with-constraints situation\n if(xActive || links.isSubplotConstrained) axList = axList.concat(links.xaxes);\n if(yActive && !links.isSubplotConstrained) axList = axList.concat(links.yaxes);\n\n if(links.isSubplotConstrained) {\n if(!xActive) axList = axList.concat(xaxes);\n else if(!yActive) axList = axList.concat(yaxes);\n }\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n if(!ax.fixedrange) {\n if(!ax._rangeInitial) {\n attrs[ax._name + '.autorange'] = true;\n } else {\n rangeInitial = ax._rangeInitial;\n attrs[ax._name + '.range[0]'] = rangeInitial[0];\n attrs[ax._name + '.range[1]'] = rangeInitial[1];\n }\n }\n }\n }\n\n gd.emit('plotly_doubleclick', null);\n Registry.call('_guiRelayout', gd, attrs);\n }\n\n // dragTail - finish a drag event with a redraw\n function dragTail() {\n // put the subplot viewboxes back to default (Because we're going to)\n // be repositioning the data in the relayout. But DON'T call\n // ticksAndAnnotations again - it's unnecessary and would overwrite `updates`\n updateSubplots([0, 0, pw, ph]);\n\n // since we may have been redrawing some things during the drag, we may have\n // accumulated MathJax promises - wait for them before we relayout.\n Lib.syncOrAsync([\n Plots.previousPromises,\n function() {\n gd._fullLayout._replotting = false;\n Registry.call('_guiRelayout', gd, updates);\n }\n ], gd);\n }\n\n // updateSubplots - find all plot viewboxes that should be\n // affected by this drag, and update them. look for all plots\n // sharing an affected axis (including the one being dragged),\n // includes also scattergl and splom logic.\n function updateSubplots(viewBox) {\n var fullLayout = gd._fullLayout;\n var plotinfos = fullLayout._plots;\n var subplots = fullLayout._subplots.cartesian;\n var i, sp, xa, ya;\n\n if(hasSplom) {\n Registry.subplotsRegistry.splom.drag(gd);\n }\n\n if(hasScatterGl) {\n for(i = 0; i < subplots.length; i++) {\n sp = plotinfos[subplots[i]];\n xa = sp.xaxis;\n ya = sp.yaxis;\n\n if(sp._scene) {\n var xrng = Lib.simpleMap(xa.range, xa.r2l);\n var yrng = Lib.simpleMap(ya.range, ya.r2l);\n sp._scene.update({range: [xrng[0], yrng[0], xrng[1], yrng[1]]});\n }\n }\n }\n\n if(hasSplom || hasScatterGl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n\n if(hasSVG) {\n var xScaleFactor = viewBox[2] / xa0._length;\n var yScaleFactor = viewBox[3] / ya0._length;\n\n for(i = 0; i < subplots.length; i++) {\n sp = plotinfos[subplots[i]];\n xa = sp.xaxis;\n ya = sp.yaxis;\n\n var editX2 = editX && !xa.fixedrange && xaHash[xa._id];\n var editY2 = editY && !ya.fixedrange && yaHash[ya._id];\n\n var xScaleFactor2, yScaleFactor2;\n var clipDx, clipDy;\n\n if(editX2) {\n xScaleFactor2 = xScaleFactor;\n clipDx = ew ? viewBox[0] : getShift(xa, xScaleFactor2);\n } else if(matches.xaHash[xa._id]) {\n xScaleFactor2 = xScaleFactor;\n clipDx = viewBox[0] * xa._length / xa0._length;\n } else if(matches.yaHash[xa._id]) {\n xScaleFactor2 = yScaleFactor;\n clipDx = yActive === 'ns' ?\n -viewBox[1] * xa._length / ya0._length :\n getShift(xa, xScaleFactor2, {n: 'top', s: 'bottom'}[yActive]);\n } else {\n xScaleFactor2 = getLinkedScaleFactor(xa, xScaleFactor, yScaleFactor);\n clipDx = scaleAndGetShift(xa, xScaleFactor2);\n }\n\n if(editY2) {\n yScaleFactor2 = yScaleFactor;\n clipDy = ns ? viewBox[1] : getShift(ya, yScaleFactor2);\n } else if(matches.yaHash[ya._id]) {\n yScaleFactor2 = yScaleFactor;\n clipDy = viewBox[1] * ya._length / ya0._length;\n } else if(matches.xaHash[ya._id]) {\n yScaleFactor2 = xScaleFactor;\n clipDy = xActive === 'ew' ?\n -viewBox[0] * ya._length / xa0._length :\n getShift(ya, yScaleFactor2, {e: 'right', w: 'left'}[xActive]);\n } else {\n yScaleFactor2 = getLinkedScaleFactor(ya, xScaleFactor, yScaleFactor);\n clipDy = scaleAndGetShift(ya, yScaleFactor2);\n }\n\n // don't scale at all if neither axis is scalable here\n if(!xScaleFactor2 && !yScaleFactor2) {\n continue;\n }\n\n // but if only one is, reset the other axis scaling\n if(!xScaleFactor2) xScaleFactor2 = 1;\n if(!yScaleFactor2) yScaleFactor2 = 1;\n\n var plotDx = xa._offset - clipDx / xScaleFactor2;\n var plotDy = ya._offset - clipDy / yScaleFactor2;\n\n // TODO could be more efficient here:\n // setTranslate and setScale do a lot of extra work\n // when working independently, should perhaps combine\n // them into a single routine.\n sp.clipRect\n .call(Drawing.setTranslate, clipDx, clipDy)\n .call(Drawing.setScale, xScaleFactor2, yScaleFactor2);\n\n sp.plot\n .call(Drawing.setTranslate, plotDx, plotDy)\n .call(Drawing.setScale, 1 / xScaleFactor2, 1 / yScaleFactor2);\n\n // apply an inverse scale to individual points to counteract\n // the scale of the trace group.\n // apply only when scale changes, as adjusting the scale of\n // all the points can be expansive.\n if(xScaleFactor2 !== sp.xScaleFactor || yScaleFactor2 !== sp.yScaleFactor) {\n Drawing.setPointGroupScale(sp.zoomScalePts, xScaleFactor2, yScaleFactor2);\n Drawing.setTextPointsScale(sp.zoomScaleTxt, xScaleFactor2, yScaleFactor2);\n }\n\n Drawing.hideOutsideRangePoints(sp.clipOnAxisFalseTraces, sp);\n\n // update x/y scaleFactor stash\n sp.xScaleFactor = xScaleFactor2;\n sp.yScaleFactor = yScaleFactor2;\n }\n }\n }\n\n // Find the appropriate scaling for this axis, if it's linked to the\n // dragged axes by constraints. 0 is special, it means this axis shouldn't\n // ever be scaled (will be converted to 1 if the other axis is scaled)\n function getLinkedScaleFactor(ax, xScaleFactor, yScaleFactor) {\n if(ax.fixedrange) return 0;\n\n if(editX && links.xaHash[ax._id]) {\n return xScaleFactor;\n }\n if(editY && (links.isSubplotConstrained ? links.xaHash : links.yaHash)[ax._id]) {\n return yScaleFactor;\n }\n return 0;\n }\n\n function scaleAndGetShift(ax, scaleFactor) {\n if(scaleFactor) {\n ax.range = ax._r.slice();\n scaleZoom(ax, scaleFactor);\n return getShift(ax, scaleFactor);\n }\n return 0;\n }\n\n function getShift(ax, scaleFactor, from) {\n return ax._length * (1 - scaleFactor) * FROM_TL[from || ax.constraintoward || 'middle'];\n }\n\n return dragger;\n}\n\nfunction makeDragger(plotinfo, nodeName, dragClass, cursor) {\n var dragger3 = Lib.ensureSingle(plotinfo.draglayer, nodeName, dragClass, function(s) {\n s.classed('drag', true)\n .style({fill: 'transparent', 'stroke-width': 0})\n .attr('data-subplot', plotinfo.id);\n });\n\n dragger3.call(setCursor, cursor);\n\n return dragger3.node();\n}\n\nfunction makeRectDragger(plotinfo, dragClass, cursor, x, y, w, h) {\n var dragger = makeDragger(plotinfo, 'rect', dragClass, cursor);\n d3.select(dragger).call(Drawing.setRect, x, y, w, h);\n return dragger;\n}\n\nfunction isDirectionActive(axList, activeVal) {\n for(var i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) return activeVal;\n }\n return '';\n}\n\nfunction getEndText(ax, end) {\n var initialVal = ax.range[end];\n var diff = Math.abs(initialVal - ax.range[1 - end]);\n var dig;\n\n // TODO: this should basically be ax.r2d but we're doing extra\n // rounding here... can we clean up at all?\n if(ax.type === 'date') {\n return initialVal;\n } else if(ax.type === 'log') {\n dig = Math.ceil(Math.max(0, -Math.log(diff) / Math.LN10)) + 3;\n return d3.format('.' + dig + 'g')(Math.pow(10, initialVal));\n } else { // linear numeric (or category... but just show numbers here)\n dig = Math.floor(Math.log(Math.abs(initialVal)) / Math.LN10) -\n Math.floor(Math.log(diff) / Math.LN10) + 4;\n return d3.format('.' + String(dig) + 'g')(initialVal);\n }\n}\n\nfunction zoomAxRanges(axList, r0Fraction, r1Fraction, updates, linkedAxes) {\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(axi.fixedrange) continue;\n\n if(axi.rangebreaks) {\n var isY = axi._id.charAt(0) === 'y';\n var r0F = isY ? (1 - r0Fraction) : r0Fraction;\n var r1F = isY ? (1 - r1Fraction) : r1Fraction;\n\n updates[axi._name + '.range[0]'] = axi.l2r(axi.p2l(r0F * axi._length));\n updates[axi._name + '.range[1]'] = axi.l2r(axi.p2l(r1F * axi._length));\n } else {\n var axRangeLinear0 = axi._rl[0];\n var axRangeLinearSpan = axi._rl[1] - axRangeLinear0;\n updates[axi._name + '.range[0]'] = axi.l2r(axRangeLinear0 + axRangeLinearSpan * r0Fraction);\n updates[axi._name + '.range[1]'] = axi.l2r(axRangeLinear0 + axRangeLinearSpan * r1Fraction);\n }\n }\n\n // zoom linked axes about their centers\n if(linkedAxes && linkedAxes.length) {\n var linkedR0Fraction = (r0Fraction + (1 - r1Fraction)) / 2;\n zoomAxRanges(linkedAxes, linkedR0Fraction, 1 - linkedR0Fraction, updates, []);\n }\n}\n\nfunction dragAxList(axList, pix) {\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(!axi.fixedrange) {\n if(axi.rangebreaks) {\n var p0 = 0;\n var p1 = axi._length;\n var d0 = axi.p2l(p0 + pix) - axi.p2l(p0);\n var d1 = axi.p2l(p1 + pix) - axi.p2l(p1);\n var delta = (d0 + d1) / 2;\n\n axi.range = [\n axi.l2r(axi._rl[0] - delta),\n axi.l2r(axi._rl[1] - delta)\n ];\n } else {\n axi.range = [\n axi.l2r(axi._rl[0] - pix / axi._m),\n axi.l2r(axi._rl[1] - pix / axi._m)\n ];\n }\n }\n }\n}\n\n// common transform for dragging one end of an axis\n// d>0 is compressing scale (cursor is over the plot,\n// the axis end should move with the cursor)\n// d<0 is expanding (cursor is off the plot, axis end moves\n// nonlinearly so you can expand far)\nfunction dZoom(d) {\n return 1 - ((d >= 0) ? Math.min(d, 0.9) :\n 1 / (1 / Math.max(d, -0.3) + 3.222));\n}\n\nfunction getDragCursor(nsew, dragmode, isMainDrag) {\n if(!nsew) return 'pointer';\n if(nsew === 'nsew') {\n // in this case here, clear cursor and\n // use the cursor style set on \n if(isMainDrag) return '';\n if(dragmode === 'pan') return 'move';\n return 'crosshair';\n }\n return nsew.toLowerCase() + '-resize';\n}\n\nfunction makeZoombox(zoomlayer, lum, xs, ys, path0) {\n return zoomlayer.append('path')\n .attr('class', 'zoombox')\n .style({\n 'fill': lum > 0.2 ? 'rgba(0,0,0,0)' : 'rgba(255,255,255,0)',\n 'stroke-width': 0\n })\n .attr('transform', 'translate(' + xs + ', ' + ys + ')')\n .attr('d', path0 + 'Z');\n}\n\nfunction makeCorners(zoomlayer, xs, ys) {\n return zoomlayer.append('path')\n .attr('class', 'zoombox-corners')\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1,\n opacity: 0\n })\n .attr('transform', 'translate(' + xs + ', ' + ys + ')')\n .attr('d', 'M0,0Z');\n}\n\nfunction updateZoombox(zb, corners, box, path0, dimmed, lum) {\n zb.attr('d',\n path0 + 'M' + (box.l) + ',' + (box.t) + 'v' + (box.h) +\n 'h' + (box.w) + 'v-' + (box.h) + 'h-' + (box.w) + 'Z');\n transitionZoombox(zb, corners, dimmed, lum);\n}\n\nfunction transitionZoombox(zb, corners, dimmed, lum) {\n if(!dimmed) {\n zb.transition()\n .style('fill', lum > 0.2 ? 'rgba(0,0,0,0.4)' :\n 'rgba(255,255,255,0.3)')\n .duration(200);\n corners.transition()\n .style('opacity', 1)\n .duration(200);\n }\n}\n\nfunction removeZoombox(gd) {\n d3.select(gd)\n .selectAll('.zoombox,.js-zoombox-backdrop,.js-zoombox-menu,.zoombox-corners')\n .remove();\n}\n\nfunction showDoubleClickNotifier(gd) {\n if(SHOWZOOMOUTTIP && gd.data && gd._context.showTips) {\n Lib.notifier(Lib._(gd, 'Double-click to zoom back out'), 'long');\n SHOWZOOMOUTTIP = false;\n }\n}\n\nfunction isSelectOrLasso(dragmode) {\n return dragmode === 'lasso' || dragmode === 'select';\n}\n\nfunction xCorners(box, y0) {\n return 'M' +\n (box.l - 0.5) + ',' + (y0 - MINZOOM - 0.5) +\n 'h-3v' + (2 * MINZOOM + 1) + 'h3ZM' +\n (box.r + 0.5) + ',' + (y0 - MINZOOM - 0.5) +\n 'h3v' + (2 * MINZOOM + 1) + 'h-3Z';\n}\n\nfunction yCorners(box, x0) {\n return 'M' +\n (x0 - MINZOOM - 0.5) + ',' + (box.t - 0.5) +\n 'v-3h' + (2 * MINZOOM + 1) + 'v3ZM' +\n (x0 - MINZOOM - 0.5) + ',' + (box.b + 0.5) +\n 'v3h' + (2 * MINZOOM + 1) + 'v-3Z';\n}\n\nfunction xyCorners(box) {\n var clen = Math.floor(Math.min(box.b - box.t, box.r - box.l, MINZOOM) / 2);\n return 'M' +\n (box.l - 3.5) + ',' + (box.t - 0.5 + clen) + 'h3v' + (-clen) +\n 'h' + clen + 'v-3h-' + (clen + 3) + 'ZM' +\n (box.r + 3.5) + ',' + (box.t - 0.5 + clen) + 'h-3v' + (-clen) +\n 'h' + (-clen) + 'v-3h' + (clen + 3) + 'ZM' +\n (box.r + 3.5) + ',' + (box.b + 0.5 - clen) + 'h-3v' + clen +\n 'h' + (-clen) + 'v3h' + (clen + 3) + 'ZM' +\n (box.l - 3.5) + ',' + (box.b + 0.5 - clen) + 'h3v' + clen +\n 'h' + clen + 'v3h-' + (clen + 3) + 'Z';\n}\n\nfunction calcLinks(gd, groups, xaHash, yaHash) {\n var isSubplotConstrained = false;\n var xLinks = {};\n var yLinks = {};\n var xID, yID, xLinkID, yLinkID;\n\n for(var i = 0; i < groups.length; i++) {\n var group = groups[i];\n // check if any of the x axes we're dragging is in this constraint group\n for(xID in xaHash) {\n if(group[xID]) {\n // put the rest of these axes into xLinks, if we're not already\n // dragging them, so we know to scale these axes automatically too\n // to match the changes in the dragged x axes\n for(xLinkID in group) {\n if(!(xLinkID.charAt(0) === 'x' ? xaHash : yaHash)[xLinkID]) {\n xLinks[xLinkID] = xID;\n }\n }\n\n // check if the x and y axes of THIS drag are linked\n for(yID in yaHash) {\n if(group[yID]) isSubplotConstrained = true;\n }\n }\n }\n\n // now check if any of the y axes we're dragging is in this constraint group\n // only look for outside links, as we've already checked for links within the dragger\n for(yID in yaHash) {\n if(group[yID]) {\n for(yLinkID in group) {\n if(!(yLinkID.charAt(0) === 'x' ? xaHash : yaHash)[yLinkID]) {\n yLinks[yLinkID] = yID;\n }\n }\n }\n }\n }\n\n if(isSubplotConstrained) {\n // merge xLinks and yLinks if the subplot is constrained,\n // since we'll always apply both anyway and the two will contain\n // duplicates\n Lib.extendFlat(xLinks, yLinks);\n yLinks = {};\n }\n\n var xaHashLinked = {};\n var xaxesLinked = [];\n for(xLinkID in xLinks) {\n var xa = getFromId(gd, xLinkID);\n xaxesLinked.push(xa);\n xaHashLinked[xa._id] = xa;\n }\n\n var yaHashLinked = {};\n var yaxesLinked = [];\n for(yLinkID in yLinks) {\n var ya = getFromId(gd, yLinkID);\n yaxesLinked.push(ya);\n yaHashLinked[ya._id] = ya;\n }\n\n return {\n xaHash: xaHashLinked,\n yaHash: yaHashLinked,\n xaxes: xaxesLinked,\n yaxes: yaxesLinked,\n xLinks: xLinks,\n yLinks: yLinks,\n isSubplotConstrained: isSubplotConstrained\n };\n}\n\n// still seems to be some confusion about onwheel vs onmousewheel...\nfunction attachWheelEventHandler(element, handler) {\n if(!supportsPassive) {\n if(element.onwheel !== undefined) element.onwheel = handler;\n else if(element.onmousewheel !== undefined) element.onmousewheel = handler;\n } else {\n var wheelEventName = element.onwheel !== undefined ? 'wheel' : 'mousewheel';\n\n if(element._onwheel) {\n element.removeEventListener(wheelEventName, element._onwheel);\n }\n element._onwheel = handler;\n\n element.addEventListener(wheelEventName, handler, {passive: false});\n }\n}\n\nfunction hashValues(hash) {\n var out = [];\n for(var k in hash) out.push(hash[k]);\n return out;\n}\n\nmodule.exports = {\n makeDragBox: makeDragBox,\n\n makeDragger: makeDragger,\n makeRectDragger: makeRectDragger,\n makeZoombox: makeZoombox,\n makeCorners: makeCorners,\n\n updateZoombox: updateZoombox,\n xyCorners: xyCorners,\n transitionZoombox: transitionZoombox,\n removeZoombox: removeZoombox,\n showDoubleClickNotifier: showDoubleClickNotifier,\n\n attachWheelEventHandler: attachWheelEventHandler\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n/* global MathJax:false */\n\nvar d3 = require('d3');\n\nvar Lib = require('../lib');\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar LINE_SPACING = require('../constants/alignment').LINE_SPACING;\n\n// text converter\n\nfunction getSize(_selection, _dimension) {\n return _selection.node().getBoundingClientRect()[_dimension];\n}\n\nvar FIND_TEX = /([^$]*)([$]+[^$]*[$]+)([^$]*)/;\n\nexports.convertToTspans = function(_context, gd, _callback) {\n var str = _context.text();\n\n // Until we get tex integrated more fully (so it can be used along with non-tex)\n // allow some elements to prohibit it by attaching 'data-notex' to the original\n var tex = (!_context.attr('data-notex')) &&\n (typeof MathJax !== 'undefined') &&\n str.match(FIND_TEX);\n\n var parent = d3.select(_context.node().parentNode);\n if(parent.empty()) return;\n var svgClass = (_context.attr('class')) ? _context.attr('class').split(' ')[0] : 'text';\n svgClass += '-math';\n parent.selectAll('svg.' + svgClass).remove();\n parent.selectAll('g.' + svgClass + '-group').remove();\n _context.style('display', null)\n .attr({\n // some callers use data-unformatted *from the element* in 'cancel'\n // so we need it here even if we're going to turn it into math\n // these two (plus style and text-anchor attributes) form the key we're\n // going to use for Drawing.bBox\n 'data-unformatted': str,\n 'data-math': 'N'\n });\n\n function showText() {\n if(!parent.empty()) {\n svgClass = _context.attr('class') + '-math';\n parent.select('svg.' + svgClass).remove();\n }\n _context.text('')\n .style('white-space', 'pre');\n\n var hasLink = buildSVGText(_context.node(), str);\n\n if(hasLink) {\n // at least in Chrome, pointer-events does not seem\n // to be honored in children of elements\n // so if we have an anchor, we have to make the\n // whole element respond\n _context.style('pointer-events', 'all');\n }\n\n exports.positionText(_context);\n\n if(_callback) _callback.call(_context);\n }\n\n if(tex) {\n ((gd && gd._promises) || []).push(new Promise(function(resolve) {\n _context.style('display', 'none');\n var fontSize = parseInt(_context.node().style.fontSize, 10);\n var config = {fontSize: fontSize};\n\n texToSVG(tex[2], config, function(_svgEl, _glyphDefs, _svgBBox) {\n parent.selectAll('svg.' + svgClass).remove();\n parent.selectAll('g.' + svgClass + '-group').remove();\n\n var newSvg = _svgEl && _svgEl.select('svg');\n if(!newSvg || !newSvg.node()) {\n showText();\n resolve();\n return;\n }\n\n var mathjaxGroup = parent.append('g')\n .classed(svgClass + '-group', true)\n .attr({\n 'pointer-events': 'none',\n 'data-unformatted': str,\n 'data-math': 'Y'\n });\n\n mathjaxGroup.node().appendChild(newSvg.node());\n\n // stitch the glyph defs\n if(_glyphDefs && _glyphDefs.node()) {\n newSvg.node().insertBefore(_glyphDefs.node().cloneNode(true),\n newSvg.node().firstChild);\n }\n\n newSvg.attr({\n 'class': svgClass,\n height: _svgBBox.height,\n preserveAspectRatio: 'xMinYMin meet'\n })\n .style({overflow: 'visible', 'pointer-events': 'none'});\n\n var fill = _context.node().style.fill || 'black';\n var g = newSvg.select('g');\n g.attr({fill: fill, stroke: fill});\n\n var newSvgW = getSize(g, 'width');\n var newSvgH = getSize(g, 'height');\n var newX = +_context.attr('x') - newSvgW *\n {start: 0, middle: 0.5, end: 1}[_context.attr('text-anchor') || 'start'];\n // font baseline is about 1/4 fontSize below centerline\n var textHeight = fontSize || getSize(_context, 'height');\n var dy = -textHeight / 4;\n\n if(svgClass[0] === 'y') {\n mathjaxGroup.attr({\n transform: 'rotate(' + [-90, +_context.attr('x'), +_context.attr('y')] +\n ') translate(' + [-newSvgW / 2, dy - newSvgH / 2] + ')'\n });\n newSvg.attr({x: +_context.attr('x'), y: +_context.attr('y')});\n } else if(svgClass[0] === 'l') {\n newSvg.attr({x: _context.attr('x'), y: dy - (newSvgH / 2)});\n } else if(svgClass[0] === 'a' && svgClass.indexOf('atitle') !== 0) {\n newSvg.attr({x: 0, y: dy});\n } else {\n newSvg.attr({x: newX, y: (+_context.attr('y') + dy - newSvgH / 2)});\n }\n\n if(_callback) _callback.call(_context, mathjaxGroup);\n resolve(mathjaxGroup);\n });\n }));\n } else showText();\n\n return _context;\n};\n\n\n// MathJax\n\nvar LT_MATCH = /(<|<|<)/g;\nvar GT_MATCH = /(>|>|>)/g;\n\nfunction cleanEscapesForTex(s) {\n return s.replace(LT_MATCH, '\\\\lt ')\n .replace(GT_MATCH, '\\\\gt ');\n}\n\nfunction texToSVG(_texString, _config, _callback) {\n var originalRenderer,\n originalConfig,\n originalProcessSectionDelay,\n tmpDiv;\n\n MathJax.Hub.Queue(\n function() {\n originalConfig = Lib.extendDeepAll({}, MathJax.Hub.config);\n\n originalProcessSectionDelay = MathJax.Hub.processSectionDelay;\n if(MathJax.Hub.processSectionDelay !== undefined) {\n // MathJax 2.5+\n MathJax.Hub.processSectionDelay = 0;\n }\n\n return MathJax.Hub.Config({\n messageStyle: 'none',\n tex2jax: {\n inlineMath: [['$', '$'], ['\\\\(', '\\\\)']]\n },\n displayAlign: 'left',\n });\n },\n function() {\n // Get original renderer\n originalRenderer = MathJax.Hub.config.menuSettings.renderer;\n if(originalRenderer !== 'SVG') {\n return MathJax.Hub.setRenderer('SVG');\n }\n },\n function() {\n var randomID = 'math-output-' + Lib.randstr({}, 64);\n tmpDiv = d3.select('body').append('div')\n .attr({id: randomID})\n .style({visibility: 'hidden', position: 'absolute'})\n .style({'font-size': _config.fontSize + 'px'})\n .text(cleanEscapesForTex(_texString));\n\n return MathJax.Hub.Typeset(tmpDiv.node());\n },\n function() {\n var glyphDefs = d3.select('body').select('#MathJax_SVG_glyphs');\n\n if(tmpDiv.select('.MathJax_SVG').empty() || !tmpDiv.select('svg').node()) {\n Lib.log('There was an error in the tex syntax.', _texString);\n _callback();\n } else {\n var svgBBox = tmpDiv.select('svg').node().getBoundingClientRect();\n _callback(tmpDiv.select('.MathJax_SVG'), glyphDefs, svgBBox);\n }\n\n tmpDiv.remove();\n\n if(originalRenderer !== 'SVG') {\n return MathJax.Hub.setRenderer(originalRenderer);\n }\n },\n function() {\n if(originalProcessSectionDelay !== undefined) {\n MathJax.Hub.processSectionDelay = originalProcessSectionDelay;\n }\n return MathJax.Hub.Config(originalConfig);\n });\n}\n\nvar TAG_STYLES = {\n // would like to use baseline-shift for sub/sup but FF doesn't support it\n // so we need to use dy along with the uber hacky shift-back-to\n // baseline below\n sup: 'font-size:70%',\n sub: 'font-size:70%',\n b: 'font-weight:bold',\n i: 'font-style:italic',\n a: 'cursor:pointer',\n span: '',\n em: 'font-style:italic;font-weight:bold'\n};\n\n// baseline shifts for sub and sup\nvar SHIFT_DY = {\n sub: '0.3em',\n sup: '-0.6em'\n};\n// reset baseline by adding a tspan (empty except for a zero-width space)\n// with dy of -70% * SHIFT_DY (because font-size=70%)\nvar RESET_DY = {\n sub: '-0.21em',\n sup: '0.42em'\n};\nvar ZERO_WIDTH_SPACE = '\\u200b';\n\n/*\n * Whitelist of protocols in user-supplied urls. Mostly we want to avoid javascript\n * and related attack vectors. The empty items are there for IE, that in various\n * versions treats relative paths as having different flavors of no protocol, while\n * other browsers have these explicitly inherit the protocol of the page they're in.\n */\nvar PROTOCOLS = ['http:', 'https:', 'mailto:', '', undefined, ':'];\n\nvar NEWLINES = exports.NEWLINES = /(\\r\\n?|\\n)/g;\n\nvar SPLIT_TAGS = /(<[^<>]*>)/;\n\nvar ONE_TAG = /<(\\/?)([^ >]*)(\\s+(.*))?>/i;\n\nvar BR_TAG = //i;\nexports.BR_TAG_ALL = //gi;\n\n/*\n * style and href: pull them out of either single or double quotes. Also\n * - target: (_blank|_self|_parent|_top|framename)\n * note that you can't use target to get a popup but if you use popup,\n * a `framename` will be passed along as the name of the popup window.\n * per the spec, cannot contain whitespace.\n * for backward compatibility we default to '_blank'\n * - popup: a custom one for us to enable popup (new window) links. String\n * for window.open -> strWindowFeatures, like 'menubar=yes,width=500,height=550'\n * note that at least in Chrome, you need to give at least one property\n * in this string or the page will open in a new tab anyway. We follow this\n * convention and will not make a popup if this string is empty.\n * per the spec, cannot contain whitespace.\n *\n * Because we hack in other attributes with style (sub & sup), drop any trailing\n * semicolon in user-supplied styles so we can consistently append the tag-dependent style\n *\n * These are for tag attributes; Chrome anyway will convert entities in\n * attribute values, but not in attribute names\n * you can test this by for example:\n * > p = document.createElement('p')\n * > p.innerHTML = 'Hi'\n * > p.innerHTML\n * <- 'Hi'\n */\nvar STYLEMATCH = /(^|[\\s\"'])style\\s*=\\s*(\"([^\"]*);?\"|'([^']*);?')/i;\nvar HREFMATCH = /(^|[\\s\"'])href\\s*=\\s*(\"([^\"]*)\"|'([^']*)')/i;\nvar TARGETMATCH = /(^|[\\s\"'])target\\s*=\\s*(\"([^\"\\s]*)\"|'([^'\\s]*)')/i;\nvar POPUPMATCH = /(^|[\\s\"'])popup\\s*=\\s*(\"([\\w=,]*)\"|'([\\w=,]*)')/i;\n\n// dedicated matcher for these quoted regexes, that can return their results\n// in two different places\nfunction getQuotedMatch(_str, re) {\n if(!_str) return null;\n var match = _str.match(re);\n var result = match && (match[3] || match[4]);\n return result && convertEntities(result);\n}\n\nvar COLORMATCH = /(^|;)\\s*color:/;\n\n/**\n * Strip string of tags\n *\n * @param {string} _str : input string\n * @param {object} opts :\n * - len {number} max length of output string\n * - allowedTags {array} list of pseudo-html tags to NOT strip\n * @return {string}\n */\nexports.plainText = function(_str, opts) {\n opts = opts || {};\n\n var len = (opts.len !== undefined && opts.len !== -1) ? opts.len : Infinity;\n var allowedTags = opts.allowedTags !== undefined ? opts.allowedTags : ['br'];\n\n var ellipsis = '...';\n var eLen = ellipsis.length;\n\n var oldParts = _str.split(SPLIT_TAGS);\n var newParts = [];\n var prevTag = '';\n var l = 0;\n\n for(var i = 0; i < oldParts.length; i++) {\n var p = oldParts[i];\n var match = p.match(ONE_TAG);\n var tagType = match && match[2].toLowerCase();\n\n if(tagType) {\n // N.B. tags do not count towards string length\n if(allowedTags.indexOf(tagType) !== -1) {\n newParts.push(p);\n prevTag = tagType;\n }\n } else {\n var pLen = p.length;\n\n if((l + pLen) < len) {\n newParts.push(p);\n l += pLen;\n } else if(l < len) {\n var pLen2 = len - l;\n\n if(prevTag && (prevTag !== 'br' || pLen2 <= eLen || pLen <= eLen)) {\n newParts.pop();\n }\n\n if(len > eLen) {\n newParts.push(p.substr(0, pLen2 - eLen) + ellipsis);\n } else {\n newParts.push(p.substr(0, pLen2));\n }\n break;\n }\n\n prevTag = '';\n }\n }\n\n return newParts.join('');\n};\n\n/*\n * N.B. HTML entities are listed without the leading '&' and trailing ';'\n * https://www.freeformatter.com/html-entities.html\n *\n * FWIW if we wanted to support the full set, it has 2261 entries:\n * https://www.w3.org/TR/html5/entities.json\n * though I notice that some of these are duplicates and/or are missing \";\"\n * eg: \"&\", \"&\", \"&\", and \"&\" all map to \"&\"\n * We no longer need to include numeric entities here, these are now handled\n * by String.fromCodePoint/fromCharCode\n *\n * Anyway the only ones that are really important to allow are the HTML special\n * chars <, >, and &, because these ones can trigger special processing if not\n * replaced by the corresponding entity.\n */\nvar entityToUnicode = {\n mu: 'μ',\n amp: '&',\n lt: '<',\n gt: '>',\n nbsp: ' ',\n times: '×',\n plusmn: '±',\n deg: '°'\n};\n\n// NOTE: in general entities can contain uppercase too (so [a-zA-Z]) but all the\n// ones we support use only lowercase. If we ever change that, update the regex.\nvar ENTITY_MATCH = /&(#\\d+|#x[\\da-fA-F]+|[a-z]+);/g;\nfunction convertEntities(_str) {\n return _str.replace(ENTITY_MATCH, function(fullMatch, innerMatch) {\n var outChar;\n if(innerMatch.charAt(0) === '#') {\n // cannot use String.fromCodePoint in IE\n outChar = fromCodePoint(\n innerMatch.charAt(1) === 'x' ?\n parseInt(innerMatch.substr(2), 16) :\n parseInt(innerMatch.substr(1), 10)\n );\n } else outChar = entityToUnicode[innerMatch];\n\n // as in regular HTML, if we didn't decode the entity just\n // leave the raw text in place.\n return outChar || fullMatch;\n });\n}\nexports.convertEntities = convertEntities;\n\nfunction fromCodePoint(code) {\n // Don't allow overflow. In Chrome this turns into � but I feel like it's\n // more useful to just not convert it at all.\n if(code > 0x10FFFF) return;\n var stringFromCodePoint = String.fromCodePoint;\n if(stringFromCodePoint) return stringFromCodePoint(code);\n\n // IE doesn't have String.fromCodePoint\n // see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/fromCodePoint\n var stringFromCharCode = String.fromCharCode;\n if(code <= 0xFFFF) return stringFromCharCode(code);\n return stringFromCharCode(\n (code >> 10) + 0xD7C0,\n (code % 0x400) + 0xDC00\n );\n}\n\n/*\n * buildSVGText: convert our pseudo-html into SVG tspan elements, and attach these\n * to containerNode\n *\n * @param {svg text element} containerNode: the node to insert this text into\n * @param {string} str: the pseudo-html string to convert to svg\n *\n * @returns {bool}: does the result contain any links? We need to handle the text element\n * somewhat differently if it does, so just keep track of this when it happens.\n */\nfunction buildSVGText(containerNode, str) {\n /*\n * Normalize behavior between IE and others wrt newlines and whitespace:pre\n * this combination makes IE barf https://github.com/plotly/plotly.js/issues/746\n * Chrome and FF display \\n, \\r, or \\r\\n as a space in this mode.\n * I feel like at some point we turned these into
but currently we don't so\n * I'm just going to cement what we do now in Chrome and FF\n */\n str = str.replace(NEWLINES, ' ');\n\n var hasLink = false;\n\n // as we're building the text, keep track of what elements we're nested inside\n // nodeStack will be an array of {node, type, style, href, target, popup}\n // where only type: 'a' gets the last 3 and node is only added when it's created\n var nodeStack = [];\n var currentNode;\n var currentLine = -1;\n\n function newLine() {\n currentLine++;\n\n var lineNode = document.createElementNS(xmlnsNamespaces.svg, 'tspan');\n d3.select(lineNode).attr({\n class: 'line',\n dy: (currentLine * LINE_SPACING) + 'em'\n });\n containerNode.appendChild(lineNode);\n\n currentNode = lineNode;\n\n var oldNodeStack = nodeStack;\n nodeStack = [{node: lineNode}];\n\n if(oldNodeStack.length > 1) {\n for(var i = 1; i < oldNodeStack.length; i++) {\n enterNode(oldNodeStack[i]);\n }\n }\n }\n\n function enterNode(nodeSpec) {\n var type = nodeSpec.type;\n var nodeAttrs = {};\n var nodeType;\n\n if(type === 'a') {\n nodeType = 'a';\n var target = nodeSpec.target;\n var href = nodeSpec.href;\n var popup = nodeSpec.popup;\n if(href) {\n nodeAttrs = {\n 'xlink:xlink:show': (target === '_blank' || target.charAt(0) !== '_') ? 'new' : 'replace',\n target: target,\n 'xlink:xlink:href': href\n };\n if(popup) {\n // security: href and target are not inserted as code but\n // as attributes. popup is, but limited to /[A-Za-z0-9_=,]/\n nodeAttrs.onclick = 'window.open(this.href.baseVal,this.target.baseVal,\"' +\n popup + '\");return false;';\n }\n }\n } else nodeType = 'tspan';\n\n if(nodeSpec.style) nodeAttrs.style = nodeSpec.style;\n\n var newNode = document.createElementNS(xmlnsNamespaces.svg, nodeType);\n\n if(type === 'sup' || type === 'sub') {\n addTextNode(currentNode, ZERO_WIDTH_SPACE);\n currentNode.appendChild(newNode);\n\n var resetter = document.createElementNS(xmlnsNamespaces.svg, 'tspan');\n addTextNode(resetter, ZERO_WIDTH_SPACE);\n d3.select(resetter).attr('dy', RESET_DY[type]);\n nodeAttrs.dy = SHIFT_DY[type];\n\n currentNode.appendChild(newNode);\n currentNode.appendChild(resetter);\n } else {\n currentNode.appendChild(newNode);\n }\n\n d3.select(newNode).attr(nodeAttrs);\n\n currentNode = nodeSpec.node = newNode;\n nodeStack.push(nodeSpec);\n }\n\n function addTextNode(node, text) {\n node.appendChild(document.createTextNode(text));\n }\n\n function exitNode(type) {\n // A bare closing tag can't close the root node. If we encounter this it\n // means there's an extra closing tag that can just be ignored:\n if(nodeStack.length === 1) {\n Lib.log('Ignoring unexpected end tag .', str);\n return;\n }\n\n var innerNode = nodeStack.pop();\n\n if(type !== innerNode.type) {\n Lib.log('Start tag <' + innerNode.type + '> doesnt match end tag <' +\n type + '>. Pretending it did match.', str);\n }\n currentNode = nodeStack[nodeStack.length - 1].node;\n }\n\n var hasLines = BR_TAG.test(str);\n\n if(hasLines) newLine();\n else {\n currentNode = containerNode;\n nodeStack = [{node: containerNode}];\n }\n\n var parts = str.split(SPLIT_TAGS);\n for(var i = 0; i < parts.length; i++) {\n var parti = parts[i];\n var match = parti.match(ONE_TAG);\n var tagType = match && match[2].toLowerCase();\n var tagStyle = TAG_STYLES[tagType];\n\n if(tagType === 'br') {\n newLine();\n } else if(tagStyle === undefined) {\n addTextNode(currentNode, convertEntities(parti));\n } else {\n // tag - open or close\n if(match[1]) {\n exitNode(tagType);\n } else {\n var extra = match[4];\n\n var nodeSpec = {type: tagType};\n\n // now add style, from both the tag name and any extra css\n // Most of the svg css that users will care about is just like html,\n // but font color is different (uses fill). Let our users ignore this.\n var css = getQuotedMatch(extra, STYLEMATCH);\n if(css) {\n css = css.replace(COLORMATCH, '$1 fill:');\n if(tagStyle) css += ';' + tagStyle;\n } else if(tagStyle) css = tagStyle;\n\n if(css) nodeSpec.style = css;\n\n if(tagType === 'a') {\n hasLink = true;\n\n var href = getQuotedMatch(extra, HREFMATCH);\n\n if(href) {\n // check safe protocols\n var dummyAnchor = document.createElement('a');\n dummyAnchor.href = href;\n if(PROTOCOLS.indexOf(dummyAnchor.protocol) !== -1) {\n // Decode href to allow both already encoded and not encoded\n // URIs. Without decoding prior encoding, an already encoded\n // URI would be encoded twice producing a semantically different URI.\n nodeSpec.href = encodeURI(decodeURI(href));\n nodeSpec.target = getQuotedMatch(extra, TARGETMATCH) || '_blank';\n nodeSpec.popup = getQuotedMatch(extra, POPUPMATCH);\n }\n }\n }\n\n enterNode(nodeSpec);\n }\n }\n }\n\n return hasLink;\n}\n\nexports.lineCount = function lineCount(s) {\n return s.selectAll('tspan.line').size() || 1;\n};\n\nexports.positionText = function positionText(s, x, y) {\n return s.each(function() {\n var text = d3.select(this);\n\n function setOrGet(attr, val) {\n if(val === undefined) {\n val = text.attr(attr);\n if(val === null) {\n text.attr(attr, 0);\n val = 0;\n }\n } else text.attr(attr, val);\n return val;\n }\n\n var thisX = setOrGet('x', x);\n var thisY = setOrGet('y', y);\n\n if(this.nodeName === 'text') {\n text.selectAll('tspan.line').attr({x: thisX, y: thisY});\n }\n });\n};\n\nfunction alignHTMLWith(_base, container, options) {\n var alignH = options.horizontalAlign;\n var alignV = options.verticalAlign || 'top';\n var bRect = _base.node().getBoundingClientRect();\n var cRect = container.node().getBoundingClientRect();\n var thisRect;\n var getTop;\n var getLeft;\n\n if(alignV === 'bottom') {\n getTop = function() { return bRect.bottom - thisRect.height; };\n } else if(alignV === 'middle') {\n getTop = function() { return bRect.top + (bRect.height - thisRect.height) / 2; };\n } else { // default: top\n getTop = function() { return bRect.top; };\n }\n\n if(alignH === 'right') {\n getLeft = function() { return bRect.right - thisRect.width; };\n } else if(alignH === 'center') {\n getLeft = function() { return bRect.left + (bRect.width - thisRect.width) / 2; };\n } else { // default: left\n getLeft = function() { return bRect.left; };\n }\n\n return function() {\n thisRect = this.node().getBoundingClientRect();\n this.style({\n top: (getTop() - cRect.top) + 'px',\n left: (getLeft() - cRect.left) + 'px',\n 'z-index': 1000\n });\n return this;\n };\n}\n\n/*\n * Editable title\n * @param {d3.selection} context: the element being edited. Normally text,\n * but if it isn't, you should provide the styling options\n * @param {object} options:\n * @param {div} options.gd: graphDiv\n * @param {d3.selection} options.delegate: item to bind events to if not this\n * @param {boolean} options.immediate: start editing now (true) or on click (false, default)\n * @param {string} options.fill: font color if not as shown\n * @param {string} options.background: background color if not as shown\n * @param {string} options.text: initial text, if not as shown\n * @param {string} options.horizontalAlign: alignment of the edit box wrt. the bound element\n * @param {string} options.verticalAlign: alignment of the edit box wrt. the bound element\n */\n\nexports.makeEditable = function(context, options) {\n var gd = options.gd;\n var _delegate = options.delegate;\n var dispatch = d3.dispatch('edit', 'input', 'cancel');\n var handlerElement = _delegate || context;\n\n context.style({'pointer-events': _delegate ? 'none' : 'all'});\n\n if(context.size() !== 1) throw new Error('boo');\n\n function handleClick() {\n appendEditable();\n context.style({opacity: 0});\n // also hide any mathjax svg\n var svgClass = handlerElement.attr('class');\n var mathjaxClass;\n if(svgClass) mathjaxClass = '.' + svgClass.split(' ')[0] + '-math-group';\n else mathjaxClass = '[class*=-math-group]';\n if(mathjaxClass) {\n d3.select(context.node().parentNode).select(mathjaxClass).style({opacity: 0});\n }\n }\n\n function selectElementContents(_el) {\n var el = _el.node();\n var range = document.createRange();\n range.selectNodeContents(el);\n var sel = window.getSelection();\n sel.removeAllRanges();\n sel.addRange(range);\n el.focus();\n }\n\n function appendEditable() {\n var plotDiv = d3.select(gd);\n var container = plotDiv.select('.svg-container');\n var div = container.append('div');\n var cStyle = context.node().style;\n var fontSize = parseFloat(cStyle.fontSize || 12);\n\n var initialText = options.text;\n if(initialText === undefined) initialText = context.attr('data-unformatted');\n\n div.classed('plugin-editable editable', true)\n .style({\n position: 'absolute',\n 'font-family': cStyle.fontFamily || 'Arial',\n 'font-size': fontSize,\n color: options.fill || cStyle.fill || 'black',\n opacity: 1,\n 'background-color': options.background || 'transparent',\n outline: '#ffffff33 1px solid',\n margin: [-fontSize / 8 + 1, 0, 0, -1].join('px ') + 'px',\n padding: '0',\n 'box-sizing': 'border-box'\n })\n .attr({contenteditable: true})\n .text(initialText)\n .call(alignHTMLWith(context, container, options))\n .on('blur', function() {\n gd._editing = false;\n context.text(this.textContent)\n .style({opacity: 1});\n var svgClass = d3.select(this).attr('class');\n var mathjaxClass;\n if(svgClass) mathjaxClass = '.' + svgClass.split(' ')[0] + '-math-group';\n else mathjaxClass = '[class*=-math-group]';\n if(mathjaxClass) {\n d3.select(context.node().parentNode).select(mathjaxClass).style({opacity: 0});\n }\n var text = this.textContent;\n d3.select(this).transition().duration(0).remove();\n d3.select(document).on('mouseup', null);\n dispatch.edit.call(context, text);\n })\n .on('focus', function() {\n var editDiv = this;\n gd._editing = true;\n d3.select(document).on('mouseup', function() {\n if(d3.event.target === editDiv) return false;\n if(document.activeElement === div.node()) div.node().blur();\n });\n })\n .on('keyup', function() {\n if(d3.event.which === 27) {\n gd._editing = false;\n context.style({opacity: 1});\n d3.select(this)\n .style({opacity: 0})\n .on('blur', function() { return false; })\n .transition().remove();\n dispatch.cancel.call(context, this.textContent);\n } else {\n dispatch.input.call(context, this.textContent);\n d3.select(this).call(alignHTMLWith(context, container, options));\n }\n })\n .on('keydown', function() {\n if(d3.event.which === 13) this.blur();\n })\n .call(selectElementContents);\n }\n\n if(options.immediate) handleClick();\n else handlerElement.on('click', handleClick);\n\n return d3.rebind(context, dispatch, 'on');\n};\n","'use strict'\r\n\r\nvar isBrowser = require('is-browser')\r\nvar hasHover\r\n\r\nif (typeof global.matchMedia === 'function') {\r\n\thasHover = !global.matchMedia('(hover: none)').matches\r\n}\r\nelse {\r\n\thasHover = isBrowser\r\n}\r\n\r\nmodule.exports = hasHover\r\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../registry');\nvar PlotSchema = require('../plot_api/plot_schema');\nvar Template = require('../plot_api/plot_template');\nvar Lib = require('../lib');\nvar Color = require('../components/color');\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nvar axisIDs = require('./cartesian/axis_ids');\n\nvar animationAttrs = require('./animation_attributes');\nvar frameAttrs = require('./frame_attributes');\n\nvar getModuleCalcData = require('../plots/get_data').getModuleCalcData;\n\nvar relinkPrivateKeys = Lib.relinkPrivateKeys;\nvar _ = Lib._;\n\nvar plots = module.exports = {};\n\n// Expose registry methods on Plots for backward-compatibility\nLib.extendFlat(plots, Registry);\n\nplots.attributes = require('./attributes');\nplots.attributes.type.values = plots.allTypes;\nplots.fontAttrs = require('./font_attributes');\nplots.layoutAttributes = require('./layout_attributes');\n\n// TODO make this a plot attribute?\nplots.fontWeight = 'normal';\n\nvar transformsRegistry = plots.transformsRegistry;\n\nvar commandModule = require('./command');\nplots.executeAPICommand = commandModule.executeAPICommand;\nplots.computeAPICommandBindings = commandModule.computeAPICommandBindings;\nplots.manageCommandObserver = commandModule.manageCommandObserver;\nplots.hasSimpleAPICommandBindings = commandModule.hasSimpleAPICommandBindings;\n\n// in some cases the browser doesn't seem to know how big\n// the text is at first, so it needs to draw it,\n// then wait a little, then draw it again\nplots.redrawText = function(gd) {\n gd = Lib.getGraphDiv(gd);\n\n var fullLayout = gd._fullLayout || {};\n var hasPolar = fullLayout._has && fullLayout._has('polar');\n var hasLegacyPolar = !hasPolar && gd.data && gd.data[0] && gd.data[0].r;\n\n // do not work if polar is present\n if(hasLegacyPolar) return;\n\n return new Promise(function(resolve) {\n setTimeout(function() {\n Registry.getComponentMethod('annotations', 'draw')(gd);\n Registry.getComponentMethod('legend', 'draw')(gd);\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n resolve(plots.previousPromises(gd));\n }, 300);\n });\n};\n\n// resize plot about the container size\nplots.resize = function(gd) {\n gd = Lib.getGraphDiv(gd);\n\n var resolveLastResize;\n var p = new Promise(function(resolve, reject) {\n if(!gd || Lib.isHidden(gd)) {\n reject(new Error('Resize must be passed a displayed plot div element.'));\n }\n\n if(gd._redrawTimer) clearTimeout(gd._redrawTimer);\n if(gd._resolveResize) resolveLastResize = gd._resolveResize;\n gd._resolveResize = resolve;\n\n gd._redrawTimer = setTimeout(function() {\n // return if there is nothing to resize or is hidden\n if(!gd.layout || (gd.layout.width && gd.layout.height) || Lib.isHidden(gd)) {\n resolve(gd);\n return;\n }\n\n delete gd.layout.width;\n delete gd.layout.height;\n\n // autosizing doesn't count as a change that needs saving\n var oldchanged = gd.changed;\n\n // nor should it be included in the undo queue\n gd.autoplay = true;\n\n Registry.call('relayout', gd, {autosize: true}).then(function() {\n gd.changed = oldchanged;\n // Only resolve if a new call hasn't been made!\n if(gd._resolveResize === resolve) {\n delete gd._resolveResize;\n resolve(gd);\n }\n });\n }, 100);\n });\n\n if(resolveLastResize) resolveLastResize(p);\n return p;\n};\n\n\n// for use in Lib.syncOrAsync, check if there are any\n// pending promises in this plot and wait for them\nplots.previousPromises = function(gd) {\n if((gd._promises || []).length) {\n return Promise.all(gd._promises)\n .then(function() { gd._promises = []; });\n }\n};\n\n/**\n * Adds the 'Edit chart' link.\n * Note that now Plotly.plot() calls this so it can regenerate whenever it replots\n *\n * Add source links to your graph inside the 'showSources' config argument.\n */\nplots.addLinks = function(gd) {\n // Do not do anything if showLink and showSources are not set to true in config\n if(!gd._context.showLink && !gd._context.showSources) return;\n\n var fullLayout = gd._fullLayout;\n\n var linkContainer = Lib.ensureSingle(fullLayout._paper, 'text', 'js-plot-link-container', function(s) {\n s.style({\n 'font-family': '\"Open Sans\", Arial, sans-serif',\n 'font-size': '12px',\n 'fill': Color.defaultLine,\n 'pointer-events': 'all'\n })\n .each(function() {\n var links = d3.select(this);\n links.append('tspan').classed('js-link-to-tool', true);\n links.append('tspan').classed('js-link-spacer', true);\n links.append('tspan').classed('js-sourcelinks', true);\n });\n });\n\n // The text node inside svg\n var text = linkContainer.node();\n var attrs = {y: fullLayout._paper.attr('height') - 9};\n\n // If text's width is bigger than the layout\n // Check that text is a child node or document.body\n // because otherwise IE/Edge might throw an exception\n // when calling getComputedTextLength().\n // Apparently offsetParent is null for invisibles.\n if(document.body.contains(text) && text.getComputedTextLength() >= (fullLayout.width - 20)) {\n // Align the text at the left\n attrs['text-anchor'] = 'start';\n attrs.x = 5;\n } else {\n // Align the text at the right\n attrs['text-anchor'] = 'end';\n attrs.x = fullLayout._paper.attr('width') - 7;\n }\n\n linkContainer.attr(attrs);\n\n var toolspan = linkContainer.select('.js-link-to-tool');\n var spacespan = linkContainer.select('.js-link-spacer');\n var sourcespan = linkContainer.select('.js-sourcelinks');\n\n if(gd._context.showSources) gd._context.showSources(gd);\n\n // 'view in plotly' link for embedded plots\n if(gd._context.showLink) positionPlayWithData(gd, toolspan);\n\n // separator if we have both sources and tool link\n spacespan.text((toolspan.text() && sourcespan.text()) ? ' - ' : '');\n};\n\n// note that now this function is only adding the brand in\n// iframes and 3rd-party apps\nfunction positionPlayWithData(gd, container) {\n container.text('');\n var link = container.append('a')\n .attr({\n 'xlink:xlink:href': '#',\n 'class': 'link--impt link--embedview',\n 'font-weight': 'bold'\n })\n .text(gd._context.linkText + ' ' + String.fromCharCode(187));\n\n if(gd._context.sendData) {\n link.on('click', function() {\n plots.sendDataToCloud(gd);\n });\n } else {\n var path = window.location.pathname.split('/');\n var query = window.location.search;\n link.attr({\n 'xlink:xlink:show': 'new',\n 'xlink:xlink:href': '/' + path[2].split('.')[0] + '/' + path[1] + query\n });\n }\n}\n\nplots.sendDataToCloud = function(gd) {\n var baseUrl = (window.PLOTLYENV || {}).BASE_URL || gd._context.plotlyServerURL;\n if(!baseUrl) return;\n\n gd.emit('plotly_beforeexport');\n\n var hiddenformDiv = d3.select(gd)\n .append('div')\n .attr('id', 'hiddenform')\n .style('display', 'none');\n\n var hiddenform = hiddenformDiv\n .append('form')\n .attr({\n action: baseUrl + '/external',\n method: 'post',\n target: '_blank'\n });\n\n var hiddenformInput = hiddenform\n .append('input')\n .attr({\n type: 'text',\n name: 'data'\n });\n\n hiddenformInput.node().value = plots.graphJson(gd, false, 'keepdata');\n hiddenform.node().submit();\n hiddenformDiv.remove();\n\n gd.emit('plotly_afterexport');\n return false;\n};\n\nvar d3FormatKeys = [\n 'days', 'shortDays', 'months', 'shortMonths', 'periods',\n 'dateTime', 'date', 'time',\n 'decimal', 'thousands', 'grouping', 'currency'\n];\n\nvar extraFormatKeys = [\n 'year', 'month', 'dayMonth', 'dayMonthYear'\n];\n\n/*\n * Fill in default values\n * @param {DOM element} gd\n * @param {object} opts\n * @param {boolean} opts.skipUpdateCalc: normally if the existing gd.calcdata looks\n * compatible with the new gd._fullData we finish by linking the new _fullData traces\n * to the old gd.calcdata, so it's correctly set if we're not going to recalc. But also,\n * if there are calcTransforms on the trace, we first remap data arrays from the old full\n * trace into the new one. Use skipUpdateCalc to defer this (needed by Plotly.react)\n *\n * gd.data, gd.layout:\n * are precisely what the user specified (except as modified by cleanData/cleanLayout),\n * these fields shouldn't be modified (except for filling in some auto values)\n * nor used directly after the supply defaults step.\n *\n * gd._fullData, gd._fullLayout:\n * are complete descriptions of how to draw the plot,\n * use these fields in all required computations.\n *\n * gd._fullLayout._modules\n * is a list of all the trace modules required to draw the plot.\n *\n * gd._fullLayout._visibleModules\n * subset of _modules, a list of modules corresponding to visible:true traces.\n *\n * gd._fullLayout._basePlotModules\n * is a list of all the plot modules required to draw the plot.\n *\n * gd._fullLayout._transformModules\n * is a list of all the transform modules invoked.\n *\n */\nplots.supplyDefaults = function(gd, opts) {\n var skipUpdateCalc = opts && opts.skipUpdateCalc;\n var oldFullLayout = gd._fullLayout || {};\n\n if(oldFullLayout._skipDefaults) {\n delete oldFullLayout._skipDefaults;\n return;\n }\n\n var newFullLayout = gd._fullLayout = {};\n var newLayout = gd.layout || {};\n\n var oldFullData = gd._fullData || [];\n var newFullData = gd._fullData = [];\n var newData = gd.data || [];\n\n var oldCalcdata = gd.calcdata || [];\n\n var context = gd._context || {};\n\n var i;\n\n // Create all the storage space for frames, but only if doesn't already exist\n if(!gd._transitionData) plots.createTransitionData(gd);\n\n // So we only need to do this once (and since we have gd here)\n // get the translated placeholder titles.\n // These ones get used as default values so need to be known at supplyDefaults\n // others keep their blank defaults but render the placeholder as desired later\n // TODO: make these work the same way, only inserting the placeholder text at draw time?\n // The challenge is that this has slightly different behavior right now in editable mode:\n // using the placeholder as default makes this text permanently (but lightly) visible,\n // but explicit '' for these titles gives you a placeholder that's hidden until you mouse\n // over it - so you're not distracted by it if you really don't want a title, but if you do\n // and you're new to plotly you may not be able to find it.\n // When editable=false the two behave the same, no title is drawn.\n newFullLayout._dfltTitle = {\n plot: _(gd, 'Click to enter Plot title'),\n x: _(gd, 'Click to enter X axis title'),\n y: _(gd, 'Click to enter Y axis title'),\n colorbar: _(gd, 'Click to enter Colorscale title'),\n annotation: _(gd, 'new text')\n };\n newFullLayout._traceWord = _(gd, 'trace');\n\n var formatObj = getFormatObj(gd, d3FormatKeys);\n\n // stash the token from context so mapbox subplots can use it as default\n newFullLayout._mapboxAccessToken = context.mapboxAccessToken;\n\n // first fill in what we can of layout without looking at data\n // because fullData needs a few things from layout\n if(oldFullLayout._initialAutoSizeIsDone) {\n // coerce the updated layout while preserving width and height\n var oldWidth = oldFullLayout.width;\n var oldHeight = oldFullLayout.height;\n\n plots.supplyLayoutGlobalDefaults(newLayout, newFullLayout, formatObj);\n\n if(!newLayout.width) newFullLayout.width = oldWidth;\n if(!newLayout.height) newFullLayout.height = oldHeight;\n plots.sanitizeMargins(newFullLayout);\n } else {\n // coerce the updated layout and autosize if needed\n plots.supplyLayoutGlobalDefaults(newLayout, newFullLayout, formatObj);\n\n var missingWidthOrHeight = (!newLayout.width || !newLayout.height);\n var autosize = newFullLayout.autosize;\n var autosizable = context.autosizable;\n var initialAutoSize = missingWidthOrHeight && (autosize || autosizable);\n\n if(initialAutoSize) plots.plotAutoSize(gd, newLayout, newFullLayout);\n else if(missingWidthOrHeight) plots.sanitizeMargins(newFullLayout);\n\n // for backwards-compatibility with Plotly v1.x.x\n if(!autosize && missingWidthOrHeight) {\n newLayout.width = newFullLayout.width;\n newLayout.height = newFullLayout.height;\n }\n }\n\n newFullLayout._d3locale = getFormatter(formatObj, newFullLayout.separators);\n newFullLayout._extraFormat = getFormatObj(gd, extraFormatKeys);\n\n newFullLayout._initialAutoSizeIsDone = true;\n\n // keep track of how many traces are inputted\n newFullLayout._dataLength = newData.length;\n\n // clear the lists of trace and baseplot modules, and subplots\n newFullLayout._modules = [];\n newFullLayout._visibleModules = [];\n newFullLayout._basePlotModules = [];\n var subplots = newFullLayout._subplots = emptySubplotLists();\n\n // initialize axis and subplot hash objects for splom-generated grids\n var splomAxes = newFullLayout._splomAxes = {x: {}, y: {}};\n var splomSubplots = newFullLayout._splomSubplots = {};\n // initialize splom grid defaults\n newFullLayout._splomGridDflt = {};\n\n // for stacked area traces to share config across traces\n newFullLayout._scatterStackOpts = {};\n // for the first scatter trace on each subplot (so it knows tonext->tozero)\n newFullLayout._firstScatter = {};\n // for grouped bar/box/violin trace to share config across traces\n newFullLayout._alignmentOpts = {};\n // track color axes referenced in the data\n newFullLayout._colorAxes = {};\n\n // for traces to request a default rangeslider on their x axes\n // eg set `_requestRangeslider.x2 = true` for xaxis2\n newFullLayout._requestRangeslider = {};\n\n // pull uids from old data to use as new defaults\n newFullLayout._traceUids = getTraceUids(oldFullData, newData);\n\n // then do the data\n newFullLayout._globalTransforms = (gd._context || {}).globalTransforms;\n plots.supplyDataDefaults(newData, newFullData, newLayout, newFullLayout);\n\n // redo grid size defaults with info about splom x/y axes,\n // and fill in generated cartesian axes and subplots\n var splomXa = Object.keys(splomAxes.x);\n var splomYa = Object.keys(splomAxes.y);\n if(splomXa.length > 1 && splomYa.length > 1) {\n Registry.getComponentMethod('grid', 'sizeDefaults')(newLayout, newFullLayout);\n\n for(i = 0; i < splomXa.length; i++) {\n Lib.pushUnique(subplots.xaxis, splomXa[i]);\n }\n for(i = 0; i < splomYa.length; i++) {\n Lib.pushUnique(subplots.yaxis, splomYa[i]);\n }\n for(var k in splomSubplots) {\n Lib.pushUnique(subplots.cartesian, k);\n }\n }\n\n // attach helper method to check whether a plot type is present on graph\n newFullLayout._has = plots._hasPlotType.bind(newFullLayout);\n\n if(oldFullData.length === newFullData.length) {\n for(i = 0; i < newFullData.length; i++) {\n relinkPrivateKeys(newFullData[i], oldFullData[i]);\n }\n }\n\n // finally, fill in the pieces of layout that may need to look at data\n plots.supplyLayoutModuleDefaults(newLayout, newFullLayout, newFullData, gd._transitionData);\n\n // Special cases that introduce interactions between traces.\n // This is after relinkPrivateKeys so we can use those in crossTraceDefaults\n // and after layout module defaults, so we can use eg barmode\n var _modules = newFullLayout._visibleModules;\n var crossTraceDefaultsFuncs = [];\n for(i = 0; i < _modules.length; i++) {\n var funci = _modules[i].crossTraceDefaults;\n // some trace types share crossTraceDefaults (ie histogram2d, histogram2dcontour)\n if(funci) Lib.pushUnique(crossTraceDefaultsFuncs, funci);\n }\n for(i = 0; i < crossTraceDefaultsFuncs.length; i++) {\n crossTraceDefaultsFuncs[i](newFullData, newFullLayout);\n }\n\n // turn on flag to optimize large splom-only graphs\n // mostly by omitting SVG layers during Cartesian.drawFramework\n newFullLayout._hasOnlyLargeSploms = (\n newFullLayout._basePlotModules.length === 1 &&\n newFullLayout._basePlotModules[0].name === 'splom' &&\n splomXa.length > 15 &&\n splomYa.length > 15 &&\n newFullLayout.shapes.length === 0 &&\n newFullLayout.images.length === 0\n );\n\n // TODO remove in v2.0.0\n // add has-plot-type refs to fullLayout for backward compatibility\n newFullLayout._hasCartesian = newFullLayout._has('cartesian');\n newFullLayout._hasGeo = newFullLayout._has('geo');\n newFullLayout._hasGL3D = newFullLayout._has('gl3d');\n newFullLayout._hasGL2D = newFullLayout._has('gl2d');\n newFullLayout._hasTernary = newFullLayout._has('ternary');\n newFullLayout._hasPie = newFullLayout._has('pie');\n\n // relink / initialize subplot axis objects\n plots.linkSubplots(newFullData, newFullLayout, oldFullData, oldFullLayout);\n\n // clean subplots and other artifacts from previous plot calls\n plots.cleanPlot(newFullData, newFullLayout, oldFullData, oldFullLayout);\n\n // clear selection outline until we implement persistent selection,\n // don't clear them though when drag handlers (e.g. listening to\n // `plotly_selecting`) update the graph.\n // we should try to come up with a better solution when implementing\n // https://github.com/plotly/plotly.js/issues/1851\n if(oldFullLayout._zoomlayer && !gd._dragging) {\n oldFullLayout._zoomlayer.selectAll('.select-outline').remove();\n }\n\n\n // fill in meta helpers\n fillMetaTextHelpers(newFullData, newFullLayout);\n\n // relink functions and _ attributes to promote consistency between plots\n relinkPrivateKeys(newFullLayout, oldFullLayout);\n\n // colorscale crossTraceDefaults needs newFullLayout with relinked keys\n Registry.getComponentMethod('colorscale', 'crossTraceDefaults')(newFullData, newFullLayout);\n\n // For persisting GUI-driven changes in layout\n // _preGUI and _tracePreGUI were already copied over in relinkPrivateKeys\n if(!newFullLayout._preGUI) newFullLayout._preGUI = {};\n // track trace GUI changes by uid rather than by trace index\n if(!newFullLayout._tracePreGUI) newFullLayout._tracePreGUI = {};\n var tracePreGUI = newFullLayout._tracePreGUI;\n var uids = {};\n var uid;\n for(uid in tracePreGUI) uids[uid] = 'old';\n for(i = 0; i < newFullData.length; i++) {\n uid = newFullData[i]._fullInput.uid;\n if(!uids[uid]) tracePreGUI[uid] = {};\n uids[uid] = 'new';\n }\n for(uid in uids) {\n if(uids[uid] === 'old') delete tracePreGUI[uid];\n }\n\n // set up containers for margin calculations\n initMargins(newFullLayout);\n\n // collect and do some initial calculations for rangesliders\n Registry.getComponentMethod('rangeslider', 'makeData')(newFullLayout);\n\n // update object references in calcdata\n if(!skipUpdateCalc && oldCalcdata.length === newFullData.length) {\n plots.supplyDefaultsUpdateCalc(oldCalcdata, newFullData);\n }\n};\n\nplots.supplyDefaultsUpdateCalc = function(oldCalcdata, newFullData) {\n for(var i = 0; i < newFullData.length; i++) {\n var newTrace = newFullData[i];\n var cd0 = (oldCalcdata[i] || [])[0];\n if(cd0 && cd0.trace) {\n var oldTrace = cd0.trace;\n if(oldTrace._hasCalcTransform) {\n var arrayAttrs = oldTrace._arrayAttrs;\n var j, astr, oldArrayVal;\n\n for(j = 0; j < arrayAttrs.length; j++) {\n astr = arrayAttrs[j];\n oldArrayVal = Lib.nestedProperty(oldTrace, astr).get().slice();\n Lib.nestedProperty(newTrace, astr).set(oldArrayVal);\n }\n }\n cd0.trace = newTrace;\n }\n }\n};\n\n/**\n * Create a list of uid strings satisfying (in this order of importance):\n * 1. all unique, all strings\n * 2. matches input uids if provided\n * 3. matches previous data uids\n */\nfunction getTraceUids(oldFullData, newData) {\n var len = newData.length;\n var oldFullInput = [];\n var i, prevFullInput;\n for(i = 0; i < oldFullData.length; i++) {\n var thisFullInput = oldFullData[i]._fullInput;\n if(thisFullInput !== prevFullInput) oldFullInput.push(thisFullInput);\n prevFullInput = thisFullInput;\n }\n var oldLen = oldFullInput.length;\n var out = new Array(len);\n var seenUids = {};\n\n function setUid(uid, i) {\n out[i] = uid;\n seenUids[uid] = 1;\n }\n\n function tryUid(uid, i) {\n if(uid && typeof uid === 'string' && !seenUids[uid]) {\n setUid(uid, i);\n return true;\n }\n }\n\n for(i = 0; i < len; i++) {\n var newUid = newData[i].uid;\n if(typeof newUid === 'number') newUid = String(newUid);\n\n if(tryUid(newUid, i)) continue;\n if(i < oldLen && tryUid(oldFullInput[i].uid, i)) continue;\n setUid(Lib.randstr(seenUids), i);\n }\n\n return out;\n}\n\n/**\n * Make a container for collecting subplots we need to display.\n *\n * Finds all subplot types we need to enumerate once and caches it,\n * but makes a new output object each time.\n * Single-trace subplots (which have no `id`) such as pie, table, etc\n * do not need to be collected because we just draw all visible traces.\n */\nfunction emptySubplotLists() {\n var collectableSubplotTypes = Registry.collectableSubplotTypes;\n var out = {};\n var i, j;\n\n if(!collectableSubplotTypes) {\n collectableSubplotTypes = [];\n\n var subplotsRegistry = Registry.subplotsRegistry;\n\n for(var subplotType in subplotsRegistry) {\n var subplotModule = subplotsRegistry[subplotType];\n var subplotAttr = subplotModule.attr;\n\n if(subplotAttr) {\n collectableSubplotTypes.push(subplotType);\n\n // special case, currently just for cartesian:\n // we need to enumerate axes, not just subplots\n if(Array.isArray(subplotAttr)) {\n for(j = 0; j < subplotAttr.length; j++) {\n Lib.pushUnique(collectableSubplotTypes, subplotAttr[j]);\n }\n }\n }\n }\n }\n\n for(i = 0; i < collectableSubplotTypes.length; i++) {\n out[collectableSubplotTypes[i]] = [];\n }\n return out;\n}\n\n/**\n * getFormatObj: use _context to get the format object from locale.\n * Used to get d3.locale argument object and extraFormat argument object\n *\n * Regarding d3.locale argument :\n * decimal and thousands can be overridden later by layout.separators\n * grouping and currency are not presently used by our automatic number\n * formatting system but can be used by custom formats.\n *\n * @returns {object} d3.locale format object\n */\nfunction getFormatObj(gd, formatKeys) {\n var locale = gd._context.locale;\n if(!locale) locale === 'en-US';\n\n var formatDone = false;\n var formatObj = {};\n\n function includeFormat(newFormat) {\n var formatFinished = true;\n for(var i = 0; i < formatKeys.length; i++) {\n var formatKey = formatKeys[i];\n if(!formatObj[formatKey]) {\n if(newFormat[formatKey]) {\n formatObj[formatKey] = newFormat[formatKey];\n } else formatFinished = false;\n }\n }\n if(formatFinished) formatDone = true;\n }\n\n // same as localize, look for format parts in each format spec in the chain\n for(var i = 0; i < 2; i++) {\n var locales = gd._context.locales;\n for(var j = 0; j < 2; j++) {\n var formatj = (locales[locale] || {}).format;\n if(formatj) {\n includeFormat(formatj);\n if(formatDone) break;\n }\n locales = Registry.localeRegistry;\n }\n\n var baseLocale = locale.split('-')[0];\n if(formatDone || baseLocale === locale) break;\n locale = baseLocale;\n }\n\n // lastly pick out defaults from english (non-US, as DMY is so much more common)\n if(!formatDone) includeFormat(Registry.localeRegistry.en.format);\n\n return formatObj;\n}\n\n/**\n * getFormatter: combine the final separators with the locale formatting object\n * we pulled earlier to generate number and time formatters\n * TODO: remove separators in v2, only use locale, so we don't need this step?\n *\n * @param {object} formatObj: d3.locale format object\n * @param {string} separators: length-2 string to override decimal and thousands\n * separators in number formatting\n *\n * @returns {object} {numberFormat, timeFormat} d3 formatter factory functions\n * for numbers and time\n */\nfunction getFormatter(formatObj, separators) {\n formatObj.decimal = separators.charAt(0);\n formatObj.thousands = separators.charAt(1);\n\n return d3.locale(formatObj);\n}\n\nfunction fillMetaTextHelpers(newFullData, newFullLayout) {\n var _meta;\n var meta4data = [];\n\n if(newFullLayout.meta) {\n _meta = newFullLayout._meta = {\n meta: newFullLayout.meta,\n layout: {meta: newFullLayout.meta}\n };\n }\n\n for(var i = 0; i < newFullData.length; i++) {\n var trace = newFullData[i];\n\n if(trace.meta) {\n meta4data[trace.index] = trace._meta = {meta: trace.meta};\n } else if(newFullLayout.meta) {\n trace._meta = {meta: newFullLayout.meta};\n }\n if(newFullLayout.meta) {\n trace._meta.layout = {meta: newFullLayout.meta};\n }\n }\n\n if(meta4data.length) {\n if(!_meta) {\n _meta = newFullLayout._meta = {};\n }\n _meta.data = meta4data;\n }\n}\n\n// Create storage for all of the data related to frames and transitions:\nplots.createTransitionData = function(gd) {\n // Set up the default keyframe if it doesn't exist:\n if(!gd._transitionData) {\n gd._transitionData = {};\n }\n\n if(!gd._transitionData._frames) {\n gd._transitionData._frames = [];\n }\n\n if(!gd._transitionData._frameHash) {\n gd._transitionData._frameHash = {};\n }\n\n if(!gd._transitionData._counter) {\n gd._transitionData._counter = 0;\n }\n\n if(!gd._transitionData._interruptCallbacks) {\n gd._transitionData._interruptCallbacks = [];\n }\n};\n\n// helper function to be bound to fullLayout to check\n// whether a certain plot type is present on plot\n// or trace has a category\nplots._hasPlotType = function(category) {\n var i;\n\n // check base plot modules\n var basePlotModules = this._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].name === category) return true;\n }\n\n // check trace modules (including non-visible:true)\n var modules = this._modules || [];\n for(i = 0; i < modules.length; i++) {\n var name = modules[i].name;\n if(name === category) return true;\n // N.B. this is modules[i] along with 'categories' as a hash object\n var _module = Registry.modules[name];\n if(_module && _module.categories[category]) return true;\n }\n\n return false;\n};\n\nplots.cleanPlot = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var i, j;\n\n var basePlotModules = oldFullLayout._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n var _module = basePlotModules[i];\n\n if(_module.clean) {\n _module.clean(newFullData, newFullLayout, oldFullData, oldFullLayout);\n }\n }\n\n var hadGl = oldFullLayout._has && oldFullLayout._has('gl');\n var hasGl = newFullLayout._has && newFullLayout._has('gl');\n\n if(hadGl && !hasGl) {\n if(oldFullLayout._glcontainer !== undefined) {\n oldFullLayout._glcontainer.selectAll('.gl-canvas').remove();\n oldFullLayout._glcontainer.selectAll('.no-webgl').remove();\n oldFullLayout._glcanvas = null;\n }\n }\n\n var hasInfoLayer = !!oldFullLayout._infolayer;\n\n oldLoop:\n for(i = 0; i < oldFullData.length; i++) {\n var oldTrace = oldFullData[i];\n var oldUid = oldTrace.uid;\n\n for(j = 0; j < newFullData.length; j++) {\n var newTrace = newFullData[j];\n\n if(oldUid === newTrace.uid) continue oldLoop;\n }\n\n // clean old colorbars\n if(hasInfoLayer) {\n oldFullLayout._infolayer.select('.cb' + oldUid).remove();\n }\n }\n};\n\nplots.linkSubplots = function(newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var i, j;\n\n var oldSubplots = oldFullLayout._plots || {};\n var newSubplots = newFullLayout._plots = {};\n var newSubplotList = newFullLayout._subplots;\n\n var mockGd = {\n _fullData: newFullData,\n _fullLayout: newFullLayout\n };\n\n var ids = newSubplotList.cartesian.concat(newSubplotList.gl2d || []);\n\n for(i = 0; i < ids.length; i++) {\n var id = ids[i];\n var oldSubplot = oldSubplots[id];\n var xaxis = axisIDs.getFromId(mockGd, id, 'x');\n var yaxis = axisIDs.getFromId(mockGd, id, 'y');\n var plotinfo;\n\n // link or create subplot object\n if(oldSubplot) {\n plotinfo = newSubplots[id] = oldSubplot;\n } else {\n plotinfo = newSubplots[id] = {};\n plotinfo.id = id;\n }\n\n // add these axis ids to each others' subplot lists\n xaxis._counterAxes.push(yaxis._id);\n yaxis._counterAxes.push(xaxis._id);\n xaxis._subplotsWith.push(id);\n yaxis._subplotsWith.push(id);\n\n // update x and y axis layout object refs\n plotinfo.xaxis = xaxis;\n plotinfo.yaxis = yaxis;\n\n // By default, we clip at the subplot level,\n // but if one trace on a given subplot has *cliponaxis* set to false,\n // we need to clip at the trace module layer level;\n // find this out here, once of for all.\n plotinfo._hasClipOnAxisFalse = false;\n\n for(j = 0; j < newFullData.length; j++) {\n var trace = newFullData[j];\n\n if(\n trace.xaxis === plotinfo.xaxis._id &&\n trace.yaxis === plotinfo.yaxis._id &&\n trace.cliponaxis === false\n ) {\n plotinfo._hasClipOnAxisFalse = true;\n break;\n }\n }\n }\n\n // while we're at it, link overlaying axes to their main axes and\n // anchored axes to the axes they're anchored to\n var axList = axisIDs.list(mockGd, null, true);\n var ax;\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n var mainAx = null;\n\n if(ax.overlaying) {\n mainAx = axisIDs.getFromId(mockGd, ax.overlaying);\n\n // you cannot overlay an axis that's already overlaying another\n if(mainAx && mainAx.overlaying) {\n ax.overlaying = false;\n mainAx = null;\n }\n }\n ax._mainAxis = mainAx || ax;\n\n /*\n * For now force overlays to overlay completely... so they\n * can drag together correctly and share backgrounds.\n * Later perhaps we make separate axis domain and\n * tick/line domain or something, so they can still share\n * the (possibly larger) dragger and background but don't\n * have to both be drawn over that whole domain\n */\n if(mainAx) ax.domain = mainAx.domain.slice();\n\n ax._anchorAxis = ax.anchor === 'free' ?\n null :\n axisIDs.getFromId(mockGd, ax.anchor);\n }\n\n // finally, we can find the main subplot for each axis\n // (on which the ticks & labels are drawn)\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n ax._counterAxes.sort(axisIDs.idSort);\n ax._subplotsWith.sort(Lib.subplotSort);\n ax._mainSubplot = findMainSubplot(ax, newFullLayout);\n\n // find \"full\" domain span of counter axes,\n // this loop can be costly, so only compute it when required\n if(ax._counterAxes.length && (\n (ax.spikemode && ax.spikemode.indexOf('across') !== -1) ||\n (ax.automargin && ax.mirror && ax.anchor !== 'free') ||\n Registry.getComponentMethod('rangeslider', 'isVisible')(ax)\n )) {\n var min = 1;\n var max = 0;\n for(j = 0; j < ax._counterAxes.length; j++) {\n var ax2 = axisIDs.getFromId(mockGd, ax._counterAxes[j]);\n min = Math.min(min, ax2.domain[0]);\n max = Math.max(max, ax2.domain[1]);\n }\n if(min < max) {\n ax._counterDomainMin = min;\n ax._counterDomainMax = max;\n }\n }\n }\n};\n\nfunction findMainSubplot(ax, fullLayout) {\n var mockGd = {_fullLayout: fullLayout};\n\n var isX = ax._id.charAt(0) === 'x';\n var anchorAx = ax._mainAxis._anchorAxis;\n var mainSubplotID = '';\n var nextBestMainSubplotID = '';\n var anchorID = '';\n\n // First try the main ID with the anchor\n if(anchorAx) {\n anchorID = anchorAx._mainAxis._id;\n mainSubplotID = isX ? (ax._id + anchorID) : (anchorID + ax._id);\n }\n\n // Then look for a subplot with the counteraxis overlaying the anchor\n // If that fails just use the first subplot including this axis\n if(!mainSubplotID || !fullLayout._plots[mainSubplotID]) {\n mainSubplotID = '';\n\n var counterIDs = ax._counterAxes;\n for(var j = 0; j < counterIDs.length; j++) {\n var counterPart = counterIDs[j];\n var id = isX ? (ax._id + counterPart) : (counterPart + ax._id);\n if(!nextBestMainSubplotID) nextBestMainSubplotID = id;\n var counterAx = axisIDs.getFromId(mockGd, counterPart);\n if(anchorID && counterAx.overlaying === anchorID) {\n mainSubplotID = id;\n break;\n }\n }\n }\n\n return mainSubplotID || nextBestMainSubplotID;\n}\n\n// This function clears any trace attributes with valType: color and\n// no set dflt filed in the plot schema. This is needed because groupby (which\n// is the only transform for which this currently applies) supplies parent\n// trace defaults, then expanded trace defaults. The result is that `null`\n// colors are default-supplied and inherited as a color instead of a null.\n// The result is that expanded trace default colors have no effect, with\n// the final result that groups are indistinguishable. This function clears\n// those colors so that individual groupby groups get unique colors.\nplots.clearExpandedTraceDefaultColors = function(trace) {\n var colorAttrs, path, i;\n\n // This uses weird closure state in order to satisfy the linter rule\n // that we can't create functions in a loop.\n function locateColorAttrs(attr, attrName, attrs, level) {\n path[level] = attrName;\n path.length = level + 1;\n if(attr.valType === 'color' && attr.dflt === undefined) {\n colorAttrs.push(path.join('.'));\n }\n }\n\n path = [];\n\n // Get the cached colorAttrs:\n colorAttrs = trace._module._colorAttrs;\n\n // Or else compute and cache the colorAttrs on the module:\n if(!colorAttrs) {\n trace._module._colorAttrs = colorAttrs = [];\n PlotSchema.crawl(\n trace._module.attributes,\n locateColorAttrs\n );\n }\n\n for(i = 0; i < colorAttrs.length; i++) {\n var origprop = Lib.nestedProperty(trace, '_input.' + colorAttrs[i]);\n\n if(!origprop.get()) {\n Lib.nestedProperty(trace, colorAttrs[i]).set(null);\n }\n }\n};\n\n\nplots.supplyDataDefaults = function(dataIn, dataOut, layout, fullLayout) {\n var modules = fullLayout._modules;\n var visibleModules = fullLayout._visibleModules;\n var basePlotModules = fullLayout._basePlotModules;\n var cnt = 0;\n var colorCnt = 0;\n\n var i, fullTrace, trace;\n\n fullLayout._transformModules = [];\n\n function pushModule(fullTrace) {\n dataOut.push(fullTrace);\n\n var _module = fullTrace._module;\n if(!_module) return;\n\n Lib.pushUnique(modules, _module);\n if(fullTrace.visible === true) Lib.pushUnique(visibleModules, _module);\n Lib.pushUnique(basePlotModules, fullTrace._module.basePlotModule);\n cnt++;\n\n // TODO: do we really want color not to increment for explicitly invisible traces?\n // This logic is weird, but matches previous behavior: traces that you explicitly\n // set to visible:false do not increment the color, but traces WE determine to be\n // empty or invalid (and thus set to visible:false) DO increment color.\n // I kind of think we should just let all traces increment color, visible or not.\n // see mock: axes-autotype-empty vs. a test of restyling visible: false that\n // I can't find right now...\n if(fullTrace._input.visible !== false) colorCnt++;\n }\n\n var carpetIndex = {};\n var carpetDependents = [];\n var dataTemplate = (layout.template || {}).data || {};\n var templater = Template.traceTemplater(dataTemplate);\n\n for(i = 0; i < dataIn.length; i++) {\n trace = dataIn[i];\n\n // reuse uid we may have pulled out of oldFullData\n // Note: templater supplies trace type\n fullTrace = templater.newTrace(trace);\n fullTrace.uid = fullLayout._traceUids[i];\n plots.supplyTraceDefaults(trace, fullTrace, colorCnt, fullLayout, i);\n\n fullTrace.index = i;\n fullTrace._input = trace;\n fullTrace._expandedIndex = cnt;\n\n if(fullTrace.transforms && fullTrace.transforms.length) {\n var sdInvisible = trace.visible !== false && fullTrace.visible === false;\n\n var expandedTraces = applyTransforms(fullTrace, dataOut, layout, fullLayout);\n\n for(var j = 0; j < expandedTraces.length; j++) {\n var expandedTrace = expandedTraces[j];\n\n // No further templating during transforms.\n var fullExpandedTrace = {\n _template: fullTrace._template,\n type: fullTrace.type,\n // set uid using parent uid and expanded index\n // to promote consistency between update calls\n uid: fullTrace.uid + j\n };\n\n // If the first supplyDefaults created `visible: false`,\n // clear it before running supplyDefaults a second time,\n // because sometimes there are items we still want to coerce\n // inside trace modules before determining that the trace is\n // again `visible: false`, for example partial visibilities\n // in `splom` traces.\n if(sdInvisible && expandedTrace.visible === false) {\n delete expandedTrace.visible;\n }\n\n plots.supplyTraceDefaults(expandedTrace, fullExpandedTrace, cnt, fullLayout, i);\n\n // relink private (i.e. underscore) keys expanded trace to full expanded trace so\n // that transform supply-default methods can set _ keys for future use.\n relinkPrivateKeys(fullExpandedTrace, expandedTrace);\n\n // add info about parent data trace\n fullExpandedTrace.index = i;\n fullExpandedTrace._input = trace;\n fullExpandedTrace._fullInput = fullTrace;\n\n // add info about the expanded data\n fullExpandedTrace._expandedIndex = cnt;\n fullExpandedTrace._expandedInput = expandedTrace;\n\n pushModule(fullExpandedTrace);\n }\n } else {\n // add identify refs for consistency with transformed traces\n fullTrace._fullInput = fullTrace;\n fullTrace._expandedInput = fullTrace;\n\n pushModule(fullTrace);\n }\n\n if(Registry.traceIs(fullTrace, 'carpetAxis')) {\n carpetIndex[fullTrace.carpet] = fullTrace;\n }\n\n if(Registry.traceIs(fullTrace, 'carpetDependent')) {\n carpetDependents.push(i);\n }\n }\n\n for(i = 0; i < carpetDependents.length; i++) {\n fullTrace = dataOut[carpetDependents[i]];\n\n if(!fullTrace.visible) continue;\n\n var carpetAxis = carpetIndex[fullTrace.carpet];\n fullTrace._carpet = carpetAxis;\n\n if(!carpetAxis || !carpetAxis.visible) {\n fullTrace.visible = false;\n continue;\n }\n\n fullTrace.xaxis = carpetAxis.xaxis;\n fullTrace.yaxis = carpetAxis.yaxis;\n }\n};\n\nplots.supplyAnimationDefaults = function(opts) {\n opts = opts || {};\n var i;\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs, attr, dflt);\n }\n\n coerce('mode');\n coerce('direction');\n coerce('fromcurrent');\n\n if(Array.isArray(opts.frame)) {\n optsOut.frame = [];\n for(i = 0; i < opts.frame.length; i++) {\n optsOut.frame[i] = plots.supplyAnimationFrameDefaults(opts.frame[i] || {});\n }\n } else {\n optsOut.frame = plots.supplyAnimationFrameDefaults(opts.frame || {});\n }\n\n if(Array.isArray(opts.transition)) {\n optsOut.transition = [];\n for(i = 0; i < opts.transition.length; i++) {\n optsOut.transition[i] = plots.supplyAnimationTransitionDefaults(opts.transition[i] || {});\n }\n } else {\n optsOut.transition = plots.supplyAnimationTransitionDefaults(opts.transition || {});\n }\n\n return optsOut;\n};\n\nplots.supplyAnimationFrameDefaults = function(opts) {\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs.frame, attr, dflt);\n }\n\n coerce('duration');\n coerce('redraw');\n\n return optsOut;\n};\n\nplots.supplyAnimationTransitionDefaults = function(opts) {\n var optsOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts || {}, optsOut, animationAttrs.transition, attr, dflt);\n }\n\n coerce('duration');\n coerce('easing');\n\n return optsOut;\n};\n\nplots.supplyFrameDefaults = function(frameIn) {\n var frameOut = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(frameIn, frameOut, frameAttrs, attr, dflt);\n }\n\n coerce('group');\n coerce('name');\n coerce('traces');\n coerce('baseframe');\n coerce('data');\n coerce('layout');\n\n return frameOut;\n};\n\nplots.supplyTraceDefaults = function(traceIn, traceOut, colorIndex, layout, traceInIndex) {\n var colorway = layout.colorway || Color.defaults;\n var defaultColor = colorway[colorIndex % colorway.length];\n\n var i;\n\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, plots.attributes, attr, dflt);\n }\n\n var visible = coerce('visible');\n\n coerce('type');\n coerce('name', layout._traceWord + ' ' + traceInIndex);\n\n coerce('uirevision', layout.uirevision);\n\n // we want even invisible traces to make their would-be subplots visible\n // so coerce the subplot id(s) now no matter what\n var _module = plots.getModule(traceOut);\n\n traceOut._module = _module;\n if(_module) {\n var basePlotModule = _module.basePlotModule;\n var subplotAttr = basePlotModule.attr;\n var subplotAttrs = basePlotModule.attributes;\n if(subplotAttr && subplotAttrs) {\n var subplots = layout._subplots;\n var subplotId = '';\n\n if(\n visible ||\n basePlotModule.name !== 'gl2d' // for now just drop empty gl2d subplots\n // TODO - currently if we draw an empty gl2d subplot, it draws\n // nothing then gets stuck and you can't get it back without newPlot\n // sort this out in the regl refactor?\n ) {\n if(Array.isArray(subplotAttr)) {\n for(i = 0; i < subplotAttr.length; i++) {\n var attri = subplotAttr[i];\n var vali = Lib.coerce(traceIn, traceOut, subplotAttrs, attri);\n\n if(subplots[attri]) Lib.pushUnique(subplots[attri], vali);\n subplotId += vali;\n }\n } else {\n subplotId = Lib.coerce(traceIn, traceOut, subplotAttrs, subplotAttr);\n }\n\n if(subplots[basePlotModule.name]) {\n Lib.pushUnique(subplots[basePlotModule.name], subplotId);\n }\n }\n }\n }\n\n if(visible) {\n coerce('customdata');\n coerce('ids');\n coerce('meta');\n\n if(Registry.traceIs(traceOut, 'showLegend')) {\n Lib.coerce(traceIn, traceOut,\n _module.attributes.showlegend ? _module.attributes : plots.attributes,\n 'showlegend'\n );\n\n coerce('legendgroup');\n\n traceOut._dfltShowLegend = true;\n } else {\n traceOut._dfltShowLegend = false;\n }\n\n if(_module) {\n _module.supplyDefaults(traceIn, traceOut, defaultColor, layout);\n }\n\n if(!Registry.traceIs(traceOut, 'noOpacity')) {\n coerce('opacity');\n }\n\n if(Registry.traceIs(traceOut, 'notLegendIsolatable')) {\n // This clears out the legendonly state for traces like carpet that\n // cannot be isolated in the legend\n traceOut.visible = !!traceOut.visible;\n }\n\n if(!Registry.traceIs(traceOut, 'noHover')) {\n if(!traceOut.hovertemplate) Lib.coerceHoverinfo(traceIn, traceOut, layout);\n\n // parcats support hover, but not hoverlabel stylings (yet)\n if(traceOut.type !== 'parcats') {\n Registry.getComponentMethod('fx', 'supplyDefaults')(traceIn, traceOut, defaultColor, layout);\n }\n }\n\n if(_module && _module.selectPoints) {\n coerce('selectedpoints');\n }\n\n plots.supplyTransformDefaults(traceIn, traceOut, layout);\n }\n\n return traceOut;\n};\n\n/**\n * hasMakesDataTransform: does this trace have a transform that makes its own\n * data, either by grabbing it from somewhere else or by creating it from input\n * parameters? If so, we should still keep going with supplyDefaults\n * even if the trace is invisible, which may just be because it has no data yet.\n */\nfunction hasMakesDataTransform(trace) {\n var transforms = trace.transforms;\n if(Array.isArray(transforms) && transforms.length) {\n for(var i = 0; i < transforms.length; i++) {\n var ti = transforms[i];\n var _module = ti._module || transformsRegistry[ti.type];\n if(_module && _module.makesData) return true;\n }\n }\n return false;\n}\n\nplots.hasMakesDataTransform = hasMakesDataTransform;\n\nplots.supplyTransformDefaults = function(traceIn, traceOut, layout) {\n // For now we only allow transforms on 1D traces, ie those that specify a _length.\n // If we were to implement 2D transforms, we'd need to have each transform\n // describe its own applicability and disable itself when it doesn't apply.\n // Also allow transforms that make their own data, but not in globalTransforms\n if(!(traceOut._length || hasMakesDataTransform(traceIn))) return;\n\n var globalTransforms = layout._globalTransforms || [];\n var transformModules = layout._transformModules || [];\n\n if(!Array.isArray(traceIn.transforms) && globalTransforms.length === 0) return;\n\n var containerIn = traceIn.transforms || [];\n var transformList = globalTransforms.concat(containerIn);\n var containerOut = traceOut.transforms = [];\n\n for(var i = 0; i < transformList.length; i++) {\n var transformIn = transformList[i];\n var type = transformIn.type;\n var _module = transformsRegistry[type];\n var transformOut;\n\n /*\n * Supply defaults may run twice. First pass runs all supply defaults steps\n * and adds the _module to any output transforms.\n * If transforms exist another pass is run so that any generated traces also\n * go through supply defaults. This has the effect of rerunning\n * supplyTransformDefaults. If the transform does not have a `transform`\n * function it could not have generated any new traces and the second stage\n * is unnecessary. We detect this case with the following variables.\n */\n var isFirstStage = !(transformIn._module && transformIn._module === _module);\n var doLaterStages = _module && typeof _module.transform === 'function';\n\n if(!_module) Lib.warn('Unrecognized transform type ' + type + '.');\n\n if(_module && _module.supplyDefaults && (isFirstStage || doLaterStages)) {\n transformOut = _module.supplyDefaults(transformIn, traceOut, layout, traceIn);\n transformOut.type = type;\n transformOut._module = _module;\n\n Lib.pushUnique(transformModules, _module);\n } else {\n transformOut = Lib.extendFlat({}, transformIn);\n }\n\n containerOut.push(transformOut);\n }\n};\n\nfunction applyTransforms(fullTrace, fullData, layout, fullLayout) {\n var container = fullTrace.transforms;\n var dataOut = [fullTrace];\n\n for(var i = 0; i < container.length; i++) {\n var transform = container[i];\n var _module = transformsRegistry[transform.type];\n\n if(_module && _module.transform) {\n dataOut = _module.transform(dataOut, {\n transform: transform,\n fullTrace: fullTrace,\n fullData: fullData,\n layout: layout,\n fullLayout: fullLayout,\n transformIndex: i\n });\n }\n }\n\n return dataOut;\n}\n\nplots.supplyLayoutGlobalDefaults = function(layoutIn, layoutOut, formatObj) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, plots.layoutAttributes, attr, dflt);\n }\n\n var template = layoutIn.template;\n if(Lib.isPlainObject(template)) {\n layoutOut.template = template;\n layoutOut._template = template.layout;\n layoutOut._dataTemplate = template.data;\n }\n\n var globalFont = Lib.coerceFont(coerce, 'font');\n\n coerce('title.text', layoutOut._dfltTitle.plot);\n\n Lib.coerceFont(coerce, 'title.font', {\n family: globalFont.family,\n size: Math.round(globalFont.size * 1.4),\n color: globalFont.color\n });\n\n coerce('title.xref');\n coerce('title.yref');\n coerce('title.x');\n coerce('title.y');\n coerce('title.xanchor');\n coerce('title.yanchor');\n coerce('title.pad.t');\n coerce('title.pad.r');\n coerce('title.pad.b');\n coerce('title.pad.l');\n\n var uniformtextMode = coerce('uniformtext.mode');\n if(uniformtextMode) {\n coerce('uniformtext.minsize');\n }\n\n // Make sure that autosize is defaulted to *true*\n // on layouts with no set width and height for backward compatibly,\n // in particular https://plotly.com/javascript/responsive-fluid-layout/\n //\n // Before https://github.com/plotly/plotly.js/pull/635 ,\n // layouts with no set width and height were set temporary set to 'initial'\n // to pass through the autosize routine\n //\n // This behavior is subject to change in v2.\n coerce('autosize', !(layoutIn.width && layoutIn.height));\n\n coerce('width');\n coerce('height');\n coerce('margin.l');\n coerce('margin.r');\n coerce('margin.t');\n coerce('margin.b');\n coerce('margin.pad');\n coerce('margin.autoexpand');\n\n if(layoutIn.width && layoutIn.height) plots.sanitizeMargins(layoutOut);\n\n Registry.getComponentMethod('grid', 'sizeDefaults')(layoutIn, layoutOut);\n\n coerce('paper_bgcolor');\n\n coerce('separators', formatObj.decimal + formatObj.thousands);\n coerce('hidesources');\n\n coerce('colorway');\n\n coerce('datarevision');\n var uirevision = coerce('uirevision');\n coerce('editrevision', uirevision);\n coerce('selectionrevision', uirevision);\n\n coerce('modebar.orientation');\n coerce('modebar.bgcolor', Color.addOpacity(layoutOut.paper_bgcolor, 0.5));\n var modebarDefaultColor = Color.contrast(Color.rgb(layoutOut.modebar.bgcolor));\n coerce('modebar.color', Color.addOpacity(modebarDefaultColor, 0.3));\n coerce('modebar.activecolor', Color.addOpacity(modebarDefaultColor, 0.7));\n coerce('modebar.uirevision', uirevision);\n\n coerce('meta');\n\n // do not include defaults in fullLayout when users do not set transition\n if(Lib.isPlainObject(layoutIn.transition)) {\n coerce('transition.duration');\n coerce('transition.easing');\n coerce('transition.ordering');\n }\n\n Registry.getComponentMethod(\n 'calendars',\n 'handleDefaults'\n )(layoutIn, layoutOut, 'calendar');\n\n Registry.getComponentMethod(\n 'fx',\n 'supplyLayoutGlobalDefaults'\n )(layoutIn, layoutOut, coerce);\n};\n\nplots.plotAutoSize = function plotAutoSize(gd, layout, fullLayout) {\n var context = gd._context || {};\n var frameMargins = context.frameMargins;\n var newWidth;\n var newHeight;\n\n var isPlotDiv = Lib.isPlotDiv(gd);\n\n if(isPlotDiv) gd.emit('plotly_autosize');\n\n // embedded in an iframe - just take the full iframe size\n // if we get to this point, with no aspect ratio restrictions\n if(context.fillFrame) {\n newWidth = window.innerWidth;\n newHeight = window.innerHeight;\n\n // somehow we get a few extra px height sometimes...\n // just hide it\n document.body.style.overflow = 'hidden';\n } else {\n // plotly.js - let the developers do what they want, either\n // provide height and width for the container div,\n // specify size in layout, or take the defaults,\n // but don't enforce any ratio restrictions\n var computedStyle = isPlotDiv ? window.getComputedStyle(gd) : {};\n\n newWidth = parseFloat(computedStyle.width) || parseFloat(computedStyle.maxWidth) || fullLayout.width;\n newHeight = parseFloat(computedStyle.height) || parseFloat(computedStyle.maxHeight) || fullLayout.height;\n\n if(isNumeric(frameMargins) && frameMargins > 0) {\n var factor = 1 - 2 * frameMargins;\n newWidth = Math.round(factor * newWidth);\n newHeight = Math.round(factor * newHeight);\n }\n }\n\n var minWidth = plots.layoutAttributes.width.min;\n var minHeight = plots.layoutAttributes.height.min;\n if(newWidth < minWidth) newWidth = minWidth;\n if(newHeight < minHeight) newHeight = minHeight;\n\n var widthHasChanged = !layout.width &&\n (Math.abs(fullLayout.width - newWidth) > 1);\n var heightHasChanged = !layout.height &&\n (Math.abs(fullLayout.height - newHeight) > 1);\n\n if(heightHasChanged || widthHasChanged) {\n if(widthHasChanged) fullLayout.width = newWidth;\n if(heightHasChanged) fullLayout.height = newHeight;\n }\n\n // cache initial autosize value, used in relayout when\n // width or height values are set to null\n if(!gd._initialAutoSize) {\n gd._initialAutoSize = { width: newWidth, height: newHeight };\n }\n\n plots.sanitizeMargins(fullLayout);\n};\n\nplots.supplyLayoutModuleDefaults = function(layoutIn, layoutOut, fullData, transitionData) {\n var componentsRegistry = Registry.componentsRegistry;\n var basePlotModules = layoutOut._basePlotModules;\n var component, i, _module;\n\n var Cartesian = Registry.subplotsRegistry.cartesian;\n\n // check if any components need to add more base plot modules\n // that weren't captured by traces\n for(component in componentsRegistry) {\n _module = componentsRegistry[component];\n\n if(_module.includeBasePlot) {\n _module.includeBasePlot(layoutIn, layoutOut);\n }\n }\n\n // make sure we *at least* have some cartesian axes\n if(!basePlotModules.length) {\n basePlotModules.push(Cartesian);\n }\n\n // ensure all cartesian axes have at least one subplot\n if(layoutOut._has('cartesian')) {\n Registry.getComponentMethod('grid', 'contentDefaults')(layoutIn, layoutOut);\n Cartesian.finalizeSubplots(layoutIn, layoutOut);\n }\n\n // sort subplot lists\n for(var subplotType in layoutOut._subplots) {\n layoutOut._subplots[subplotType].sort(Lib.subplotSort);\n }\n\n // base plot module layout defaults\n for(i = 0; i < basePlotModules.length; i++) {\n _module = basePlotModules[i];\n\n // e.g. pie does not have a layout-defaults step\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n\n // trace module layout defaults\n // use _modules rather than _visibleModules so that even\n // legendonly traces can include settings - eg barmode, which affects\n // legend.traceorder default value.\n var modules = layoutOut._modules;\n for(i = 0; i < modules.length; i++) {\n _module = modules[i];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n\n // transform module layout defaults\n var transformModules = layoutOut._transformModules;\n for(i = 0; i < transformModules.length; i++) {\n _module = transformModules[i];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData, transitionData);\n }\n }\n\n for(component in componentsRegistry) {\n _module = componentsRegistry[component];\n\n if(_module.supplyLayoutDefaults) {\n _module.supplyLayoutDefaults(layoutIn, layoutOut, fullData);\n }\n }\n};\n\n// Remove all plotly attributes from a div so it can be replotted fresh\n// TODO: these really need to be encapsulated into a much smaller set...\nplots.purge = function(gd) {\n // note: we DO NOT remove _context because it doesn't change when we insert\n // a new plot, and may have been set outside of our scope.\n\n var fullLayout = gd._fullLayout || {};\n if(fullLayout._glcontainer !== undefined) {\n fullLayout._glcontainer.selectAll('.gl-canvas').remove();\n fullLayout._glcontainer.remove();\n fullLayout._glcanvas = null;\n }\n\n // remove modebar\n if(fullLayout._modeBar) fullLayout._modeBar.destroy();\n\n if(gd._transitionData) {\n // Ensure any dangling callbacks are simply dropped if the plot is purged.\n // This is more or less only actually important for testing.\n if(gd._transitionData._interruptCallbacks) {\n gd._transitionData._interruptCallbacks.length = 0;\n }\n\n if(gd._transitionData._animationRaf) {\n window.cancelAnimationFrame(gd._transitionData._animationRaf);\n }\n }\n\n // remove any planned throttles\n Lib.clearThrottle();\n\n // remove responsive handler\n Lib.clearResponsive(gd);\n\n // data and layout\n delete gd.data;\n delete gd.layout;\n delete gd._fullData;\n delete gd._fullLayout;\n delete gd.calcdata;\n delete gd.framework;\n delete gd.empty;\n\n delete gd.fid;\n\n delete gd.undoqueue; // action queue\n delete gd.undonum;\n delete gd.autoplay; // are we doing an action that doesn't go in undo queue?\n delete gd.changed;\n\n // these get recreated on Plotly.plot anyway, but just to be safe\n // (and to have a record of them...)\n delete gd._promises;\n delete gd._redrawTimer;\n delete gd._hmlumcount;\n delete gd._hmpixcount;\n delete gd._transitionData;\n delete gd._transitioning;\n delete gd._initialAutoSize;\n delete gd._transitioningWithDuration;\n\n // created during certain events, that *should* clean them up\n // themselves, but may not if there was an error\n delete gd._dragging;\n delete gd._dragged;\n delete gd._dragdata;\n delete gd._hoverdata;\n delete gd._snapshotInProgress;\n delete gd._editing;\n delete gd._mouseDownTime;\n delete gd._legendMouseDownTime;\n\n // remove all event listeners\n if(gd.removeAllListeners) gd.removeAllListeners();\n};\n\nplots.style = function(gd) {\n var _modules = gd._fullLayout._visibleModules;\n var styleModules = [];\n var i;\n\n // some trace modules reuse the same style method,\n // make sure to not unnecessary call them multiple times.\n\n for(i = 0; i < _modules.length; i++) {\n var _module = _modules[i];\n if(_module.style) {\n Lib.pushUnique(styleModules, _module.style);\n }\n }\n\n for(i = 0; i < styleModules.length; i++) {\n styleModules[i](gd);\n }\n};\n\nplots.sanitizeMargins = function(fullLayout) {\n // polar doesn't do margins...\n if(!fullLayout || !fullLayout.margin) return;\n\n var width = fullLayout.width;\n var height = fullLayout.height;\n var margin = fullLayout.margin;\n var plotWidth = width - (margin.l + margin.r);\n var plotHeight = height - (margin.t + margin.b);\n var correction;\n\n // if margin.l + margin.r = 0 then plotWidth > 0\n // as width >= 10 by supplyDefaults\n // similarly for margin.t + margin.b\n\n if(plotWidth < 0) {\n correction = (width - 1) / (margin.l + margin.r);\n margin.l = Math.floor(correction * margin.l);\n margin.r = Math.floor(correction * margin.r);\n }\n\n if(plotHeight < 0) {\n correction = (height - 1) / (margin.t + margin.b);\n margin.t = Math.floor(correction * margin.t);\n margin.b = Math.floor(correction * margin.b);\n }\n};\n\nplots.clearAutoMarginIds = function(gd) {\n gd._fullLayout._pushmarginIds = {};\n};\n\nplots.allowAutoMargin = function(gd, id) {\n gd._fullLayout._pushmarginIds[id] = 1;\n};\n\nfunction initMargins(fullLayout) {\n var margin = fullLayout.margin;\n\n if(!fullLayout._size) {\n var gs = fullLayout._size = {\n l: Math.round(margin.l),\n r: Math.round(margin.r),\n t: Math.round(margin.t),\n b: Math.round(margin.b),\n p: Math.round(margin.pad)\n };\n gs.w = Math.round(fullLayout.width) - gs.l - gs.r;\n gs.h = Math.round(fullLayout.height) - gs.t - gs.b;\n }\n if(!fullLayout._pushmargin) fullLayout._pushmargin = {};\n if(!fullLayout._pushmarginIds) fullLayout._pushmarginIds = {};\n}\n\n/**\n * autoMargin: called by components that may need to expand the margins to\n * be rendered on-plot.\n *\n * @param {DOM element} gd\n * @param {string} id - an identifier unique (within this plot) to this object,\n * so we can remove a previous margin expansion from the same object.\n * @param {object} o - the margin requirements of this object, or omit to delete\n * this entry (like if it's hidden). Keys are:\n * x, y: plot fraction of the anchor point.\n * xl, xr, yt, yb: if the object has an extent defined in plot fraction,\n * you can specify both edges as plot fractions in each dimension\n * l, r, t, b: the pixels to pad past the plot fraction x[l|r] and y[t|b]\n * pad: extra pixels to add in all directions, default 12 (why?)\n */\nplots.autoMargin = function(gd, id, o) {\n var fullLayout = gd._fullLayout;\n\n var pushMargin = fullLayout._pushmargin;\n var pushMarginIds = fullLayout._pushmarginIds;\n\n if(fullLayout.margin.autoexpand !== false) {\n if(!o) {\n delete pushMargin[id];\n delete pushMarginIds[id];\n } else {\n var pad = o.pad;\n if(pad === undefined) {\n var margin = fullLayout.margin;\n // if no explicit pad is given, use 12px unless there's a\n // specified margin that's smaller than that\n pad = Math.min(12, margin.l, margin.r, margin.t, margin.b);\n }\n\n // if the item is too big, just give it enough automargin to\n // make sure you can still grab it and bring it back\n if(o.l + o.r > fullLayout.width * 0.5) {\n Lib.log('Margin push', id, 'is too big in x, dropping');\n o.l = o.r = 0;\n }\n if(o.b + o.t > fullLayout.height * 0.5) {\n Lib.log('Margin push', id, 'is too big in y, dropping');\n o.b = o.t = 0;\n }\n\n var xl = o.xl !== undefined ? o.xl : o.x;\n var xr = o.xr !== undefined ? o.xr : o.x;\n var yt = o.yt !== undefined ? o.yt : o.y;\n var yb = o.yb !== undefined ? o.yb : o.y;\n\n pushMargin[id] = {\n l: {val: xl, size: o.l + pad},\n r: {val: xr, size: o.r + pad},\n b: {val: yb, size: o.b + pad},\n t: {val: yt, size: o.t + pad}\n };\n pushMarginIds[id] = 1;\n }\n\n if(!fullLayout._replotting) {\n return plots.doAutoMargin(gd);\n }\n }\n};\n\nplots.doAutoMargin = function(gd) {\n var fullLayout = gd._fullLayout;\n if(!fullLayout._size) fullLayout._size = {};\n initMargins(fullLayout);\n\n var gs = fullLayout._size;\n var margin = fullLayout.margin;\n var oldMargins = Lib.extendFlat({}, gs);\n\n // adjust margins for outside components\n // fullLayout.margin is the requested margin,\n // fullLayout._size has margins and plotsize after adjustment\n var ml = margin.l;\n var mr = margin.r;\n var mt = margin.t;\n var mb = margin.b;\n var width = fullLayout.width;\n var height = fullLayout.height;\n var pushMargin = fullLayout._pushmargin;\n var pushMarginIds = fullLayout._pushmarginIds;\n\n if(fullLayout.margin.autoexpand !== false) {\n for(var k in pushMargin) {\n if(!pushMarginIds[k]) delete pushMargin[k];\n }\n\n // fill in the requested margins\n pushMargin.base = {\n l: {val: 0, size: ml},\n r: {val: 1, size: mr},\n t: {val: 1, size: mt},\n b: {val: 0, size: mb}\n };\n\n // now cycle through all the combinations of l and r\n // (and t and b) to find the required margins\n\n for(var k1 in pushMargin) {\n var pushleft = pushMargin[k1].l || {};\n var pushbottom = pushMargin[k1].b || {};\n var fl = pushleft.val;\n var pl = pushleft.size;\n var fb = pushbottom.val;\n var pb = pushbottom.size;\n\n for(var k2 in pushMargin) {\n if(isNumeric(pl) && pushMargin[k2].r) {\n var fr = pushMargin[k2].r.val;\n var pr = pushMargin[k2].r.size;\n\n if(fr > fl) {\n var newL = (pl * fr + (pr - width) * fl) / (fr - fl);\n var newR = (pr * (1 - fl) + (pl - width) * (1 - fr)) / (fr - fl);\n if(newL >= 0 && newR >= 0 && width - (newL + newR) > 0 && newL + newR > ml + mr) {\n ml = newL;\n mr = newR;\n }\n }\n }\n\n if(isNumeric(pb) && pushMargin[k2].t) {\n var ft = pushMargin[k2].t.val;\n var pt = pushMargin[k2].t.size;\n\n if(ft > fb) {\n var newB = (pb * ft + (pt - height) * fb) / (ft - fb);\n var newT = (pt * (1 - fb) + (pb - height) * (1 - ft)) / (ft - fb);\n if(newB >= 0 && newT >= 0 && height - (newT + newB) > 0 && newB + newT > mb + mt) {\n mb = newB;\n mt = newT;\n }\n }\n }\n }\n }\n }\n\n gs.l = Math.round(ml);\n gs.r = Math.round(mr);\n gs.t = Math.round(mt);\n gs.b = Math.round(mb);\n gs.p = Math.round(margin.pad);\n gs.w = Math.round(width) - gs.l - gs.r;\n gs.h = Math.round(height) - gs.t - gs.b;\n\n // if things changed and we're not already redrawing, trigger a redraw\n if(!fullLayout._replotting && plots.didMarginChange(oldMargins, gs)) {\n if('_redrawFromAutoMarginCount' in fullLayout) {\n fullLayout._redrawFromAutoMarginCount++;\n } else {\n fullLayout._redrawFromAutoMarginCount = 1;\n }\n\n // Always allow at least one redraw and give each margin-push\n // call 3 loops to converge. Of course, for most cases this way too many,\n // but let's keep things on the safe side until we fix our\n // auto-margin pipeline problems:\n // https://github.com/plotly/plotly.js/issues/2704\n var maxNumberOfRedraws = 3 * (1 + Object.keys(pushMarginIds).length);\n\n if(fullLayout._redrawFromAutoMarginCount < maxNumberOfRedraws) {\n return Registry.call('plot', gd);\n } else {\n Lib.warn('Too many auto-margin redraws.');\n }\n }\n};\n\nvar marginKeys = ['l', 'r', 't', 'b', 'p', 'w', 'h'];\n\nplots.didMarginChange = function(margin0, margin1) {\n for(var i = 0; i < marginKeys.length; i++) {\n var k = marginKeys[i];\n var m0 = margin0[k];\n var m1 = margin1[k];\n // use 1px tolerance in case we old/new differ only\n // by rounding errors, which can lead to infinite loops\n if(!isNumeric(m0) || Math.abs(m1 - m0) > 1) {\n return true;\n }\n }\n return false;\n};\n\n/**\n * JSONify the graph data and layout\n *\n * This function needs to recurse because some src can be inside\n * sub-objects.\n *\n * It also strips out functions and private (starts with _) elements.\n * Therefore, we can add temporary things to data and layout that don't\n * get saved.\n *\n * @param gd The graphDiv\n * @param {Boolean} dataonly If true, don't return layout.\n * @param {'keepref'|'keepdata'|'keepall'} [mode='keepref'] Filter what's kept\n * keepref: remove data for which there's a src present\n * eg if there's xsrc present (and xsrc is well-formed,\n * ie has : and some chars before it), strip out x\n * keepdata: remove all src tags, don't remove the data itself\n * keepall: keep data and src\n * @param {String} output If you specify 'object', the result will not be stringified\n * @param {Boolean} useDefaults If truthy, use _fullLayout and _fullData\n * @param {Boolean} includeConfig If truthy, include _context\n * @returns {Object|String}\n */\nplots.graphJson = function(gd, dataonly, mode, output, useDefaults, includeConfig) {\n // if the defaults aren't supplied yet, we need to do that...\n if((useDefaults && dataonly && !gd._fullData) ||\n (useDefaults && !dataonly && !gd._fullLayout)) {\n plots.supplyDefaults(gd);\n }\n\n var data = (useDefaults) ? gd._fullData : gd.data;\n var layout = (useDefaults) ? gd._fullLayout : gd.layout;\n var frames = (gd._transitionData || {})._frames;\n\n function stripObj(d, keepFunction) {\n if(typeof d === 'function') {\n return keepFunction ? '_function_' : null;\n }\n if(Lib.isPlainObject(d)) {\n var o = {};\n var src;\n Object.keys(d).sort().forEach(function(v) {\n // remove private elements and functions\n // _ is for private, [ is a mistake ie [object Object]\n if(['_', '['].indexOf(v.charAt(0)) !== -1) return;\n\n // if a function, add if necessary then move on\n if(typeof d[v] === 'function') {\n if(keepFunction) o[v] = '_function';\n return;\n }\n\n // look for src/data matches and remove the appropriate one\n if(mode === 'keepdata') {\n // keepdata: remove all ...src tags\n if(v.substr(v.length - 3) === 'src') {\n return;\n }\n } else if(mode === 'keepstream') {\n // keep sourced data if it's being streamed.\n // similar to keepref, but if the 'stream' object exists\n // in a trace, we will keep the data array.\n src = d[v + 'src'];\n if(typeof src === 'string' && src.indexOf(':') > 0) {\n if(!Lib.isPlainObject(d.stream)) {\n return;\n }\n }\n } else if(mode !== 'keepall') {\n // keepref: remove sourced data but only\n // if the source tag is well-formed\n src = d[v + 'src'];\n if(typeof src === 'string' && src.indexOf(':') > 0) {\n return;\n }\n }\n\n // OK, we're including this... recurse into it\n o[v] = stripObj(d[v], keepFunction);\n });\n return o;\n }\n\n if(Array.isArray(d)) {\n return d.map(function(x) {return stripObj(x, keepFunction);});\n }\n\n if(Lib.isTypedArray(d)) {\n return Lib.simpleMap(d, Lib.identity);\n }\n\n // convert native dates to date strings...\n // mostly for external users exporting to plotly\n if(Lib.isJSDate(d)) return Lib.ms2DateTimeLocal(+d);\n\n return d;\n }\n\n var obj = {\n data: (data || []).map(function(v) {\n var d = stripObj(v);\n // fit has some little arrays in it that don't contain data,\n // just fit params and meta\n if(dataonly) { delete d.fit; }\n return d;\n })\n };\n if(!dataonly) { obj.layout = stripObj(layout); }\n\n if(gd.framework && gd.framework.isPolar) obj = gd.framework.getConfig();\n\n if(frames) obj.frames = stripObj(frames);\n\n if(includeConfig) obj.config = stripObj(gd._context, true);\n\n return (output === 'object') ? obj : JSON.stringify(obj);\n};\n\n/**\n * Modify a keyframe using a list of operations:\n *\n * @param {array of objects} operations\n * Sequence of operations to be performed on the keyframes\n */\nplots.modifyFrames = function(gd, operations) {\n var i, op, frame;\n var _frames = gd._transitionData._frames;\n var _frameHash = gd._transitionData._frameHash;\n\n for(i = 0; i < operations.length; i++) {\n op = operations[i];\n\n switch(op.type) {\n // No reason this couldn't exist, but is currently unused/untested:\n /* case 'rename':\n frame = _frames[op.index];\n delete _frameHash[frame.name];\n _frameHash[op.name] = frame;\n frame.name = op.name;\n break;*/\n case 'replace':\n frame = op.value;\n var oldName = (_frames[op.index] || {}).name;\n var newName = frame.name;\n _frames[op.index] = _frameHash[newName] = frame;\n\n if(newName !== oldName) {\n // If name has changed in addition to replacement, then update\n // the lookup table:\n delete _frameHash[oldName];\n _frameHash[newName] = frame;\n }\n\n break;\n case 'insert':\n frame = op.value;\n _frameHash[frame.name] = frame;\n _frames.splice(op.index, 0, frame);\n break;\n case 'delete':\n frame = _frames[op.index];\n delete _frameHash[frame.name];\n _frames.splice(op.index, 1);\n break;\n }\n }\n\n return Promise.resolve();\n};\n\n/*\n * Compute a keyframe. Merge a keyframe into its base frame(s) and\n * expand properties.\n *\n * @param {object} frameLookup\n * An object containing frames keyed by name (i.e. gd._transitionData._frameHash)\n * @param {string} frame\n * The name of the keyframe to be computed\n *\n * Returns: a new object with the merged content\n */\nplots.computeFrame = function(gd, frameName) {\n var frameLookup = gd._transitionData._frameHash;\n var i, traceIndices, traceIndex, destIndex;\n\n // Null or undefined will fail on .toString(). We'll allow numbers since we\n // make it clear frames must be given string names, but we'll allow numbers\n // here since they're otherwise fine for looking up frames as long as they're\n // properly cast to strings. We really just want to ensure here that this\n // 1) doesn't fail, and\n // 2) doens't give an incorrect answer (which String(frameName) would)\n if(!frameName) {\n throw new Error('computeFrame must be given a string frame name');\n }\n\n var framePtr = frameLookup[frameName.toString()];\n\n // Return false if the name is invalid:\n if(!framePtr) {\n return false;\n }\n\n var frameStack = [framePtr];\n var frameNameStack = [framePtr.name];\n\n // Follow frame pointers:\n while(framePtr.baseframe && (framePtr = frameLookup[framePtr.baseframe.toString()])) {\n // Avoid infinite loops:\n if(frameNameStack.indexOf(framePtr.name) !== -1) break;\n\n frameStack.push(framePtr);\n frameNameStack.push(framePtr.name);\n }\n\n // A new object for the merged result:\n var result = {};\n\n // Merge, starting with the last and ending with the desired frame:\n while((framePtr = frameStack.pop())) {\n if(framePtr.layout) {\n result.layout = plots.extendLayout(result.layout, framePtr.layout);\n }\n\n if(framePtr.data) {\n if(!result.data) {\n result.data = [];\n }\n traceIndices = framePtr.traces;\n\n if(!traceIndices) {\n // If not defined, assume serial order starting at zero\n traceIndices = [];\n for(i = 0; i < framePtr.data.length; i++) {\n traceIndices[i] = i;\n }\n }\n\n if(!result.traces) {\n result.traces = [];\n }\n\n for(i = 0; i < framePtr.data.length; i++) {\n // Loop through this frames data, find out where it should go,\n // and merge it!\n traceIndex = traceIndices[i];\n if(traceIndex === undefined || traceIndex === null) {\n continue;\n }\n\n destIndex = result.traces.indexOf(traceIndex);\n if(destIndex === -1) {\n destIndex = result.data.length;\n result.traces[destIndex] = traceIndex;\n }\n\n result.data[destIndex] = plots.extendTrace(result.data[destIndex], framePtr.data[i]);\n }\n }\n }\n\n return result;\n};\n\n/*\n * Recompute the lookup table that maps frame name -> frame object. addFrames/\n * deleteFrames already manages this data one at a time, so the only time this\n * is necessary is if you poke around manually in `gd._transitionData._frames`\n * and create and haven't updated the lookup table.\n */\nplots.recomputeFrameHash = function(gd) {\n var hash = gd._transitionData._frameHash = {};\n var frames = gd._transitionData._frames;\n for(var i = 0; i < frames.length; i++) {\n var frame = frames[i];\n if(frame && frame.name) {\n hash[frame.name] = frame;\n }\n }\n};\n\n/**\n * Extend an object, treating container arrays very differently by extracting\n * their contents and merging them separately.\n *\n * This exists so that we can extendDeepNoArrays and avoid stepping into data\n * arrays without knowledge of the plot schema, but so that we may also manually\n * recurse into known container arrays, such as transforms.\n *\n * See extendTrace and extendLayout below for usage.\n */\nplots.extendObjectWithContainers = function(dest, src, containerPaths) {\n var containerProp, containerVal, i, j, srcProp, destProp, srcContainer, destContainer;\n var copy = Lib.extendDeepNoArrays({}, src || {});\n var expandedObj = Lib.expandObjectPaths(copy);\n var containerObj = {};\n\n // Step through and extract any container properties. Otherwise extendDeepNoArrays\n // will clobber any existing properties with an empty array and then supplyDefaults\n // will reset everything to defaults.\n if(containerPaths && containerPaths.length) {\n for(i = 0; i < containerPaths.length; i++) {\n containerProp = Lib.nestedProperty(expandedObj, containerPaths[i]);\n containerVal = containerProp.get();\n\n if(containerVal === undefined) {\n Lib.nestedProperty(containerObj, containerPaths[i]).set(null);\n } else {\n containerProp.set(null);\n Lib.nestedProperty(containerObj, containerPaths[i]).set(containerVal);\n }\n }\n }\n\n dest = Lib.extendDeepNoArrays(dest || {}, expandedObj);\n\n if(containerPaths && containerPaths.length) {\n for(i = 0; i < containerPaths.length; i++) {\n srcProp = Lib.nestedProperty(containerObj, containerPaths[i]);\n srcContainer = srcProp.get();\n\n if(!srcContainer) continue;\n\n destProp = Lib.nestedProperty(dest, containerPaths[i]);\n destContainer = destProp.get();\n\n if(!Array.isArray(destContainer)) {\n destContainer = [];\n destProp.set(destContainer);\n }\n\n for(j = 0; j < srcContainer.length; j++) {\n var srcObj = srcContainer[j];\n\n if(srcObj === null) destContainer[j] = null;\n else {\n destContainer[j] = plots.extendObjectWithContainers(destContainer[j], srcObj);\n }\n }\n\n destProp.set(destContainer);\n }\n }\n\n return dest;\n};\n\nplots.dataArrayContainers = ['transforms', 'dimensions'];\nplots.layoutArrayContainers = Registry.layoutArrayContainers;\n\n/*\n * Extend a trace definition. This method:\n *\n * 1. directly transfers any array references\n * 2. manually recurses into container arrays like transforms\n *\n * The result is the original object reference with the new contents merged in.\n */\nplots.extendTrace = function(destTrace, srcTrace) {\n return plots.extendObjectWithContainers(destTrace, srcTrace, plots.dataArrayContainers);\n};\n\n/*\n * Extend a layout definition. This method:\n *\n * 1. directly transfers any array references (not critically important for\n * layout since there aren't really data arrays)\n * 2. manually recurses into container arrays like annotations\n *\n * The result is the original object reference with the new contents merged in.\n */\nplots.extendLayout = function(destLayout, srcLayout) {\n return plots.extendObjectWithContainers(destLayout, srcLayout, plots.layoutArrayContainers);\n};\n\n/**\n * Transition to a set of new data and layout properties from Plotly.animate\n *\n * @param {DOM element} gd\n * @param {Object[]} data\n * an array of data objects following the normal Plotly data definition format\n * @param {Object} layout\n * a layout object, following normal Plotly layout format\n * @param {Number[]} traces\n * indices of the corresponding traces specified in `data`\n * @param {Object} frameOpts\n * options for the frame (i.e. whether to redraw post-transition)\n * @param {Object} transitionOpts\n * options for the transition\n */\nplots.transition = function(gd, data, layout, traces, frameOpts, transitionOpts) {\n var opts = {redraw: frameOpts.redraw};\n var transitionedTraces = {};\n var axEdits = [];\n\n opts.prepareFn = function() {\n var dataLength = Array.isArray(data) ? data.length : 0;\n var traceIndices = traces.slice(0, dataLength);\n\n for(var i = 0; i < traceIndices.length; i++) {\n var traceIdx = traceIndices[i];\n var trace = gd._fullData[traceIdx];\n var _module = trace._module;\n\n // There's nothing to do if this module is not defined:\n if(!_module) continue;\n\n // Don't register the trace as transitioned if it doesn't know what to do.\n // If it *is* registered, it will receive a callback that it's responsible\n // for calling in order to register the transition as having completed.\n if(_module.animatable) {\n var n = _module.basePlotModule.name;\n if(!transitionedTraces[n]) transitionedTraces[n] = [];\n transitionedTraces[n].push(traceIdx);\n }\n\n gd.data[traceIndices[i]] = plots.extendTrace(gd.data[traceIndices[i]], data[i]);\n }\n\n // Follow the same procedure. Clone it so we don't mangle the input, then\n // expand any object paths so we can merge deep into gd.layout:\n var layoutUpdate = Lib.expandObjectPaths(Lib.extendDeepNoArrays({}, layout));\n\n // Before merging though, we need to modify the incoming layout. We only\n // know how to *transition* layout ranges, so it's imperative that a new\n // range not be sent to the layout before the transition has started. So\n // we must remove the things we can transition:\n var axisAttrRe = /^[xy]axis[0-9]*$/;\n for(var attr in layoutUpdate) {\n if(!axisAttrRe.test(attr)) continue;\n delete layoutUpdate[attr].range;\n }\n\n plots.extendLayout(gd.layout, layoutUpdate);\n\n // Supply defaults after applying the incoming properties. Note that any attempt\n // to simplify this step and reduce the amount of work resulted in the reconstruction\n // of essentially the whole supplyDefaults step, so that it seems sensible to just use\n // supplyDefaults even though it's heavier than would otherwise be desired for\n // transitions:\n\n // first delete calcdata so supplyDefaults knows a calc step is coming\n delete gd.calcdata;\n\n plots.supplyDefaults(gd);\n plots.doCalcdata(gd);\n\n var newLayout = Lib.expandObjectPaths(layout);\n\n if(newLayout) {\n var subplots = gd._fullLayout._plots;\n\n for(var k in subplots) {\n var plotinfo = subplots[k];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr0 = xa.range.slice();\n var yr0 = ya.range.slice();\n\n var xr1 = null;\n var yr1 = null;\n var editX = null;\n var editY = null;\n\n if(Array.isArray(newLayout[xa._name + '.range'])) {\n xr1 = newLayout[xa._name + '.range'].slice();\n } else if(Array.isArray((newLayout[xa._name] || {}).range)) {\n xr1 = newLayout[xa._name].range.slice();\n }\n if(Array.isArray(newLayout[ya._name + '.range'])) {\n yr1 = newLayout[ya._name + '.range'].slice();\n } else if(Array.isArray((newLayout[ya._name] || {}).range)) {\n yr1 = newLayout[ya._name].range.slice();\n }\n\n if(xr0 && xr1 &&\n (xa.r2l(xr0[0]) !== xa.r2l(xr1[0]) || xa.r2l(xr0[1]) !== xa.r2l(xr1[1]))\n ) {\n editX = {xr0: xr0, xr1: xr1};\n }\n if(yr0 && yr1 &&\n (ya.r2l(yr0[0]) !== ya.r2l(yr1[0]) || ya.r2l(yr0[1]) !== ya.r2l(yr1[1]))\n ) {\n editY = {yr0: yr0, yr1: yr1};\n }\n\n if(editX || editY) {\n axEdits.push(Lib.extendFlat({plotinfo: plotinfo}, editX, editY));\n }\n }\n }\n\n return Promise.resolve();\n };\n\n opts.runFn = function(makeCallback) {\n var traceTransitionOpts;\n var basePlotModules = gd._fullLayout._basePlotModules;\n var hasAxisTransition = axEdits.length;\n var i;\n\n if(layout) {\n for(i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].transitionAxes) {\n basePlotModules[i].transitionAxes(gd, axEdits, transitionOpts, makeCallback);\n }\n }\n }\n\n // Here handle the exception that we refuse to animate scales and axes at the same\n // time. In other words, if there's an axis transition, then set the data transition\n // to instantaneous.\n if(hasAxisTransition) {\n traceTransitionOpts = Lib.extendFlat({}, transitionOpts);\n traceTransitionOpts.duration = 0;\n // This means do not transition cartesian traces,\n // this happens on layout-only (e.g. axis range) animations\n delete transitionedTraces.cartesian;\n } else {\n traceTransitionOpts = transitionOpts;\n }\n\n // Note that we pass a callback to *create* the callback that must be invoked on completion.\n // This is since not all traces know about transitions, so it greatly simplifies matters if\n // the trace is responsible for creating a callback, if needed, and then executing it when\n // the time is right.\n for(var n in transitionedTraces) {\n var traceIndices = transitionedTraces[n];\n var _module = gd._fullData[traceIndices[0]]._module;\n _module.basePlotModule.plot(gd, traceIndices, traceTransitionOpts, makeCallback);\n }\n };\n\n return _transition(gd, transitionOpts, opts);\n};\n\n/**\n * Transition to a set of new data and layout properties from Plotly.react\n *\n * @param {DOM element} gd\n * @param {object} restyleFlags\n * - anim {'all'|'some'}\n * @param {object} relayoutFlags\n * - anim {'all'|'some'}\n * @param {object} oldFullLayout : old (pre Plotly.react) fullLayout\n */\nplots.transitionFromReact = function(gd, restyleFlags, relayoutFlags, oldFullLayout) {\n var fullLayout = gd._fullLayout;\n var transitionOpts = fullLayout.transition;\n var opts = {};\n var axEdits = [];\n\n opts.prepareFn = function() {\n var subplots = fullLayout._plots;\n\n // no need to redraw at end of transition,\n // if all changes are animatable\n opts.redraw = false;\n if(restyleFlags.anim === 'some') opts.redraw = true;\n if(relayoutFlags.anim === 'some') opts.redraw = true;\n\n for(var k in subplots) {\n var plotinfo = subplots[k];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr0 = oldFullLayout[xa._name].range.slice();\n var yr0 = oldFullLayout[ya._name].range.slice();\n var xr1 = xa.range.slice();\n var yr1 = ya.range.slice();\n\n xa.setScale();\n ya.setScale();\n\n var editX = null;\n var editY = null;\n\n if(xa.r2l(xr0[0]) !== xa.r2l(xr1[0]) || xa.r2l(xr0[1]) !== xa.r2l(xr1[1])) {\n editX = {xr0: xr0, xr1: xr1};\n }\n if(ya.r2l(yr0[0]) !== ya.r2l(yr1[0]) || ya.r2l(yr0[1]) !== ya.r2l(yr1[1])) {\n editY = {yr0: yr0, yr1: yr1};\n }\n\n if(editX || editY) {\n axEdits.push(Lib.extendFlat({plotinfo: plotinfo}, editX, editY));\n }\n }\n\n return Promise.resolve();\n };\n\n opts.runFn = function(makeCallback) {\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n var basePlotModules = fullLayout._basePlotModules;\n\n var axisTransitionOpts;\n var traceTransitionOpts;\n var transitionedTraces;\n\n var allTraceIndices = [];\n for(var i = 0; i < fullData.length; i++) {\n allTraceIndices.push(i);\n }\n\n function transitionAxes() {\n for(var j = 0; j < basePlotModules.length; j++) {\n if(basePlotModules[j].transitionAxes) {\n basePlotModules[j].transitionAxes(gd, axEdits, axisTransitionOpts, makeCallback);\n }\n }\n }\n\n function transitionTraces() {\n for(var j = 0; j < basePlotModules.length; j++) {\n basePlotModules[j].plot(gd, transitionedTraces, traceTransitionOpts, makeCallback);\n }\n }\n\n if(axEdits.length && restyleFlags.anim) {\n if(transitionOpts.ordering === 'traces first') {\n axisTransitionOpts = Lib.extendFlat({}, transitionOpts, {duration: 0});\n transitionedTraces = allTraceIndices;\n traceTransitionOpts = transitionOpts;\n setTimeout(transitionAxes, transitionOpts.duration);\n transitionTraces();\n } else {\n axisTransitionOpts = transitionOpts;\n transitionedTraces = null;\n traceTransitionOpts = Lib.extendFlat({}, transitionOpts, {duration: 0});\n setTimeout(transitionTraces, axisTransitionOpts.duration);\n transitionAxes();\n }\n } else if(axEdits.length) {\n axisTransitionOpts = transitionOpts;\n transitionAxes();\n } else if(restyleFlags.anim) {\n transitionedTraces = allTraceIndices;\n traceTransitionOpts = transitionOpts;\n transitionTraces();\n }\n };\n\n return _transition(gd, transitionOpts, opts);\n};\n\n/**\n * trace/layout transition wrapper that works\n * for transitions initiated by Plotly.animate and Plotly.react.\n *\n * @param {DOM element} gd\n * @param {object} transitionOpts\n * @param {object} opts\n * - redraw {boolean}\n * - prepareFn {function} *should return a Promise*\n * - runFn {function} ran inside executeTransitions\n */\nfunction _transition(gd, transitionOpts, opts) {\n var aborted = false;\n\n function executeCallbacks(list) {\n var p = Promise.resolve();\n if(!list) return p;\n while(list.length) {\n p = p.then((list.shift()));\n }\n return p;\n }\n\n function flushCallbacks(list) {\n if(!list) return;\n while(list.length) {\n list.shift();\n }\n }\n\n function executeTransitions() {\n gd.emit('plotly_transitioning', []);\n\n return new Promise(function(resolve) {\n // This flag is used to disabled things like autorange:\n gd._transitioning = true;\n\n // When instantaneous updates are coming through quickly, it's too much to simply disable\n // all interaction, so store this flag so we can disambiguate whether mouse interactions\n // should be fully disabled or not:\n if(transitionOpts.duration > 0) {\n gd._transitioningWithDuration = true;\n }\n\n // If another transition is triggered, this callback will be executed simply because it's\n // in the interruptCallbacks queue. If this transition completes, it will instead flush\n // that queue and forget about this callback.\n gd._transitionData._interruptCallbacks.push(function() {\n aborted = true;\n });\n\n if(opts.redraw) {\n gd._transitionData._interruptCallbacks.push(function() {\n return Registry.call('redraw', gd);\n });\n }\n\n // Emit this and make sure it happens last:\n gd._transitionData._interruptCallbacks.push(function() {\n gd.emit('plotly_transitioninterrupted', []);\n });\n\n // Construct callbacks that are executed on transition end. This ensures the d3 transitions\n // are *complete* before anything else is done.\n var numCallbacks = 0;\n var numCompleted = 0;\n function makeCallback() {\n numCallbacks++;\n return function() {\n numCompleted++;\n // When all are complete, perform a redraw:\n if(!aborted && numCompleted === numCallbacks) {\n completeTransition(resolve);\n }\n };\n }\n\n opts.runFn(makeCallback);\n\n // If nothing else creates a callback, then this will trigger the completion in the next tick:\n setTimeout(makeCallback());\n });\n }\n\n function completeTransition(callback) {\n // This a simple workaround for tests which purge the graph before animations\n // have completed. That's not a very common case, so this is the simplest\n // fix.\n if(!gd._transitionData) return;\n\n flushCallbacks(gd._transitionData._interruptCallbacks);\n\n return Promise.resolve().then(function() {\n if(opts.redraw) {\n return Registry.call('redraw', gd);\n }\n }).then(function() {\n // Set transitioning false again once the redraw has occurred. This is used, for example,\n // to prevent the trailing redraw from autoranging:\n gd._transitioning = false;\n gd._transitioningWithDuration = false;\n\n gd.emit('plotly_transitioned', []);\n }).then(callback);\n }\n\n function interruptPreviousTransitions() {\n // Fail-safe against purged plot:\n if(!gd._transitionData) return;\n\n // If a transition is interrupted, set this to false. At the moment, the only thing that would\n // interrupt a transition is another transition, so that it will momentarily be set to true\n // again, but this determines whether autorange or dragbox work, so it's for the sake of\n // cleanliness:\n gd._transitioning = false;\n\n return executeCallbacks(gd._transitionData._interruptCallbacks);\n }\n\n var seq = [\n plots.previousPromises,\n interruptPreviousTransitions,\n opts.prepareFn,\n plots.rehover,\n executeTransitions\n ];\n\n var transitionStarting = Lib.syncOrAsync(seq, gd);\n\n if(!transitionStarting || !transitionStarting.then) {\n transitionStarting = Promise.resolve();\n }\n\n return transitionStarting.then(function() { return gd; });\n}\n\nplots.doCalcdata = function(gd, traces) {\n var axList = axisIDs.list(gd);\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n\n var trace, _module, i, j;\n\n // XXX: Is this correct? Needs a closer look so that *some* traces can be recomputed without\n // *all* needing doCalcdata:\n var calcdata = new Array(fullData.length);\n var oldCalcdata = (gd.calcdata || []).slice();\n gd.calcdata = calcdata;\n\n // extra helper variables\n\n // how many box/violins plots do we have (in case they're grouped)\n fullLayout._numBoxes = 0;\n fullLayout._numViolins = 0;\n\n // initialize violin per-scale-group stats container\n fullLayout._violinScaleGroupStats = {};\n\n // for calculating avg luminosity of heatmaps\n gd._hmpixcount = 0;\n gd._hmlumcount = 0;\n\n // for sharing colors across pies / sunbursts / treemap / funnelarea (and for legend)\n fullLayout._piecolormap = {};\n fullLayout._sunburstcolormap = {};\n fullLayout._treemapcolormap = {};\n fullLayout._funnelareacolormap = {};\n\n // If traces were specified and this trace was not included,\n // then transfer it over from the old calcdata:\n for(i = 0; i < fullData.length; i++) {\n if(Array.isArray(traces) && traces.indexOf(i) === -1) {\n calcdata[i] = oldCalcdata[i];\n continue;\n }\n }\n\n for(i = 0; i < fullData.length; i++) {\n trace = fullData[i];\n\n trace._arrayAttrs = PlotSchema.findArrayAttributes(trace);\n\n // keep track of trace extremes (for autorange) in here\n trace._extremes = {};\n }\n\n // add polar axes to axis list\n var polarIds = fullLayout._subplots.polar || [];\n for(i = 0; i < polarIds.length; i++) {\n axList.push(\n fullLayout[polarIds[i]].radialaxis,\n fullLayout[polarIds[i]].angularaxis\n );\n }\n\n // clear relinked cmin/cmax values in shared axes to start aggregation from scratch\n for(var k in fullLayout._colorAxes) {\n var cOpts = fullLayout[k];\n if(cOpts.cauto !== false) {\n delete cOpts.cmin;\n delete cOpts.cmax;\n }\n }\n\n var hasCalcTransform = false;\n\n function transformCalci(i) {\n trace = fullData[i];\n _module = trace._module;\n\n if(trace.visible === true && trace.transforms) {\n // we need one round of trace module calc before\n // the calc transform to 'fill in' the categories list\n // used for example in the data-to-coordinate method\n if(_module && _module.calc) {\n var cdi = _module.calc(gd, trace);\n\n // must clear scene 'batches', so that 2nd\n // _module.calc call starts from scratch\n if(cdi[0] && cdi[0].t && cdi[0].t._scene) {\n delete cdi[0].t._scene.dirty;\n }\n }\n\n for(j = 0; j < trace.transforms.length; j++) {\n var transform = trace.transforms[j];\n\n _module = transformsRegistry[transform.type];\n if(_module && _module.calcTransform) {\n trace._hasCalcTransform = true;\n hasCalcTransform = true;\n _module.calcTransform(gd, trace, transform);\n }\n }\n }\n }\n\n function calci(i, isContainer) {\n trace = fullData[i];\n _module = trace._module;\n\n if(!!_module.isContainer !== isContainer) return;\n\n var cd = [];\n\n if(trace.visible === true && trace._length !== 0) {\n // clear existing ref in case it got relinked\n delete trace._indexToPoints;\n // keep ref of index-to-points map object of the *last* enabled transform,\n // this index-to-points map object is required to determine the calcdata indices\n // that correspond to input indices (e.g. from 'selectedpoints')\n var transforms = trace.transforms || [];\n for(j = transforms.length - 1; j >= 0; j--) {\n if(transforms[j].enabled) {\n trace._indexToPoints = transforms[j]._indexToPoints;\n break;\n }\n }\n\n if(_module && _module.calc) {\n cd = _module.calc(gd, trace);\n }\n }\n\n // Make sure there is a first point.\n //\n // This ensures there is a calcdata item for every trace,\n // even if cartesian logic doesn't handle it (for things like legends).\n if(!Array.isArray(cd) || !cd[0]) {\n cd = [{x: BADNUM, y: BADNUM}];\n }\n\n // add the trace-wide properties to the first point,\n // per point properties to every point\n // t is the holder for trace-wide properties\n if(!cd[0].t) cd[0].t = {};\n cd[0].trace = trace;\n\n calcdata[i] = cd;\n }\n\n setupAxisCategories(axList, fullData, fullLayout);\n\n // 'transform' loop - must calc container traces first\n // so that if their dependent traces can get transform properly\n for(i = 0; i < fullData.length; i++) calci(i, true);\n for(i = 0; i < fullData.length; i++) transformCalci(i);\n\n // clear stuff that should recomputed in 'regular' loop\n if(hasCalcTransform) setupAxisCategories(axList, fullData, fullLayout);\n\n // 'regular' loop - make sure container traces (eg carpet) calc before\n // contained traces (eg contourcarpet)\n for(i = 0; i < fullData.length; i++) calci(i, true);\n for(i = 0; i < fullData.length; i++) calci(i, false);\n\n doCrossTraceCalc(gd);\n\n // Sort axis categories per value if specified\n var sorted = sortAxisCategoriesByValue(axList, gd);\n if(sorted.length) {\n // how many box/violins plots do we have (in case they're grouped)\n fullLayout._numBoxes = 0;\n fullLayout._numViolins = 0;\n // If a sort operation was performed, run calc() again\n for(i = 0; i < sorted.length; i++) calci(sorted[i], true);\n for(i = 0; i < sorted.length; i++) calci(sorted[i], false);\n doCrossTraceCalc(gd);\n }\n\n Registry.getComponentMethod('fx', 'calc')(gd);\n Registry.getComponentMethod('errorbars', 'calc')(gd);\n};\n\nvar sortAxisCategoriesByValueRegex = /(total|sum|min|max|mean|median) (ascending|descending)/;\n\nfunction sortAxisCategoriesByValue(axList, gd) {\n var affectedTraces = [];\n var i, j, k, l, o;\n\n function zMapCategory(type, ax, value) {\n var axLetter = ax._id.charAt(0);\n if(type === 'histogram2dcontour') {\n var counterAxLetter = ax._counterAxes[0];\n var counterAx = axisIDs.getFromId(gd, counterAxLetter);\n\n var xCategorical = axLetter === 'x' || (counterAxLetter === 'x' && counterAx.type === 'category');\n var yCategorical = axLetter === 'y' || (counterAxLetter === 'y' && counterAx.type === 'category');\n\n return function(o, l) {\n if(o === 0 || l === 0) return -1; // Skip first row and column\n if(xCategorical && o === value[l].length - 1) return -1;\n if(yCategorical && l === value.length - 1) return -1;\n\n return (axLetter === 'y' ? l : o) - 1;\n };\n } else {\n return function(o, l) {\n return axLetter === 'y' ? l : o;\n };\n }\n }\n\n var aggFn = {\n 'min': function(values) {return Lib.aggNums(Math.min, null, values);},\n 'max': function(values) {return Lib.aggNums(Math.max, null, values);},\n 'sum': function(values) {return Lib.aggNums(function(a, b) { return a + b;}, null, values);},\n 'total': function(values) {return Lib.aggNums(function(a, b) { return a + b;}, null, values);},\n 'mean': function(values) {return Lib.mean(values);},\n 'median': function(values) {return Lib.median(values);}\n };\n\n for(i = 0; i < axList.length; i++) {\n var ax = axList[i];\n if(ax.type !== 'category') continue;\n\n // Order by value\n var match = ax.categoryorder.match(sortAxisCategoriesByValueRegex);\n if(match) {\n var aggregator = match[1];\n var order = match[2];\n\n // Store values associated with each category\n var categoriesValue = [];\n for(j = 0; j < ax._categories.length; j++) {\n categoriesValue.push([ax._categories[j], []]);\n }\n\n // Collect values across traces\n for(j = 0; j < ax._traceIndices.length; j++) {\n var traceIndex = ax._traceIndices[j];\n var fullTrace = gd._fullData[traceIndex];\n var axLetter = ax._id.charAt(0);\n\n // Skip over invisible traces\n if(fullTrace.visible !== true) continue;\n\n var type = fullTrace.type;\n if(Registry.traceIs(fullTrace, 'histogram')) {\n delete fullTrace._xautoBinFinished;\n delete fullTrace._yautoBinFinished;\n }\n\n var cd = gd.calcdata[traceIndex];\n for(k = 0; k < cd.length; k++) {\n var cdi = cd[k];\n var cat, catIndex, value;\n\n if(type === 'splom') {\n // If `splom`, collect values across dimensions\n // Find which dimension the current axis is representing\n var currentDimensionIndex = fullTrace._axesDim[ax._id];\n\n // Apply logic to associated x axis if it's defined\n if(axLetter === 'y') {\n var associatedXAxisID = fullTrace._diag[currentDimensionIndex][0];\n if(associatedXAxisID) ax = gd._fullLayout[axisIDs.id2name(associatedXAxisID)];\n }\n\n var categories = cdi.trace.dimensions[currentDimensionIndex].values;\n for(l = 0; l < categories.length; l++) {\n cat = categories[l];\n catIndex = ax._categoriesMap[cat];\n\n // Collect associated values at index `l` over all other dimensions\n for(o = 0; o < cdi.trace.dimensions.length; o++) {\n if(o === currentDimensionIndex) continue;\n var dimension = cdi.trace.dimensions[o];\n categoriesValue[catIndex][1].push(dimension.values[l]);\n }\n }\n } else if(type === 'scattergl') {\n // If `scattergl`, collect all values stashed under cdi.t\n for(l = 0; l < cdi.t.x.length; l++) {\n if(axLetter === 'x') {\n cat = cdi.t.x[l];\n catIndex = cat;\n value = cdi.t.y[l];\n }\n\n if(axLetter === 'y') {\n cat = cdi.t.y[l];\n catIndex = cat;\n value = cdi.t.x[l];\n }\n categoriesValue[catIndex][1].push(value);\n }\n // must clear scene 'batches', so that 2nd\n // _module.calc call starts from scratch\n if(cdi.t && cdi.t._scene) {\n delete cdi.t._scene.dirty;\n }\n } else if(cdi.hasOwnProperty('z')) {\n // If 2dMap, collect values in `z`\n value = cdi.z;\n var mapping = zMapCategory(fullTrace.type, ax, value);\n\n for(l = 0; l < value.length; l++) {\n for(o = 0; o < value[l].length; o++) {\n catIndex = mapping(o, l);\n if(catIndex + 1) categoriesValue[catIndex][1].push(value[l][o]);\n }\n }\n } else {\n // For all other 2d cartesian traces\n if(axLetter === 'x') {\n cat = cdi.p + 1 ? cdi.p : cdi.x;\n value = cdi.s || cdi.v || cdi.y;\n } else if(axLetter === 'y') {\n cat = cdi.p + 1 ? cdi.p : cdi.y;\n value = cdi.s || cdi.v || cdi.x;\n }\n if(!Array.isArray(value)) value = [value];\n for(l = 0; l < value.length; l++) {\n categoriesValue[cat][1].push(value[l]);\n }\n }\n }\n }\n\n ax._categoriesValue = categoriesValue;\n\n var categoriesAggregatedValue = [];\n for(j = 0; j < categoriesValue.length; j++) {\n categoriesAggregatedValue.push([\n categoriesValue[j][0],\n aggFn[aggregator](categoriesValue[j][1])\n ]);\n }\n\n // Sort by aggregated value\n categoriesAggregatedValue.sort(function(a, b) {\n return a[1] - b[1];\n });\n\n ax._categoriesAggregatedValue = categoriesAggregatedValue;\n\n // Set new category order\n ax._initialCategories = categoriesAggregatedValue.map(function(c) {\n return c[0];\n });\n\n // Reverse if descending\n if(order === 'descending') {\n ax._initialCategories.reverse();\n }\n\n // Sort all matching axes\n affectedTraces = affectedTraces.concat(ax.sortByInitialCategories());\n }\n }\n return affectedTraces;\n}\n\nfunction setupAxisCategories(axList, fullData, fullLayout) {\n var axLookup = {};\n var i, ax, axId;\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n axId = ax._id;\n\n ax.clearCalc();\n if(ax.type === 'multicategory') {\n ax.setupMultiCategory(fullData);\n }\n\n axLookup[ax._id] = 1;\n }\n\n // look into match groups for 'missing' axes\n var matchGroups = fullLayout._axisMatchGroups || [];\n for(i = 0; i < matchGroups.length; i++) {\n for(axId in matchGroups[i]) {\n if(!axLookup[axId]) {\n ax = fullLayout[axisIDs.id2name(axId)];\n ax.clearCalc();\n }\n }\n }\n}\n\nfunction doCrossTraceCalc(gd) {\n var fullLayout = gd._fullLayout;\n var modules = fullLayout._visibleModules;\n var hash = {};\n var i, j, k;\n\n // position and range calculations for traces that\n // depend on each other ie bars (stacked or grouped)\n // and boxes (grouped) push each other out of the way\n\n for(j = 0; j < modules.length; j++) {\n var _module = modules[j];\n var fn = _module.crossTraceCalc;\n if(fn) {\n var spType = _module.basePlotModule.name;\n if(hash[spType]) {\n Lib.pushUnique(hash[spType], fn);\n } else {\n hash[spType] = [fn];\n }\n }\n }\n\n for(k in hash) {\n var methods = hash[k];\n var subplots = fullLayout._subplots[k];\n\n if(Array.isArray(subplots)) {\n for(i = 0; i < subplots.length; i++) {\n var sp = subplots[i];\n var spInfo = k === 'cartesian' ?\n fullLayout._plots[sp] :\n fullLayout[sp];\n\n for(j = 0; j < methods.length; j++) {\n methods[j](gd, spInfo, sp);\n }\n }\n } else {\n for(j = 0; j < methods.length; j++) {\n methods[j](gd);\n }\n }\n }\n}\n\nplots.rehover = function(gd) {\n if(gd._fullLayout._rehover) {\n gd._fullLayout._rehover();\n }\n};\n\nplots.redrag = function(gd) {\n if(gd._fullLayout._redrag) {\n gd._fullLayout._redrag();\n }\n};\n\nplots.generalUpdatePerTraceModule = function(gd, subplot, subplotCalcData, subplotLayout) {\n var traceHashOld = subplot.traceHash;\n var traceHash = {};\n var i;\n\n // build up moduleName -> calcData hash\n for(i = 0; i < subplotCalcData.length; i++) {\n var calcTraces = subplotCalcData[i];\n var trace = calcTraces[0].trace;\n\n // skip over visible === false traces\n // as they don't have `_module` ref\n if(trace.visible) {\n traceHash[trace.type] = traceHash[trace.type] || [];\n traceHash[trace.type].push(calcTraces);\n }\n }\n\n // when a trace gets deleted, make sure that its module's\n // plot method is called so that it is properly\n // removed from the DOM.\n for(var moduleNameOld in traceHashOld) {\n if(!traceHash[moduleNameOld]) {\n var fakeCalcTrace = traceHashOld[moduleNameOld][0];\n var fakeTrace = fakeCalcTrace[0].trace;\n\n fakeTrace.visible = false;\n traceHash[moduleNameOld] = [fakeCalcTrace];\n }\n }\n\n // call module plot method\n for(var moduleName in traceHash) {\n var moduleCalcData = traceHash[moduleName];\n var _module = moduleCalcData[0][0].trace._module;\n\n _module.plot(gd, subplot, Lib.filterVisible(moduleCalcData), subplotLayout);\n }\n\n // update moduleName -> calcData hash\n subplot.traceHash = traceHash;\n};\n\nplots.plotBasePlot = function(desiredType, gd, traces, transitionOpts, makeOnCompleteCallback) {\n var _module = Registry.getModule(desiredType);\n var cdmodule = getModuleCalcData(gd.calcdata, _module)[0];\n _module.plot(gd, cdmodule, transitionOpts, makeOnCompleteCallback);\n};\n\nplots.cleanBasePlot = function(desiredType, newFullData, newFullLayout, oldFullData, oldFullLayout) {\n var had = (oldFullLayout._has && oldFullLayout._has(desiredType));\n var has = (newFullLayout._has && newFullLayout._has(desiredType));\n\n if(had && !has) {\n oldFullLayout['_' + desiredType + 'layer'].selectAll('g.trace').remove();\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = function doAvg(size, counts) {\n var nMax = size.length;\n var total = 0;\n for(var i = 0; i < nMax; i++) {\n if(counts[i]) {\n size[i] /= counts[i];\n total += size[i];\n } else size[i] = null;\n }\n return total;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n calc: require('./calc'),\n plot: require('./plot'),\n colorbar: require('./colorbar'),\n style: require('./style'),\n hoverPoints: require('./hover'),\n\n moduleType: 'trace',\n name: 'heatmap',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['cartesian', 'svg', '2dMap', 'showLegend'],\n meta: {\n description: [\n 'The data that describes the heatmap value-to-color mapping',\n 'is set in `z`.',\n 'Data in `z` can either be a {2D array} of values (ragged or not)',\n 'or a 1D array of values.',\n\n 'In the case where `z` is a {2D array},',\n 'say that `z` has N rows and M columns.',\n 'Then, by default, the resulting heatmap will have N partitions along',\n 'the y axis and M partitions along the x axis.',\n 'In other words, the i-th row/ j-th column cell in `z`',\n 'is mapped to the i-th partition of the y axis',\n '(starting from the bottom of the plot) and the j-th partition',\n 'of the x-axis (starting from the left of the plot).',\n 'This behavior can be flipped by using `transpose`.',\n 'Moreover, `x` (`y`) can be provided with M or M+1 (N or N+1) elements.',\n 'If M (N), then the coordinates correspond to the center of the',\n 'heatmap cells and the cells have equal width.',\n 'If M+1 (N+1), then the coordinates correspond to the edges of the',\n 'heatmap cells.',\n\n 'In the case where `z` is a 1D {array}, the x and y coordinates must be',\n 'provided in `x` and `y` respectively to form data triplets.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nmodule.exports = function handleStyleDefaults(traceIn, traceOut, coerce) {\n var zsmooth = coerce('zsmooth');\n if(zsmooth === false) {\n // ensure that xgap and ygap are coerced only when zsmooth allows them to have an effect.\n coerce('xgap');\n coerce('ygap');\n }\n\n coerce('zhoverformat');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar timerCache = {};\n\n/**\n * Throttle a callback. `callback` executes synchronously only if\n * more than `minInterval` milliseconds have already elapsed since the latest\n * call (if any). Otherwise we wait until `minInterval` is over and execute the\n * last callback received while waiting.\n * So the first and last events in a train are always executed (eventually)\n * but some of the events in the middle can be dropped.\n *\n * @param {string} id: an identifier to mark events to throttle together\n * @param {number} minInterval: minimum time, in milliseconds, between\n * invocations of `callback`\n * @param {function} callback: the function to throttle. `callback` itself\n * should be a purely synchronous function.\n */\nexports.throttle = function throttle(id, minInterval, callback) {\n var cache = timerCache[id];\n var now = Date.now();\n\n if(!cache) {\n /*\n * Throw out old items before making a new one, to prevent the cache\n * getting overgrown, for example from old plots that have been replaced.\n * 1 minute age is arbitrary.\n */\n for(var idi in timerCache) {\n if(timerCache[idi].ts < now - 60000) {\n delete timerCache[idi];\n }\n }\n cache = timerCache[id] = {ts: 0, timer: null};\n }\n\n _clearTimeout(cache);\n\n function exec() {\n callback();\n cache.ts = Date.now();\n if(cache.onDone) {\n cache.onDone();\n cache.onDone = null;\n }\n }\n\n if(now > cache.ts + minInterval) {\n exec();\n return;\n }\n\n cache.timer = setTimeout(function() {\n exec();\n cache.timer = null;\n }, minInterval);\n};\n\nexports.done = function(id) {\n var cache = timerCache[id];\n if(!cache || !cache.timer) return Promise.resolve();\n\n return new Promise(function(resolve) {\n var previousOnDone = cache.onDone;\n cache.onDone = function onDone() {\n if(previousOnDone) previousOnDone();\n resolve();\n cache.onDone = null;\n };\n });\n};\n\n/**\n * Clear the throttle cache for one or all timers\n * @param {optional string} id:\n * if provided, clear just this timer\n * if omitted, clear all timers (mainly useful for testing)\n */\nexports.clear = function(id) {\n if(id) {\n _clearTimeout(timerCache[id]);\n delete timerCache[id];\n } else {\n for(var idi in timerCache) exports.clear(idi);\n }\n};\n\nfunction _clearTimeout(cache) {\n if(cache && cache.timer !== null) {\n clearTimeout(cache.timer);\n cache.timer = null;\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar Lib = require('../../lib');\nvar dragElement = require('../dragelement');\nvar helpers = require('./helpers');\nvar layoutAttributes = require('./layout_attributes');\nvar hoverModule = require('./hover');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'fx',\n\n constants: require('./constants'),\n schema: {\n layout: layoutAttributes\n },\n\n attributes: require('./attributes'),\n layoutAttributes: layoutAttributes,\n\n supplyLayoutGlobalDefaults: require('./layout_global_defaults'),\n supplyDefaults: require('./defaults'),\n supplyLayoutDefaults: require('./layout_defaults'),\n\n calc: require('./calc'),\n\n getDistanceFunction: helpers.getDistanceFunction,\n getClosest: helpers.getClosest,\n inbox: helpers.inbox,\n quadrature: helpers.quadrature,\n appendArrayPointValue: helpers.appendArrayPointValue,\n\n castHoverOption: castHoverOption,\n castHoverinfo: castHoverinfo,\n\n hover: hoverModule.hover,\n unhover: dragElement.unhover,\n\n loneHover: hoverModule.loneHover,\n loneUnhover: loneUnhover,\n\n click: require('./click')\n};\n\nfunction loneUnhover(containerOrSelection) {\n // duck type whether the arg is a d3 selection because ie9 doesn't\n // handle instanceof like modern browsers do.\n var selection = Lib.isD3Selection(containerOrSelection) ?\n containerOrSelection :\n d3.select(containerOrSelection);\n\n selection.selectAll('g.hovertext').remove();\n selection.selectAll('.spikeline').remove();\n}\n\n// helpers for traces that use Fx.loneHover\n\nfunction castHoverOption(trace, ptNumber, attr) {\n return Lib.castOption(trace, ptNumber, 'hoverlabel.' + attr);\n}\n\nfunction castHoverinfo(trace, fullLayout, ptNumber) {\n function _coerce(val) {\n return Lib.coerceHoverinfo({hoverinfo: val}, {_module: trace._module}, fullLayout);\n }\n\n return Lib.castOption(trace, ptNumber, 'hoverinfo', _coerce);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Polar = module.exports = require('./micropolar');\n\nPolar.manager = require('./micropolar_manager');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\nvar name = constants.name;\nvar stepAttrs = attributes.steps;\n\n\nmodule.exports = function slidersDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: name,\n handleItemDefaults: sliderDefaults\n });\n};\n\nfunction sliderDefaults(sliderIn, sliderOut, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(sliderIn, sliderOut, attributes, attr, dflt);\n }\n\n var steps = handleArrayContainerDefaults(sliderIn, sliderOut, {\n name: 'steps',\n handleItemDefaults: stepDefaults\n });\n\n var stepCount = 0;\n for(var i = 0; i < steps.length; i++) {\n if(steps[i].visible) stepCount++;\n }\n\n var visible;\n // If it has fewer than two options, it's not really a slider\n if(stepCount < 2) visible = sliderOut.visible = false;\n else visible = coerce('visible');\n if(!visible) return;\n\n sliderOut._stepCount = stepCount;\n var visSteps = sliderOut._visibleSteps = Lib.filterVisible(steps);\n\n var active = coerce('active');\n if(!(steps[active] || {}).visible) sliderOut.active = visSteps[0]._index;\n\n coerce('x');\n coerce('y');\n Lib.noneOrAll(sliderIn, sliderOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n coerce('len');\n coerce('lenmode');\n\n coerce('pad.t');\n coerce('pad.r');\n coerce('pad.b');\n coerce('pad.l');\n\n Lib.coerceFont(coerce, 'font', layoutOut.font);\n\n var currentValueIsVisible = coerce('currentvalue.visible');\n\n if(currentValueIsVisible) {\n coerce('currentvalue.xanchor');\n coerce('currentvalue.prefix');\n coerce('currentvalue.suffix');\n coerce('currentvalue.offset');\n\n Lib.coerceFont(coerce, 'currentvalue.font', sliderOut.font);\n }\n\n coerce('transition.duration');\n coerce('transition.easing');\n\n coerce('bgcolor');\n coerce('activebgcolor');\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('ticklen');\n coerce('tickwidth');\n coerce('tickcolor');\n coerce('minorticklen');\n}\n\nfunction stepDefaults(valueIn, valueOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(valueIn, valueOut, stepAttrs, attr, dflt);\n }\n\n var visible;\n if(valueIn.method !== 'skip' && !Array.isArray(valueIn.args)) {\n visible = valueOut.visible = false;\n } else visible = coerce('visible');\n\n if(visible) {\n coerce('method');\n coerce('args');\n var label = coerce('label', 'step-' + valueOut._index);\n coerce('value', label);\n coerce('execute');\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar axisIds = require('../../plots/cartesian/axis_ids');\nvar scatterSubTypes = require('../../traces/scatter/subtypes');\nvar Registry = require('../../registry');\nvar isUnifiedHover = require('../fx/helpers').isUnifiedHover;\n\nvar createModeBar = require('./modebar');\nvar modeBarButtons = require('./buttons');\n\n/**\n * ModeBar wrapper around 'create' and 'update',\n * chooses buttons to pass to ModeBar constructor based on\n * plot type and plot config.\n *\n * @param {object} gd main plot object\n *\n */\nmodule.exports = function manageModeBar(gd) {\n var fullLayout = gd._fullLayout;\n var context = gd._context;\n var modeBar = fullLayout._modeBar;\n\n if(!context.displayModeBar && !context.watermark) {\n if(modeBar) {\n modeBar.destroy();\n delete fullLayout._modeBar;\n }\n return;\n }\n\n if(!Array.isArray(context.modeBarButtonsToRemove)) {\n throw new Error([\n '*modeBarButtonsToRemove* configuration options',\n 'must be an array.'\n ].join(' '));\n }\n\n if(!Array.isArray(context.modeBarButtonsToAdd)) {\n throw new Error([\n '*modeBarButtonsToAdd* configuration options',\n 'must be an array.'\n ].join(' '));\n }\n\n var customButtons = context.modeBarButtons;\n var buttonGroups;\n\n if(Array.isArray(customButtons) && customButtons.length) {\n buttonGroups = fillCustomButton(customButtons);\n } else if(!context.displayModeBar && context.watermark) {\n buttonGroups = [];\n } else {\n buttonGroups = getButtonGroups(gd);\n }\n\n if(modeBar) modeBar.update(gd, buttonGroups);\n else fullLayout._modeBar = createModeBar(gd, buttonGroups);\n};\n\n// logic behind which buttons are displayed by default\nfunction getButtonGroups(gd) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var context = gd._context;\n var buttonsToRemove = context.modeBarButtonsToRemove;\n var buttonsToAdd = context.modeBarButtonsToAdd;\n\n var hasCartesian = fullLayout._has('cartesian');\n var hasGL3D = fullLayout._has('gl3d');\n var hasGeo = fullLayout._has('geo');\n var hasPie = fullLayout._has('pie');\n var hasFunnelarea = fullLayout._has('funnelarea');\n var hasGL2D = fullLayout._has('gl2d');\n var hasTernary = fullLayout._has('ternary');\n var hasMapbox = fullLayout._has('mapbox');\n var hasPolar = fullLayout._has('polar');\n var hasSankey = fullLayout._has('sankey');\n var allAxesFixed = areAllAxesFixed(fullLayout);\n var hasUnifiedHoverLabel = isUnifiedHover(fullLayout.hovermode);\n\n var groups = [];\n\n function addGroup(newGroup) {\n if(!newGroup.length) return;\n\n var out = [];\n\n for(var i = 0; i < newGroup.length; i++) {\n var button = newGroup[i];\n if(buttonsToRemove.indexOf(button) !== -1) continue;\n out.push(modeBarButtons[button]);\n }\n\n groups.push(out);\n }\n\n // buttons common to all plot types\n var commonGroup = ['toImage'];\n if(context.showEditInChartStudio) commonGroup.push('editInChartStudio');\n else if(context.showSendToCloud) commonGroup.push('sendDataToCloud');\n addGroup(commonGroup);\n\n var zoomGroup = [];\n var hoverGroup = [];\n var resetGroup = [];\n var dragModeGroup = [];\n\n if((hasCartesian || hasGL2D || hasPie || hasFunnelarea || hasTernary) + hasGeo + hasGL3D + hasMapbox + hasPolar > 1) {\n // graphs with more than one plot types get 'union buttons'\n // which reset the view or toggle hover labels across all subplots.\n hoverGroup = ['toggleHover'];\n resetGroup = ['resetViews'];\n } else if(hasGeo) {\n zoomGroup = ['zoomInGeo', 'zoomOutGeo'];\n hoverGroup = ['hoverClosestGeo'];\n resetGroup = ['resetGeo'];\n } else if(hasGL3D) {\n hoverGroup = ['hoverClosest3d'];\n resetGroup = ['resetCameraDefault3d', 'resetCameraLastSave3d'];\n } else if(hasMapbox) {\n zoomGroup = ['zoomInMapbox', 'zoomOutMapbox'];\n hoverGroup = ['toggleHover'];\n resetGroup = ['resetViewMapbox'];\n } else if(hasGL2D) {\n hoverGroup = ['hoverClosestGl2d'];\n } else if(hasPie) {\n hoverGroup = ['hoverClosestPie'];\n } else if(hasSankey) {\n hoverGroup = ['hoverClosestCartesian', 'hoverCompareCartesian'];\n resetGroup = ['resetViewSankey'];\n } else { // hasPolar, hasTernary\n // always show at least one hover icon.\n hoverGroup = ['toggleHover'];\n }\n // if we have cartesian, allow switching between closest and compare\n // regardless of what other types are on the plot, since they'll all\n // just treat any truthy hovermode as 'closest'\n if(hasCartesian) {\n hoverGroup = ['toggleSpikelines', 'hoverClosestCartesian', 'hoverCompareCartesian'];\n }\n if(hasNoHover(fullData) || hasUnifiedHoverLabel) {\n hoverGroup = [];\n }\n\n if((hasCartesian || hasGL2D) && !allAxesFixed) {\n zoomGroup = ['zoomIn2d', 'zoomOut2d', 'autoScale2d'];\n if(resetGroup[0] !== 'resetViews') resetGroup = ['resetScale2d'];\n }\n\n if(hasGL3D) {\n dragModeGroup = ['zoom3d', 'pan3d', 'orbitRotation', 'tableRotation'];\n } else if(((hasCartesian || hasGL2D) && !allAxesFixed) || hasTernary) {\n dragModeGroup = ['zoom2d', 'pan2d'];\n } else if(hasMapbox || hasGeo) {\n dragModeGroup = ['pan2d'];\n } else if(hasPolar) {\n dragModeGroup = ['zoom2d'];\n }\n if(isSelectable(fullData)) {\n dragModeGroup.push('select2d', 'lasso2d');\n }\n\n addGroup(dragModeGroup);\n addGroup(zoomGroup.concat(resetGroup));\n addGroup(hoverGroup);\n\n return appendButtonsToGroups(groups, buttonsToAdd);\n}\n\nfunction areAllAxesFixed(fullLayout) {\n var axList = axisIds.list({_fullLayout: fullLayout}, null, true);\n\n for(var i = 0; i < axList.length; i++) {\n if(!axList[i].fixedrange) {\n return false;\n }\n }\n\n return true;\n}\n\n// look for traces that support selection\n// to be updated as we add more selectPoints handlers\nfunction isSelectable(fullData) {\n var selectable = false;\n\n for(var i = 0; i < fullData.length; i++) {\n if(selectable) break;\n\n var trace = fullData[i];\n\n if(!trace._module || !trace._module.selectPoints) continue;\n\n if(Registry.traceIs(trace, 'scatter-like')) {\n if(scatterSubTypes.hasMarkers(trace) || scatterSubTypes.hasText(trace)) {\n selectable = true;\n }\n } else if(Registry.traceIs(trace, 'box-violin')) {\n if(trace.boxpoints === 'all' || trace.points === 'all') {\n selectable = true;\n }\n } else {\n // assume that in general if the trace module has selectPoints,\n // then it's selectable. Scatter is an exception to this because it must\n // have markers or text, not just be a scatter type.\n\n selectable = true;\n }\n }\n\n return selectable;\n}\n\n// check whether all trace are 'noHover'\nfunction hasNoHover(fullData) {\n for(var i = 0; i < fullData.length; i++) {\n if(!Registry.traceIs(fullData[i], 'noHover')) return false;\n }\n return true;\n}\n\nfunction appendButtonsToGroups(groups, buttons) {\n if(buttons.length) {\n if(Array.isArray(buttons[0])) {\n for(var i = 0; i < buttons.length; i++) {\n groups.push(buttons[i]);\n }\n } else groups.push(buttons);\n }\n\n return groups;\n}\n\n// fill in custom buttons referring to default mode bar buttons\nfunction fillCustomButton(customButtons) {\n for(var i = 0; i < customButtons.length; i++) {\n var buttonGroup = customButtons[i];\n\n for(var j = 0; j < buttonGroup.length; j++) {\n var button = buttonGroup[j];\n\n if(typeof button === 'string') {\n if(modeBarButtons[button] !== undefined) {\n customButtons[i][j] = modeBarButtons[button];\n } else {\n throw new Error([\n '*modeBarButtons* configuration options',\n 'invalid button name'\n ].join(' '));\n }\n }\n }\n }\n\n return customButtons;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../lib');\nvar plotAttributes = require('../plots/attributes');\n\nvar TEMPLATEITEMNAME = 'templateitemname';\n\nvar templateAttrs = {\n name: {\n valType: 'string',\n role: 'style',\n editType: 'none',\n description: [\n 'When used in a template, named items are created in the output figure',\n 'in addition to any items the figure already has in this array.',\n 'You can modify these items in the output figure by making your own',\n 'item with `templateitemname` matching this `name`',\n 'alongside your modifications (including `visible: false` or',\n '`enabled: false` to hide it).',\n 'Has no effect outside of a template.'\n ].join(' ')\n }\n};\ntemplateAttrs[TEMPLATEITEMNAME] = {\n valType: 'string',\n role: 'info',\n editType: 'calc',\n description: [\n 'Used to refer to a named item in this array in the template. Named',\n 'items from the template will be created even without a matching item',\n 'in the input figure, but you can modify one by making an item with',\n '`templateitemname` matching its `name`, alongside your modifications',\n '(including `visible: false` or `enabled: false` to hide it).',\n 'If there is no template or no matching item, this item will be',\n 'hidden unless you explicitly show it with `visible: true`.'\n ].join(' ')\n};\n\n/**\n * templatedArray: decorate an attributes object with templating (and array)\n * properties.\n *\n * @param {string} name: the singular form of the array name. Sets\n * `_isLinkedToArray` to this, so the schema knows to treat this as an array.\n * @param {object} attrs: the item attributes. Since all callers are expected\n * to be constructing this object on the spot, we mutate it here for\n * performance, rather than extending a new object with it.\n *\n * @returns {object}: the decorated `attrs` object\n */\nexports.templatedArray = function(name, attrs) {\n attrs._isLinkedToArray = name;\n attrs.name = templateAttrs.name;\n attrs[TEMPLATEITEMNAME] = templateAttrs[TEMPLATEITEMNAME];\n return attrs;\n};\n\n/**\n * traceTemplater: logic for matching traces to trace templates\n *\n * @param {object} dataTemplate: collection of {traceType: [{template}, ...]}\n * ie each type the template applies to contains a list of template objects,\n * to be provided cyclically to data traces of that type.\n *\n * @returns {object}: {newTrace}, a function:\n * newTrace(traceIn): that takes the input traceIn, coerces its type, then\n * uses that type to find the next template to apply. returns the output\n * traceOut with template attached, ready to continue supplyDefaults.\n */\nexports.traceTemplater = function(dataTemplate) {\n var traceCounts = {};\n var traceType, typeTemplates;\n\n for(traceType in dataTemplate) {\n typeTemplates = dataTemplate[traceType];\n if(Array.isArray(typeTemplates) && typeTemplates.length) {\n traceCounts[traceType] = 0;\n }\n }\n\n function newTrace(traceIn) {\n traceType = Lib.coerce(traceIn, {}, plotAttributes, 'type');\n var traceOut = {type: traceType, _template: null};\n if(traceType in traceCounts) {\n typeTemplates = dataTemplate[traceType];\n // cycle through traces in the template set for this type\n var typei = traceCounts[traceType] % typeTemplates.length;\n traceCounts[traceType]++;\n traceOut._template = typeTemplates[typei];\n } else {\n // TODO: anything we should do for types missing from the template?\n // try to apply some other type? Or just bail as we do here?\n // Actually I think yes, we should apply other types; would be nice\n // if all scatter* could inherit from each other, and if histogram\n // could inherit from bar, etc... but how to specify this? And do we\n // compose them, or if a type is present require it to be complete?\n // Actually this could apply to layout too - 3D annotations\n // inheriting from 2D, axes of different types inheriting from each\n // other...\n }\n return traceOut;\n }\n\n return {\n newTrace: newTrace\n // TODO: function to figure out what's left & what didn't work\n };\n};\n\n/**\n * newContainer: Create a new sub-container inside `container` and propagate any\n * applicable template to it. If there's no template, still propagates\n * `undefined` so relinkPrivate will not retain an old template!\n *\n * @param {object} container: the outer container, should already have _template\n * if there *is* a template for this plot\n * @param {string} name: the key of the new container to make\n * @param {string} baseName: if applicable, a base attribute to take the\n * template from, ie for xaxis3 the base would be xaxis\n *\n * @returns {object}: an object for inclusion _full*, empty except for the\n * appropriate template piece\n */\nexports.newContainer = function(container, name, baseName) {\n var template = container._template;\n var part = template && (template[name] || (baseName && template[baseName]));\n if(!Lib.isPlainObject(part)) part = null;\n\n var out = container[name] = {_template: part};\n return out;\n};\n\n/**\n * arrayTemplater: special logic for templating both defaults and specific items\n * in a container array (annotations etc)\n *\n * @param {object} container: the outer container, should already have _template\n * if there *is* a template for this plot\n * @param {string} name: the name of the array to template (ie 'annotations')\n * will be used to find default ('annotationdefaults' object) and specific\n * ('annotations' array) template specs.\n * @param {string} inclusionAttr: the attribute determining this item's\n * inclusion in the output, usually 'visible' or 'enabled'\n *\n * @returns {object}: {newItem, defaultItems}, both functions:\n * newItem(itemIn): create an output item, bare except for the correct\n * template and name(s), as the base for supplyDefaults\n * defaultItems(): to be called after all newItem calls, return any\n * specific template items that have not already beeen included,\n * also as bare output items ready for supplyDefaults.\n */\nexports.arrayTemplater = function(container, name, inclusionAttr) {\n var template = container._template;\n var defaultsTemplate = template && template[arrayDefaultKey(name)];\n var templateItems = template && template[name];\n if(!Array.isArray(templateItems) || !templateItems.length) {\n templateItems = [];\n }\n\n var usedNames = {};\n\n function newItem(itemIn) {\n // include name and templateitemname in the output object for ALL\n // container array items. Note: you could potentially use different\n // name and templateitemname, if you're using one template to make\n // another template. templateitemname would be the name in the original\n // template, and name is the new \"subclassed\" item name.\n var out = {name: itemIn.name, _input: itemIn};\n var templateItemName = out[TEMPLATEITEMNAME] = itemIn[TEMPLATEITEMNAME];\n\n // no itemname: use the default template\n if(!validItemName(templateItemName)) {\n out._template = defaultsTemplate;\n return out;\n }\n\n // look for an item matching this itemname\n // note these do not inherit from the default template, only the item.\n for(var i = 0; i < templateItems.length; i++) {\n var templateItem = templateItems[i];\n if(templateItem.name === templateItemName) {\n // Note: it's OK to use a template item more than once\n // but using it at least once will stop it from generating\n // a default item at the end.\n usedNames[templateItemName] = 1;\n out._template = templateItem;\n return out;\n }\n }\n\n // Didn't find a matching template item, so since this item is intended\n // to only be modifications it's most likely broken. Hide it unless\n // it's explicitly marked visible - in which case it gets NO template,\n // not even the default.\n out[inclusionAttr] = itemIn[inclusionAttr] || false;\n // special falsy value we can look for in validateTemplate\n out._template = false;\n return out;\n }\n\n function defaultItems() {\n var out = [];\n for(var i = 0; i < templateItems.length; i++) {\n var templateItem = templateItems[i];\n var name = templateItem.name;\n // only allow named items to be added as defaults,\n // and only allow each name once\n if(validItemName(name) && !usedNames[name]) {\n var outi = {\n _template: templateItem,\n name: name,\n _input: {_templateitemname: name}\n };\n outi[TEMPLATEITEMNAME] = templateItem[TEMPLATEITEMNAME];\n out.push(outi);\n usedNames[name] = 1;\n }\n }\n return out;\n }\n\n return {\n newItem: newItem,\n defaultItems: defaultItems\n };\n};\n\nfunction validItemName(name) {\n return name && typeof name === 'string';\n}\n\nfunction arrayDefaultKey(name) {\n var lastChar = name.length - 1;\n if(name.charAt(lastChar) !== 's') {\n Lib.warn('bad argument to arrayDefaultKey: ' + name);\n }\n return name.substr(0, name.length - 1) + 'defaults';\n}\nexports.arrayDefaultKey = arrayDefaultKey;\n\n/**\n * arrayEditor: helper for editing array items that may have come from\n * template defaults (in which case they will not exist in the input yet)\n *\n * @param {object} parentIn: the input container (eg gd.layout)\n * @param {string} containerStr: the attribute string for the container inside\n * `parentIn`.\n * @param {object} itemOut: the _full* item (eg gd._fullLayout.annotations[0])\n * that we'll be editing. Assumed to have been created by `arrayTemplater`.\n *\n * @returns {object}: {modifyBase, modifyItem, getUpdateObj, applyUpdate}, all functions:\n * modifyBase(attr, value): Add an update that's *not* related to the item.\n * `attr` is the full attribute string.\n * modifyItem(attr, value): Add an update to the item. `attr` is just the\n * portion of the attribute string inside the item.\n * getUpdateObj(): Get the final constructed update object, to use in\n * `restyle` or `relayout`. Also resets the update object in case this\n * update was canceled.\n * applyUpdate(attr, value): optionally add an update `attr: value`,\n * then apply it to `parent` which should be the parent of `containerIn`,\n * ie the object to which `containerStr` is the attribute string.\n */\nexports.arrayEditor = function(parentIn, containerStr, itemOut) {\n var lengthIn = (Lib.nestedProperty(parentIn, containerStr).get() || []).length;\n var index = itemOut._index;\n // Check that we are indeed off the end of this container.\n // Otherwise a devious user could put a key `_templateitemname` in their\n // own input and break lots of things.\n var templateItemName = (index >= lengthIn) && (itemOut._input || {})._templateitemname;\n if(templateItemName) index = lengthIn;\n var itemStr = containerStr + '[' + index + ']';\n\n var update;\n function resetUpdate() {\n update = {};\n if(templateItemName) {\n update[itemStr] = {};\n update[itemStr][TEMPLATEITEMNAME] = templateItemName;\n }\n }\n resetUpdate();\n\n function modifyBase(attr, value) {\n update[attr] = value;\n }\n\n function modifyItem(attr, value) {\n if(templateItemName) {\n // we're making a new object: edit that object\n Lib.nestedProperty(update[itemStr], attr).set(value);\n } else {\n // we're editing an existing object: include *just* the edit\n update[itemStr + '.' + attr] = value;\n }\n }\n\n function getUpdateObj() {\n var updateOut = update;\n resetUpdate();\n return updateOut;\n }\n\n function applyUpdate(attr, value) {\n if(attr) modifyItem(attr, value);\n var updateToApply = getUpdateObj();\n for(var key in updateToApply) {\n Lib.nestedProperty(parentIn, key).set(updateToApply[key]);\n }\n }\n\n return {\n modifyBase: modifyBase,\n modifyItem: modifyItem,\n getUpdateObj: getUpdateObj,\n applyUpdate: applyUpdate\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var opts = Lib.extendFlat({}, layout.hoverlabel);\n if(traceOut.hovertemplate) opts.namelength = -1;\n\n handleHoverLabelDefaults(traceIn, traceOut, coerce, opts);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = function calcSelection(cd, trace) {\n if(Lib.isArrayOrTypedArray(trace.selectedpoints)) {\n Lib.tagSelected(cd, trace);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\n\nvar makeComputeError = require('./compute_error');\n\nmodule.exports = function calc(gd) {\n var calcdata = gd.calcdata;\n\n for(var i = 0; i < calcdata.length; i++) {\n var calcTrace = calcdata[i];\n var trace = calcTrace[0].trace;\n\n if(trace.visible === true && Registry.traceIs(trace, 'errorBarsOK')) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n calcOneAxis(calcTrace, trace, xa, 'x');\n calcOneAxis(calcTrace, trace, ya, 'y');\n }\n }\n};\n\nfunction calcOneAxis(calcTrace, trace, axis, coord) {\n var opts = trace['error_' + coord] || {};\n var isVisible = (opts.visible && ['linear', 'log'].indexOf(axis.type) !== -1);\n var vals = [];\n\n if(!isVisible) return;\n\n var computeError = makeComputeError(opts);\n\n for(var i = 0; i < calcTrace.length; i++) {\n var calcPt = calcTrace[i];\n\n var iIn = calcPt.i;\n\n // for types that don't include `i` in each calcdata point\n if(iIn === undefined) iIn = i;\n\n // for stacked area inserted points\n // TODO: errorbars have been tested cursorily with stacked area,\n // but not thoroughly. It's not even really clear what you want to do:\n // Should it just be calculated based on that trace's size data?\n // Should you add errors from below in quadrature?\n // And what about normalization, where in principle the errors shrink\n // again when you get up to the top end?\n // One option would be to forbid errorbars with stacking until we\n // decide how to handle these questions.\n else if(iIn === null) continue;\n\n var calcCoord = calcPt[coord];\n\n if(!isNumeric(axis.c2l(calcCoord))) continue;\n\n var errors = computeError(calcCoord, iIn);\n if(isNumeric(errors[0]) && isNumeric(errors[1])) {\n var shoe = calcPt[coord + 's'] = calcCoord - errors[0];\n var hat = calcPt[coord + 'h'] = calcCoord + errors[1];\n vals.push(shoe, hat);\n }\n }\n\n var axId = axis._id;\n var baseExtremes = trace._extremes[axId];\n var extremes = Axes.findExtremes(\n axis,\n vals,\n Lib.extendFlat({tozero: baseExtremes.opts.tozero}, {padded: true})\n );\n baseExtremes.min = baseExtremes.min.concat(extremes.min);\n baseExtremes.max = baseExtremes.max.concat(extremes.max);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nmodule.exports = function style(gd) {\n d3.select(gd).selectAll('.hm image')\n .style('opacity', function(d) {\n return d.trace.opacity;\n });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar colorAttributes = require('../color/attributes');\n\nmodule.exports = {\n bgcolor: {\n valType: 'color',\n dflt: colorAttributes.background,\n role: 'style',\n editType: 'plot',\n description: 'Sets the background color of the range slider.'\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttributes.defaultLine,\n role: 'style',\n editType: 'plot',\n description: 'Sets the border color of the range slider.'\n },\n borderwidth: {\n valType: 'integer',\n dflt: 0,\n min: 0,\n role: 'style',\n editType: 'plot',\n description: 'Sets the border width of the range slider.'\n },\n autorange: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'calc',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Determines whether or not the range slider range is',\n 'computed in relation to the input data.',\n 'If `range` is provided, then `autorange` is set to *false*.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n role: 'info',\n items: [\n {valType: 'any', editType: 'calc', impliedEdits: {'^autorange': false}},\n {valType: 'any', editType: 'calc', impliedEdits: {'^autorange': false}}\n ],\n editType: 'calc',\n impliedEdits: {'autorange': false},\n description: [\n 'Sets the range of the range slider.',\n 'If not set, defaults to the full xaxis range.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n thickness: {\n valType: 'number',\n dflt: 0.15,\n min: 0,\n max: 1,\n role: 'style',\n editType: 'plot',\n description: [\n 'The height of the range slider as a fraction of the',\n 'total plot area height.'\n ].join(' ')\n },\n visible: {\n valType: 'boolean',\n dflt: true,\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not the range slider will be visible.',\n 'If visible, perpendicular axes will be set to `fixedrange`'\n ].join(' ')\n },\n editType: 'calc'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar draw = require('./draw').draw;\n\n\nmodule.exports = function calcAutorange(gd) {\n var fullLayout = gd._fullLayout;\n var annotationList = Lib.filterVisible(fullLayout.annotations);\n\n if(annotationList.length && gd._fullData.length) {\n return Lib.syncOrAsync([draw, annAutorange], gd);\n }\n};\n\nfunction annAutorange(gd) {\n var fullLayout = gd._fullLayout;\n\n // find the bounding boxes for each of these annotations'\n // relative to their anchor points\n // use the arrow and the text bg rectangle,\n // as the whole anno may include hidden text in its bbox\n Lib.filterVisible(fullLayout.annotations).forEach(function(ann) {\n var xa = Axes.getFromId(gd, ann.xref);\n var ya = Axes.getFromId(gd, ann.yref);\n\n ann._extremes = {};\n if(xa) calcAxisExpansion(ann, xa);\n if(ya) calcAxisExpansion(ann, ya);\n });\n}\n\nfunction calcAxisExpansion(ann, ax) {\n var axId = ax._id;\n var letter = axId.charAt(0);\n var pos = ann[letter];\n var apos = ann['a' + letter];\n var ref = ann[letter + 'ref'];\n var aref = ann['a' + letter + 'ref'];\n var padplus = ann['_' + letter + 'padplus'];\n var padminus = ann['_' + letter + 'padminus'];\n var shift = {x: 1, y: -1}[letter] * ann[letter + 'shift'];\n var headSize = 3 * ann.arrowsize * ann.arrowwidth || 0;\n var headPlus = headSize + shift;\n var headMinus = headSize - shift;\n var startHeadSize = 3 * ann.startarrowsize * ann.arrowwidth || 0;\n var startHeadPlus = startHeadSize + shift;\n var startHeadMinus = startHeadSize - shift;\n var extremes;\n\n if(aref === ref) {\n // expand for the arrowhead (padded by arrowhead)\n var extremeArrowHead = Axes.findExtremes(ax, [ax.r2c(pos)], {\n ppadplus: headPlus,\n ppadminus: headMinus\n });\n // again for the textbox (padded by textbox)\n var extremeText = Axes.findExtremes(ax, [ax.r2c(apos)], {\n ppadplus: Math.max(padplus, startHeadPlus),\n ppadminus: Math.max(padminus, startHeadMinus)\n });\n extremes = {\n min: [extremeArrowHead.min[0], extremeText.min[0]],\n max: [extremeArrowHead.max[0], extremeText.max[0]]\n };\n } else {\n startHeadPlus = apos ? startHeadPlus + apos : startHeadPlus;\n startHeadMinus = apos ? startHeadMinus - apos : startHeadMinus;\n extremes = Axes.findExtremes(ax, [ax.r2c(pos)], {\n ppadplus: Math.max(padplus, headPlus, startHeadPlus),\n ppadminus: Math.max(padminus, headMinus, startHeadMinus)\n });\n }\n\n ann._extremes[axId] = extremes;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar hoverLabelAttrs = require('./layout_attributes').hoverlabel;\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = {\n hoverlabel: {\n bgcolor: extendFlat({}, hoverLabelAttrs.bgcolor, {\n arrayOk: true,\n description: 'Sets the background color of the hover labels for this trace'\n }),\n bordercolor: extendFlat({}, hoverLabelAttrs.bordercolor, {\n arrayOk: true,\n description: 'Sets the border color of the hover labels for this trace.'\n }),\n font: fontAttrs({\n arrayOk: true,\n editType: 'none',\n description: 'Sets the font used in hover labels.'\n }),\n align: extendFlat({}, hoverLabelAttrs.align, {arrayOk: true}),\n namelength: extendFlat({}, hoverLabelAttrs.namelength, {arrayOk: true}),\n editType: 'none'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\nvar d3 = require('d3');\nvar Lib = require('../../../lib');\nvar extendDeepAll = Lib.extendDeepAll;\nvar MID_SHIFT = require('../../../constants/alignment').MID_SHIFT;\n\nvar µ = module.exports = { version: '0.2.2' };\n\nµ.Axis = function module() {\n var config = {\n data: [],\n layout: {}\n }, inputConfig = {}, liveConfig = {};\n var svg, container, dispatch = d3.dispatch('hover'), radialScale, angularScale;\n var exports = {};\n function render(_container) {\n container = _container || container;\n var data = config.data;\n var axisConfig = config.layout;\n if (typeof container == 'string' || container.nodeName) container = d3.select(container);\n container.datum(data).each(function(_data, _index) {\n var dataOriginal = _data.slice();\n liveConfig = {\n data: µ.util.cloneJson(dataOriginal),\n layout: µ.util.cloneJson(axisConfig)\n };\n var colorIndex = 0;\n dataOriginal.forEach(function(d, i) {\n if (!d.color) {\n d.color = axisConfig.defaultColorRange[colorIndex];\n colorIndex = (colorIndex + 1) % axisConfig.defaultColorRange.length;\n }\n if (!d.strokeColor) {\n d.strokeColor = d.geometry === 'LinePlot' ? d.color : d3.rgb(d.color).darker().toString();\n }\n liveConfig.data[i].color = d.color;\n liveConfig.data[i].strokeColor = d.strokeColor;\n liveConfig.data[i].strokeDash = d.strokeDash;\n liveConfig.data[i].strokeSize = d.strokeSize;\n });\n var data = dataOriginal.filter(function(d, i) {\n var visible = d.visible;\n return typeof visible === 'undefined' || visible === true;\n });\n var isStacked = false;\n var dataWithGroupId = data.map(function(d, i) {\n isStacked = isStacked || typeof d.groupId !== 'undefined';\n return d;\n });\n if (isStacked) {\n var grouped = d3.nest().key(function(d, i) {\n return typeof d.groupId != 'undefined' ? d.groupId : 'unstacked';\n }).entries(dataWithGroupId);\n var dataYStack = [];\n var stacked = grouped.map(function(d, i) {\n if (d.key === 'unstacked') return d.values; else {\n var prevArray = d.values[0].r.map(function(d, i) {\n return 0;\n });\n d.values.forEach(function(d, i, a) {\n d.yStack = [ prevArray ];\n dataYStack.push(prevArray);\n prevArray = µ.util.sumArrays(d.r, prevArray);\n });\n return d.values;\n }\n });\n data = d3.merge(stacked);\n }\n data.forEach(function(d, i) {\n d.t = Array.isArray(d.t[0]) ? d.t : [ d.t ];\n d.r = Array.isArray(d.r[0]) ? d.r : [ d.r ];\n });\n var radius = Math.min(axisConfig.width - axisConfig.margin.left - axisConfig.margin.right, axisConfig.height - axisConfig.margin.top - axisConfig.margin.bottom) / 2;\n radius = Math.max(10, radius);\n var chartCenter = [ axisConfig.margin.left + radius, axisConfig.margin.top + radius ];\n var extent;\n if (isStacked) {\n var highestStackedValue = d3.max(µ.util.sumArrays(µ.util.arrayLast(data).r[0], µ.util.arrayLast(dataYStack)));\n extent = [ 0, highestStackedValue ];\n } else extent = d3.extent(µ.util.flattenArray(data.map(function(d, i) {\n return d.r;\n })));\n if (axisConfig.radialAxis.domain != µ.DATAEXTENT) extent[0] = 0;\n radialScale = d3.scale.linear().domain(axisConfig.radialAxis.domain != µ.DATAEXTENT && axisConfig.radialAxis.domain ? axisConfig.radialAxis.domain : extent).range([ 0, radius ]);\n liveConfig.layout.radialAxis.domain = radialScale.domain();\n var angularDataMerged = µ.util.flattenArray(data.map(function(d, i) {\n return d.t;\n }));\n var isOrdinal = typeof angularDataMerged[0] === 'string';\n var ticks;\n if (isOrdinal) {\n angularDataMerged = µ.util.deduplicate(angularDataMerged);\n ticks = angularDataMerged.slice();\n angularDataMerged = d3.range(angularDataMerged.length);\n data = data.map(function(d, i) {\n var result = d;\n d.t = [ angularDataMerged ];\n if (isStacked) result.yStack = d.yStack;\n return result;\n });\n }\n var hasOnlyLineOrDotPlot = data.filter(function(d, i) {\n return d.geometry === 'LinePlot' || d.geometry === 'DotPlot';\n }).length === data.length;\n var needsEndSpacing = axisConfig.needsEndSpacing === null ? isOrdinal || !hasOnlyLineOrDotPlot : axisConfig.needsEndSpacing;\n var useProvidedDomain = axisConfig.angularAxis.domain && axisConfig.angularAxis.domain != µ.DATAEXTENT && !isOrdinal && axisConfig.angularAxis.domain[0] >= 0;\n var angularDomain = useProvidedDomain ? axisConfig.angularAxis.domain : d3.extent(angularDataMerged);\n var angularDomainStep = Math.abs(angularDataMerged[1] - angularDataMerged[0]);\n if (hasOnlyLineOrDotPlot && !isOrdinal) angularDomainStep = 0;\n var angularDomainWithPadding = angularDomain.slice();\n if (needsEndSpacing && isOrdinal) angularDomainWithPadding[1] += angularDomainStep;\n var tickCount = axisConfig.angularAxis.ticksCount || 4;\n if (tickCount > 8) tickCount = tickCount / (tickCount / 8) + tickCount % 8;\n if (axisConfig.angularAxis.ticksStep) {\n tickCount = (angularDomainWithPadding[1] - angularDomainWithPadding[0]) / tickCount;\n }\n var angularTicksStep = axisConfig.angularAxis.ticksStep || (angularDomainWithPadding[1] - angularDomainWithPadding[0]) / (tickCount * (axisConfig.minorTicks + 1));\n if (ticks) angularTicksStep = Math.max(Math.round(angularTicksStep), 1);\n if (!angularDomainWithPadding[2]) angularDomainWithPadding[2] = angularTicksStep;\n var angularAxisRange = d3.range.apply(this, angularDomainWithPadding);\n angularAxisRange = angularAxisRange.map(function(d, i) {\n return parseFloat(d.toPrecision(12));\n });\n angularScale = d3.scale.linear().domain(angularDomainWithPadding.slice(0, 2)).range(axisConfig.direction === 'clockwise' ? [ 0, 360 ] : [ 360, 0 ]);\n liveConfig.layout.angularAxis.domain = angularScale.domain();\n liveConfig.layout.angularAxis.endPadding = needsEndSpacing ? angularDomainStep : 0;\n svg = d3.select(this).select('svg.chart-root');\n if (typeof svg === 'undefined' || svg.empty()) {\n var skeleton = \"' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '' + '\";\n var doc = new DOMParser().parseFromString(skeleton, 'application/xml');\n var newSvg = this.appendChild(this.ownerDocument.importNode(doc.documentElement, true));\n svg = d3.select(newSvg);\n }\n svg.select('.guides-group').style({\n 'pointer-events': 'none'\n });\n svg.select('.angular.axis-group').style({\n 'pointer-events': 'none'\n });\n svg.select('.radial.axis-group').style({\n 'pointer-events': 'none'\n });\n var chartGroup = svg.select('.chart-group');\n var lineStyle = {\n fill: 'none',\n stroke: axisConfig.tickColor\n };\n var fontStyle = {\n 'font-size': axisConfig.font.size,\n 'font-family': axisConfig.font.family,\n fill: axisConfig.font.color,\n 'text-shadow': [ '-1px 0px', '1px -1px', '-1px 1px', '1px 1px' ].map(function(d, i) {\n return ' ' + d + ' 0 ' + axisConfig.font.outlineColor;\n }).join(',')\n };\n var legendContainer;\n if (axisConfig.showLegend) {\n legendContainer = svg.select('.legend-group').attr({\n transform: 'translate(' + [ radius, axisConfig.margin.top ] + ')'\n }).style({\n display: 'block'\n });\n var elements = data.map(function(d, i) {\n var datumClone = µ.util.cloneJson(d);\n datumClone.symbol = d.geometry === 'DotPlot' ? d.dotType || 'circle' : d.geometry != 'LinePlot' ? 'square' : 'line';\n datumClone.visibleInLegend = typeof d.visibleInLegend === 'undefined' || d.visibleInLegend;\n datumClone.color = d.geometry === 'LinePlot' ? d.strokeColor : d.color;\n return datumClone;\n });\n\n µ.Legend().config({\n data: data.map(function(d, i) {\n return d.name || 'Element' + i;\n }),\n legendConfig: extendDeepAll({},\n µ.Legend.defaultConfig().legendConfig,\n {\n container: legendContainer,\n elements: elements,\n reverseOrder: axisConfig.legend.reverseOrder\n }\n )\n })();\n\n var legendBBox = legendContainer.node().getBBox();\n radius = Math.min(axisConfig.width - legendBBox.width - axisConfig.margin.left - axisConfig.margin.right, axisConfig.height - axisConfig.margin.top - axisConfig.margin.bottom) / 2;\n radius = Math.max(10, radius);\n chartCenter = [ axisConfig.margin.left + radius, axisConfig.margin.top + radius ];\n radialScale.range([ 0, radius ]);\n liveConfig.layout.radialAxis.domain = radialScale.domain();\n legendContainer.attr('transform', 'translate(' + [ chartCenter[0] + radius, chartCenter[1] - radius ] + ')');\n } else {\n legendContainer = svg.select('.legend-group').style({\n display: 'none'\n });\n }\n svg.attr({\n width: axisConfig.width,\n height: axisConfig.height\n }).style({\n opacity: axisConfig.opacity\n });\n chartGroup.attr('transform', 'translate(' + chartCenter + ')').style({\n cursor: 'crosshair'\n });\n var centeringOffset = [ (axisConfig.width - (axisConfig.margin.left + axisConfig.margin.right + radius * 2 + (legendBBox ? legendBBox.width : 0))) / 2, (axisConfig.height - (axisConfig.margin.top + axisConfig.margin.bottom + radius * 2)) / 2 ];\n centeringOffset[0] = Math.max(0, centeringOffset[0]);\n centeringOffset[1] = Math.max(0, centeringOffset[1]);\n svg.select('.outer-group').attr('transform', 'translate(' + centeringOffset + ')');\n if (axisConfig.title && axisConfig.title.text) {\n var title = svg.select('g.title-group text').style(fontStyle).text(axisConfig.title.text);\n var titleBBox = title.node().getBBox();\n title.attr({\n x: chartCenter[0] - titleBBox.width / 2,\n y: chartCenter[1] - radius - 20\n });\n }\n var radialAxis = svg.select('.radial.axis-group');\n if (axisConfig.radialAxis.gridLinesVisible) {\n var gridCircles = radialAxis.selectAll('circle.grid-circle').data(radialScale.ticks(5));\n gridCircles.enter().append('circle').attr({\n 'class': 'grid-circle'\n }).style(lineStyle);\n gridCircles.attr('r', radialScale);\n gridCircles.exit().remove();\n }\n radialAxis.select('circle.outside-circle').attr({\n r: radius\n }).style(lineStyle);\n var backgroundCircle = svg.select('circle.background-circle').attr({\n r: radius\n }).style({\n fill: axisConfig.backgroundColor,\n stroke: axisConfig.stroke\n });\n function currentAngle(d, i) {\n return angularScale(d) % 360 + axisConfig.orientation;\n }\n if (axisConfig.radialAxis.visible) {\n var axis = d3.svg.axis().scale(radialScale).ticks(5).tickSize(5);\n radialAxis.call(axis).attr({\n transform: 'rotate(' + axisConfig.radialAxis.orientation + ')'\n });\n radialAxis.selectAll('.domain').style(lineStyle);\n radialAxis.selectAll('g>text').text(function(d, i) {\n return this.textContent + axisConfig.radialAxis.ticksSuffix;\n }).style(fontStyle).style({\n 'text-anchor': 'start'\n }).attr({\n x: 0,\n y: 0,\n dx: 0,\n dy: 0,\n transform: function(d, i) {\n if (axisConfig.radialAxis.tickOrientation === 'horizontal') {\n return 'rotate(' + -axisConfig.radialAxis.orientation + ') translate(' + [ 0, fontStyle['font-size'] ] + ')';\n } else return 'translate(' + [ 0, fontStyle['font-size'] ] + ')';\n }\n });\n radialAxis.selectAll('g>line').style({\n stroke: 'black'\n });\n }\n var angularAxis = svg.select('.angular.axis-group').selectAll('g.angular-tick').data(angularAxisRange);\n var angularAxisEnter = angularAxis.enter().append('g').classed('angular-tick', true);\n angularAxis.attr({\n transform: function(d, i) {\n return 'rotate(' + currentAngle(d, i) + ')';\n }\n }).style({\n display: axisConfig.angularAxis.visible ? 'block' : 'none'\n });\n angularAxis.exit().remove();\n angularAxisEnter.append('line').classed('grid-line', true).classed('major', function(d, i) {\n return i % (axisConfig.minorTicks + 1) == 0;\n }).classed('minor', function(d, i) {\n return !(i % (axisConfig.minorTicks + 1) == 0);\n }).style(lineStyle);\n angularAxisEnter.selectAll('.minor').style({\n stroke: axisConfig.minorTickColor\n });\n angularAxis.select('line.grid-line').attr({\n x1: axisConfig.tickLength ? radius - axisConfig.tickLength : 0,\n x2: radius\n }).style({\n display: axisConfig.angularAxis.gridLinesVisible ? 'block' : 'none'\n });\n angularAxisEnter.append('text').classed('axis-text', true).style(fontStyle);\n var ticksText = angularAxis.select('text.axis-text').attr({\n x: radius + axisConfig.labelOffset,\n dy: MID_SHIFT + 'em',\n transform: function(d, i) {\n var angle = currentAngle(d, i);\n var rad = radius + axisConfig.labelOffset;\n var orient = axisConfig.angularAxis.tickOrientation;\n if (orient == 'horizontal') return 'rotate(' + -angle + ' ' + rad + ' 0)'; else if (orient == 'radial') return angle < 270 && angle > 90 ? 'rotate(180 ' + rad + ' 0)' : null; else return 'rotate(' + (angle <= 180 && angle > 0 ? -90 : 90) + ' ' + rad + ' 0)';\n }\n }).style({\n 'text-anchor': 'middle',\n display: axisConfig.angularAxis.labelsVisible ? 'block' : 'none'\n }).text(function(d, i) {\n if (i % (axisConfig.minorTicks + 1) != 0) return '';\n if (ticks) {\n return ticks[d] + axisConfig.angularAxis.ticksSuffix;\n } else return d + axisConfig.angularAxis.ticksSuffix;\n }).style(fontStyle);\n if (axisConfig.angularAxis.rewriteTicks) ticksText.text(function(d, i) {\n if (i % (axisConfig.minorTicks + 1) != 0) return '';\n return axisConfig.angularAxis.rewriteTicks(this.textContent, i);\n });\n var rightmostTickEndX = d3.max(chartGroup.selectAll('.angular-tick text')[0].map(function(d, i) {\n return d.getCTM().e + d.getBBox().width;\n }));\n legendContainer.attr({\n transform: 'translate(' + [ radius + rightmostTickEndX, axisConfig.margin.top ] + ')'\n });\n var hasGeometry = svg.select('g.geometry-group').selectAll('g').size() > 0;\n var geometryContainer = svg.select('g.geometry-group').selectAll('g.geometry').data(data);\n geometryContainer.enter().append('g').attr({\n 'class': function(d, i) {\n return 'geometry geometry' + i;\n }\n });\n geometryContainer.exit().remove();\n if (data[0] || hasGeometry) {\n var geometryConfigs = [];\n data.forEach(function(d, i) {\n var geometryConfig = {};\n geometryConfig.radialScale = radialScale;\n geometryConfig.angularScale = angularScale;\n geometryConfig.container = geometryContainer.filter(function(dB, iB) {\n return iB == i;\n });\n geometryConfig.geometry = d.geometry;\n geometryConfig.orientation = axisConfig.orientation;\n geometryConfig.direction = axisConfig.direction;\n geometryConfig.index = i;\n geometryConfigs.push({\n data: d,\n geometryConfig: geometryConfig\n });\n });\n var geometryConfigsGrouped = d3.nest().key(function(d, i) {\n return typeof d.data.groupId != 'undefined' || 'unstacked';\n }).entries(geometryConfigs);\n var geometryConfigsGrouped2 = [];\n geometryConfigsGrouped.forEach(function(d, i) {\n if (d.key === 'unstacked') geometryConfigsGrouped2 = geometryConfigsGrouped2.concat(d.values.map(function(d, i) {\n return [ d ];\n })); else geometryConfigsGrouped2.push(d.values);\n });\n geometryConfigsGrouped2.forEach(function(d, i) {\n var geometry;\n if (Array.isArray(d)) geometry = d[0].geometryConfig.geometry; else geometry = d.geometryConfig.geometry;\n var finalGeometryConfig = d.map(function(dB, iB) {\n return extendDeepAll(µ[geometry].defaultConfig(), dB);\n });\n µ[geometry]().config(finalGeometryConfig)();\n });\n }\n var guides = svg.select('.guides-group');\n var tooltipContainer = svg.select('.tooltips-group');\n var angularTooltip = µ.tooltipPanel().config({\n container: tooltipContainer,\n fontSize: 8\n })();\n var radialTooltip = µ.tooltipPanel().config({\n container: tooltipContainer,\n fontSize: 8\n })();\n var geometryTooltip = µ.tooltipPanel().config({\n container: tooltipContainer,\n hasTick: true\n })();\n var angularValue, radialValue;\n if (!isOrdinal) {\n var angularGuideLine = guides.select('line').attr({\n x1: 0,\n y1: 0,\n y2: 0\n }).style({\n stroke: 'grey',\n 'pointer-events': 'none'\n });\n chartGroup.on('mousemove.angular-guide', function(d, i) {\n var mouseAngle = µ.util.getMousePos(backgroundCircle).angle;\n angularGuideLine.attr({\n x2: -radius,\n transform: 'rotate(' + mouseAngle + ')'\n }).style({\n opacity: .5\n });\n var angleWithOriginOffset = (mouseAngle + 180 + 360 - axisConfig.orientation) % 360;\n angularValue = angularScale.invert(angleWithOriginOffset);\n var pos = µ.util.convertToCartesian(radius + 12, mouseAngle + 180);\n angularTooltip.text(µ.util.round(angularValue)).move([ pos[0] + chartCenter[0], pos[1] + chartCenter[1] ]);\n }).on('mouseout.angular-guide', function(d, i) {\n guides.select('line').style({\n opacity: 0\n });\n });\n }\n var angularGuideCircle = guides.select('circle').style({\n stroke: 'grey',\n fill: 'none'\n });\n chartGroup.on('mousemove.radial-guide', function(d, i) {\n var r = µ.util.getMousePos(backgroundCircle).radius;\n angularGuideCircle.attr({\n r: r\n }).style({\n opacity: .5\n });\n radialValue = radialScale.invert(µ.util.getMousePos(backgroundCircle).radius);\n var pos = µ.util.convertToCartesian(r, axisConfig.radialAxis.orientation);\n radialTooltip.text(µ.util.round(radialValue)).move([ pos[0] + chartCenter[0], pos[1] + chartCenter[1] ]);\n }).on('mouseout.radial-guide', function(d, i) {\n angularGuideCircle.style({\n opacity: 0\n });\n geometryTooltip.hide();\n angularTooltip.hide();\n radialTooltip.hide();\n });\n svg.selectAll('.geometry-group .mark').on('mouseover.tooltip', function(d, i) {\n var el = d3.select(this);\n var color = this.style.fill;\n var newColor = 'black';\n var opacity = this.style.opacity || 1;\n el.attr({\n 'data-opacity': opacity\n });\n if (color && color !== 'none') {\n el.attr({\n 'data-fill': color\n });\n newColor = d3.hsl(color).darker().toString();\n el.style({\n fill: newColor,\n opacity: 1\n });\n var textData = {\n t: µ.util.round(d[0]),\n r: µ.util.round(d[1])\n };\n if (isOrdinal) textData.t = ticks[d[0]];\n var text = 't: ' + textData.t + ', r: ' + textData.r;\n var bbox = this.getBoundingClientRect();\n var svgBBox = svg.node().getBoundingClientRect();\n var pos = [ bbox.left + bbox.width / 2 - centeringOffset[0] - svgBBox.left, bbox.top + bbox.height / 2 - centeringOffset[1] - svgBBox.top ];\n geometryTooltip.config({\n color: newColor\n }).text(text);\n geometryTooltip.move(pos);\n } else {\n color = this.style.stroke || 'black';\n el.attr({\n 'data-stroke': color\n });\n newColor = d3.hsl(color).darker().toString();\n el.style({\n stroke: newColor,\n opacity: 1\n });\n }\n }).on('mousemove.tooltip', function(d, i) {\n if (d3.event.which != 0) return false;\n if (d3.select(this).attr('data-fill')) geometryTooltip.show();\n }).on('mouseout.tooltip', function(d, i) {\n geometryTooltip.hide();\n var el = d3.select(this);\n var fillColor = el.attr('data-fill');\n if (fillColor) el.style({\n fill: fillColor,\n opacity: el.attr('data-opacity')\n }); else el.style({\n stroke: el.attr('data-stroke'),\n opacity: el.attr('data-opacity')\n });\n });\n });\n return exports;\n }\n exports.render = function(_container) {\n render(_container);\n return this;\n };\n exports.config = function(_x) {\n if (!arguments.length) return config;\n var xClone = µ.util.cloneJson(_x);\n xClone.data.forEach(function(d, i) {\n if (!config.data[i]) config.data[i] = {};\n extendDeepAll(config.data[i], µ.Axis.defaultConfig().data[0]);\n extendDeepAll(config.data[i], d);\n });\n extendDeepAll(config.layout, µ.Axis.defaultConfig().layout);\n extendDeepAll(config.layout, xClone.layout);\n return this;\n };\n exports.getLiveConfig = function() {\n return liveConfig;\n };\n exports.getinputConfig = function() {\n return inputConfig;\n };\n exports.radialScale = function(_x) {\n return radialScale;\n };\n exports.angularScale = function(_x) {\n return angularScale;\n };\n exports.svg = function() {\n return svg;\n };\n d3.rebind(exports, dispatch, 'on');\n return exports;\n};\n\nµ.Axis.defaultConfig = function(d, i) {\n var config = {\n data: [ {\n t: [ 1, 2, 3, 4 ],\n r: [ 10, 11, 12, 13 ],\n name: 'Line1',\n geometry: 'LinePlot',\n color: null,\n strokeDash: 'solid',\n strokeColor: null,\n strokeSize: '1',\n visibleInLegend: true,\n opacity: 1\n } ],\n layout: {\n defaultColorRange: d3.scale.category10().range(),\n title: null,\n height: 450,\n width: 500,\n margin: {\n top: 40,\n right: 40,\n bottom: 40,\n left: 40\n },\n font: {\n size: 12,\n color: 'gray',\n outlineColor: 'white',\n family: 'Tahoma, sans-serif'\n },\n direction: 'clockwise',\n orientation: 0,\n labelOffset: 10,\n radialAxis: {\n domain: null,\n orientation: -45,\n ticksSuffix: '',\n visible: true,\n gridLinesVisible: true,\n tickOrientation: 'horizontal',\n rewriteTicks: null\n },\n angularAxis: {\n domain: [ 0, 360 ],\n ticksSuffix: '',\n visible: true,\n gridLinesVisible: true,\n labelsVisible: true,\n tickOrientation: 'horizontal',\n rewriteTicks: null,\n ticksCount: null,\n ticksStep: null\n },\n minorTicks: 0,\n tickLength: null,\n tickColor: 'silver',\n minorTickColor: '#eee',\n backgroundColor: 'none',\n needsEndSpacing: null,\n showLegend: true,\n legend: {\n reverseOrder: false\n },\n opacity: 1\n }\n };\n return config;\n};\n\nµ.util = {};\n\nµ.DATAEXTENT = 'dataExtent';\n\nµ.AREA = 'AreaChart';\n\nµ.LINE = 'LinePlot';\n\nµ.DOT = 'DotPlot';\n\nµ.BAR = 'BarChart';\n\nµ.util._override = function(_objA, _objB) {\n for (var x in _objA) if (x in _objB) _objB[x] = _objA[x];\n};\n\nµ.util._extend = function(_objA, _objB) {\n for (var x in _objA) _objB[x] = _objA[x];\n};\n\nµ.util._rndSnd = function() {\n return Math.random() * 2 - 1 + (Math.random() * 2 - 1) + (Math.random() * 2 - 1);\n};\n\nµ.util.dataFromEquation2 = function(_equation, _step) {\n var step = _step || 6;\n var data = d3.range(0, 360 + step, step).map(function(deg, index) {\n var theta = deg * Math.PI / 180;\n var radius = _equation(theta);\n return [ deg, radius ];\n });\n return data;\n};\n\nµ.util.dataFromEquation = function(_equation, _step, _name) {\n var step = _step || 6;\n var t = [], r = [];\n d3.range(0, 360 + step, step).forEach(function(deg, index) {\n var theta = deg * Math.PI / 180;\n var radius = _equation(theta);\n t.push(deg);\n r.push(radius);\n });\n var result = {\n t: t,\n r: r\n };\n if (_name) result.name = _name;\n return result;\n};\n\nµ.util.ensureArray = function(_val, _count) {\n if (typeof _val === 'undefined') return null;\n var arr = [].concat(_val);\n return d3.range(_count).map(function(d, i) {\n return arr[i] || arr[0];\n });\n};\n\nµ.util.fillArrays = function(_obj, _valueNames, _count) {\n _valueNames.forEach(function(d, i) {\n _obj[d] = µ.util.ensureArray(_obj[d], _count);\n });\n return _obj;\n};\n\nµ.util.cloneJson = function(json) {\n return JSON.parse(JSON.stringify(json));\n};\n\nµ.util.validateKeys = function(obj, keys) {\n if (typeof keys === 'string') keys = keys.split('.');\n var next = keys.shift();\n return obj[next] && (!keys.length || objHasKeys(obj[next], keys));\n};\n\nµ.util.sumArrays = function(a, b) {\n return d3.zip(a, b).map(function(d, i) {\n return d3.sum(d);\n });\n};\n\nµ.util.arrayLast = function(a) {\n return a[a.length - 1];\n};\n\nµ.util.arrayEqual = function(a, b) {\n var i = Math.max(a.length, b.length, 1);\n while (i-- >= 0 && a[i] === b[i]) ;\n return i === -2;\n};\n\nµ.util.flattenArray = function(arr) {\n var r = [];\n while (!µ.util.arrayEqual(r, arr)) {\n r = arr;\n arr = [].concat.apply([], arr);\n }\n return arr;\n};\n\nµ.util.deduplicate = function(arr) {\n return arr.filter(function(v, i, a) {\n return a.indexOf(v) == i;\n });\n};\n\nµ.util.convertToCartesian = function(radius, theta) {\n var thetaRadians = theta * Math.PI / 180;\n var x = radius * Math.cos(thetaRadians);\n var y = radius * Math.sin(thetaRadians);\n return [ x, y ];\n};\n\nµ.util.round = function(_value, _digits) {\n var digits = _digits || 2;\n var mult = Math.pow(10, digits);\n return Math.round(_value * mult) / mult;\n};\n\nµ.util.getMousePos = function(_referenceElement) {\n var mousePos = d3.mouse(_referenceElement.node());\n var mouseX = mousePos[0];\n var mouseY = mousePos[1];\n var mouse = {};\n mouse.x = mouseX;\n mouse.y = mouseY;\n mouse.pos = mousePos;\n mouse.angle = (Math.atan2(mouseY, mouseX) + Math.PI) * 180 / Math.PI;\n mouse.radius = Math.sqrt(mouseX * mouseX + mouseY * mouseY);\n return mouse;\n};\n\nµ.util.duplicatesCount = function(arr) {\n var uniques = {}, val;\n var dups = {};\n for (var i = 0, len = arr.length; i < len; i++) {\n val = arr[i];\n if (val in uniques) {\n uniques[val]++;\n dups[val] = uniques[val];\n } else {\n uniques[val] = 1;\n }\n }\n return dups;\n};\n\nµ.util.duplicates = function(arr) {\n return Object.keys(µ.util.duplicatesCount(arr));\n};\n\nµ.util.translator = function(obj, sourceBranch, targetBranch, reverse) {\n if (reverse) {\n var targetBranchCopy = targetBranch.slice();\n targetBranch = sourceBranch;\n sourceBranch = targetBranchCopy;\n }\n var value = sourceBranch.reduce(function(previousValue, currentValue) {\n if (typeof previousValue != 'undefined') return previousValue[currentValue];\n }, obj);\n if (typeof value === 'undefined') return;\n sourceBranch.reduce(function(previousValue, currentValue, index) {\n if (typeof previousValue == 'undefined') return;\n if (index === sourceBranch.length - 1) delete previousValue[currentValue];\n return previousValue[currentValue];\n }, obj);\n targetBranch.reduce(function(previousValue, currentValue, index) {\n if (typeof previousValue[currentValue] === 'undefined') previousValue[currentValue] = {};\n if (index === targetBranch.length - 1) previousValue[currentValue] = value;\n return previousValue[currentValue];\n }, obj);\n};\n\nµ.PolyChart = function module() {\n var config = [ µ.PolyChart.defaultConfig() ];\n var dispatch = d3.dispatch('hover');\n var dashArray = {\n solid: 'none',\n dash: [ 5, 2 ],\n dot: [ 2, 5 ]\n };\n var colorScale;\n function exports() {\n var geometryConfig = config[0].geometryConfig;\n var container = geometryConfig.container;\n if (typeof container == 'string') container = d3.select(container);\n container.datum(config).each(function(_config, _index) {\n var isStack = !!_config[0].data.yStack;\n var data = _config.map(function(d, i) {\n if (isStack) return d3.zip(d.data.t[0], d.data.r[0], d.data.yStack[0]); else return d3.zip(d.data.t[0], d.data.r[0]);\n });\n var angularScale = geometryConfig.angularScale;\n var domainMin = geometryConfig.radialScale.domain()[0];\n var generator = {};\n generator.bar = function(d, i, pI) {\n var dataConfig = _config[pI].data;\n var h = geometryConfig.radialScale(d[1]) - geometryConfig.radialScale(0);\n var stackTop = geometryConfig.radialScale(d[2] || 0);\n var w = dataConfig.barWidth;\n d3.select(this).attr({\n 'class': 'mark bar',\n d: 'M' + [ [ h + stackTop, -w / 2 ], [ h + stackTop, w / 2 ], [ stackTop, w / 2 ], [ stackTop, -w / 2 ] ].join('L') + 'Z',\n transform: function(d, i) {\n return 'rotate(' + (geometryConfig.orientation + angularScale(d[0])) + ')';\n }\n });\n };\n generator.dot = function(d, i, pI) {\n var stackedData = d[2] ? [ d[0], d[1] + d[2] ] : d;\n var symbol = d3.svg.symbol().size(_config[pI].data.dotSize).type(_config[pI].data.dotType)(d, i);\n d3.select(this).attr({\n 'class': 'mark dot',\n d: symbol,\n transform: function(d, i) {\n var coord = convertToCartesian(getPolarCoordinates(stackedData));\n return 'translate(' + [ coord.x, coord.y ] + ')';\n }\n });\n };\n var line = d3.svg.line.radial().interpolate(_config[0].data.lineInterpolation).radius(function(d) {\n return geometryConfig.radialScale(d[1]);\n }).angle(function(d) {\n return geometryConfig.angularScale(d[0]) * Math.PI / 180;\n });\n generator.line = function(d, i, pI) {\n var lineData = d[2] ? data[pI].map(function(d, i) {\n return [ d[0], d[1] + d[2] ];\n }) : data[pI];\n d3.select(this).each(generator['dot']).style({\n opacity: function(dB, iB) {\n return +_config[pI].data.dotVisible;\n },\n fill: markStyle.stroke(d, i, pI)\n }).attr({\n 'class': 'mark dot'\n });\n if (i > 0) return;\n var lineSelection = d3.select(this.parentNode).selectAll('path.line').data([ 0 ]);\n lineSelection.enter().insert('path');\n lineSelection.attr({\n 'class': 'line',\n d: line(lineData),\n transform: function(dB, iB) {\n return 'rotate(' + (geometryConfig.orientation + 90) + ')';\n },\n 'pointer-events': 'none'\n }).style({\n fill: function(dB, iB) {\n return markStyle.fill(d, i, pI);\n },\n 'fill-opacity': 0,\n stroke: function(dB, iB) {\n return markStyle.stroke(d, i, pI);\n },\n 'stroke-width': function(dB, iB) {\n return markStyle['stroke-width'](d, i, pI);\n },\n 'stroke-dasharray': function(dB, iB) {\n return markStyle['stroke-dasharray'](d, i, pI);\n },\n opacity: function(dB, iB) {\n return markStyle.opacity(d, i, pI);\n },\n display: function(dB, iB) {\n return markStyle.display(d, i, pI);\n }\n });\n };\n var angularRange = geometryConfig.angularScale.range();\n var triangleAngle = Math.abs(angularRange[1] - angularRange[0]) / data[0].length * Math.PI / 180;\n var arc = d3.svg.arc().startAngle(function(d) {\n return -triangleAngle / 2;\n }).endAngle(function(d) {\n return triangleAngle / 2;\n }).innerRadius(function(d) {\n return geometryConfig.radialScale(domainMin + (d[2] || 0));\n }).outerRadius(function(d) {\n return geometryConfig.radialScale(domainMin + (d[2] || 0)) + geometryConfig.radialScale(d[1]);\n });\n generator.arc = function(d, i, pI) {\n d3.select(this).attr({\n 'class': 'mark arc',\n d: arc,\n transform: function(d, i) {\n return 'rotate(' + (geometryConfig.orientation + angularScale(d[0]) + 90) + ')';\n }\n });\n };\n var markStyle = {\n fill: function(d, i, pI) {\n return _config[pI].data.color;\n },\n stroke: function(d, i, pI) {\n return _config[pI].data.strokeColor;\n },\n 'stroke-width': function(d, i, pI) {\n return _config[pI].data.strokeSize + 'px';\n },\n 'stroke-dasharray': function(d, i, pI) {\n return dashArray[_config[pI].data.strokeDash];\n },\n opacity: function(d, i, pI) {\n return _config[pI].data.opacity;\n },\n display: function(d, i, pI) {\n return typeof _config[pI].data.visible === 'undefined' || _config[pI].data.visible ? 'block' : 'none';\n }\n };\n var geometryLayer = d3.select(this).selectAll('g.layer').data(data);\n geometryLayer.enter().append('g').attr({\n 'class': 'layer'\n });\n var geometry = geometryLayer.selectAll('path.mark').data(function(d, i) {\n return d;\n });\n geometry.enter().append('path').attr({\n 'class': 'mark'\n });\n geometry.style(markStyle).each(generator[geometryConfig.geometryType]);\n geometry.exit().remove();\n geometryLayer.exit().remove();\n function getPolarCoordinates(d, i) {\n var r = geometryConfig.radialScale(d[1]);\n var t = (geometryConfig.angularScale(d[0]) + geometryConfig.orientation) * Math.PI / 180;\n return {\n r: r,\n t: t\n };\n }\n function convertToCartesian(polarCoordinates) {\n var x = polarCoordinates.r * Math.cos(polarCoordinates.t);\n var y = polarCoordinates.r * Math.sin(polarCoordinates.t);\n return {\n x: x,\n y: y\n };\n }\n });\n }\n exports.config = function(_x) {\n if (!arguments.length) return config;\n _x.forEach(function(d, i) {\n if (!config[i]) config[i] = {};\n extendDeepAll(config[i], µ.PolyChart.defaultConfig());\n extendDeepAll(config[i], d);\n });\n return this;\n };\n exports.getColorScale = function() {\n return colorScale;\n };\n d3.rebind(exports, dispatch, 'on');\n return exports;\n};\n\nµ.PolyChart.defaultConfig = function() {\n var config = {\n data: {\n name: 'geom1',\n t: [ [ 1, 2, 3, 4 ] ],\n r: [ [ 1, 2, 3, 4 ] ],\n dotType: 'circle',\n dotSize: 64,\n dotVisible: false,\n barWidth: 20,\n color: '#ffa500',\n strokeSize: 1,\n strokeColor: 'silver',\n strokeDash: 'solid',\n opacity: 1,\n index: 0,\n visible: true,\n visibleInLegend: true\n },\n geometryConfig: {\n geometry: 'LinePlot',\n geometryType: 'arc',\n direction: 'clockwise',\n orientation: 0,\n container: 'body',\n radialScale: null,\n angularScale: null,\n colorScale: d3.scale.category20()\n }\n };\n return config;\n};\n\nµ.BarChart = function module() {\n return µ.PolyChart();\n};\n\nµ.BarChart.defaultConfig = function() {\n var config = {\n geometryConfig: {\n geometryType: 'bar'\n }\n };\n return config;\n};\n\nµ.AreaChart = function module() {\n return µ.PolyChart();\n};\n\nµ.AreaChart.defaultConfig = function() {\n var config = {\n geometryConfig: {\n geometryType: 'arc'\n }\n };\n return config;\n};\n\nµ.DotPlot = function module() {\n return µ.PolyChart();\n};\n\nµ.DotPlot.defaultConfig = function() {\n var config = {\n geometryConfig: {\n geometryType: 'dot',\n dotType: 'circle'\n }\n };\n return config;\n};\n\nµ.LinePlot = function module() {\n return µ.PolyChart();\n};\n\nµ.LinePlot.defaultConfig = function() {\n var config = {\n geometryConfig: {\n geometryType: 'line'\n }\n };\n return config;\n};\n\nµ.Legend = function module() {\n var config = µ.Legend.defaultConfig();\n var dispatch = d3.dispatch('hover');\n function exports() {\n var legendConfig = config.legendConfig;\n var flattenData = config.data.map(function(d, i) {\n return [].concat(d).map(function(dB, iB) {\n var element = extendDeepAll({}, legendConfig.elements[i]);\n element.name = dB;\n element.color = [].concat(legendConfig.elements[i].color)[iB];\n return element;\n });\n });\n var data = d3.merge(flattenData);\n data = data.filter(function(d, i) {\n return legendConfig.elements[i] && (legendConfig.elements[i].visibleInLegend || typeof legendConfig.elements[i].visibleInLegend === 'undefined');\n });\n if (legendConfig.reverseOrder) data = data.reverse();\n var container = legendConfig.container;\n if (typeof container == 'string' || container.nodeName) container = d3.select(container);\n var colors = data.map(function(d, i) {\n return d.color;\n });\n var lineHeight = legendConfig.fontSize;\n var isContinuous = legendConfig.isContinuous == null ? typeof data[0] === 'number' : legendConfig.isContinuous;\n var height = isContinuous ? legendConfig.height : lineHeight * data.length;\n var legendContainerGroup = container.classed('legend-group', true);\n var svg = legendContainerGroup.selectAll('svg').data([ 0 ]);\n var svgEnter = svg.enter().append('svg').attr({\n width: 300,\n height: height + lineHeight,\n xmlns: 'http://www.w3.org/2000/svg',\n 'xmlns:xlink': 'http://www.w3.org/1999/xlink',\n version: '1.1'\n });\n svgEnter.append('g').classed('legend-axis', true);\n svgEnter.append('g').classed('legend-marks', true);\n var dataNumbered = d3.range(data.length);\n var colorScale = d3.scale[isContinuous ? 'linear' : 'ordinal']().domain(dataNumbered).range(colors);\n var dataScale = d3.scale[isContinuous ? 'linear' : 'ordinal']().domain(dataNumbered)[isContinuous ? 'range' : 'rangePoints']([ 0, height ]);\n var shapeGenerator = function(_type, _size) {\n var squareSize = _size * 3;\n if (_type === 'line') {\n return 'M' + [ [ -_size / 2, -_size / 12 ], [ _size / 2, -_size / 12 ], [ _size / 2, _size / 12 ], [ -_size / 2, _size / 12 ] ] + 'Z';\n } else if (d3.svg.symbolTypes.indexOf(_type) != -1) return d3.svg.symbol().type(_type).size(squareSize)(); else return d3.svg.symbol().type('square').size(squareSize)();\n };\n if (isContinuous) {\n var gradient = svg.select('.legend-marks').append('defs').append('linearGradient').attr({\n id: 'grad1',\n x1: '0%',\n y1: '0%',\n x2: '0%',\n y2: '100%'\n }).selectAll('stop').data(colors);\n gradient.enter().append('stop');\n gradient.attr({\n offset: function(d, i) {\n return i / (colors.length - 1) * 100 + '%';\n }\n }).style({\n 'stop-color': function(d, i) {\n return d;\n }\n });\n svg.append('rect').classed('legend-mark', true).attr({\n height: legendConfig.height,\n width: legendConfig.colorBandWidth,\n fill: 'url(#grad1)'\n });\n } else {\n var legendElement = svg.select('.legend-marks').selectAll('path.legend-mark').data(data);\n legendElement.enter().append('path').classed('legend-mark', true);\n legendElement.attr({\n transform: function(d, i) {\n return 'translate(' + [ lineHeight / 2, dataScale(i) + lineHeight / 2 ] + ')';\n },\n d: function(d, i) {\n var symbolType = d.symbol;\n return shapeGenerator(symbolType, lineHeight);\n },\n fill: function(d, i) {\n return colorScale(i);\n }\n });\n legendElement.exit().remove();\n }\n var legendAxis = d3.svg.axis().scale(dataScale).orient('right');\n var axis = svg.select('g.legend-axis').attr({\n transform: 'translate(' + [ isContinuous ? legendConfig.colorBandWidth : lineHeight, lineHeight / 2 ] + ')'\n }).call(legendAxis);\n axis.selectAll('.domain').style({\n fill: 'none',\n stroke: 'none'\n });\n axis.selectAll('line').style({\n fill: 'none',\n stroke: isContinuous ? legendConfig.textColor : 'none'\n });\n axis.selectAll('text').style({\n fill: legendConfig.textColor,\n 'font-size': legendConfig.fontSize\n }).text(function(d, i) {\n return data[i].name;\n });\n return exports;\n }\n exports.config = function(_x) {\n if (!arguments.length) return config;\n extendDeepAll(config, _x);\n return this;\n };\n d3.rebind(exports, dispatch, 'on');\n return exports;\n};\n\nµ.Legend.defaultConfig = function(d, i) {\n var config = {\n data: [ 'a', 'b', 'c' ],\n legendConfig: {\n elements: [ {\n symbol: 'line',\n color: 'red'\n }, {\n symbol: 'square',\n color: 'yellow'\n }, {\n symbol: 'diamond',\n color: 'limegreen'\n } ],\n height: 150,\n colorBandWidth: 30,\n fontSize: 12,\n container: 'body',\n isContinuous: null,\n textColor: 'grey',\n reverseOrder: false\n }\n };\n return config;\n};\n\nµ.tooltipPanel = function() {\n var tooltipEl, tooltipTextEl, backgroundEl;\n var config = {\n container: null,\n hasTick: false,\n fontSize: 12,\n color: 'white',\n padding: 5\n };\n var id = 'tooltip-' + µ.tooltipPanel.uid++;\n var tickSize = 10;\n var exports = function() {\n tooltipEl = config.container.selectAll('g.' + id).data([ 0 ]);\n var tooltipEnter = tooltipEl.enter().append('g').classed(id, true).style({\n 'pointer-events': 'none',\n display: 'none'\n });\n backgroundEl = tooltipEnter.append('path').style({\n fill: 'white',\n 'fill-opacity': .9\n }).attr({\n d: 'M0 0'\n });\n tooltipTextEl = tooltipEnter.append('text').attr({\n dx: config.padding + tickSize,\n dy: +config.fontSize * .3\n });\n return exports;\n };\n exports.text = function(_text) {\n var l = d3.hsl(config.color).l;\n var strokeColor = l >= .5 ? '#aaa' : 'white';\n var fillColor = l >= .5 ? 'black' : 'white';\n var text = _text || '';\n tooltipTextEl.style({\n fill: fillColor,\n 'font-size': config.fontSize + 'px'\n }).text(text);\n var padding = config.padding;\n var bbox = tooltipTextEl.node().getBBox();\n var boxStyle = {\n fill: config.color,\n stroke: strokeColor,\n 'stroke-width': '2px'\n };\n var backGroundW = bbox.width + padding * 2 + tickSize;\n var backGroundH = bbox.height + padding * 2;\n backgroundEl.attr({\n d: 'M' + [ [ tickSize, -backGroundH / 2 ], [ tickSize, -backGroundH / 4 ], [ config.hasTick ? 0 : tickSize, 0 ], [ tickSize, backGroundH / 4 ], [ tickSize, backGroundH / 2 ], [ backGroundW, backGroundH / 2 ], [ backGroundW, -backGroundH / 2 ] ].join('L') + 'Z'\n }).style(boxStyle);\n tooltipEl.attr({\n transform: 'translate(' + [ tickSize, -backGroundH / 2 + padding * 2 ] + ')'\n });\n tooltipEl.style({\n display: 'block'\n });\n return exports;\n };\n exports.move = function(_pos) {\n if (!tooltipEl) return;\n tooltipEl.attr({\n transform: 'translate(' + [ _pos[0], _pos[1] ] + ')'\n }).style({\n display: 'block'\n });\n return exports;\n };\n exports.hide = function() {\n if (!tooltipEl) return;\n tooltipEl.style({\n display: 'none'\n });\n return exports;\n };\n exports.show = function() {\n if (!tooltipEl) return;\n tooltipEl.style({\n display: 'block'\n });\n return exports;\n };\n exports.config = function(_x) {\n extendDeepAll(config, _x);\n return exports;\n };\n return exports;\n};\n\nµ.tooltipPanel.uid = 1;\n\nµ.adapter = {};\n\nµ.adapter.plotly = function module() {\n var exports = {};\n exports.convert = function(_inputConfig, reverse) {\n var outputConfig = {};\n if (_inputConfig.data) {\n outputConfig.data = _inputConfig.data.map(function(d, i) {\n var r = extendDeepAll({}, d);\n var toTranslate = [\n [ r, [ 'marker', 'color' ], [ 'color' ] ],\n [ r, [ 'marker', 'opacity' ], [ 'opacity' ] ],\n [ r, [ 'marker', 'line', 'color' ], [ 'strokeColor' ] ],\n [ r, [ 'marker', 'line', 'dash' ], [ 'strokeDash' ] ],\n [ r, [ 'marker', 'line', 'width' ], [ 'strokeSize' ] ],\n [ r, [ 'marker', 'symbol' ], [ 'dotType' ] ],\n [ r, [ 'marker', 'size' ], [ 'dotSize' ] ],\n [ r, [ 'marker', 'barWidth' ], [ 'barWidth' ] ],\n [ r, [ 'line', 'interpolation' ], [ 'lineInterpolation' ] ],\n [ r, [ 'showlegend' ], [ 'visibleInLegend' ] ]\n ];\n toTranslate.forEach(function(d, i) {\n µ.util.translator.apply(null, d.concat(reverse));\n });\n\n if (!reverse) delete r.marker;\n if (reverse) delete r.groupId;\n if (!reverse) {\n if (r.type === 'scatter') {\n if (r.mode === 'lines') r.geometry = 'LinePlot'; else if (r.mode === 'markers') r.geometry = 'DotPlot'; else if (r.mode === 'lines+markers') {\n r.geometry = 'LinePlot';\n r.dotVisible = true;\n }\n } else if (r.type === 'area') r.geometry = 'AreaChart'; else if (r.type === 'bar') r.geometry = 'BarChart';\n delete r.mode;\n delete r.type;\n } else {\n if (r.geometry === 'LinePlot') {\n r.type = 'scatter';\n if (r.dotVisible === true) {\n delete r.dotVisible;\n r.mode = 'lines+markers';\n } else r.mode = 'lines';\n } else if (r.geometry === 'DotPlot') {\n r.type = 'scatter';\n r.mode = 'markers';\n } else if (r.geometry === 'AreaChart') r.type = 'area'; else if (r.geometry === 'BarChart') r.type = 'bar';\n delete r.geometry;\n }\n return r;\n });\n if (!reverse && _inputConfig.layout && _inputConfig.layout.barmode === 'stack') {\n var duplicates = µ.util.duplicates(outputConfig.data.map(function(d, i) {\n return d.geometry;\n }));\n outputConfig.data.forEach(function(d, i) {\n var idx = duplicates.indexOf(d.geometry);\n if (idx != -1) outputConfig.data[i].groupId = idx;\n });\n }\n }\n if (_inputConfig.layout) {\n var r = extendDeepAll({}, _inputConfig.layout);\n var toTranslate = [\n [ r, [ 'plot_bgcolor' ], [ 'backgroundColor' ] ],\n [ r, [ 'showlegend' ], [ 'showLegend' ] ],\n [ r, [ 'radialaxis' ], [ 'radialAxis' ] ],\n [ r, [ 'angularaxis' ], [ 'angularAxis' ] ],\n [ r.angularaxis, [ 'showline' ], [ 'gridLinesVisible' ] ],\n [ r.angularaxis, [ 'showticklabels' ], [ 'labelsVisible' ] ],\n [ r.angularaxis, [ 'nticks' ], [ 'ticksCount' ] ],\n [ r.angularaxis, [ 'tickorientation' ], [ 'tickOrientation' ] ],\n [ r.angularaxis, [ 'ticksuffix' ], [ 'ticksSuffix' ] ],\n [ r.angularaxis, [ 'range' ], [ 'domain' ] ],\n [ r.angularaxis, [ 'endpadding' ], [ 'endPadding' ] ],\n [ r.radialaxis, [ 'showline' ], [ 'gridLinesVisible' ] ],\n [ r.radialaxis, [ 'tickorientation' ], [ 'tickOrientation' ] ],\n [ r.radialaxis, [ 'ticksuffix' ], [ 'ticksSuffix' ] ],\n [ r.radialaxis, [ 'range' ], [ 'domain' ] ],\n [ r.angularAxis, [ 'showline' ], [ 'gridLinesVisible' ] ],\n [ r.angularAxis, [ 'showticklabels' ], [ 'labelsVisible' ] ],\n [ r.angularAxis, [ 'nticks' ], [ 'ticksCount' ] ],\n [ r.angularAxis, [ 'tickorientation' ], [ 'tickOrientation' ] ],\n [ r.angularAxis, [ 'ticksuffix' ], [ 'ticksSuffix' ] ],\n [ r.angularAxis, [ 'range' ], [ 'domain' ] ],\n [ r.angularAxis, [ 'endpadding' ], [ 'endPadding' ] ],\n [ r.radialAxis, [ 'showline' ], [ 'gridLinesVisible' ] ],\n [ r.radialAxis, [ 'tickorientation' ], [ 'tickOrientation' ] ],\n [ r.radialAxis, [ 'ticksuffix' ], [ 'ticksSuffix' ] ],\n [ r.radialAxis, [ 'range' ], [ 'domain' ] ],\n [ r.font, [ 'outlinecolor' ], [ 'outlineColor' ] ],\n [ r.legend, [ 'traceorder' ], [ 'reverseOrder' ] ],\n [ r, [ 'labeloffset' ], [ 'labelOffset' ] ],\n [ r, [ 'defaultcolorrange' ], [ 'defaultColorRange' ] ]\n ];\n toTranslate.forEach(function(d, i) {\n µ.util.translator.apply(null, d.concat(reverse));\n });\n\n if (!reverse) {\n if (r.angularAxis && typeof r.angularAxis.ticklen !== 'undefined') r.tickLength = r.angularAxis.ticklen;\n if (r.angularAxis && typeof r.angularAxis.tickcolor !== 'undefined') r.tickColor = r.angularAxis.tickcolor;\n } else {\n if (typeof r.tickLength !== 'undefined') {\n r.angularaxis.ticklen = r.tickLength;\n delete r.tickLength;\n }\n if (r.tickColor) {\n r.angularaxis.tickcolor = r.tickColor;\n delete r.tickColor;\n }\n }\n if (r.legend && typeof r.legend.reverseOrder != 'boolean') {\n r.legend.reverseOrder = r.legend.reverseOrder != 'normal';\n }\n if (r.legend && typeof r.legend.traceorder == 'boolean') {\n r.legend.traceorder = r.legend.traceorder ? 'reversed' : 'normal';\n delete r.legend.reverseOrder;\n }\n if (r.margin && typeof r.margin.t != 'undefined') {\n var source = [ 't', 'r', 'b', 'l', 'pad' ];\n var target = [ 'top', 'right', 'bottom', 'left', 'pad' ];\n var margin = {};\n d3.entries(r.margin).forEach(function(dB, iB) {\n margin[target[source.indexOf(dB.key)]] = dB.value;\n });\n r.margin = margin;\n }\n if (reverse) {\n delete r.needsEndSpacing;\n delete r.minorTickColor;\n delete r.minorTicks;\n delete r.angularaxis.ticksCount;\n delete r.angularaxis.ticksCount;\n delete r.angularaxis.ticksStep;\n delete r.angularaxis.rewriteTicks;\n delete r.angularaxis.nticks;\n delete r.radialaxis.ticksCount;\n delete r.radialaxis.ticksCount;\n delete r.radialaxis.ticksStep;\n delete r.radialaxis.rewriteTicks;\n delete r.radialaxis.nticks;\n }\n outputConfig.layout = r;\n }\n return outputConfig;\n };\n return exports;\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar tinycolor = require('tinycolor2');\n\nvar scales = {\n 'Greys': [\n [0, 'rgb(0,0,0)'], [1, 'rgb(255,255,255)']\n ],\n\n 'YlGnBu': [\n [0, 'rgb(8,29,88)'], [0.125, 'rgb(37,52,148)'],\n [0.25, 'rgb(34,94,168)'], [0.375, 'rgb(29,145,192)'],\n [0.5, 'rgb(65,182,196)'], [0.625, 'rgb(127,205,187)'],\n [0.75, 'rgb(199,233,180)'], [0.875, 'rgb(237,248,217)'],\n [1, 'rgb(255,255,217)']\n ],\n\n 'Greens': [\n [0, 'rgb(0,68,27)'], [0.125, 'rgb(0,109,44)'],\n [0.25, 'rgb(35,139,69)'], [0.375, 'rgb(65,171,93)'],\n [0.5, 'rgb(116,196,118)'], [0.625, 'rgb(161,217,155)'],\n [0.75, 'rgb(199,233,192)'], [0.875, 'rgb(229,245,224)'],\n [1, 'rgb(247,252,245)']\n ],\n\n 'YlOrRd': [\n [0, 'rgb(128,0,38)'], [0.125, 'rgb(189,0,38)'],\n [0.25, 'rgb(227,26,28)'], [0.375, 'rgb(252,78,42)'],\n [0.5, 'rgb(253,141,60)'], [0.625, 'rgb(254,178,76)'],\n [0.75, 'rgb(254,217,118)'], [0.875, 'rgb(255,237,160)'],\n [1, 'rgb(255,255,204)']\n ],\n\n 'Bluered': [\n [0, 'rgb(0,0,255)'], [1, 'rgb(255,0,0)']\n ],\n\n // modified RdBu based on\n // http://www.kennethmoreland.com/color-maps/\n 'RdBu': [\n [0, 'rgb(5,10,172)'], [0.35, 'rgb(106,137,247)'],\n [0.5, 'rgb(190,190,190)'], [0.6, 'rgb(220,170,132)'],\n [0.7, 'rgb(230,145,90)'], [1, 'rgb(178,10,28)']\n ],\n\n // Scale for non-negative numeric values\n 'Reds': [\n [0, 'rgb(220,220,220)'], [0.2, 'rgb(245,195,157)'],\n [0.4, 'rgb(245,160,105)'], [1, 'rgb(178,10,28)']\n ],\n\n // Scale for non-positive numeric values\n 'Blues': [\n [0, 'rgb(5,10,172)'], [0.35, 'rgb(40,60,190)'],\n [0.5, 'rgb(70,100,245)'], [0.6, 'rgb(90,120,245)'],\n [0.7, 'rgb(106,137,247)'], [1, 'rgb(220,220,220)']\n ],\n\n 'Picnic': [\n [0, 'rgb(0,0,255)'], [0.1, 'rgb(51,153,255)'],\n [0.2, 'rgb(102,204,255)'], [0.3, 'rgb(153,204,255)'],\n [0.4, 'rgb(204,204,255)'], [0.5, 'rgb(255,255,255)'],\n [0.6, 'rgb(255,204,255)'], [0.7, 'rgb(255,153,255)'],\n [0.8, 'rgb(255,102,204)'], [0.9, 'rgb(255,102,102)'],\n [1, 'rgb(255,0,0)']\n ],\n\n 'Rainbow': [\n [0, 'rgb(150,0,90)'], [0.125, 'rgb(0,0,200)'],\n [0.25, 'rgb(0,25,255)'], [0.375, 'rgb(0,152,255)'],\n [0.5, 'rgb(44,255,150)'], [0.625, 'rgb(151,255,0)'],\n [0.75, 'rgb(255,234,0)'], [0.875, 'rgb(255,111,0)'],\n [1, 'rgb(255,0,0)']\n ],\n\n 'Portland': [\n [0, 'rgb(12,51,131)'], [0.25, 'rgb(10,136,186)'],\n [0.5, 'rgb(242,211,56)'], [0.75, 'rgb(242,143,56)'],\n [1, 'rgb(217,30,30)']\n ],\n\n 'Jet': [\n [0, 'rgb(0,0,131)'], [0.125, 'rgb(0,60,170)'],\n [0.375, 'rgb(5,255,255)'], [0.625, 'rgb(255,255,0)'],\n [0.875, 'rgb(250,0,0)'], [1, 'rgb(128,0,0)']\n ],\n\n 'Hot': [\n [0, 'rgb(0,0,0)'], [0.3, 'rgb(230,0,0)'],\n [0.6, 'rgb(255,210,0)'], [1, 'rgb(255,255,255)']\n ],\n\n 'Blackbody': [\n [0, 'rgb(0,0,0)'], [0.2, 'rgb(230,0,0)'],\n [0.4, 'rgb(230,210,0)'], [0.7, 'rgb(255,255,255)'],\n [1, 'rgb(160,200,255)']\n ],\n\n 'Earth': [\n [0, 'rgb(0,0,130)'], [0.1, 'rgb(0,180,180)'],\n [0.2, 'rgb(40,210,40)'], [0.4, 'rgb(230,230,50)'],\n [0.6, 'rgb(120,70,20)'], [1, 'rgb(255,255,255)']\n ],\n\n 'Electric': [\n [0, 'rgb(0,0,0)'], [0.15, 'rgb(30,0,100)'],\n [0.4, 'rgb(120,0,100)'], [0.6, 'rgb(160,90,0)'],\n [0.8, 'rgb(230,200,0)'], [1, 'rgb(255,250,220)']\n ],\n\n 'Viridis': [\n [0, '#440154'], [0.06274509803921569, '#48186a'],\n [0.12549019607843137, '#472d7b'], [0.18823529411764706, '#424086'],\n [0.25098039215686274, '#3b528b'], [0.3137254901960784, '#33638d'],\n [0.3764705882352941, '#2c728e'], [0.4392156862745098, '#26828e'],\n [0.5019607843137255, '#21918c'], [0.5647058823529412, '#1fa088'],\n [0.6274509803921569, '#28ae80'], [0.6901960784313725, '#3fbc73'],\n [0.7529411764705882, '#5ec962'], [0.8156862745098039, '#84d44b'],\n [0.8784313725490196, '#addc30'], [0.9411764705882353, '#d8e219'],\n [1, '#fde725']\n ],\n\n 'Cividis': [\n [0.000000, 'rgb(0,32,76)'], [0.058824, 'rgb(0,42,102)'],\n [0.117647, 'rgb(0,52,110)'], [0.176471, 'rgb(39,63,108)'],\n [0.235294, 'rgb(60,74,107)'], [0.294118, 'rgb(76,85,107)'],\n [0.352941, 'rgb(91,95,109)'], [0.411765, 'rgb(104,106,112)'],\n [0.470588, 'rgb(117,117,117)'], [0.529412, 'rgb(131,129,120)'],\n [0.588235, 'rgb(146,140,120)'], [0.647059, 'rgb(161,152,118)'],\n [0.705882, 'rgb(176,165,114)'], [0.764706, 'rgb(192,177,109)'],\n [0.823529, 'rgb(209,191,102)'], [0.882353, 'rgb(225,204,92)'],\n [0.941176, 'rgb(243,219,79)'], [1.000000, 'rgb(255,233,69)']\n ]\n};\n\nvar defaultScale = scales.RdBu;\n\nfunction getScale(scl, dflt) {\n if(!dflt) dflt = defaultScale;\n if(!scl) return dflt;\n\n function parseScale() {\n try {\n scl = scales[scl] || JSON.parse(scl);\n } catch(e) {\n scl = dflt;\n }\n }\n\n if(typeof scl === 'string') {\n parseScale();\n // occasionally scl is double-JSON encoded...\n if(typeof scl === 'string') parseScale();\n }\n\n if(!isValidScaleArray(scl)) return dflt;\n return scl;\n}\n\n\nfunction isValidScaleArray(scl) {\n var highestVal = 0;\n\n if(!Array.isArray(scl) || scl.length < 2) return false;\n\n if(!scl[0] || !scl[scl.length - 1]) return false;\n\n if(+scl[0][0] !== 0 || +scl[scl.length - 1][0] !== 1) return false;\n\n for(var i = 0; i < scl.length; i++) {\n var si = scl[i];\n\n if(si.length !== 2 || +si[0] < highestVal || !tinycolor(si[1]).isValid()) {\n return false;\n }\n\n highestVal = +si[0];\n }\n\n return true;\n}\n\nfunction isValidScale(scl) {\n if(scales[scl] !== undefined) return true;\n else return isValidScaleArray(scl);\n}\n\nmodule.exports = {\n scales: scales,\n defaultScale: defaultScale,\n\n get: getScale,\n isValid: isValidScale\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\nvar isPlainObject = require('./is_plain_object');\n\n/**\n * Relink private _keys and keys with a function value from one container\n * to the new container.\n * Relink means copying if object is pass-by-value and adding a reference\n * if object is pass-by-ref.\n * This prevents deepCopying massive structures like a webgl context.\n */\nmodule.exports = function relinkPrivateKeys(toContainer, fromContainer) {\n for(var k in fromContainer) {\n var fromVal = fromContainer[k];\n var toVal = toContainer[k];\n\n if(toVal === fromVal) {\n continue;\n }\n if(k.charAt(0) === '_' || typeof fromVal === 'function') {\n // if it already exists at this point, it's something\n // that we recreate each time around, so ignore it\n if(k in toContainer) continue;\n\n toContainer[k] = fromVal;\n } else if(isArrayOrTypedArray(fromVal) && isArrayOrTypedArray(toVal) && isPlainObject(fromVal[0])) {\n // filter out data_array items that can contain user objects\n // most of the time the toVal === fromVal check will catch these early\n // but if the user makes new ones we also don't want to recurse in.\n if(k === 'customdata' || k === 'ids') continue;\n\n // recurse into arrays containers\n var minLen = Math.min(fromVal.length, toVal.length);\n for(var j = 0; j < minLen; j++) {\n if((toVal[j] !== fromVal[j]) && isPlainObject(fromVal[j]) && isPlainObject(toVal[j])) {\n relinkPrivateKeys(toVal[j], fromVal[j]);\n }\n }\n } else if(isPlainObject(fromVal) && isPlainObject(toVal)) {\n // recurse into objects, but only if they still exist\n relinkPrivateKeys(toVal, fromVal);\n\n if(!Object.keys(toVal).length) delete toContainer[k];\n }\n }\n};\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// filter a list of segments based on boolean operations\n//\n\nfunction select(segments, selection, buildLog){\n\tvar result = [];\n\tsegments.forEach(function(seg){\n\t\tvar index =\n\t\t\t(seg.myFill.above ? 8 : 0) +\n\t\t\t(seg.myFill.below ? 4 : 0) +\n\t\t\t((seg.otherFill && seg.otherFill.above) ? 2 : 0) +\n\t\t\t((seg.otherFill && seg.otherFill.below) ? 1 : 0);\n\t\tif (selection[index] !== 0){\n\t\t\t// copy the segment to the results, while also calculating the fill status\n\t\t\tresult.push({\n\t\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\t\tstart: seg.start,\n\t\t\t\tend: seg.end,\n\t\t\t\tmyFill: {\n\t\t\t\t\tabove: selection[index] === 1, // 1 if filled above\n\t\t\t\t\tbelow: selection[index] === 2 // 2 if filled below\n\t\t\t\t},\n\t\t\t\totherFill: null\n\t\t\t});\n\t\t}\n\t});\n\n\tif (buildLog)\n\t\tbuildLog.selected(result);\n\n\treturn result;\n}\n\nvar SegmentSelector = {\n\tunion: function(segments, buildLog){ // primary | secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => yes filled below 2\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => no 0\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => yes filled above 1\n\t\t// 1 0 1 1 => no 0\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => no 0\n\t\t// 1 1 1 0 => no 0\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t2, 2, 0, 0,\n\t\t\t1, 0, 1, 0,\n\t\t\t0, 0, 0, 0\n\t\t], buildLog);\n\t},\n\tintersect: function(segments, buildLog){ // primary & secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => no 0\n\t\t// 0 0 1 0 => no 0\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => no 0\n\t\t// 0 1 0 1 => yes filled below 2\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => yes filled below 2\n\t\t// 1 0 0 0 => no 0\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => yes filled above 1\n\t\t// 1 0 1 1 => yes filled above 1\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled below 2\n\t\t// 1 1 1 0 => yes filled above 1\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 0, 0, 0,\n\t\t\t0, 2, 0, 2,\n\t\t\t0, 0, 1, 1,\n\t\t\t0, 2, 1, 0\n\t\t], buildLog);\n\t},\n\tdifference: function(segments, buildLog){ // primary - secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => no 0\n\t\t// 0 0 1 0 => no 0\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => yes filled below 2\n\t\t// 0 1 1 1 => no 0\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => yes filled above 1\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => no 0\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled above 1\n\t\t// 1 1 1 0 => yes filled below 2\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 0, 0, 0,\n\t\t\t2, 0, 2, 0,\n\t\t\t1, 1, 0, 0,\n\t\t\t0, 1, 2, 0\n\t\t], buildLog);\n\t},\n\tdifferenceRev: function(segments, buildLog){ // secondary - primary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => no 0\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => yes filled above 1\n\t\t// 0 1 1 1 => yes filled above 1\n\t\t// 1 0 0 0 => no 0\n\t\t// 1 0 0 1 => yes filled below 2\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => yes filled below 2\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => no 0\n\t\t// 1 1 1 0 => no 0\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t0, 0, 1, 1,\n\t\t\t0, 2, 0, 2,\n\t\t\t0, 0, 0, 0\n\t\t], buildLog);\n\t},\n\txor: function(segments, buildLog){ // primary ^ secondary\n\t\t// above1 below1 above2 below2 Keep? Value\n\t\t// 0 0 0 0 => no 0\n\t\t// 0 0 0 1 => yes filled below 2\n\t\t// 0 0 1 0 => yes filled above 1\n\t\t// 0 0 1 1 => no 0\n\t\t// 0 1 0 0 => yes filled below 2\n\t\t// 0 1 0 1 => no 0\n\t\t// 0 1 1 0 => no 0\n\t\t// 0 1 1 1 => yes filled above 1\n\t\t// 1 0 0 0 => yes filled above 1\n\t\t// 1 0 0 1 => no 0\n\t\t// 1 0 1 0 => no 0\n\t\t// 1 0 1 1 => yes filled below 2\n\t\t// 1 1 0 0 => no 0\n\t\t// 1 1 0 1 => yes filled above 1\n\t\t// 1 1 1 0 => yes filled below 2\n\t\t// 1 1 1 1 => no 0\n\t\treturn select(segments, [\n\t\t\t0, 2, 1, 0,\n\t\t\t2, 0, 0, 1,\n\t\t\t1, 0, 0, 2,\n\t\t\t0, 1, 2, 0\n\t\t], buildLog);\n\t}\n};\n\nmodule.exports = SegmentSelector;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar counterRegex = require('../../lib/regex').counter;\nvar domainAttrs = require('../../plots/domain').attributes;\nvar cartesianIdRegex = require('../../plots/cartesian/constants').idRegex;\nvar Template = require('../../plot_api/plot_template');\n\nvar gridAttrs = {\n rows: {\n valType: 'integer',\n min: 1,\n role: 'info',\n editType: 'plot',\n description: [\n 'The number of rows in the grid. If you provide a 2D `subplots`',\n 'array or a `yaxes` array, its length is used as the default.',\n 'But it\\'s also possible to have a different length, if you',\n 'want to leave a row at the end for non-cartesian subplots.'\n ].join(' ')\n },\n roworder: {\n valType: 'enumerated',\n values: ['top to bottom', 'bottom to top'],\n dflt: 'top to bottom',\n role: 'info',\n editType: 'plot',\n description: [\n 'Is the first row the top or the bottom? Note that columns',\n 'are always enumerated from left to right.'\n ].join(' ')\n },\n columns: {\n valType: 'integer',\n min: 1,\n role: 'info',\n editType: 'plot',\n description: [\n 'The number of columns in the grid. If you provide a 2D `subplots`',\n 'array, the length of its longest row is used as the default.',\n 'If you give an `xaxes` array, its length is used as the default.',\n 'But it\\'s also possible to have a different length, if you',\n 'want to leave a row at the end for non-cartesian subplots.'\n ].join(' ')\n },\n subplots: {\n valType: 'info_array',\n freeLength: true,\n dimensions: 2,\n items: {valType: 'enumerated', values: [counterRegex('xy').toString(), ''], editType: 'plot'},\n role: 'info',\n editType: 'plot',\n description: [\n 'Used for freeform grids, where some axes may be shared across subplots',\n 'but others are not. Each entry should be a cartesian subplot id, like',\n '*xy* or *x3y2*, or ** to leave that cell empty. You may reuse x axes',\n 'within the same column, and y axes within the same row.',\n 'Non-cartesian subplots and traces that support `domain` can place themselves',\n 'in this grid separately using the `gridcell` attribute.'\n ].join(' ')\n },\n xaxes: {\n valType: 'info_array',\n freeLength: true,\n items: {valType: 'enumerated', values: [cartesianIdRegex.x.toString(), ''], editType: 'plot'},\n role: 'info',\n editType: 'plot',\n description: [\n 'Used with `yaxes` when the x and y axes are shared across columns and rows.',\n 'Each entry should be an x axis id like *x*, *x2*, etc., or ** to',\n 'not put an x axis in that column. Entries other than ** must be unique.',\n 'Ignored if `subplots` is present. If missing but `yaxes` is present,',\n 'will generate consecutive IDs.'\n ].join(' ')\n },\n yaxes: {\n valType: 'info_array',\n freeLength: true,\n items: {valType: 'enumerated', values: [cartesianIdRegex.y.toString(), ''], editType: 'plot'},\n role: 'info',\n editType: 'plot',\n description: [\n 'Used with `yaxes` when the x and y axes are shared across columns and rows.',\n 'Each entry should be an y axis id like *y*, *y2*, etc., or ** to',\n 'not put a y axis in that row. Entries other than ** must be unique.',\n 'Ignored if `subplots` is present. If missing but `xaxes` is present,',\n 'will generate consecutive IDs.'\n ].join(' ')\n },\n pattern: {\n valType: 'enumerated',\n values: ['independent', 'coupled'],\n dflt: 'coupled',\n role: 'info',\n editType: 'plot',\n description: [\n 'If no `subplots`, `xaxes`, or `yaxes` are given but we do have `rows` and `columns`,',\n 'we can generate defaults using consecutive axis IDs, in two ways:',\n '*coupled* gives one x axis per column and one y axis per row.',\n '*independent* uses a new xy pair for each cell, left-to-right across each row',\n 'then iterating rows according to `roworder`.'\n ].join(' ')\n },\n xgap: {\n valType: 'number',\n min: 0,\n max: 1,\n role: 'info',\n editType: 'plot',\n description: [\n 'Horizontal space between grid cells, expressed as a fraction',\n 'of the total width available to one cell. Defaults to 0.1',\n 'for coupled-axes grids and 0.2 for independent grids.'\n ].join(' ')\n },\n ygap: {\n valType: 'number',\n min: 0,\n max: 1,\n role: 'info',\n editType: 'plot',\n description: [\n 'Vertical space between grid cells, expressed as a fraction',\n 'of the total height available to one cell. Defaults to 0.1',\n 'for coupled-axes grids and 0.3 for independent grids.'\n ].join(' ')\n },\n domain: domainAttrs({name: 'grid', editType: 'plot', noGridCell: true}, {\n description: [\n 'The first and last cells end exactly at the domain',\n 'edges, with no grout around the edges.'\n ].join(' ')\n }),\n xside: {\n valType: 'enumerated',\n values: ['bottom', 'bottom plot', 'top plot', 'top'],\n dflt: 'bottom plot',\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets where the x axis labels and titles go. *bottom* means',\n 'the very bottom of the grid. *bottom plot* is the lowest plot',\n 'that each x axis is used in. *top* and *top plot* are similar.'\n ].join(' ')\n },\n yside: {\n valType: 'enumerated',\n values: ['left', 'left plot', 'right plot', 'right'],\n dflt: 'left plot',\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets where the y axis labels and titles go. *left* means',\n 'the very left edge of the grid. *left plot* is the leftmost plot',\n 'that each y axis is used in. *right* and *right plot* are similar.'\n ].join(' ')\n },\n editType: 'plot'\n};\n\nfunction getAxes(layout, grid, axLetter) {\n var gridVal = grid[axLetter + 'axes'];\n var splomVal = Object.keys((layout._splomAxes || {})[axLetter] || {});\n\n if(Array.isArray(gridVal)) return gridVal;\n if(splomVal.length) return splomVal;\n}\n\n// the shape of the grid - this needs to be done BEFORE supplyDataDefaults\n// so that non-subplot traces can place themselves in the grid\nfunction sizeDefaults(layoutIn, layoutOut) {\n var gridIn = layoutIn.grid || {};\n var xAxes = getAxes(layoutOut, gridIn, 'x');\n var yAxes = getAxes(layoutOut, gridIn, 'y');\n\n if(!layoutIn.grid && !xAxes && !yAxes) return;\n\n var hasSubplotGrid = Array.isArray(gridIn.subplots) && Array.isArray(gridIn.subplots[0]);\n var hasXaxes = Array.isArray(xAxes);\n var hasYaxes = Array.isArray(yAxes);\n var isSplomGenerated = (\n hasXaxes && xAxes !== gridIn.xaxes &&\n hasYaxes && yAxes !== gridIn.yaxes\n );\n\n var dfltRows, dfltColumns;\n\n if(hasSubplotGrid) {\n dfltRows = gridIn.subplots.length;\n dfltColumns = gridIn.subplots[0].length;\n } else {\n if(hasYaxes) dfltRows = yAxes.length;\n if(hasXaxes) dfltColumns = xAxes.length;\n }\n\n var gridOut = Template.newContainer(layoutOut, 'grid');\n\n function coerce(attr, dflt) {\n return Lib.coerce(gridIn, gridOut, gridAttrs, attr, dflt);\n }\n\n var rows = coerce('rows', dfltRows);\n var columns = coerce('columns', dfltColumns);\n\n if(!(rows * columns > 1)) {\n delete layoutOut.grid;\n return;\n }\n\n if(!hasSubplotGrid && !hasXaxes && !hasYaxes) {\n var useDefaultSubplots = coerce('pattern') === 'independent';\n if(useDefaultSubplots) hasSubplotGrid = true;\n }\n gridOut._hasSubplotGrid = hasSubplotGrid;\n\n var rowOrder = coerce('roworder');\n var reversed = rowOrder === 'top to bottom';\n\n var dfltGapX = hasSubplotGrid ? 0.2 : 0.1;\n var dfltGapY = hasSubplotGrid ? 0.3 : 0.1;\n\n var dfltSideX, dfltSideY;\n if(isSplomGenerated && layoutOut._splomGridDflt) {\n dfltSideX = layoutOut._splomGridDflt.xside;\n dfltSideY = layoutOut._splomGridDflt.yside;\n }\n\n gridOut._domains = {\n x: fillGridPositions('x', coerce, dfltGapX, dfltSideX, columns),\n y: fillGridPositions('y', coerce, dfltGapY, dfltSideY, rows, reversed)\n };\n}\n\n// coerce x or y sizing attributes and return an array of domains for this direction\nfunction fillGridPositions(axLetter, coerce, dfltGap, dfltSide, len, reversed) {\n var dirGap = coerce(axLetter + 'gap', dfltGap);\n var domain = coerce('domain.' + axLetter);\n coerce(axLetter + 'side', dfltSide);\n\n var out = new Array(len);\n var start = domain[0];\n var step = (domain[1] - start) / (len - dirGap);\n var cellDomain = step * (1 - dirGap);\n for(var i = 0; i < len; i++) {\n var cellStart = start + step * i;\n out[reversed ? (len - 1 - i) : i] = [cellStart, cellStart + cellDomain];\n }\n return out;\n}\n\n// the (cartesian) contents of the grid - this needs to happen AFTER supplyDataDefaults\n// so that we know what cartesian subplots are available\nfunction contentDefaults(layoutIn, layoutOut) {\n var gridOut = layoutOut.grid;\n // make sure we got to the end of handleGridSizing\n if(!gridOut || !gridOut._domains) return;\n\n var gridIn = layoutIn.grid || {};\n var subplots = layoutOut._subplots;\n var hasSubplotGrid = gridOut._hasSubplotGrid;\n var rows = gridOut.rows;\n var columns = gridOut.columns;\n var useDefaultSubplots = gridOut.pattern === 'independent';\n\n var i, j, xId, yId, subplotId, subplotsOut, yPos;\n\n var axisMap = gridOut._axisMap = {};\n\n if(hasSubplotGrid) {\n var subplotsIn = gridIn.subplots || [];\n subplotsOut = gridOut.subplots = new Array(rows);\n var index = 1;\n\n for(i = 0; i < rows; i++) {\n var rowOut = subplotsOut[i] = new Array(columns);\n var rowIn = subplotsIn[i] || [];\n for(j = 0; j < columns; j++) {\n if(useDefaultSubplots) {\n subplotId = (index === 1) ? 'xy' : ('x' + index + 'y' + index);\n index++;\n } else subplotId = rowIn[j];\n\n rowOut[j] = '';\n\n if(subplots.cartesian.indexOf(subplotId) !== -1) {\n yPos = subplotId.indexOf('y');\n xId = subplotId.slice(0, yPos);\n yId = subplotId.slice(yPos);\n if((axisMap[xId] !== undefined && axisMap[xId] !== j) ||\n (axisMap[yId] !== undefined && axisMap[yId] !== i)\n ) {\n continue;\n }\n\n rowOut[j] = subplotId;\n axisMap[xId] = j;\n axisMap[yId] = i;\n }\n }\n }\n } else {\n var xAxes = getAxes(layoutOut, gridIn, 'x');\n var yAxes = getAxes(layoutOut, gridIn, 'y');\n gridOut.xaxes = fillGridAxes(xAxes, subplots.xaxis, columns, axisMap, 'x');\n gridOut.yaxes = fillGridAxes(yAxes, subplots.yaxis, rows, axisMap, 'y');\n }\n\n var anchors = gridOut._anchors = {};\n var reversed = gridOut.roworder === 'top to bottom';\n\n for(var axisId in axisMap) {\n var axLetter = axisId.charAt(0);\n var side = gridOut[axLetter + 'side'];\n\n var i0, inc, iFinal;\n\n if(side.length < 8) {\n // grid edge - ie not \"* plot\" - make these as free axes\n // since we're not guaranteed to have a subplot there at all\n anchors[axisId] = 'free';\n } else if(axLetter === 'x') {\n if((side.charAt(0) === 't') === reversed) {\n i0 = 0;\n inc = 1;\n iFinal = rows;\n } else {\n i0 = rows - 1;\n inc = -1;\n iFinal = -1;\n }\n if(hasSubplotGrid) {\n var column = axisMap[axisId];\n for(i = i0; i !== iFinal; i += inc) {\n subplotId = subplotsOut[i][column];\n if(!subplotId) continue;\n yPos = subplotId.indexOf('y');\n if(subplotId.slice(0, yPos) === axisId) {\n anchors[axisId] = subplotId.slice(yPos);\n break;\n }\n }\n } else {\n for(i = i0; i !== iFinal; i += inc) {\n yId = gridOut.yaxes[i];\n if(subplots.cartesian.indexOf(axisId + yId) !== -1) {\n anchors[axisId] = yId;\n break;\n }\n }\n }\n } else {\n if((side.charAt(0) === 'l')) {\n i0 = 0;\n inc = 1;\n iFinal = columns;\n } else {\n i0 = columns - 1;\n inc = -1;\n iFinal = -1;\n }\n if(hasSubplotGrid) {\n var row = axisMap[axisId];\n for(i = i0; i !== iFinal; i += inc) {\n subplotId = subplotsOut[row][i];\n if(!subplotId) continue;\n yPos = subplotId.indexOf('y');\n if(subplotId.slice(yPos) === axisId) {\n anchors[axisId] = subplotId.slice(0, yPos);\n break;\n }\n }\n } else {\n for(i = i0; i !== iFinal; i += inc) {\n xId = gridOut.xaxes[i];\n if(subplots.cartesian.indexOf(xId + axisId) !== -1) {\n anchors[axisId] = xId;\n break;\n }\n }\n }\n }\n }\n}\n\nfunction fillGridAxes(axesIn, axesAllowed, len, axisMap, axLetter) {\n var out = new Array(len);\n var i;\n\n function fillOneAxis(i, axisId) {\n if(axesAllowed.indexOf(axisId) !== -1 && axisMap[axisId] === undefined) {\n out[i] = axisId;\n axisMap[axisId] = i;\n } else out[i] = '';\n }\n\n if(Array.isArray(axesIn)) {\n for(i = 0; i < len; i++) {\n fillOneAxis(i, axesIn[i]);\n }\n } else {\n // default axis list is the first `len` axis ids\n fillOneAxis(0, axLetter);\n for(i = 1; i < len; i++) {\n fillOneAxis(i, axLetter + (i + 1));\n }\n }\n\n return out;\n}\n\nmodule.exports = {\n moduleType: 'component',\n name: 'grid',\n\n schema: {\n layout: {grid: gridAttrs}\n },\n\n layoutAttributes: gridAttrs,\n sizeDefaults: sizeDefaults,\n contentDefaults: contentDefaults\n};\n","'use strict';\r\n\r\n/**\r\n * Is this string all whitespace?\r\n * This solution kind of makes my brain hurt, but it's significantly faster\r\n * than !str.trim() or any other solution I could find.\r\n *\r\n * whitespace codes from: http://en.wikipedia.org/wiki/Whitespace_character\r\n * and verified with:\r\n *\r\n * for(var i = 0; i < 65536; i++) {\r\n * var s = String.fromCharCode(i);\r\n * if(+s===0 && !s.trim()) console.log(i, s);\r\n * }\r\n *\r\n * which counts a couple of these as *not* whitespace, but finds nothing else\r\n * that *is* whitespace. Note that charCodeAt stops at 16 bits, but it appears\r\n * that there are no whitespace characters above this, and code points above\r\n * this do not map onto white space characters.\r\n */\r\n\r\nmodule.exports = function(str){\r\n var l = str.length,\r\n a;\r\n for(var i = 0; i < l; i++) {\r\n a = str.charCodeAt(i);\r\n if((a < 9 || a > 13) && (a !== 32) && (a !== 133) && (a !== 160) &&\r\n (a !== 5760) && (a !== 6158) && (a < 8192 || a > 8205) &&\r\n (a !== 8232) && (a !== 8233) && (a !== 8239) && (a !== 8287) &&\r\n (a !== 8288) && (a !== 12288) && (a !== 65279)) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Fx = require('../../components/fx');\nvar Registry = require('../../registry');\nvar getTraceColor = require('./get_trace_color');\nvar Color = require('../../components/color');\nvar fillText = Lib.fillText;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var xpx = xa.c2p(xval);\n var ypx = ya.c2p(yval);\n var pt = [xpx, ypx];\n var hoveron = trace.hoveron || '';\n var minRad = (trace.mode.indexOf('markers') !== -1) ? 3 : 0.5;\n\n // look for points to hover on first, then take fills only if we\n // didn't find a point\n if(hoveron.indexOf('points') !== -1) {\n var dx = function(di) {\n // dx and dy are used in compare modes - here we want to always\n // prioritize the closest data point, at least as long as markers are\n // the same size or nonexistent, but still try to prioritize small markers too.\n var rad = Math.max(3, di.mrc || 0);\n var kink = 1 - 1 / rad;\n var dxRaw = Math.abs(xa.c2p(di.x) - xpx);\n var d = (dxRaw < rad) ? (kink * dxRaw / rad) : (dxRaw - rad + kink);\n return d;\n };\n var dy = function(di) {\n var rad = Math.max(3, di.mrc || 0);\n var kink = 1 - 1 / rad;\n var dyRaw = Math.abs(ya.c2p(di.y) - ypx);\n return (dyRaw < rad) ? (kink * dyRaw / rad) : (dyRaw - rad + kink);\n };\n var dxy = function(di) {\n // scatter points: d.mrc is the calculated marker radius\n // adjust the distance so if you're inside the marker it\n // always will show up regardless of point size, but\n // prioritize smaller points\n var rad = Math.max(minRad, di.mrc || 0);\n var dx = xa.c2p(di.x) - xpx;\n var dy = ya.c2p(di.y) - ypx;\n return Math.max(Math.sqrt(dx * dx + dy * dy) - rad, 1 - minRad / rad);\n };\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n\n Fx.getClosest(cd, distfn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index !== false) {\n // the closest data point\n var di = cd[pointData.index];\n var xc = xa.c2p(di.x, true);\n var yc = ya.c2p(di.y, true);\n var rad = di.mrc || 1;\n\n // now we're done using the whole `calcdata` array, replace the\n // index with the original index (in case of inserted point from\n // stacked area)\n pointData.index = di.i;\n\n var orientation = cd[0].t.orientation;\n // TODO: for scatter and bar, option to show (sub)totals and\n // raw data? Currently stacked and/or normalized bars just show\n // the normalized individual sizes, so that's what I'm doing here\n // for now.\n var sizeVal = orientation && (di.sNorm || di.s);\n var xLabelVal = (orientation === 'h') ? sizeVal : di.x;\n var yLabelVal = (orientation === 'v') ? sizeVal : di.y;\n\n Lib.extendFlat(pointData, {\n color: getTraceColor(trace, di),\n\n x0: xc - rad,\n x1: xc + rad,\n xLabelVal: xLabelVal,\n\n y0: yc - rad,\n y1: yc + rad,\n yLabelVal: yLabelVal,\n\n spikeDistance: dxy(di),\n hovertemplate: trace.hovertemplate\n });\n\n fillText(di, trace, pointData);\n Registry.getComponentMethod('errorbars', 'hoverInfo')(di, trace, pointData);\n\n return [pointData];\n }\n }\n\n // even if hoveron is 'fills', only use it if we have polygons too\n if(hoveron.indexOf('fills') !== -1 && trace._polygons) {\n var polygons = trace._polygons;\n var polygonsIn = [];\n var inside = false;\n var xmin = Infinity;\n var xmax = -Infinity;\n var ymin = Infinity;\n var ymax = -Infinity;\n\n var i, j, polygon, pts, xCross, x0, x1, y0, y1;\n\n for(i = 0; i < polygons.length; i++) {\n polygon = polygons[i];\n // TODO: this is not going to work right for curved edges, it will\n // act as though they're straight. That's probably going to need\n // the elements themselves to capture the events. Worth it?\n if(polygon.contains(pt)) {\n inside = !inside;\n // TODO: need better than just the overall bounding box\n polygonsIn.push(polygon);\n ymin = Math.min(ymin, polygon.ymin);\n ymax = Math.max(ymax, polygon.ymax);\n }\n }\n\n if(inside) {\n // constrain ymin/max to the visible plot, so the label goes\n // at the middle of the piece you can see\n ymin = Math.max(ymin, 0);\n ymax = Math.min(ymax, ya._length);\n\n // find the overall left-most and right-most points of the\n // polygon(s) we're inside at their combined vertical midpoint.\n // This is where we will draw the hover label.\n // Note that this might not be the vertical midpoint of the\n // whole trace, if it's disjoint.\n var yAvg = (ymin + ymax) / 2;\n for(i = 0; i < polygonsIn.length; i++) {\n pts = polygonsIn[i].pts;\n for(j = 1; j < pts.length; j++) {\n y0 = pts[j - 1][1];\n y1 = pts[j][1];\n if((y0 > yAvg) !== (y1 >= yAvg)) {\n x0 = pts[j - 1][0];\n x1 = pts[j][0];\n if(y1 - y0) {\n xCross = x0 + (x1 - x0) * (yAvg - y0) / (y1 - y0);\n xmin = Math.min(xmin, xCross);\n xmax = Math.max(xmax, xCross);\n }\n }\n }\n }\n\n // constrain xmin/max to the visible plot now too\n xmin = Math.max(xmin, 0);\n xmax = Math.min(xmax, xa._length);\n\n // get only fill or line color for the hover color\n var color = Color.defaultLine;\n if(Color.opacity(trace.fillcolor)) color = trace.fillcolor;\n else if(Color.opacity((trace.line || {}).color)) {\n color = trace.line.color;\n }\n\n Lib.extendFlat(pointData, {\n // never let a 2D override 1D type as closest point\n // also: no spikeDistance, it's not allowed for fills\n distance: pointData.maxHoverDistance,\n x0: xmin,\n x1: xmax,\n y0: yAvg,\n y1: yAvg,\n color: color,\n hovertemplate: false\n });\n\n delete pointData.index;\n\n if(trace.text && !Array.isArray(trace.text)) {\n pointData.text = String(trace.text);\n } else pointData.text = trace.name;\n\n return [pointData];\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar Drawing = require('../../components/drawing');\nvar Registry = require('../../registry');\n\nfunction style(gd) {\n var s = d3.select(gd).selectAll('g.trace.scatter');\n\n s.style('opacity', function(d) {\n return d[0].trace.opacity;\n });\n\n s.selectAll('g.points').each(function(d) {\n var sel = d3.select(this);\n var trace = d.trace || d[0].trace;\n stylePoints(sel, trace, gd);\n });\n\n s.selectAll('g.text').each(function(d) {\n var sel = d3.select(this);\n var trace = d.trace || d[0].trace;\n styleText(sel, trace, gd);\n });\n\n s.selectAll('g.trace path.js-line')\n .call(Drawing.lineGroupStyle);\n\n s.selectAll('g.trace path.js-fill')\n .call(Drawing.fillGroupStyle);\n\n Registry.getComponentMethod('errorbars', 'style')(s);\n}\n\nfunction stylePoints(sel, trace, gd) {\n Drawing.pointStyle(sel.selectAll('path.point'), trace, gd);\n}\n\nfunction styleText(sel, trace, gd) {\n Drawing.textPointStyle(sel.selectAll('text'), trace, gd);\n}\n\nfunction styleOnSelect(gd, cd, sel) {\n var trace = cd[0].trace;\n\n if(trace.selectedpoints) {\n Drawing.selectedPointStyle(sel.selectAll('path.point'), trace);\n Drawing.selectedTextStyle(sel.selectAll('text'), trace);\n } else {\n stylePoints(sel, trace, gd);\n styleText(sel, trace, gd);\n }\n}\n\nmodule.exports = {\n style: style,\n stylePoints: stylePoints,\n styleText: styleText,\n styleOnSelect: styleOnSelect\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\n\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Registry = require('../../registry');\nvar tickText = require('../../plots/cartesian/axes').tickText;\n\nvar uniformText = require('./uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\n\nvar style = require('./style');\nvar helpers = require('./helpers');\nvar constants = require('./constants');\nvar attributes = require('./attributes');\n\nvar attributeText = attributes.text;\nvar attributeTextPosition = attributes.textposition;\n\nvar appendArrayPointValue = require('../../components/fx/helpers').appendArrayPointValue;\n\nvar TEXTPAD = constants.TEXTPAD;\n\nfunction keyFunc(d) {return d.id;}\nfunction getKeyFunc(trace) {\n if(trace.ids) {\n return keyFunc;\n }\n}\n\nfunction dirSign(a, b) {\n return (a < b) ? 1 : -1;\n}\n\nfunction getXY(di, xa, ya, isHorizontal) {\n var s = [];\n var p = [];\n\n var sAxis = isHorizontal ? xa : ya;\n var pAxis = isHorizontal ? ya : xa;\n\n s[0] = sAxis.c2p(di.s0, true);\n p[0] = pAxis.c2p(di.p0, true);\n\n s[1] = sAxis.c2p(di.s1, true);\n p[1] = pAxis.c2p(di.p1, true);\n\n return isHorizontal ? [s, p] : [p, s];\n}\n\nfunction transition(selection, fullLayout, opts, makeOnCompleteCallback) {\n if(!fullLayout.uniformtext.mode && hasTransition(opts)) {\n var onComplete;\n if(makeOnCompleteCallback) {\n onComplete = makeOnCompleteCallback();\n }\n return selection\n .transition()\n .duration(opts.duration)\n .ease(opts.easing)\n .each('end', function() { onComplete && onComplete(); })\n .each('interrupt', function() { onComplete && onComplete(); });\n } else {\n return selection;\n }\n}\n\nfunction hasTransition(transitionOpts) {\n return transitionOpts && transitionOpts.duration > 0;\n}\n\nfunction plot(gd, plotinfo, cdModule, traceLayer, opts, makeOnCompleteCallback) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var fullLayout = gd._fullLayout;\n\n if(!opts) {\n opts = {\n mode: fullLayout.barmode,\n norm: fullLayout.barmode,\n gap: fullLayout.bargap,\n groupgap: fullLayout.bargroupgap\n };\n\n // don't clear bar when this is called from waterfall or funnel\n clearMinTextSize('bar', fullLayout);\n }\n\n var bartraces = Lib.makeTraceGroups(traceLayer, cdModule, 'trace bars').each(function(cd) {\n var plotGroup = d3.select(this);\n var trace = cd[0].trace;\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n var isBar = (trace.type === 'bar');\n var shouldDisplayZeros = (isBar || isFunnel);\n\n var adjustPixel = 0;\n if(isWaterfall && trace.connector.visible && trace.connector.mode === 'between') {\n adjustPixel = trace.connector.line.width / 2;\n }\n\n var isHorizontal = (trace.orientation === 'h');\n var withTransition = hasTransition(opts);\n\n var pointGroup = Lib.ensureSingle(plotGroup, 'g', 'points');\n\n var keyFunc = getKeyFunc(trace);\n var bars = pointGroup.selectAll('g.point').data(Lib.identity, keyFunc);\n\n bars.enter().append('g')\n .classed('point', true);\n\n bars.exit().remove();\n\n bars.each(function(di, i) {\n var bar = d3.select(this);\n\n // now display the bar\n // clipped xf/yf (2nd arg true): non-positive\n // log values go off-screen by plotwidth\n // so you see them continue if you drag the plot\n var xy = getXY(di, xa, ya, isHorizontal);\n\n var x0 = xy[0][0];\n var x1 = xy[0][1];\n var y0 = xy[1][0];\n var y1 = xy[1][1];\n\n // empty bars\n var isBlank = (isHorizontal ? x1 - x0 : y1 - y0) === 0;\n\n // display zeros if line.width > 0\n if(isBlank && shouldDisplayZeros && helpers.getLineWidth(trace, di)) {\n isBlank = false;\n }\n\n // skip nulls\n if(!isBlank) {\n isBlank = (\n !isNumeric(x0) ||\n !isNumeric(x1) ||\n !isNumeric(y0) ||\n !isNumeric(y1)\n );\n }\n\n // record isBlank\n di.isBlank = isBlank;\n\n // for blank bars, ensure start and end positions are equal - important for smooth transitions\n if(isBlank) {\n if(isHorizontal) {\n x1 = x0;\n } else {\n y1 = y0;\n }\n }\n\n // in waterfall mode `between` we need to adjust bar end points to match the connector width\n if(adjustPixel && !isBlank) {\n if(isHorizontal) {\n x0 -= dirSign(x0, x1) * adjustPixel;\n x1 += dirSign(x0, x1) * adjustPixel;\n } else {\n y0 -= dirSign(y0, y1) * adjustPixel;\n y1 += dirSign(y0, y1) * adjustPixel;\n }\n }\n\n var lw;\n var mc;\n\n if(trace.type === 'waterfall') {\n if(!isBlank) {\n var cont = trace[di.dir].marker;\n lw = cont.line.width;\n mc = cont.color;\n }\n } else {\n lw = helpers.getLineWidth(trace, di);\n mc = di.mc || trace.marker.color;\n }\n\n function roundWithLine(v) {\n var offset = d3.round((lw / 2) % 1, 2);\n\n // if there are explicit gaps, don't round,\n // it can make the gaps look crappy\n return (opts.gap === 0 && opts.groupgap === 0) ?\n d3.round(Math.round(v) - offset, 2) : v;\n }\n\n function expandToVisible(v, vc, hideZeroSpan) {\n if(hideZeroSpan && v === vc) {\n // should not expand zero span bars\n // when start and end positions are identical\n // i.e. for vertical when y0 === y1\n // and for horizontal when x0 === x1\n return v;\n }\n\n // if it's not in danger of disappearing entirely,\n // round more precisely\n return Math.abs(v - vc) >= 2 ? roundWithLine(v) :\n // but if it's very thin, expand it so it's\n // necessarily visible, even if it might overlap\n // its neighbor\n (v > vc ? Math.ceil(v) : Math.floor(v));\n }\n\n if(!gd._context.staticPlot) {\n // if bars are not fully opaque or they have a line\n // around them, round to integer pixels, mainly for\n // safari so we prevent overlaps from its expansive\n // pixelation. if the bars ARE fully opaque and have\n // no line, expand to a full pixel to make sure we\n // can see them\n\n var op = Color.opacity(mc);\n var fixpx = (op < 1 || lw > 0.01) ? roundWithLine : expandToVisible;\n\n x0 = fixpx(x0, x1, isHorizontal);\n x1 = fixpx(x1, x0, isHorizontal);\n y0 = fixpx(y0, y1, !isHorizontal);\n y1 = fixpx(y1, y0, !isHorizontal);\n }\n\n var sel = transition(Lib.ensureSingle(bar, 'path'), fullLayout, opts, makeOnCompleteCallback);\n sel\n .style('vector-effect', 'non-scaling-stroke')\n .attr('d', isNaN((x1 - x0) * (y1 - y0)) ? 'M0,0Z' : 'M' + x0 + ',' + y0 + 'V' + y1 + 'H' + x1 + 'V' + y0 + 'Z')\n .call(Drawing.setClipUrl, plotinfo.layerClipId, gd);\n\n if(!fullLayout.uniformtext.mode && withTransition) {\n var styleFns = Drawing.makePointStyleFns(trace);\n Drawing.singlePointStyle(di, sel, trace, styleFns, gd);\n }\n\n appendBarText(gd, plotinfo, bar, cd, i, x0, x1, y0, y1, opts, makeOnCompleteCallback);\n\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(di, bar.select('text'), xa, ya, trace.xcalendar, trace.ycalendar);\n }\n });\n\n // lastly, clip points groups of `cliponaxis !== false` traces\n // on `plotinfo._hasClipOnAxisFalse === true` subplots\n var hasClipOnAxisFalse = trace.cliponaxis === false;\n Drawing.setClipUrl(plotGroup, hasClipOnAxisFalse ? null : plotinfo.layerClipId, gd);\n });\n\n // error bars are on the top\n Registry.getComponentMethod('errorbars', 'plot')(gd, bartraces, plotinfo, opts);\n}\n\nfunction appendBarText(gd, plotinfo, bar, cd, i, x0, x1, y0, y1, opts, makeOnCompleteCallback) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var fullLayout = gd._fullLayout;\n var textPosition;\n\n function appendTextNode(bar, text, font) {\n var textSelection = Lib.ensureSingle(bar, 'text')\n .text(text)\n .attr({\n 'class': 'bartext bartext-' + textPosition,\n 'text-anchor': 'middle',\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n 'data-notex': 1\n })\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n return textSelection;\n }\n\n // get trace attributes\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n\n var text = getText(fullLayout, cd, i, xa, ya);\n textPosition = getTextPosition(trace, i);\n\n // compute text position\n var inStackOrRelativeMode =\n opts.mode === 'stack' ||\n opts.mode === 'relative';\n\n var calcBar = cd[i];\n var isOutmostBar = !inStackOrRelativeMode || calcBar._outmost;\n\n if(!text ||\n textPosition === 'none' ||\n ((calcBar.isBlank || x0 === x1 || y0 === y1) && (\n textPosition === 'auto' ||\n textPosition === 'inside'))) {\n bar.select('text').remove();\n return;\n }\n\n var layoutFont = fullLayout.font;\n var barColor = style.getBarColor(cd[i], trace);\n var insideTextFont = style.getInsideTextFont(trace, i, layoutFont, barColor);\n var outsideTextFont = style.getOutsideTextFont(trace, i, layoutFont);\n\n // Special case: don't use the c2p(v, true) value on log size axes,\n // so that we can get correctly inside text scaling\n var di = bar.datum();\n if(isHorizontal) {\n if(xa.type === 'log' && di.s0 <= 0) {\n if(xa.range[0] < xa.range[1]) {\n x0 = 0;\n } else {\n x0 = xa._length;\n }\n }\n } else {\n if(ya.type === 'log' && di.s0 <= 0) {\n if(ya.range[0] < ya.range[1]) {\n y0 = ya._length;\n } else {\n y0 = 0;\n }\n }\n }\n\n // padding excluded\n var barWidth = Math.abs(x1 - x0) - 2 * TEXTPAD;\n var barHeight = Math.abs(y1 - y0) - 2 * TEXTPAD;\n\n var textSelection;\n var textBB;\n var textWidth;\n var textHeight;\n var font;\n\n if(textPosition === 'outside') {\n if(!isOutmostBar && !calcBar.hasB) textPosition = 'inside';\n }\n\n if(textPosition === 'auto') {\n if(isOutmostBar) {\n // draw text using insideTextFont and check if it fits inside bar\n textPosition = 'inside';\n\n font = Lib.ensureUniformFontSize(gd, insideTextFont);\n\n textSelection = appendTextNode(bar, text, font);\n\n textBB = Drawing.bBox(textSelection.node()),\n textWidth = textBB.width,\n textHeight = textBB.height;\n\n var textHasSize = (textWidth > 0 && textHeight > 0);\n var fitsInside = (textWidth <= barWidth && textHeight <= barHeight);\n var fitsInsideIfRotated = (textWidth <= barHeight && textHeight <= barWidth);\n var fitsInsideIfShrunk = (isHorizontal) ?\n (barWidth >= textWidth * (barHeight / textHeight)) :\n (barHeight >= textHeight * (barWidth / textWidth));\n\n if(textHasSize && (\n fitsInside ||\n fitsInsideIfRotated ||\n fitsInsideIfShrunk)\n ) {\n textPosition = 'inside';\n } else {\n textPosition = 'outside';\n textSelection.remove();\n textSelection = null;\n }\n } else {\n textPosition = 'inside';\n }\n }\n\n if(!textSelection) {\n font = Lib.ensureUniformFontSize(gd, (textPosition === 'outside') ? outsideTextFont : insideTextFont);\n\n textSelection = appendTextNode(bar, text, font);\n\n var currentTransform = textSelection.attr('transform');\n textSelection.attr('transform', '');\n textBB = Drawing.bBox(textSelection.node()),\n textWidth = textBB.width,\n textHeight = textBB.height;\n textSelection.attr('transform', currentTransform);\n\n if(textWidth <= 0 || textHeight <= 0) {\n textSelection.remove();\n return;\n }\n }\n\n var angle = trace.textangle;\n\n // compute text transform\n var transform, constrained;\n if(textPosition === 'outside') {\n constrained =\n trace.constraintext === 'both' ||\n trace.constraintext === 'outside';\n\n transform = toMoveOutsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: isHorizontal,\n constrained: constrained,\n angle: angle\n });\n } else {\n constrained =\n trace.constraintext === 'both' ||\n trace.constraintext === 'inside';\n\n transform = toMoveInsideBar(x0, x1, y0, y1, textBB, {\n isHorizontal: isHorizontal,\n constrained: constrained,\n angle: angle,\n anchor: trace.insidetextanchor\n });\n }\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type, transform, fullLayout);\n calcBar.transform = transform;\n\n transition(textSelection, fullLayout, opts, makeOnCompleteCallback)\n .attr('transform', Lib.getTextTransform(transform));\n}\n\nfunction getRotateFromAngle(angle) {\n return (angle === 'auto') ? 0 : angle;\n}\n\nfunction getRotatedTextSize(textBB, rotate) {\n var a = Math.PI / 180 * rotate;\n var absSin = Math.abs(Math.sin(a));\n var absCos = Math.abs(Math.cos(a));\n\n return {\n x: textBB.width * absCos + textBB.height * absSin,\n y: textBB.width * absSin + textBB.height * absCos\n };\n}\n\nfunction toMoveInsideBar(x0, x1, y0, y1, textBB, opts) {\n var isHorizontal = !!opts.isHorizontal;\n var constrained = !!opts.constrained;\n var angle = opts.angle || 0;\n var anchor = opts.anchor || 'end';\n var isEnd = anchor === 'end';\n var isStart = anchor === 'start';\n var leftToRight = opts.leftToRight || 0; // left: -1, center: 0, right: 1\n var toRight = (leftToRight + 1) / 2;\n var toLeft = 1 - toRight;\n\n var textWidth = textBB.width;\n var textHeight = textBB.height;\n var lx = Math.abs(x1 - x0);\n var ly = Math.abs(y1 - y0);\n\n // compute remaining space\n var textpad = (\n lx > (2 * TEXTPAD) &&\n ly > (2 * TEXTPAD)\n ) ? TEXTPAD : 0;\n\n lx -= 2 * textpad;\n ly -= 2 * textpad;\n\n var rotate = getRotateFromAngle(angle);\n if((angle === 'auto') &&\n !(textWidth <= lx && textHeight <= ly) &&\n (textWidth > lx || textHeight > ly) && (\n !(textWidth > ly || textHeight > lx) ||\n ((textWidth < textHeight) !== (lx < ly))\n )) {\n rotate += 90;\n }\n\n var t = getRotatedTextSize(textBB, rotate);\n\n var scale = 1;\n if(constrained) {\n scale = Math.min(\n 1,\n lx / t.x,\n ly / t.y\n );\n }\n\n // compute text and target positions\n var textX = (\n textBB.left * toLeft +\n textBB.right * toRight\n );\n var textY = (textBB.top + textBB.bottom) / 2;\n var targetX = (\n (x0 + TEXTPAD) * toLeft +\n (x1 - TEXTPAD) * toRight\n );\n var targetY = (y0 + y1) / 2;\n var anchorX = 0;\n var anchorY = 0;\n if(isStart || isEnd) {\n var extrapad = (isHorizontal ? t.x : t.y) / 2;\n var dir = isHorizontal ? dirSign(x0, x1) : dirSign(y0, y1);\n\n if(isHorizontal) {\n if(isStart) {\n targetX = x0 + dir * textpad;\n anchorX = -dir * extrapad;\n } else {\n targetX = x1 - dir * textpad;\n anchorX = dir * extrapad;\n }\n } else {\n if(isStart) {\n targetY = y0 + dir * textpad;\n anchorY = -dir * extrapad;\n } else {\n targetY = y1 - dir * textpad;\n anchorY = dir * extrapad;\n }\n }\n }\n\n return {\n textX: textX,\n textY: textY,\n targetX: targetX,\n targetY: targetY,\n anchorX: anchorX,\n anchorY: anchorY,\n scale: scale,\n rotate: rotate\n };\n}\n\nfunction toMoveOutsideBar(x0, x1, y0, y1, textBB, opts) {\n var isHorizontal = !!opts.isHorizontal;\n var constrained = !!opts.constrained;\n var angle = opts.angle || 0;\n\n var textWidth = textBB.width;\n var textHeight = textBB.height;\n var lx = Math.abs(x1 - x0);\n var ly = Math.abs(y1 - y0);\n\n var textpad;\n // Keep the padding so the text doesn't sit right against\n // the bars, but don't factor it into barWidth\n if(isHorizontal) {\n textpad = (ly > 2 * TEXTPAD) ? TEXTPAD : 0;\n } else {\n textpad = (lx > 2 * TEXTPAD) ? TEXTPAD : 0;\n }\n\n // compute rotate and scale\n var scale = 1;\n if(constrained) {\n scale = (isHorizontal) ?\n Math.min(1, ly / textHeight) :\n Math.min(1, lx / textWidth);\n }\n\n var rotate = getRotateFromAngle(angle);\n var t = getRotatedTextSize(textBB, rotate);\n\n // compute text and target positions\n var extrapad = (isHorizontal ? t.x : t.y) / 2;\n var textX = (textBB.left + textBB.right) / 2;\n var textY = (textBB.top + textBB.bottom) / 2;\n var targetX = (x0 + x1) / 2;\n var targetY = (y0 + y1) / 2;\n var anchorX = 0;\n var anchorY = 0;\n\n var dir = isHorizontal ? dirSign(x1, x0) : dirSign(y0, y1);\n if(isHorizontal) {\n targetX = x1 - dir * textpad;\n anchorX = dir * extrapad;\n } else {\n targetY = y1 + dir * textpad;\n anchorY = -dir * extrapad;\n }\n\n return {\n textX: textX,\n textY: textY,\n targetX: targetX,\n targetY: targetY,\n anchorX: anchorX,\n anchorY: anchorY,\n scale: scale,\n rotate: rotate\n };\n}\n\nfunction getText(fullLayout, cd, index, xa, ya) {\n var trace = cd[0].trace;\n var texttemplate = trace.texttemplate;\n\n var value;\n if(texttemplate) {\n value = calcTexttemplate(fullLayout, cd, index, xa, ya);\n } else if(trace.textinfo) {\n value = calcTextinfo(cd, index, xa, ya);\n } else {\n value = helpers.getValue(trace.text, index);\n }\n\n return helpers.coerceString(attributeText, value);\n}\n\nfunction getTextPosition(trace, index) {\n var value = helpers.getValue(trace.textposition, index);\n return helpers.coerceEnumerated(attributeTextPosition, value);\n}\n\nfunction calcTexttemplate(fullLayout, cd, index, xa, ya) {\n var trace = cd[0].trace;\n var texttemplate = Lib.castOption(trace, index, 'texttemplate');\n if(!texttemplate) return '';\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n\n var pLetter, pAxis;\n var vLetter, vAxis;\n if(trace.orientation === 'h') {\n pLetter = 'y';\n pAxis = ya;\n vLetter = 'x';\n vAxis = xa;\n } else {\n pLetter = 'x';\n pAxis = xa;\n vLetter = 'y';\n vAxis = ya;\n }\n\n function formatLabel(u) {\n return tickText(pAxis, u, true).text;\n }\n\n function formatNumber(v) {\n return tickText(vAxis, +v, true).text;\n }\n\n var cdi = cd[index];\n var obj = {};\n\n obj.label = cdi.p;\n obj.labelLabel = obj[pLetter + 'Label'] = formatLabel(cdi.p);\n\n var tx = Lib.castOption(trace, cdi.i, 'text');\n if(tx === 0 || tx) obj.text = tx;\n\n obj.value = cdi.s;\n obj.valueLabel = obj[vLetter + 'Label'] = formatNumber(cdi.s);\n\n var pt = {};\n appendArrayPointValue(pt, trace, cdi.i);\n\n if(isWaterfall) {\n obj.delta = +cdi.rawS || cdi.s;\n obj.deltaLabel = formatNumber(obj.delta);\n obj.final = cdi.v;\n obj.finalLabel = formatNumber(obj.final);\n obj.initial = obj.final - obj.delta;\n obj.initialLabel = formatNumber(obj.initial);\n }\n\n if(isFunnel) {\n obj.value = cdi.s;\n obj.valueLabel = formatNumber(obj.value);\n\n obj.percentInitial = cdi.begR;\n obj.percentInitialLabel = Lib.formatPercent(cdi.begR);\n obj.percentPrevious = cdi.difR;\n obj.percentPreviousLabel = Lib.formatPercent(cdi.difR);\n obj.percentTotal = cdi.sumR;\n obj.percenTotalLabel = Lib.formatPercent(cdi.sumR);\n }\n\n var customdata = Lib.castOption(trace, cdi.i, 'customdata');\n if(customdata) obj.customdata = customdata;\n return Lib.texttemplateString(texttemplate, obj, fullLayout._d3locale, pt, obj, trace._meta || {});\n}\n\nfunction calcTextinfo(cd, index, xa, ya) {\n var trace = cd[0].trace;\n var isHorizontal = (trace.orientation === 'h');\n var isWaterfall = (trace.type === 'waterfall');\n var isFunnel = (trace.type === 'funnel');\n\n function formatLabel(u) {\n var pAxis = isHorizontal ? ya : xa;\n return tickText(pAxis, u, true).text;\n }\n\n function formatNumber(v) {\n var sAxis = isHorizontal ? xa : ya;\n return tickText(sAxis, +v, true).text;\n }\n\n var textinfo = trace.textinfo;\n var cdi = cd[index];\n\n var parts = textinfo.split('+');\n var text = [];\n var tx;\n\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n\n if(hasFlag('label')) {\n text.push(formatLabel(cd[index].p));\n }\n\n if(hasFlag('text')) {\n tx = Lib.castOption(trace, cdi.i, 'text');\n if(tx === 0 || tx) text.push(tx);\n }\n\n if(isWaterfall) {\n var delta = +cdi.rawS || cdi.s;\n var final = cdi.v;\n var initial = final - delta;\n\n if(hasFlag('initial')) text.push(formatNumber(initial));\n if(hasFlag('delta')) text.push(formatNumber(delta));\n if(hasFlag('final')) text.push(formatNumber(final));\n }\n\n if(isFunnel) {\n if(hasFlag('value')) text.push(formatNumber(cdi.s));\n\n var nPercent = 0;\n if(hasFlag('percent initial')) nPercent++;\n if(hasFlag('percent previous')) nPercent++;\n if(hasFlag('percent total')) nPercent++;\n\n var hasMultiplePercents = nPercent > 1;\n\n if(hasFlag('percent initial')) {\n tx = Lib.formatPercent(cdi.begR);\n if(hasMultiplePercents) tx += ' of initial';\n text.push(tx);\n }\n if(hasFlag('percent previous')) {\n tx = Lib.formatPercent(cdi.difR);\n if(hasMultiplePercents) tx += ' of previous';\n text.push(tx);\n }\n if(hasFlag('percent total')) {\n tx = Lib.formatPercent(cdi.sumR);\n if(hasMultiplePercents) tx += ' of total';\n text.push(tx);\n }\n }\n\n return text.join('
');\n}\n\nmodule.exports = {\n plot: plot,\n toMoveInsideBar: toMoveInsideBar\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Lib = require('../../lib');\nvar Events = require('../../lib/events');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar overrideCursor = require('../../lib/override_cursor');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar dragElement = require('../dragelement');\nvar Axes = require('../../plots/cartesian/axes');\nvar Registry = require('../../registry');\n\nvar helpers = require('./helpers');\nvar constants = require('./constants');\n\nvar legendSupplyDefaults = require('../legend/defaults');\nvar legendDraw = require('../legend/draw');\n\n// hover labels for multiple horizontal bars get tilted by some angle,\n// then need to be offset differently if they overlap\nvar YANGLE = constants.YANGLE;\nvar YA_RADIANS = Math.PI * YANGLE / 180;\n\n// expansion of projected height\nvar YFACTOR = 1 / Math.sin(YA_RADIANS);\n\n// to make the appropriate post-rotation x offset,\n// you need both x and y offsets\nvar YSHIFTX = Math.cos(YA_RADIANS);\nvar YSHIFTY = Math.sin(YA_RADIANS);\n\n// size and display constants for hover text\nvar HOVERARROWSIZE = constants.HOVERARROWSIZE;\nvar HOVERTEXTPAD = constants.HOVERTEXTPAD;\n\n// fx.hover: highlight data on hover\n// evt can be a mousemove event, or an object with data about what points\n// to hover on\n// {xpx,ypx[,hovermode]} - pixel locations from top left\n// (with optional overriding hovermode)\n// {xval,yval[,hovermode]} - data values\n// [{curveNumber,(pointNumber|xval and/or yval)}] -\n// array of specific points to highlight\n// pointNumber is a single integer if gd.data[curveNumber] is 1D,\n// or a two-element array if it's 2D\n// xval and yval are data values,\n// 1D data may specify either or both,\n// 2D data must specify both\n// subplot is an id string (default \"xy\")\n// makes use of gl.hovermode, which can be:\n// x (find the points with the closest x values, ie a column),\n// closest (find the single closest point)\n// internally there are two more that occasionally get used:\n// y (pick out a row - only used for multiple horizontal bar charts)\n// array (used when the user specifies an explicit\n// array of points to hover on)\n//\n// We wrap the hovers in a timer, to limit their frequency.\n// The actual rendering is done by private function _hover.\nexports.hover = function hover(gd, evt, subplot, noHoverEvent) {\n gd = Lib.getGraphDiv(gd);\n\n Lib.throttle(\n gd._fullLayout._uid + constants.HOVERID,\n constants.HOVERMINTIME,\n function() { _hover(gd, evt, subplot, noHoverEvent); }\n );\n};\n\n/*\n * Draw a single hover item or an array of hover item in a pre-existing svg container somewhere\n * hoverItem should have keys:\n * - x and y (or x0, x1, y0, and y1):\n * the pixel position to mark, relative to opts.container\n * - xLabel, yLabel, zLabel, text, and name:\n * info to go in the label\n * - color:\n * the background color for the label.\n * - idealAlign (optional):\n * 'left' or 'right' for which side of the x/y box to try to put this on first\n * - borderColor (optional):\n * color for the border, defaults to strongest contrast with color\n * - fontFamily (optional):\n * string, the font for this label, defaults to constants.HOVERFONT\n * - fontSize (optional):\n * the label font size, defaults to constants.HOVERFONTSIZE\n * - fontColor (optional):\n * defaults to borderColor\n * opts should have keys:\n * - bgColor:\n * the background color this is against, used if the trace is\n * non-opaque, and for the name, which goes outside the box\n * - container:\n * a or element to add the hover label to\n * - outerContainer:\n * normally a parent of `container`, sets the bounding box to use to\n * constrain the hover label and determine whether to show it on the left or right\n * opts can have optional keys:\n * - anchorIndex:\n the index of the hover item used as an anchor for positioning.\n The other hover items will be pushed up or down to prevent overlap.\n */\nexports.loneHover = function loneHover(hoverItems, opts) {\n var multiHover = true;\n if(!Array.isArray(hoverItems)) {\n multiHover = false;\n hoverItems = [hoverItems];\n }\n\n var pointsData = hoverItems.map(function(hoverItem) {\n return {\n color: hoverItem.color || Color.defaultLine,\n x0: hoverItem.x0 || hoverItem.x || 0,\n x1: hoverItem.x1 || hoverItem.x || 0,\n y0: hoverItem.y0 || hoverItem.y || 0,\n y1: hoverItem.y1 || hoverItem.y || 0,\n xLabel: hoverItem.xLabel,\n yLabel: hoverItem.yLabel,\n zLabel: hoverItem.zLabel,\n text: hoverItem.text,\n name: hoverItem.name,\n idealAlign: hoverItem.idealAlign,\n\n // optional extra bits of styling\n borderColor: hoverItem.borderColor,\n fontFamily: hoverItem.fontFamily,\n fontSize: hoverItem.fontSize,\n fontColor: hoverItem.fontColor,\n nameLength: hoverItem.nameLength,\n textAlign: hoverItem.textAlign,\n\n // filler to make createHoverText happy\n trace: hoverItem.trace || {\n index: 0,\n hoverinfo: ''\n },\n xa: {_offset: 0},\n ya: {_offset: 0},\n index: 0,\n\n hovertemplate: hoverItem.hovertemplate || false,\n eventData: hoverItem.eventData || false,\n hovertemplateLabels: hoverItem.hovertemplateLabels || false,\n };\n });\n\n var container3 = d3.select(opts.container);\n var outerContainer3 = opts.outerContainer ? d3.select(opts.outerContainer) : container3;\n\n var fullOpts = {\n hovermode: 'closest',\n rotateLabels: false,\n bgColor: opts.bgColor || Color.background,\n container: container3,\n outerContainer: outerContainer3\n };\n\n var hoverLabel = createHoverText(pointsData, fullOpts, opts.gd);\n\n // Fix vertical overlap\n var tooltipSpacing = 5;\n var lastBottomY = 0;\n var anchor = 0;\n hoverLabel\n .sort(function(a, b) {return a.y0 - b.y0;})\n .each(function(d, i) {\n var topY = d.y0 - d.by / 2;\n\n if((topY - tooltipSpacing) < lastBottomY) {\n d.offset = (lastBottomY - topY) + tooltipSpacing;\n } else {\n d.offset = 0;\n }\n\n lastBottomY = topY + d.by + d.offset;\n\n if(i === opts.anchorIndex || 0) anchor = d.offset;\n })\n .each(function(d) {\n d.offset -= anchor;\n });\n\n alignHoverText(hoverLabel, fullOpts.rotateLabels);\n\n return multiHover ? hoverLabel : hoverLabel.node();\n};\n\n// The actual implementation is here:\nfunction _hover(gd, evt, subplot, noHoverEvent) {\n if(!subplot) subplot = 'xy';\n\n // if the user passed in an array of subplots,\n // use those instead of finding overlayed plots\n var subplots = Array.isArray(subplot) ? subplot : [subplot];\n\n var fullLayout = gd._fullLayout;\n var plots = fullLayout._plots || [];\n var plotinfo = plots[subplot];\n var hasCartesian = fullLayout._has('cartesian');\n\n // list of all overlaid subplots to look at\n if(plotinfo) {\n var overlayedSubplots = plotinfo.overlays.map(function(pi) {\n return pi.id;\n });\n\n subplots = subplots.concat(overlayedSubplots);\n }\n\n var len = subplots.length;\n var xaArray = new Array(len);\n var yaArray = new Array(len);\n var supportsCompare = false;\n\n for(var i = 0; i < len; i++) {\n var spId = subplots[i];\n\n if(plots[spId]) {\n // 'cartesian' case\n supportsCompare = true;\n xaArray[i] = plots[spId].xaxis;\n yaArray[i] = plots[spId].yaxis;\n } else if(fullLayout[spId] && fullLayout[spId]._subplot) {\n // other subplot types\n var _subplot = fullLayout[spId]._subplot;\n xaArray[i] = _subplot.xaxis;\n yaArray[i] = _subplot.yaxis;\n } else {\n Lib.warn('Unrecognized subplot: ' + spId);\n return;\n }\n }\n\n var hovermode = evt.hovermode || fullLayout.hovermode;\n\n if(hovermode && !supportsCompare) hovermode = 'closest';\n\n if(['x', 'y', 'closest', 'x unified', 'y unified'].indexOf(hovermode) === -1 || !gd.calcdata ||\n gd.querySelector('.zoombox') || gd._dragging) {\n return dragElement.unhoverRaw(gd, evt);\n }\n\n var hoverdistance = fullLayout.hoverdistance === -1 ? Infinity : fullLayout.hoverdistance;\n var spikedistance = fullLayout.spikedistance === -1 ? Infinity : fullLayout.spikedistance;\n\n // hoverData: the set of candidate points we've found to highlight\n var hoverData = [];\n\n // searchData: the data to search in. Mostly this is just a copy of\n // gd.calcdata, filtered to the subplot and overlays we're on\n // but if a point array is supplied it will be a mapping\n // of indicated curves\n var searchData = [];\n\n // [x|y]valArray: the axis values of the hover event\n // mapped onto each of the currently selected overlaid subplots\n var xvalArray, yvalArray;\n\n var itemnum, curvenum, cd, trace, subplotId, subploti, mode,\n xval, yval, pointData, closedataPreviousLength;\n\n // spikePoints: the set of candidate points we've found to draw spikes to\n var spikePoints = {\n hLinePoint: null,\n vLinePoint: null\n };\n\n // does subplot have one (or more) horizontal traces?\n // This is used to determine whether we rotate the labels or not\n var hasOneHorizontalTrace = false;\n\n // Figure out what we're hovering on:\n // mouse location or user-supplied data\n\n if(Array.isArray(evt)) {\n // user specified an array of points to highlight\n hovermode = 'array';\n for(itemnum = 0; itemnum < evt.length; itemnum++) {\n cd = gd.calcdata[evt[itemnum].curveNumber || 0];\n if(cd) {\n trace = cd[0].trace;\n if(cd[0].trace.hoverinfo !== 'skip') {\n searchData.push(cd);\n if(trace.orientation === 'h') {\n hasOneHorizontalTrace = true;\n }\n }\n }\n }\n } else {\n for(curvenum = 0; curvenum < gd.calcdata.length; curvenum++) {\n cd = gd.calcdata[curvenum];\n trace = cd[0].trace;\n if(trace.hoverinfo !== 'skip' && helpers.isTraceInSubplots(trace, subplots)) {\n searchData.push(cd);\n if(trace.orientation === 'h') {\n hasOneHorizontalTrace = true;\n }\n }\n }\n\n // [x|y]px: the pixels (from top left) of the mouse location\n // on the currently selected plot area\n // add pointerX|Y property for drawing the spikes in spikesnap 'cursor' situation\n var hasUserCalledHover = !evt.target;\n var xpx, ypx;\n\n if(hasUserCalledHover) {\n if('xpx' in evt) xpx = evt.xpx;\n else xpx = xaArray[0]._length / 2;\n\n if('ypx' in evt) ypx = evt.ypx;\n else ypx = yaArray[0]._length / 2;\n } else {\n // fire the beforehover event and quit if it returns false\n // note that we're only calling this on real mouse events, so\n // manual calls to fx.hover will always run.\n if(Events.triggerHandler(gd, 'plotly_beforehover', evt) === false) {\n return;\n }\n\n var dbb = evt.target.getBoundingClientRect();\n\n xpx = evt.clientX - dbb.left;\n ypx = evt.clientY - dbb.top;\n\n // in case hover was called from mouseout into hovertext,\n // it's possible you're not actually over the plot anymore\n if(xpx < 0 || xpx > xaArray[0]._length || ypx < 0 || ypx > yaArray[0]._length) {\n return dragElement.unhoverRaw(gd, evt);\n }\n }\n\n evt.pointerX = xpx + xaArray[0]._offset;\n evt.pointerY = ypx + yaArray[0]._offset;\n\n if('xval' in evt) xvalArray = helpers.flat(subplots, evt.xval);\n else xvalArray = helpers.p2c(xaArray, xpx);\n\n if('yval' in evt) yvalArray = helpers.flat(subplots, evt.yval);\n else yvalArray = helpers.p2c(yaArray, ypx);\n\n if(!isNumeric(xvalArray[0]) || !isNumeric(yvalArray[0])) {\n Lib.warn('Fx.hover failed', evt, gd);\n return dragElement.unhoverRaw(gd, evt);\n }\n }\n\n // the pixel distance to beat as a matching point\n // in 'x' or 'y' mode this resets for each trace\n var distance = Infinity;\n\n // find the closest point in each trace\n // this is minimum dx and/or dy, depending on mode\n // and the pixel position for the label (labelXpx, labelYpx)\n function findHoverPoints(customXVal, customYVal) {\n for(curvenum = 0; curvenum < searchData.length; curvenum++) {\n cd = searchData[curvenum];\n\n // filter out invisible or broken data\n if(!cd || !cd[0] || !cd[0].trace) continue;\n\n trace = cd[0].trace;\n\n if(trace.visible !== true || trace._length === 0) continue;\n\n // Explicitly bail out for these two. I don't know how to otherwise prevent\n // the rest of this function from running and failing\n if(['carpet', 'contourcarpet'].indexOf(trace._module.name) !== -1) continue;\n\n if(trace.type === 'splom') {\n // splom traces do not generate overlay subplots,\n // it is safe to assume here splom traces correspond to the 0th subplot\n subploti = 0;\n subplotId = subplots[subploti];\n } else {\n subplotId = helpers.getSubplot(trace);\n subploti = subplots.indexOf(subplotId);\n }\n\n // within one trace mode can sometimes be overridden\n mode = hovermode;\n if(helpers.isUnifiedHover(mode)) {\n mode = mode.charAt(0);\n }\n\n // container for new point, also used to pass info into module.hoverPoints\n pointData = {\n // trace properties\n cd: cd,\n trace: trace,\n xa: xaArray[subploti],\n ya: yaArray[subploti],\n\n // max distances for hover and spikes - for points that want to show but do not\n // want to override other points, set distance/spikeDistance equal to max*Distance\n // and it will not get filtered out but it will be guaranteed to have a greater\n // distance than any point that calculated a real distance.\n maxHoverDistance: hoverdistance,\n maxSpikeDistance: spikedistance,\n\n // point properties - override all of these\n index: false, // point index in trace - only used by plotly.js hoverdata consumers\n distance: Math.min(distance, hoverdistance), // pixel distance or pseudo-distance\n\n // distance/pseudo-distance for spikes. This distance should always be calculated\n // as if in \"closest\" mode, and should only be set if this point should\n // generate a spike.\n spikeDistance: Infinity,\n\n // in some cases the spikes have different positioning from the hover label\n // they don't need x0/x1, just one position\n xSpike: undefined,\n ySpike: undefined,\n\n // where and how to display the hover label\n color: Color.defaultLine, // trace color\n name: trace.name,\n x0: undefined,\n x1: undefined,\n y0: undefined,\n y1: undefined,\n xLabelVal: undefined,\n yLabelVal: undefined,\n zLabelVal: undefined,\n text: undefined\n };\n\n // add ref to subplot object (non-cartesian case)\n if(fullLayout[subplotId]) {\n pointData.subplot = fullLayout[subplotId]._subplot;\n }\n // add ref to splom scene\n if(fullLayout._splomScenes && fullLayout._splomScenes[trace.uid]) {\n pointData.scene = fullLayout._splomScenes[trace.uid];\n }\n\n closedataPreviousLength = hoverData.length;\n\n // for a highlighting array, figure out what\n // we're searching for with this element\n if(mode === 'array') {\n var selection = evt[curvenum];\n if('pointNumber' in selection) {\n pointData.index = selection.pointNumber;\n mode = 'closest';\n } else {\n mode = '';\n if('xval' in selection) {\n xval = selection.xval;\n mode = 'x';\n }\n if('yval' in selection) {\n yval = selection.yval;\n mode = mode ? 'closest' : 'y';\n }\n }\n } else if(customXVal !== undefined && customYVal !== undefined) {\n xval = customXVal;\n yval = customYVal;\n } else {\n xval = xvalArray[subploti];\n yval = yvalArray[subploti];\n }\n\n // Now if there is range to look in, find the points to hover.\n if(hoverdistance !== 0) {\n if(trace._module && trace._module.hoverPoints) {\n var newPoints = trace._module.hoverPoints(pointData, xval, yval, mode, fullLayout._hoverlayer);\n if(newPoints) {\n var newPoint;\n for(var newPointNum = 0; newPointNum < newPoints.length; newPointNum++) {\n newPoint = newPoints[newPointNum];\n if(isNumeric(newPoint.x0) && isNumeric(newPoint.y0)) {\n hoverData.push(cleanPoint(newPoint, hovermode));\n }\n }\n }\n } else {\n Lib.log('Unrecognized trace type in hover:', trace);\n }\n }\n\n // in closest mode, remove any existing (farther) points\n // and don't look any farther than this latest point (or points, some\n // traces like box & violin make multiple hover labels at once)\n if(hovermode === 'closest' && hoverData.length > closedataPreviousLength) {\n hoverData.splice(0, closedataPreviousLength);\n distance = hoverData[0].distance;\n }\n\n // Now if there is range to look in, find the points to draw the spikelines\n // Do it only if there is no hoverData\n if(hasCartesian && (spikedistance !== 0)) {\n if(hoverData.length === 0) {\n pointData.distance = spikedistance;\n pointData.index = false;\n var closestPoints = trace._module.hoverPoints(pointData, xval, yval, 'closest', fullLayout._hoverlayer);\n if(closestPoints) {\n closestPoints = closestPoints.filter(function(point) {\n // some hover points, like scatter fills, do not allow spikes,\n // so will generate a hover point but without a valid spikeDistance\n return point.spikeDistance <= spikedistance;\n });\n }\n if(closestPoints && closestPoints.length) {\n var tmpPoint;\n var closestVPoints = closestPoints.filter(function(point) {\n return point.xa.showspikes && point.xa.spikesnap !== 'hovered data';\n });\n if(closestVPoints.length) {\n var closestVPt = closestVPoints[0];\n if(isNumeric(closestVPt.x0) && isNumeric(closestVPt.y0)) {\n tmpPoint = fillSpikePoint(closestVPt);\n if(!spikePoints.vLinePoint || (spikePoints.vLinePoint.spikeDistance > tmpPoint.spikeDistance)) {\n spikePoints.vLinePoint = tmpPoint;\n }\n }\n }\n\n var closestHPoints = closestPoints.filter(function(point) {\n return point.ya.showspikes && point.ya.spikesnap !== 'hovered data';\n });\n if(closestHPoints.length) {\n var closestHPt = closestHPoints[0];\n if(isNumeric(closestHPt.x0) && isNumeric(closestHPt.y0)) {\n tmpPoint = fillSpikePoint(closestHPt);\n if(!spikePoints.hLinePoint || (spikePoints.hLinePoint.spikeDistance > tmpPoint.spikeDistance)) {\n spikePoints.hLinePoint = tmpPoint;\n }\n }\n }\n }\n }\n }\n }\n }\n\n findHoverPoints();\n\n function selectClosestPoint(pointsData, spikedistance) {\n var resultPoint = null;\n var minDistance = Infinity;\n var thisSpikeDistance;\n for(var i = 0; i < pointsData.length; i++) {\n thisSpikeDistance = pointsData[i].spikeDistance;\n if(thisSpikeDistance <= minDistance && thisSpikeDistance <= spikedistance) {\n resultPoint = pointsData[i];\n minDistance = thisSpikeDistance;\n }\n }\n return resultPoint;\n }\n\n function fillSpikePoint(point) {\n if(!point) return null;\n return {\n xa: point.xa,\n ya: point.ya,\n x: point.xSpike !== undefined ? point.xSpike : (point.x0 + point.x1) / 2,\n y: point.ySpike !== undefined ? point.ySpike : (point.y0 + point.y1) / 2,\n distance: point.distance,\n spikeDistance: point.spikeDistance,\n curveNumber: point.trace.index,\n color: point.color,\n pointNumber: point.index\n };\n }\n\n var spikelineOpts = {\n fullLayout: fullLayout,\n container: fullLayout._hoverlayer,\n outerContainer: fullLayout._paperdiv,\n event: evt\n };\n var oldspikepoints = gd._spikepoints;\n var newspikepoints = {\n vLinePoint: spikePoints.vLinePoint,\n hLinePoint: spikePoints.hLinePoint\n };\n gd._spikepoints = newspikepoints;\n\n // Now if it is not restricted by spikedistance option, set the points to draw the spikelines\n if(hasCartesian && (spikedistance !== 0)) {\n if(hoverData.length !== 0) {\n var tmpHPointData = hoverData.filter(function(point) {\n return point.ya.showspikes;\n });\n var tmpHPoint = selectClosestPoint(tmpHPointData, spikedistance);\n spikePoints.hLinePoint = fillSpikePoint(tmpHPoint);\n\n var tmpVPointData = hoverData.filter(function(point) {\n return point.xa.showspikes;\n });\n var tmpVPoint = selectClosestPoint(tmpVPointData, spikedistance);\n spikePoints.vLinePoint = fillSpikePoint(tmpVPoint);\n }\n }\n\n // if hoverData is empty check for the spikes to draw and quit if there are none\n if(hoverData.length === 0) {\n var result = dragElement.unhoverRaw(gd, evt);\n if(hasCartesian && ((spikePoints.hLinePoint !== null) || (spikePoints.vLinePoint !== null))) {\n if(spikesChanged(oldspikepoints)) {\n createSpikelines(gd, spikePoints, spikelineOpts);\n }\n }\n return result;\n }\n\n if(hasCartesian) {\n if(spikesChanged(oldspikepoints)) {\n createSpikelines(gd, spikePoints, spikelineOpts);\n }\n }\n\n hoverData.sort(function(d1, d2) { return d1.distance - d2.distance; });\n\n // If in compare mode, select every point at position\n if(\n helpers.isXYhover(mode) &&\n hoverData[0].length !== 0 &&\n hoverData[0].trace.type !== 'splom' // TODO: add support for splom\n ) {\n var hd = hoverData[0];\n var cd0 = hd.cd[hd.index];\n var isGrouped = (fullLayout.boxmode === 'group' || fullLayout.violinmode === 'group');\n\n var xVal = hd.xVal;\n var ax = hd.xa;\n if(ax.type === 'category') xVal = ax._categoriesMap[xVal];\n if(ax.type === 'date') xVal = ax.d2c(xVal);\n if(cd0 && cd0.t && cd0.t.posLetter === ax._id && isGrouped) {\n xVal += cd0.t.dPos;\n }\n\n var yVal = hd.yVal;\n ax = hd.ya;\n if(ax.type === 'category') yVal = ax._categoriesMap[yVal];\n if(ax.type === 'date') yVal = ax.d2c(yVal);\n if(cd0 && cd0.t && cd0.t.posLetter === ax._id && isGrouped) {\n yVal += cd0.t.dPos;\n }\n\n findHoverPoints(xVal, yVal);\n\n // Remove duplicated hoverData points\n // note that d3 also filters identical points in the rendering steps\n var repeated = {};\n hoverData = hoverData.filter(function(hd) {\n var key = hoverDataKey(hd);\n if(!repeated[key]) {\n repeated[key] = true;\n return repeated[key];\n }\n });\n }\n\n // lastly, emit custom hover/unhover events\n var oldhoverdata = gd._hoverdata;\n var newhoverdata = [];\n\n // pull out just the data that's useful to\n // other people and send it to the event\n for(itemnum = 0; itemnum < hoverData.length; itemnum++) {\n var pt = hoverData[itemnum];\n var eventData = helpers.makeEventData(pt, pt.trace, pt.cd);\n\n if(pt.hovertemplate !== false) {\n var ht = false;\n if(pt.cd[pt.index] && pt.cd[pt.index].ht) {\n ht = pt.cd[pt.index].ht;\n }\n pt.hovertemplate = ht || pt.trace.hovertemplate || false;\n }\n\n pt.eventData = [eventData];\n newhoverdata.push(eventData);\n }\n\n gd._hoverdata = newhoverdata;\n\n var rotateLabels = (\n (hovermode === 'y' && (searchData.length > 1 || hoverData.length > 1)) ||\n (hovermode === 'closest' && hasOneHorizontalTrace && hoverData.length > 1)\n );\n\n var bgColor = Color.combine(\n fullLayout.plot_bgcolor || Color.background,\n fullLayout.paper_bgcolor\n );\n\n var labelOpts = {\n hovermode: hovermode,\n rotateLabels: rotateLabels,\n bgColor: bgColor,\n container: fullLayout._hoverlayer,\n outerContainer: fullLayout._paperdiv,\n commonLabelOpts: fullLayout.hoverlabel,\n hoverdistance: fullLayout.hoverdistance\n };\n\n var hoverLabels = createHoverText(hoverData, labelOpts, gd);\n\n if(!helpers.isUnifiedHover(hovermode)) {\n hoverAvoidOverlaps(hoverLabels, rotateLabels ? 'xa' : 'ya', fullLayout);\n alignHoverText(hoverLabels, rotateLabels);\n }\n\n // TODO: tagName hack is needed to appease geo.js's hack of using evt.target=true\n // we should improve the \"fx\" API so other plots can use it without these hack.\n if(evt.target && evt.target.tagName) {\n var hasClickToShow = Registry.getComponentMethod('annotations', 'hasClickToShow')(gd, newhoverdata);\n overrideCursor(d3.select(evt.target), hasClickToShow ? 'pointer' : '');\n }\n\n // don't emit events if called manually\n if(!evt.target || noHoverEvent || !hoverChanged(gd, evt, oldhoverdata)) return;\n\n if(oldhoverdata) {\n gd.emit('plotly_unhover', {\n event: evt,\n points: oldhoverdata\n });\n }\n\n gd.emit('plotly_hover', {\n event: evt,\n points: gd._hoverdata,\n xaxes: xaArray,\n yaxes: yaArray,\n xvals: xvalArray,\n yvals: yvalArray\n });\n}\n\nfunction hoverDataKey(d) {\n return [d.trace.index, d.index, d.x0, d.y0, d.name, d.attr, d.xa, d.ya || ''].join(',');\n}\n\nvar EXTRA_STRING_REGEX = /([\\s\\S]*)<\\/extra>/;\n\nfunction createHoverText(hoverData, opts, gd) {\n var fullLayout = gd._fullLayout;\n var hovermode = opts.hovermode;\n var rotateLabels = opts.rotateLabels;\n var bgColor = opts.bgColor;\n var container = opts.container;\n var outerContainer = opts.outerContainer;\n var commonLabelOpts = opts.commonLabelOpts || {};\n\n // opts.fontFamily/Size are used for the common label\n // and as defaults for each hover label, though the individual labels\n // can override this.\n var fontFamily = opts.fontFamily || constants.HOVERFONT;\n var fontSize = opts.fontSize || constants.HOVERFONTSIZE;\n\n var c0 = hoverData[0];\n var xa = c0.xa;\n var ya = c0.ya;\n var commonAttr = hovermode.charAt(0) === 'y' ? 'yLabel' : 'xLabel';\n var t0 = c0[commonAttr];\n var t00 = (String(t0) || '').split(' ')[0];\n var outerContainerBB = outerContainer.node().getBoundingClientRect();\n var outerTop = outerContainerBB.top;\n var outerWidth = outerContainerBB.width;\n var outerHeight = outerContainerBB.height;\n\n // show the common label, if any, on the axis\n // never show a common label in array mode,\n // even if sometimes there could be one\n var showCommonLabel = (\n (t0 !== undefined) &&\n (c0.distance <= opts.hoverdistance) &&\n (hovermode === 'x' || hovermode === 'y')\n );\n\n // all hover traces hoverinfo must contain the hovermode\n // to have common labels\n if(showCommonLabel) {\n var allHaveZ = true;\n var i, traceHoverinfo;\n for(i = 0; i < hoverData.length; i++) {\n if(allHaveZ && hoverData[i].zLabel === undefined) allHaveZ = false;\n\n traceHoverinfo = hoverData[i].hoverinfo || hoverData[i].trace.hoverinfo;\n if(traceHoverinfo) {\n var parts = Array.isArray(traceHoverinfo) ? traceHoverinfo : traceHoverinfo.split('+');\n if(parts.indexOf('all') === -1 &&\n parts.indexOf(hovermode) === -1) {\n showCommonLabel = false;\n break;\n }\n }\n }\n\n // xyz labels put all info in their main label, so have no need of a common label\n if(allHaveZ) showCommonLabel = false;\n }\n\n var commonLabel = container.selectAll('g.axistext')\n .data(showCommonLabel ? [0] : []);\n commonLabel.enter().append('g')\n .classed('axistext', true);\n commonLabel.exit().remove();\n\n commonLabel.each(function() {\n var label = d3.select(this);\n var lpath = Lib.ensureSingle(label, 'path', '', function(s) {\n s.style({'stroke-width': '1px'});\n });\n var ltext = Lib.ensureSingle(label, 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var commonBgColor = commonLabelOpts.bgcolor || Color.defaultLine;\n var commonStroke = commonLabelOpts.bordercolor || Color.contrast(commonBgColor);\n var contrastColor = Color.contrast(commonBgColor);\n var commonLabelFont = {\n family: commonLabelOpts.font.family || fontFamily,\n size: commonLabelOpts.font.size || fontSize,\n color: commonLabelOpts.font.color || contrastColor\n };\n\n lpath.style({\n fill: commonBgColor,\n stroke: commonStroke\n });\n\n ltext.text(t0)\n .call(Drawing.font, commonLabelFont)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n label.attr('transform', '');\n\n var tbb = ltext.node().getBoundingClientRect();\n var lx, ly;\n\n if(hovermode === 'x') {\n var topsign = xa.side === 'top' ? '-' : '';\n\n ltext.attr('text-anchor', 'middle')\n .call(svgTextUtils.positionText, 0, (xa.side === 'top' ?\n (outerTop - tbb.bottom - HOVERARROWSIZE - HOVERTEXTPAD) :\n (outerTop - tbb.top + HOVERARROWSIZE + HOVERTEXTPAD)));\n\n lx = xa._offset + (c0.x0 + c0.x1) / 2;\n ly = ya._offset + (xa.side === 'top' ? 0 : ya._length);\n\n var halfWidth = tbb.width / 2 + HOVERTEXTPAD;\n\n if(lx < halfWidth) {\n lx = halfWidth;\n\n lpath.attr('d', 'M-' + (halfWidth - HOVERARROWSIZE) + ',0' +\n 'L-' + (halfWidth - HOVERARROWSIZE * 2) + ',' + topsign + HOVERARROWSIZE +\n 'H' + (HOVERTEXTPAD + tbb.width / 2) +\n 'v' + topsign + (HOVERTEXTPAD * 2 + tbb.height) +\n 'H-' + halfWidth +\n 'V' + topsign + HOVERARROWSIZE +\n 'Z');\n } else if(lx > (fullLayout.width - halfWidth)) {\n lx = fullLayout.width - halfWidth;\n\n lpath.attr('d', 'M' + (halfWidth - HOVERARROWSIZE) + ',0' +\n 'L' + halfWidth + ',' + topsign + HOVERARROWSIZE +\n 'v' + topsign + (HOVERTEXTPAD * 2 + tbb.height) +\n 'H-' + halfWidth +\n 'V' + topsign + HOVERARROWSIZE +\n 'H' + (halfWidth - HOVERARROWSIZE * 2) + 'Z');\n } else {\n lpath.attr('d', 'M0,0' +\n 'L' + HOVERARROWSIZE + ',' + topsign + HOVERARROWSIZE +\n 'H' + (HOVERTEXTPAD + tbb.width / 2) +\n 'v' + topsign + (HOVERTEXTPAD * 2 + tbb.height) +\n 'H-' + (HOVERTEXTPAD + tbb.width / 2) +\n 'V' + topsign + HOVERARROWSIZE +\n 'H-' + HOVERARROWSIZE + 'Z');\n }\n } else {\n var anchor;\n var sgn;\n var leftsign;\n if(ya.side === 'right') {\n anchor = 'start';\n sgn = 1;\n leftsign = '';\n lx = xa._offset + xa._length;\n } else {\n anchor = 'end';\n sgn = -1;\n leftsign = '-';\n lx = xa._offset;\n }\n\n ly = ya._offset + (c0.y0 + c0.y1) / 2;\n\n ltext.attr('text-anchor', anchor);\n\n lpath.attr('d', 'M0,0' +\n 'L' + leftsign + HOVERARROWSIZE + ',' + HOVERARROWSIZE +\n 'V' + (HOVERTEXTPAD + tbb.height / 2) +\n 'h' + leftsign + (HOVERTEXTPAD * 2 + tbb.width) +\n 'V-' + (HOVERTEXTPAD + tbb.height / 2) +\n 'H' + leftsign + HOVERARROWSIZE + 'V-' + HOVERARROWSIZE + 'Z');\n\n var halfHeight = tbb.height / 2;\n var lty = outerTop - tbb.top - halfHeight;\n var clipId = 'clip' + fullLayout._uid + 'commonlabel' + ya._id;\n var clipPath;\n\n if(lx < (tbb.width + 2 * HOVERTEXTPAD + HOVERARROWSIZE)) {\n clipPath = 'M-' + (HOVERARROWSIZE + HOVERTEXTPAD) + '-' + halfHeight +\n 'h-' + (tbb.width - HOVERTEXTPAD) +\n 'V' + halfHeight +\n 'h' + (tbb.width - HOVERTEXTPAD) + 'Z';\n\n var ltx = tbb.width - lx + HOVERTEXTPAD;\n svgTextUtils.positionText(ltext, ltx, lty);\n\n // shift each line (except the longest) so that start-of-line\n // is always visible\n if(anchor === 'end') {\n ltext.selectAll('tspan').each(function() {\n var s = d3.select(this);\n var dummy = Drawing.tester.append('text')\n .text(s.text())\n .call(Drawing.font, commonLabelFont);\n var dummyBB = dummy.node().getBoundingClientRect();\n if(Math.round(dummyBB.width) < Math.round(tbb.width)) {\n s.attr('x', ltx - dummyBB.width);\n }\n dummy.remove();\n });\n }\n } else {\n svgTextUtils.positionText(ltext, sgn * (HOVERTEXTPAD + HOVERARROWSIZE), lty);\n clipPath = null;\n }\n\n var textClip = fullLayout._topclips.selectAll('#' + clipId).data(clipPath ? [0] : []);\n textClip.enter().append('clipPath').attr('id', clipId).append('path');\n textClip.exit().remove();\n textClip.select('path').attr('d', clipPath);\n Drawing.setClipUrl(ltext, clipPath ? clipId : null, gd);\n }\n\n label.attr('transform', 'translate(' + lx + ',' + ly + ')');\n\n // remove the \"close but not quite\" points\n // because of error bars, only take up to a space\n hoverData = filterClosePoints(hoverData);\n });\n\n function filterClosePoints(hoverData) {\n return hoverData.filter(function(d) {\n return (d.zLabelVal !== undefined) ||\n (d[commonAttr] || '').split(' ')[0] === t00;\n });\n }\n\n // Show a single hover label\n if(helpers.isUnifiedHover(hovermode)) {\n // Delete leftover hover labels from other hovermodes\n container.selectAll('g.hovertext').remove();\n\n // similarly to compare mode, we remove the \"close but not quite together\" points\n if((t0 !== undefined) && (c0.distance <= opts.hoverdistance)) hoverData = filterClosePoints(hoverData);\n\n // Return early if nothing is hovered on\n if(hoverData.length === 0) return;\n\n // mock legend\n var mockLayoutIn = {\n showlegend: true,\n legend: {\n title: {text: t0, font: fullLayout.hoverlabel.font},\n font: fullLayout.hoverlabel.font,\n bgcolor: fullLayout.hoverlabel.bgcolor,\n bordercolor: fullLayout.hoverlabel.bordercolor,\n borderwidth: 1,\n tracegroupgap: 7,\n traceorder: fullLayout.legend ? fullLayout.legend.traceorder : undefined,\n orientation: 'v'\n }\n };\n var mockLayoutOut = {};\n legendSupplyDefaults(mockLayoutIn, mockLayoutOut, gd._fullData);\n var legendOpts = mockLayoutOut.legend;\n\n // prepare items for the legend\n legendOpts.entries = [];\n for(var j = 0; j < hoverData.length; j++) {\n var texts = getHoverLabelText(hoverData[j], true, hovermode, fullLayout, t0);\n var text = texts[0];\n var name = texts[1];\n var pt = hoverData[j];\n pt.name = name;\n if(name !== '') {\n pt.text = name + ' : ' + text;\n } else {\n pt.text = text;\n }\n\n // pass through marker's calcdata to style legend items\n var cd = pt.cd[pt.index];\n if(cd) {\n if(cd.mc) pt.mc = cd.mc;\n if(cd.mcc) pt.mc = cd.mcc;\n if(cd.mlc) pt.mlc = cd.mlc;\n if(cd.mlcc) pt.mlc = cd.mlcc;\n if(cd.mlw) pt.mlw = cd.mlw;\n if(cd.mrc) pt.mrc = cd.mrc;\n if(cd.dir) pt.dir = cd.dir;\n }\n pt._distinct = true;\n\n legendOpts.entries.push([pt]);\n }\n legendOpts.entries.sort(function(a, b) { return a[0].trace.index - b[0].trace.index;});\n legendOpts.layer = container;\n\n // Draw unified hover label\n legendDraw(gd, legendOpts);\n\n // Position the hover\n var ly = Lib.mean(hoverData.map(function(c) {return (c.y0 + c.y1) / 2;}));\n var lx = Lib.mean(hoverData.map(function(c) {return (c.x0 + c.x1) / 2;}));\n var legendContainer = container.select('g.legend');\n var tbb = legendContainer.node().getBoundingClientRect();\n lx += xa._offset;\n ly += ya._offset - tbb.height / 2;\n\n // Change horizontal alignment to end up on screen\n var txWidth = tbb.width + 2 * HOVERTEXTPAD;\n var anchorStartOK = lx + txWidth <= outerWidth;\n var anchorEndOK = lx - txWidth >= 0;\n if(!anchorStartOK && anchorEndOK) {\n lx -= txWidth;\n } else {\n lx += 2 * HOVERTEXTPAD;\n }\n\n // Change vertical alignement to end up on screen\n var txHeight = tbb.height + 2 * HOVERTEXTPAD;\n var overflowTop = ly <= outerTop;\n var overflowBottom = ly + txHeight >= outerHeight;\n var canFit = txHeight <= outerHeight;\n if(canFit) {\n if(overflowTop) {\n ly = ya._offset + 2 * HOVERTEXTPAD;\n } else if(overflowBottom) {\n ly = outerHeight - txHeight;\n }\n }\n legendContainer.attr('transform', 'translate(' + lx + ',' + ly + ')');\n\n return legendContainer;\n }\n\n // show all the individual labels\n\n // first create the objects\n var hoverLabels = container.selectAll('g.hovertext')\n .data(hoverData, function(d) {\n // N.B. when multiple items have the same result key-function value,\n // only the first of those items in hoverData gets rendered\n return hoverDataKey(d);\n });\n hoverLabels.enter().append('g')\n .classed('hovertext', true)\n .each(function() {\n var g = d3.select(this);\n // trace name label (rect and text.name)\n g.append('rect')\n .call(Color.fill, Color.addOpacity(bgColor, 0.8));\n g.append('text').classed('name', true);\n // trace data label (path and text.nums)\n g.append('path')\n .style('stroke-width', '1px');\n g.append('text').classed('nums', true)\n .call(Drawing.font, fontFamily, fontSize);\n });\n hoverLabels.exit().remove();\n\n // then put the text in, position the pointer to the data,\n // and figure out sizes\n hoverLabels.each(function(d) {\n var g = d3.select(this).attr('transform', '');\n\n // combine possible non-opaque trace color with bgColor\n var color0 = d.bgcolor || d.color;\n // color for 'nums' part of the label\n var numsColor = Color.combine(\n Color.opacity(color0) ? color0 : Color.defaultLine,\n bgColor\n );\n // color for 'name' part of the label\n var nameColor = Color.combine(\n Color.opacity(d.color) ? d.color : Color.defaultLine,\n bgColor\n );\n // find a contrasting color for border and text\n var contrastColor = d.borderColor || Color.contrast(numsColor);\n\n var texts = getHoverLabelText(d, showCommonLabel, hovermode, fullLayout, t0, g);\n var text = texts[0];\n var name = texts[1];\n\n // main label\n var tx = g.select('text.nums')\n .call(Drawing.font,\n d.fontFamily || fontFamily,\n d.fontSize || fontSize,\n d.fontColor || contrastColor)\n .text(text)\n .attr('data-notex', 1)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n var tx2 = g.select('text.name');\n var tx2width = 0;\n var tx2height = 0;\n\n // secondary label for non-empty 'name'\n if(name && name !== text) {\n tx2.call(Drawing.font,\n d.fontFamily || fontFamily,\n d.fontSize || fontSize,\n nameColor)\n .text(name)\n .attr('data-notex', 1)\n .call(svgTextUtils.positionText, 0, 0)\n .call(svgTextUtils.convertToTspans, gd);\n\n var t2bb = tx2.node().getBoundingClientRect();\n tx2width = t2bb.width + 2 * HOVERTEXTPAD;\n tx2height = t2bb.height + 2 * HOVERTEXTPAD;\n } else {\n tx2.remove();\n g.select('rect').remove();\n }\n\n g.select('path').style({\n fill: numsColor,\n stroke: contrastColor\n });\n\n var tbb = tx.node().getBoundingClientRect();\n var htx = d.xa._offset + (d.x0 + d.x1) / 2;\n var hty = d.ya._offset + (d.y0 + d.y1) / 2;\n var dx = Math.abs(d.x1 - d.x0);\n var dy = Math.abs(d.y1 - d.y0);\n var txTotalWidth = tbb.width + HOVERARROWSIZE + HOVERTEXTPAD + tx2width;\n var anchorStartOK, anchorEndOK;\n\n d.ty0 = outerTop - tbb.top;\n d.bx = tbb.width + 2 * HOVERTEXTPAD;\n d.by = Math.max(tbb.height + 2 * HOVERTEXTPAD, tx2height);\n d.anchor = 'start';\n d.txwidth = tbb.width;\n d.tx2width = tx2width;\n d.offset = 0;\n\n if(rotateLabels) {\n d.pos = htx;\n anchorStartOK = hty + dy / 2 + txTotalWidth <= outerHeight;\n anchorEndOK = hty - dy / 2 - txTotalWidth >= 0;\n if((d.idealAlign === 'top' || !anchorStartOK) && anchorEndOK) {\n hty -= dy / 2;\n d.anchor = 'end';\n } else if(anchorStartOK) {\n hty += dy / 2;\n d.anchor = 'start';\n } else d.anchor = 'middle';\n } else {\n d.pos = hty;\n anchorStartOK = htx + dx / 2 + txTotalWidth <= outerWidth;\n anchorEndOK = htx - dx / 2 - txTotalWidth >= 0;\n\n if((d.idealAlign === 'left' || !anchorStartOK) && anchorEndOK) {\n htx -= dx / 2;\n d.anchor = 'end';\n } else if(anchorStartOK) {\n htx += dx / 2;\n d.anchor = 'start';\n } else {\n d.anchor = 'middle';\n\n var txHalfWidth = txTotalWidth / 2;\n var overflowR = htx + txHalfWidth - outerWidth;\n var overflowL = htx - txHalfWidth;\n if(overflowR > 0) htx -= overflowR;\n if(overflowL < 0) htx += -overflowL;\n }\n }\n\n tx.attr('text-anchor', d.anchor);\n if(tx2width) tx2.attr('text-anchor', d.anchor);\n g.attr('transform', 'translate(' + htx + ',' + hty + ')' +\n (rotateLabels ? 'rotate(' + YANGLE + ')' : ''));\n });\n\n return hoverLabels;\n}\n\nfunction getHoverLabelText(d, showCommonLabel, hovermode, fullLayout, t0, g) {\n var name = '';\n var text = '';\n // to get custom 'name' labels pass cleanPoint\n if(d.nameOverride !== undefined) d.name = d.nameOverride;\n\n if(d.name) {\n if(d.trace._meta) {\n d.name = Lib.templateString(d.name, d.trace._meta);\n }\n name = plainText(d.name, d.nameLength);\n }\n\n if(d.zLabel !== undefined) {\n if(d.xLabel !== undefined) text += 'x: ' + d.xLabel + '
';\n if(d.yLabel !== undefined) text += 'y: ' + d.yLabel + '
';\n if(d.trace.type !== 'choropleth' && d.trace.type !== 'choroplethmapbox') {\n text += (text ? 'z: ' : '') + d.zLabel;\n }\n } else if(showCommonLabel && d[hovermode.charAt(0) + 'Label'] === t0) {\n text = d[(hovermode.charAt(0) === 'x' ? 'y' : 'x') + 'Label'] || '';\n } else if(d.xLabel === undefined) {\n if(d.yLabel !== undefined && d.trace.type !== 'scattercarpet') {\n text = d.yLabel;\n }\n } else if(d.yLabel === undefined) text = d.xLabel;\n else text = '(' + d.xLabel + ', ' + d.yLabel + ')';\n\n if((d.text || d.text === 0) && !Array.isArray(d.text)) {\n text += (text ? '
' : '') + d.text;\n }\n\n // used by other modules (initially just ternary) that\n // manage their own hoverinfo independent of cleanPoint\n // the rest of this will still apply, so such modules\n // can still put things in (x|y|z)Label, text, and name\n // and hoverinfo will still determine their visibility\n if(d.extraText !== undefined) text += (text ? '
' : '') + d.extraText;\n\n // if 'text' is empty at this point,\n // and hovertemplate is not defined,\n // put 'name' in main label and don't show secondary label\n if(g && text === '' && !d.hovertemplate) {\n // if 'name' is also empty, remove entire label\n if(name === '') g.remove();\n text = name;\n }\n\n // hovertemplate\n var d3locale = fullLayout._d3locale;\n var hovertemplate = d.hovertemplate || false;\n var hovertemplateLabels = d.hovertemplateLabels || d;\n var eventData = d.eventData[0] || {};\n if(hovertemplate) {\n text = Lib.hovertemplateString(\n hovertemplate,\n hovertemplateLabels,\n d3locale,\n eventData,\n d.trace._meta\n );\n\n text = text.replace(EXTRA_STRING_REGEX, function(match, extra) {\n // assign name for secondary text label\n name = plainText(extra, d.nameLength);\n // remove from main text label\n return '';\n });\n }\n return [text, name];\n}\n\n// Make groups of touching points, and within each group\n// move each point so that no labels overlap, but the average\n// label position is the same as it was before moving. Indicentally,\n// this is equivalent to saying all the labels are on equal linear\n// springs about their initial position. Initially, each point is\n// its own group, but as we find overlaps we will clump the points.\n//\n// Also, there are hard constraints at the edges of the graphs,\n// that push all groups to the middle so they are visible. I don't\n// know what happens if the group spans all the way from one edge to\n// the other, though it hardly matters - there's just too much\n// information then.\nfunction hoverAvoidOverlaps(hoverLabels, axKey, fullLayout) {\n var nummoves = 0;\n var axSign = 1;\n var nLabels = hoverLabels.size();\n\n // make groups of touching points\n var pointgroups = new Array(nLabels);\n var k = 0;\n\n hoverLabels.each(function(d) {\n var ax = d[axKey];\n var axIsX = ax._id.charAt(0) === 'x';\n var rng = ax.range;\n\n if(k === 0 && rng && ((rng[0] > rng[1]) !== axIsX)) {\n axSign = -1;\n }\n pointgroups[k++] = [{\n datum: d,\n traceIndex: d.trace.index,\n dp: 0,\n pos: d.pos,\n posref: d.posref,\n size: d.by * (axIsX ? YFACTOR : 1) / 2,\n pmin: 0,\n pmax: (axIsX ? fullLayout.width : fullLayout.height)\n }];\n });\n\n pointgroups.sort(function(a, b) {\n return (a[0].posref - b[0].posref) ||\n // for equal positions, sort trace indices increasing or decreasing\n // depending on whether the axis is reversed or not... so stacked\n // traces will generally keep their order even if one trace adds\n // nothing to the stack.\n (axSign * (b[0].traceIndex - a[0].traceIndex));\n });\n\n var donepositioning, topOverlap, bottomOverlap, i, j, pti, sumdp;\n\n function constrainGroup(grp) {\n var minPt = grp[0];\n var maxPt = grp[grp.length - 1];\n\n // overlap with the top - positive vals are overlaps\n topOverlap = minPt.pmin - minPt.pos - minPt.dp + minPt.size;\n\n // overlap with the bottom - positive vals are overlaps\n bottomOverlap = maxPt.pos + maxPt.dp + maxPt.size - minPt.pmax;\n\n // check for min overlap first, so that we always\n // see the largest labels\n // allow for .01px overlap, so we don't get an\n // infinite loop from rounding errors\n if(topOverlap > 0.01) {\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp += topOverlap;\n donepositioning = false;\n }\n if(bottomOverlap < 0.01) return;\n if(topOverlap < -0.01) {\n // make sure we're not pushing back and forth\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp -= bottomOverlap;\n donepositioning = false;\n }\n if(!donepositioning) return;\n\n // no room to fix positioning, delete off-screen points\n\n // first see how many points we need to delete\n var deleteCount = 0;\n for(i = 0; i < grp.length; i++) {\n pti = grp[i];\n if(pti.pos + pti.dp + pti.size > minPt.pmax) deleteCount++;\n }\n\n // start by deleting points whose data is off screen\n for(i = grp.length - 1; i >= 0; i--) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n\n // pos has already been constrained to [pmin,pmax]\n // so look for points close to that to delete\n if(pti.pos > minPt.pmax - 1) {\n pti.del = true;\n deleteCount--;\n }\n }\n for(i = 0; i < grp.length; i++) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n\n // pos has already been constrained to [pmin,pmax]\n // so look for points close to that to delete\n if(pti.pos < minPt.pmin + 1) {\n pti.del = true;\n deleteCount--;\n\n // shift the whole group minus into this new space\n bottomOverlap = pti.size * 2;\n for(j = grp.length - 1; j >= 0; j--) grp[j].dp -= bottomOverlap;\n }\n }\n // then delete points that go off the bottom\n for(i = grp.length - 1; i >= 0; i--) {\n if(deleteCount <= 0) break;\n pti = grp[i];\n if(pti.pos + pti.dp + pti.size > minPt.pmax) {\n pti.del = true;\n deleteCount--;\n }\n }\n }\n\n // loop through groups, combining them if they overlap,\n // until nothing moves\n while(!donepositioning && nummoves <= nLabels) {\n // to avoid infinite loops, don't move more times\n // than there are traces\n nummoves++;\n\n // assume nothing will move in this iteration,\n // reverse this if it does\n donepositioning = true;\n i = 0;\n while(i < pointgroups.length - 1) {\n // the higher (g0) and lower (g1) point group\n var g0 = pointgroups[i];\n var g1 = pointgroups[i + 1];\n\n // the lowest point in the higher group (p0)\n // the highest point in the lower group (p1)\n var p0 = g0[g0.length - 1];\n var p1 = g1[0];\n topOverlap = p0.pos + p0.dp + p0.size - p1.pos - p1.dp + p1.size;\n\n // Only group points that lie on the same axes\n if(topOverlap > 0.01 && (p0.pmin === p1.pmin) && (p0.pmax === p1.pmax)) {\n // push the new point(s) added to this group out of the way\n for(j = g1.length - 1; j >= 0; j--) g1[j].dp += topOverlap;\n\n // add them to the group\n g0.push.apply(g0, g1);\n pointgroups.splice(i + 1, 1);\n\n // adjust for minimum average movement\n sumdp = 0;\n for(j = g0.length - 1; j >= 0; j--) sumdp += g0[j].dp;\n bottomOverlap = sumdp / g0.length;\n for(j = g0.length - 1; j >= 0; j--) g0[j].dp -= bottomOverlap;\n donepositioning = false;\n } else i++;\n }\n\n // check if we're going off the plot on either side and fix\n pointgroups.forEach(constrainGroup);\n }\n\n // now put these offsets into hoverData\n for(i = pointgroups.length - 1; i >= 0; i--) {\n var grp = pointgroups[i];\n for(j = grp.length - 1; j >= 0; j--) {\n var pt = grp[j];\n var hoverPt = pt.datum;\n hoverPt.offset = pt.dp;\n hoverPt.del = pt.del;\n }\n }\n}\n\nfunction alignHoverText(hoverLabels, rotateLabels) {\n // finally set the text positioning relative to the data and draw the\n // box around it\n hoverLabels.each(function(d) {\n var g = d3.select(this);\n if(d.del) return g.remove();\n\n var tx = g.select('text.nums');\n var anchor = d.anchor;\n var horzSign = anchor === 'end' ? -1 : 1;\n var alignShift = {start: 1, end: -1, middle: 0}[anchor];\n var txx = alignShift * (HOVERARROWSIZE + HOVERTEXTPAD);\n var tx2x = txx + alignShift * (d.txwidth + HOVERTEXTPAD);\n var offsetX = 0;\n var offsetY = d.offset;\n\n if(anchor === 'middle') {\n txx -= d.tx2width / 2;\n tx2x += d.txwidth / 2 + HOVERTEXTPAD;\n }\n if(rotateLabels) {\n offsetY *= -YSHIFTY;\n offsetX = d.offset * YSHIFTX;\n }\n\n g.select('path').attr('d', anchor === 'middle' ?\n // middle aligned: rect centered on data\n ('M-' + (d.bx / 2 + d.tx2width / 2) + ',' + (offsetY - d.by / 2) +\n 'h' + d.bx + 'v' + d.by + 'h-' + d.bx + 'Z') :\n // left or right aligned: side rect with arrow to data\n ('M0,0L' + (horzSign * HOVERARROWSIZE + offsetX) + ',' + (HOVERARROWSIZE + offsetY) +\n 'v' + (d.by / 2 - HOVERARROWSIZE) +\n 'h' + (horzSign * d.bx) +\n 'v-' + d.by +\n 'H' + (horzSign * HOVERARROWSIZE + offsetX) +\n 'V' + (offsetY - HOVERARROWSIZE) +\n 'Z'));\n\n var posX = txx + offsetX;\n var posY = offsetY + d.ty0 - d.by / 2 + HOVERTEXTPAD;\n var textAlign = d.textAlign || 'auto';\n\n if(textAlign !== 'auto') {\n if(textAlign === 'left' && anchor !== 'start') {\n tx.attr('text-anchor', 'start');\n posX = anchor === 'middle' ?\n -d.bx / 2 - d.tx2width / 2 + HOVERTEXTPAD :\n -d.bx - HOVERTEXTPAD;\n } else if(textAlign === 'right' && anchor !== 'end') {\n tx.attr('text-anchor', 'end');\n posX = anchor === 'middle' ?\n d.bx / 2 - d.tx2width / 2 - HOVERTEXTPAD :\n d.bx + HOVERTEXTPAD;\n }\n }\n\n tx.call(svgTextUtils.positionText, posX, posY);\n\n if(d.tx2width) {\n g.select('text.name')\n .call(svgTextUtils.positionText,\n tx2x + alignShift * HOVERTEXTPAD + offsetX,\n offsetY + d.ty0 - d.by / 2 + HOVERTEXTPAD);\n g.select('rect')\n .call(Drawing.setRect,\n tx2x + (alignShift - 1) * d.tx2width / 2 + offsetX,\n offsetY - d.by / 2 - 1,\n d.tx2width, d.by + 2);\n }\n });\n}\n\nfunction cleanPoint(d, hovermode) {\n var index = d.index;\n var trace = d.trace || {};\n var cd0 = d.cd[0];\n var cd = d.cd[index] || {};\n\n function pass(v) {\n return v || (isNumeric(v) && v === 0);\n }\n\n var getVal = Array.isArray(index) ?\n function(calcKey, traceKey) {\n var v = Lib.castOption(cd0, index, calcKey);\n return pass(v) ? v : Lib.extractOption({}, trace, '', traceKey);\n } :\n function(calcKey, traceKey) {\n return Lib.extractOption(cd, trace, calcKey, traceKey);\n };\n\n function fill(key, calcKey, traceKey) {\n var val = getVal(calcKey, traceKey);\n if(pass(val)) d[key] = val;\n }\n\n fill('hoverinfo', 'hi', 'hoverinfo');\n fill('bgcolor', 'hbg', 'hoverlabel.bgcolor');\n fill('borderColor', 'hbc', 'hoverlabel.bordercolor');\n fill('fontFamily', 'htf', 'hoverlabel.font.family');\n fill('fontSize', 'hts', 'hoverlabel.font.size');\n fill('fontColor', 'htc', 'hoverlabel.font.color');\n fill('nameLength', 'hnl', 'hoverlabel.namelength');\n fill('textAlign', 'hta', 'hoverlabel.align');\n\n d.posref = (hovermode === 'y' || (hovermode === 'closest' && trace.orientation === 'h')) ?\n (d.xa._offset + (d.x0 + d.x1) / 2) :\n (d.ya._offset + (d.y0 + d.y1) / 2);\n\n // then constrain all the positions to be on the plot\n d.x0 = Lib.constrain(d.x0, 0, d.xa._length);\n d.x1 = Lib.constrain(d.x1, 0, d.xa._length);\n d.y0 = Lib.constrain(d.y0, 0, d.ya._length);\n d.y1 = Lib.constrain(d.y1, 0, d.ya._length);\n\n // and convert the x and y label values into formatted text\n if(d.xLabelVal !== undefined) {\n d.xLabel = ('xLabel' in d) ? d.xLabel : Axes.hoverLabelText(d.xa, d.xLabelVal);\n d.xVal = d.xa.c2d(d.xLabelVal);\n }\n if(d.yLabelVal !== undefined) {\n d.yLabel = ('yLabel' in d) ? d.yLabel : Axes.hoverLabelText(d.ya, d.yLabelVal);\n d.yVal = d.ya.c2d(d.yLabelVal);\n }\n\n // Traces like heatmaps generate the zLabel in their hoverPoints function\n if(d.zLabelVal !== undefined && d.zLabel === undefined) {\n d.zLabel = String(d.zLabelVal);\n }\n\n // for box means and error bars, add the range to the label\n if(!isNaN(d.xerr) && !(d.xa.type === 'log' && d.xerr <= 0)) {\n var xeText = Axes.tickText(d.xa, d.xa.c2l(d.xerr), 'hover').text;\n if(d.xerrneg !== undefined) {\n d.xLabel += ' +' + xeText + ' / -' +\n Axes.tickText(d.xa, d.xa.c2l(d.xerrneg), 'hover').text;\n } else d.xLabel += ' ± ' + xeText;\n\n // small distance penalty for error bars, so that if there are\n // traces with errors and some without, the error bar label will\n // hoist up to the point\n if(hovermode === 'x') d.distance += 1;\n }\n if(!isNaN(d.yerr) && !(d.ya.type === 'log' && d.yerr <= 0)) {\n var yeText = Axes.tickText(d.ya, d.ya.c2l(d.yerr), 'hover').text;\n if(d.yerrneg !== undefined) {\n d.yLabel += ' +' + yeText + ' / -' +\n Axes.tickText(d.ya, d.ya.c2l(d.yerrneg), 'hover').text;\n } else d.yLabel += ' ± ' + yeText;\n\n if(hovermode === 'y') d.distance += 1;\n }\n\n var infomode = d.hoverinfo || d.trace.hoverinfo;\n\n if(infomode && infomode !== 'all') {\n infomode = Array.isArray(infomode) ? infomode : infomode.split('+');\n if(infomode.indexOf('x') === -1) d.xLabel = undefined;\n if(infomode.indexOf('y') === -1) d.yLabel = undefined;\n if(infomode.indexOf('z') === -1) d.zLabel = undefined;\n if(infomode.indexOf('text') === -1) d.text = undefined;\n if(infomode.indexOf('name') === -1) d.name = undefined;\n }\n\n return d;\n}\n\nfunction createSpikelines(gd, closestPoints, opts) {\n var container = opts.container;\n var fullLayout = opts.fullLayout;\n var gs = fullLayout._size;\n var evt = opts.event;\n var showY = !!closestPoints.hLinePoint;\n var showX = !!closestPoints.vLinePoint;\n\n var xa, ya;\n\n // Remove old spikeline items\n container.selectAll('.spikeline').remove();\n\n if(!(showX || showY)) return;\n\n var contrastColor = Color.combine(fullLayout.plot_bgcolor, fullLayout.paper_bgcolor);\n\n // Horizontal line (to y-axis)\n if(showY) {\n var hLinePoint = closestPoints.hLinePoint;\n var hLinePointX, hLinePointY;\n\n xa = hLinePoint && hLinePoint.xa;\n ya = hLinePoint && hLinePoint.ya;\n var ySnap = ya.spikesnap;\n\n if(ySnap === 'cursor') {\n hLinePointX = evt.pointerX;\n hLinePointY = evt.pointerY;\n } else {\n hLinePointX = xa._offset + hLinePoint.x;\n hLinePointY = ya._offset + hLinePoint.y;\n }\n var dfltHLineColor = tinycolor.readability(hLinePoint.color, contrastColor) < 1.5 ?\n Color.contrast(contrastColor) : hLinePoint.color;\n var yMode = ya.spikemode;\n var yThickness = ya.spikethickness;\n var yColor = ya.spikecolor || dfltHLineColor;\n var xEdge = Axes.getPxPosition(gd, ya);\n var xBase, xEndSpike;\n\n if(yMode.indexOf('toaxis') !== -1 || yMode.indexOf('across') !== -1) {\n if(yMode.indexOf('toaxis') !== -1) {\n xBase = xEdge;\n xEndSpike = hLinePointX;\n }\n if(yMode.indexOf('across') !== -1) {\n var xAcross0 = ya._counterDomainMin;\n var xAcross1 = ya._counterDomainMax;\n if(ya.anchor === 'free') {\n xAcross0 = Math.min(xAcross0, ya.position);\n xAcross1 = Math.max(xAcross1, ya.position);\n }\n xBase = gs.l + xAcross0 * gs.w;\n xEndSpike = gs.l + xAcross1 * gs.w;\n }\n\n // Foreground horizontal line (to y-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: xBase,\n x2: xEndSpike,\n y1: hLinePointY,\n y2: hLinePointY,\n 'stroke-width': yThickness,\n stroke: yColor,\n 'stroke-dasharray': Drawing.dashStyle(ya.spikedash, yThickness)\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n\n // Background horizontal Line (to y-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: xBase,\n x2: xEndSpike,\n y1: hLinePointY,\n y2: hLinePointY,\n 'stroke-width': yThickness + 2,\n stroke: contrastColor\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n }\n // Y axis marker\n if(yMode.indexOf('marker') !== -1) {\n container.insert('circle', ':first-child')\n .attr({\n cx: xEdge + (ya.side !== 'right' ? yThickness : -yThickness),\n cy: hLinePointY,\n r: yThickness,\n fill: yColor\n })\n .classed('spikeline', true);\n }\n }\n\n if(showX) {\n var vLinePoint = closestPoints.vLinePoint;\n var vLinePointX, vLinePointY;\n\n xa = vLinePoint && vLinePoint.xa;\n ya = vLinePoint && vLinePoint.ya;\n var xSnap = xa.spikesnap;\n\n if(xSnap === 'cursor') {\n vLinePointX = evt.pointerX;\n vLinePointY = evt.pointerY;\n } else {\n vLinePointX = xa._offset + vLinePoint.x;\n vLinePointY = ya._offset + vLinePoint.y;\n }\n var dfltVLineColor = tinycolor.readability(vLinePoint.color, contrastColor) < 1.5 ?\n Color.contrast(contrastColor) : vLinePoint.color;\n var xMode = xa.spikemode;\n var xThickness = xa.spikethickness;\n var xColor = xa.spikecolor || dfltVLineColor;\n var yEdge = Axes.getPxPosition(gd, xa);\n var yBase, yEndSpike;\n\n if(xMode.indexOf('toaxis') !== -1 || xMode.indexOf('across') !== -1) {\n if(xMode.indexOf('toaxis') !== -1) {\n yBase = yEdge;\n yEndSpike = vLinePointY;\n }\n if(xMode.indexOf('across') !== -1) {\n var yAcross0 = xa._counterDomainMin;\n var yAcross1 = xa._counterDomainMax;\n if(xa.anchor === 'free') {\n yAcross0 = Math.min(yAcross0, xa.position);\n yAcross1 = Math.max(yAcross1, xa.position);\n }\n yBase = gs.t + (1 - yAcross1) * gs.h;\n yEndSpike = gs.t + (1 - yAcross0) * gs.h;\n }\n\n // Foreground vertical line (to x-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: vLinePointX,\n x2: vLinePointX,\n y1: yBase,\n y2: yEndSpike,\n 'stroke-width': xThickness,\n stroke: xColor,\n 'stroke-dasharray': Drawing.dashStyle(xa.spikedash, xThickness)\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n\n // Background vertical line (to x-axis)\n container.insert('line', ':first-child')\n .attr({\n x1: vLinePointX,\n x2: vLinePointX,\n y1: yBase,\n y2: yEndSpike,\n 'stroke-width': xThickness + 2,\n stroke: contrastColor\n })\n .classed('spikeline', true)\n .classed('crisp', true);\n }\n\n // X axis marker\n if(xMode.indexOf('marker') !== -1) {\n container.insert('circle', ':first-child')\n .attr({\n cx: vLinePointX,\n cy: yEdge - (xa.side !== 'top' ? xThickness : -xThickness),\n r: xThickness,\n fill: xColor\n })\n .classed('spikeline', true);\n }\n }\n}\n\nfunction hoverChanged(gd, evt, oldhoverdata) {\n // don't emit any events if nothing changed\n if(!oldhoverdata || oldhoverdata.length !== gd._hoverdata.length) return true;\n\n for(var i = oldhoverdata.length - 1; i >= 0; i--) {\n var oldPt = oldhoverdata[i];\n var newPt = gd._hoverdata[i];\n\n if(oldPt.curveNumber !== newPt.curveNumber ||\n String(oldPt.pointNumber) !== String(newPt.pointNumber) ||\n String(oldPt.pointNumbers) !== String(newPt.pointNumbers)\n ) {\n return true;\n }\n }\n return false;\n}\n\nfunction spikesChanged(gd, oldspikepoints) {\n // don't relayout the plot because of new spikelines if spikelines points didn't change\n if(!oldspikepoints) return true;\n if(oldspikepoints.vLinePoint !== gd._spikepoints.vLinePoint ||\n oldspikepoints.hLinePoint !== gd._spikepoints.hLinePoint\n ) return true;\n return false;\n}\n\nfunction plainText(s, len) {\n return svgTextUtils.plainText(s || '', {\n len: len,\n allowedTags: ['br', 'sub', 'sup', 'b', 'i', 'em']\n });\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = {\n percent: function(size, total) {\n var nMax = size.length;\n var norm = 100 / total;\n for(var n = 0; n < nMax; n++) size[n] *= norm;\n },\n probability: function(size, total) {\n var nMax = size.length;\n for(var n = 0; n < nMax; n++) size[n] /= total;\n },\n density: function(size, total, inc, yinc) {\n var nMax = size.length;\n yinc = yinc || 1;\n for(var n = 0; n < nMax; n++) size[n] *= inc[n] * yinc;\n },\n 'probability density': function(size, total, inc, yinc) {\n var nMax = size.length;\n if(yinc) total /= yinc;\n for(var n = 0; n < nMax; n++) size[n] *= inc[n] / total;\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n\n // 'y' position pad above counter axis domain\n yPad: 0.02,\n\n // minimum button width (regardless of text size)\n minButtonWidth: 30,\n\n // buttons rect radii\n rx: 3,\n ry: 3,\n\n // light fraction used to compute the 'activecolor' default\n lightAmount: 25,\n darkAmount: 10\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar constants = require('./constants');\n\nvar Lib = require('../../lib');\n\n// special position conversion functions... category axis positions can't be\n// specified by their data values, because they don't make a continuous mapping.\n// so these have to be specified in terms of the category serial numbers,\n// but can take fractional values. Other axis types we specify position based on\n// the actual data values.\n// TODO: in V2.0 (when log axis ranges are in data units) range and shape position\n// will be identical, so rangeToShapePosition and shapePositionToRange can be\n// removed entirely.\n\nexports.rangeToShapePosition = function(ax) {\n return (ax.type === 'log') ? ax.r2d : function(v) { return v; };\n};\n\nexports.shapePositionToRange = function(ax) {\n return (ax.type === 'log') ? ax.d2r : function(v) { return v; };\n};\n\nexports.decodeDate = function(convertToPx) {\n return function(v) {\n if(v.replace) v = v.replace('_', ' ');\n return convertToPx(v);\n };\n};\n\nexports.encodeDate = function(convertToDate) {\n return function(v) { return convertToDate(v).replace(' ', '_'); };\n};\n\nexports.extractPathCoords = function(path, paramsToUse) {\n var extractedCoordinates = [];\n\n var segments = path.match(constants.segmentRE);\n segments.forEach(function(segment) {\n var relevantParamIdx = paramsToUse[segment.charAt(0)].drawn;\n if(relevantParamIdx === undefined) return;\n\n var params = segment.substr(1).match(constants.paramRE);\n if(!params || params.length < relevantParamIdx) return;\n\n extractedCoordinates.push(Lib.cleanNumber(params[relevantParamIdx]));\n });\n\n return extractedCoordinates;\n};\n\nexports.getDataToPixel = function(gd, axis, isVertical) {\n var gs = gd._fullLayout._size;\n var dataToPixel;\n\n if(axis) {\n var d2r = exports.shapePositionToRange(axis);\n\n dataToPixel = function(v) {\n return axis._offset + axis.r2p(d2r(v, true));\n };\n\n if(axis.type === 'date') dataToPixel = exports.decodeDate(dataToPixel);\n } else if(isVertical) {\n dataToPixel = function(v) { return gs.t + gs.h * (1 - v); };\n } else {\n dataToPixel = function(v) { return gs.l + gs.w * v; };\n }\n\n return dataToPixel;\n};\n\nexports.getPixelToData = function(gd, axis, isVertical) {\n var gs = gd._fullLayout._size;\n var pixelToData;\n\n if(axis) {\n var r2d = exports.rangeToShapePosition(axis);\n pixelToData = function(p) { return r2d(axis.p2r(p - axis._offset)); };\n } else if(isVertical) {\n pixelToData = function(p) { return 1 - (p - gs.t) / gs.h; };\n } else {\n pixelToData = function(p) { return (p - gs.l) / gs.w; };\n }\n\n return pixelToData;\n};\n\n/**\n * Based on the given stroke width, rounds the passed\n * position value to represent either a full or half pixel.\n *\n * In case of an odd stroke width (e.g. 1), this measure ensures\n * that a stroke positioned at the returned position isn't rendered\n * blurry due to anti-aliasing.\n *\n * In case of an even stroke width (e.g. 2), this measure ensures\n * that the position value is transformed to a full pixel value\n * so that anti-aliasing doesn't take effect either.\n *\n * @param {number} pos The raw position value to be transformed\n * @param {number} strokeWidth The stroke width\n * @returns {number} either an integer or a .5 decimal number\n */\nexports.roundPositionForSharpStrokeRendering = function(pos, strokeWidth) {\n var strokeWidthIsOdd = Math.round(strokeWidth % 2) === 1;\n var posValAsInt = Math.round(pos);\n\n return strokeWidthIsOdd ? posValAsInt + 0.5 : posValAsInt;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar ONEDAY = require('../../constants/numerical').ONEDAY;\n\n/**\n * Return a validated dtick value for this axis\n *\n * @param {any} dtick: the candidate dtick. valid values are numbers and strings,\n * and further constrained depending on the axis type.\n * @param {string} axType: the axis type\n */\nexports.dtick = function(dtick, axType) {\n var isLog = axType === 'log';\n var isDate = axType === 'date';\n var isCat = axType === 'category';\n var dtickDflt = isDate ? ONEDAY : 1;\n\n if(!dtick) return dtickDflt;\n\n if(isNumeric(dtick)) {\n dtick = Number(dtick);\n if(dtick <= 0) return dtickDflt;\n if(isCat) {\n // category dtick must be positive integers\n return Math.max(1, Math.round(dtick));\n }\n if(isDate) {\n // date dtick must be at least 0.1ms (our current precision)\n return Math.max(0.1, dtick);\n }\n return dtick;\n }\n\n if(typeof dtick !== 'string' || !(isDate || isLog)) {\n return dtickDflt;\n }\n\n var prefix = dtick.charAt(0);\n var dtickNum = dtick.substr(1);\n dtickNum = isNumeric(dtickNum) ? Number(dtickNum) : 0;\n\n if((dtickNum <= 0) || !(\n // \"M\" gives ticks every (integer) n months\n (isDate && prefix === 'M' && dtickNum === Math.round(dtickNum)) ||\n // \"L\" gives ticks linearly spaced in data (not in position) every (float) f\n (isLog && prefix === 'L') ||\n // \"D1\" gives powers of 10 with all small digits between, \"D2\" gives only 2 and 5\n (isLog && prefix === 'D' && (dtickNum === 1 || dtickNum === 2))\n )) {\n return dtickDflt;\n }\n\n return dtick;\n};\n\n/**\n * Return a validated tick0 for this axis\n *\n * @param {any} tick0: the candidate tick0. Valid values are numbers and strings,\n * further constrained depending on the axis type\n * @param {string} axType: the axis type\n * @param {string} calendar: for date axes, the calendar to validate/convert with\n * @param {any} dtick: an already valid dtick. Only used for D1 and D2 log dticks,\n * which do not support tick0 at all.\n */\nexports.tick0 = function(tick0, axType, calendar, dtick) {\n if(axType === 'date') {\n return Lib.cleanDate(tick0, Lib.dateTick0(calendar));\n }\n if(dtick === 'D1' || dtick === 'D2') {\n // D1 and D2 modes ignore tick0 entirely\n return undefined;\n }\n // Aside from date axes, tick0 must be numeric\n return isNumeric(tick0) ? Number(tick0) : 0;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nexports.manage = require('./manage');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n// look for either subplot or xaxis and yaxis attributes\n// does not handle splom case\nexports.getSubplot = function(trace) {\n return trace.subplot || (trace.xaxis + trace.yaxis) || trace.geo;\n};\n\n// is trace in given list of subplots?\n// does handle splom case\nexports.isTraceInSubplots = function(trace, subplots) {\n if(trace.type === 'splom') {\n var xaxes = trace.xaxes || [];\n var yaxes = trace.yaxes || [];\n for(var i = 0; i < xaxes.length; i++) {\n for(var j = 0; j < yaxes.length; j++) {\n if(subplots.indexOf(xaxes[i] + yaxes[j]) !== -1) {\n return true;\n }\n }\n }\n return false;\n }\n\n return subplots.indexOf(exports.getSubplot(trace)) !== -1;\n};\n\n// convenience functions for mapping all relevant axes\nexports.flat = function(subplots, v) {\n var out = new Array(subplots.length);\n for(var i = 0; i < subplots.length; i++) {\n out[i] = v;\n }\n return out;\n};\n\nexports.p2c = function(axArray, v) {\n var out = new Array(axArray.length);\n for(var i = 0; i < axArray.length; i++) {\n out[i] = axArray[i].p2c(v);\n }\n return out;\n};\n\nexports.getDistanceFunction = function(mode, dx, dy, dxy) {\n if(mode === 'closest') return dxy || exports.quadrature(dx, dy);\n return mode.charAt(0) === 'x' ? dx : dy;\n};\n\nexports.getClosest = function(cd, distfn, pointData) {\n // do we already have a point number? (array mode only)\n if(pointData.index !== false) {\n if(pointData.index >= 0 && pointData.index < cd.length) {\n pointData.distance = 0;\n } else pointData.index = false;\n } else {\n // apply the distance function to each data point\n // this is the longest loop... if this bogs down, we may need\n // to create pre-sorted data (by x or y), not sure how to\n // do this for 'closest'\n for(var i = 0; i < cd.length; i++) {\n var newDistance = distfn(cd[i]);\n if(newDistance <= pointData.distance) {\n pointData.index = i;\n pointData.distance = newDistance;\n }\n }\n }\n return pointData;\n};\n\n/*\n * pseudo-distance function for hover effects on areas: inside the region\n * distance is finite (`passVal`), outside it's Infinity.\n *\n * @param {number} v0: signed difference between the current position and the left edge\n * @param {number} v1: signed difference between the current position and the right edge\n * @param {number} passVal: the value to return on success\n */\nexports.inbox = function(v0, v1, passVal) {\n return (v0 * v1 < 0 || v0 === 0) ? passVal : Infinity;\n};\n\nexports.quadrature = function(dx, dy) {\n return function(di) {\n var x = dx(di);\n var y = dy(di);\n return Math.sqrt(x * x + y * y);\n };\n};\n\n/** Fill event data point object for hover and selection.\n * Invokes _module.eventData if present.\n *\n * N.B. note that point 'index' corresponds to input data array index\n * whereas 'number' is its post-transform version.\n *\n * If the hovered/selected pt corresponds to an multiple input points\n * (e.g. for histogram and transformed traces), 'pointNumbers` and 'pointIndices'\n * are include in the event data.\n *\n * @param {object} pt\n * @param {object} trace\n * @param {object} cd\n * @return {object}\n */\nexports.makeEventData = function(pt, trace, cd) {\n // hover uses 'index', select uses 'pointNumber'\n var pointNumber = 'index' in pt ? pt.index : pt.pointNumber;\n\n var out = {\n data: trace._input,\n fullData: trace,\n curveNumber: trace.index,\n pointNumber: pointNumber\n };\n\n if(trace._indexToPoints) {\n var pointIndices = trace._indexToPoints[pointNumber];\n\n if(pointIndices.length === 1) {\n out.pointIndex = pointIndices[0];\n } else {\n out.pointIndices = pointIndices;\n }\n } else {\n out.pointIndex = pointNumber;\n }\n\n if(trace._module.eventData) {\n out = trace._module.eventData(out, pt, trace, cd, pointNumber);\n } else {\n if('xVal' in pt) out.x = pt.xVal;\n else if('x' in pt) out.x = pt.x;\n\n if('yVal' in pt) out.y = pt.yVal;\n else if('y' in pt) out.y = pt.y;\n\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n if(pt.zLabelVal !== undefined) out.z = pt.zLabelVal;\n }\n\n exports.appendArrayPointValue(out, trace, pointNumber);\n\n return out;\n};\n\n/** Appends values inside array attributes corresponding to given point number\n *\n * @param {object} pointData : point data object (gets mutated here)\n * @param {object} trace : full trace object\n * @param {number|Array(number)} pointNumber : point number. May be a length-2 array\n * [row, col] to dig into 2D arrays\n */\nexports.appendArrayPointValue = function(pointData, trace, pointNumber) {\n var arrayAttrs = trace._arrayAttrs;\n\n if(!arrayAttrs) {\n return;\n }\n\n for(var i = 0; i < arrayAttrs.length; i++) {\n var astr = arrayAttrs[i];\n var key = getPointKey(astr);\n\n if(pointData[key] === undefined) {\n var val = Lib.nestedProperty(trace, astr).get();\n var pointVal = getPointData(val, pointNumber);\n\n if(pointVal !== undefined) pointData[key] = pointVal;\n }\n }\n};\n\n/**\n * Appends values inside array attributes corresponding to given point number array\n * For use when pointData references a plot entity that arose (or potentially arose)\n * from multiple points in the input data\n *\n * @param {object} pointData : point data object (gets mutated here)\n * @param {object} trace : full trace object\n * @param {Array(number)|Array(Array(number))} pointNumbers : Array of point numbers.\n * Each entry in the array may itself be a length-2 array [row, col] to dig into 2D arrays\n */\nexports.appendArrayMultiPointValues = function(pointData, trace, pointNumbers) {\n var arrayAttrs = trace._arrayAttrs;\n\n if(!arrayAttrs) {\n return;\n }\n\n for(var i = 0; i < arrayAttrs.length; i++) {\n var astr = arrayAttrs[i];\n var key = getPointKey(astr);\n\n if(pointData[key] === undefined) {\n var val = Lib.nestedProperty(trace, astr).get();\n var keyVal = new Array(pointNumbers.length);\n\n for(var j = 0; j < pointNumbers.length; j++) {\n keyVal[j] = getPointData(val, pointNumbers[j]);\n }\n pointData[key] = keyVal;\n }\n }\n};\n\nvar pointKeyMap = {\n ids: 'id',\n locations: 'location',\n labels: 'label',\n values: 'value',\n 'marker.colors': 'color',\n parents: 'parent'\n};\n\nfunction getPointKey(astr) {\n return pointKeyMap[astr] || astr;\n}\n\nfunction getPointData(val, pointNumber) {\n if(Array.isArray(pointNumber)) {\n if(Array.isArray(val) && Array.isArray(val[pointNumber[0]])) {\n return val[pointNumber[0]][pointNumber[1]];\n }\n } else {\n return val[pointNumber];\n }\n}\n\nvar xyHoverMode = {\n x: true,\n y: true\n};\n\nvar unifiedHoverMode = {\n 'x unified': true,\n 'y unified': true\n};\n\nexports.isUnifiedHover = function(hovermode) {\n if(typeof hovermode !== 'string') return false;\n return !!unifiedHoverMode[hovermode];\n};\n\nexports.isXYhover = function(hovermode) {\n if(typeof hovermode !== 'string') return false;\n return !!xyHoverMode[hovermode];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar perStackAttrs = ['orientation', 'groupnorm', 'stackgaps'];\n\nmodule.exports = function handleStackDefaults(traceIn, traceOut, layout, coerce) {\n var stackOpts = layout._scatterStackOpts;\n\n var stackGroup = coerce('stackgroup');\n if(stackGroup) {\n // use independent stacking options per subplot\n var subplot = traceOut.xaxis + traceOut.yaxis;\n var subplotStackOpts = stackOpts[subplot];\n if(!subplotStackOpts) subplotStackOpts = stackOpts[subplot] = {};\n\n var groupOpts = subplotStackOpts[stackGroup];\n var firstTrace = false;\n if(groupOpts) {\n groupOpts.traces.push(traceOut);\n } else {\n groupOpts = subplotStackOpts[stackGroup] = {\n // keep track of trace indices for use during stacking calculations\n // this will be filled in during `calc` and used during `crossTraceCalc`\n // so it's OK if we don't recreate it during a non-calc edit\n traceIndices: [],\n // Hold on to the whole set of prior traces\n // First one is most important, so we can clear defaults\n // there if we find explicit values only in later traces.\n // We're only going to *use* the values stored in groupOpts,\n // but for the editor and validate we want things self-consistent\n // The full set of traces is used only to fix `fill` default if\n // we find `orientation: 'h'` beyond the first trace\n traces: [traceOut]\n };\n firstTrace = true;\n }\n // TODO: how is this going to work with groupby transforms?\n // in principle it should be OK I guess, as long as explicit group styles\n // don't override explicit base-trace styles?\n\n var dflts = {\n orientation: (traceOut.x && !traceOut.y) ? 'h' : 'v'\n };\n\n for(var i = 0; i < perStackAttrs.length; i++) {\n var attr = perStackAttrs[i];\n var attrFound = attr + 'Found';\n if(!groupOpts[attrFound]) {\n var traceHasAttr = traceIn[attr] !== undefined;\n var isOrientation = attr === 'orientation';\n if(traceHasAttr || firstTrace) {\n groupOpts[attr] = coerce(attr, dflts[attr]);\n\n if(isOrientation) {\n groupOpts.fillDflt = groupOpts[attr] === 'h' ?\n 'tonextx' : 'tonexty';\n }\n\n if(traceHasAttr) {\n // Note: this will show a value here even if it's invalid\n // in which case it will revert to default.\n groupOpts[attrFound] = true;\n\n // Note: only one trace in the stack will get a _fullData\n // entry for a given stack-wide attribute. If no traces\n // (or the first trace) specify that attribute, the\n // first trace will get it. If the first trace does NOT\n // specify it but some later trace does, then it gets\n // removed from the first trace and only included in the\n // one that specified it. This is mostly important for\n // editors (that want to see the full values to know\n // what settings are available) and Plotly.react diffing.\n // Editors may want to use fullLayout._scatterStackOpts\n // directly and make these settings available from all\n // traces in the stack... then set the new value into\n // the first trace, and clear all later traces.\n if(!firstTrace) {\n delete groupOpts.traces[0][attr];\n\n // orientation can affect default fill of previous traces\n if(isOrientation) {\n for(var j = 0; j < groupOpts.traces.length - 1; j++) {\n var trace2 = groupOpts.traces[j];\n if(trace2._input.fill !== trace2.fill) {\n trace2.fill = groupOpts.fillDflt;\n }\n }\n }\n }\n }\n }\n }\n }\n return groupOpts;\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nmodule.exports = {\n hasLines: function(trace) {\n return trace.visible && trace.mode &&\n trace.mode.indexOf('lines') !== -1;\n },\n\n hasMarkers: function(trace) {\n return trace.visible && (\n (trace.mode && trace.mode.indexOf('markers') !== -1) ||\n // until splom implements 'mode'\n trace.type === 'splom'\n );\n },\n\n hasText: function(trace) {\n return trace.visible && trace.mode &&\n trace.mode.indexOf('text') !== -1;\n },\n\n isBubble: function(trace) {\n return Lib.isPlainObject(trace.marker) &&\n Lib.isArrayOrTypedArray(trace.marker.size);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fxAttrs = require('../components/fx/attributes');\n\nmodule.exports = {\n type: {\n valType: 'enumerated',\n role: 'info',\n values: [], // listed dynamically\n dflt: 'scatter',\n editType: 'calc+clearAxisTypes',\n _noTemplating: true // we handle this at a higher level\n },\n visible: {\n valType: 'enumerated',\n values: [true, false, 'legendonly'],\n role: 'info',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not this trace is visible.',\n 'If *legendonly*, the trace is not drawn,',\n 'but can appear as a legend item',\n '(provided that the legend itself is visible).'\n ].join(' ')\n },\n showlegend: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'style',\n description: [\n 'Determines whether or not an item corresponding to this',\n 'trace is shown in the legend.'\n ].join(' ')\n },\n legendgroup: {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: 'style',\n description: [\n 'Sets the legend group for this trace.',\n 'Traces part of the same legend group hide/show at the same time',\n 'when toggling legend items.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n role: 'style',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'style',\n description: 'Sets the opacity of the trace.'\n },\n name: {\n valType: 'string',\n role: 'info',\n editType: 'style',\n description: [\n 'Sets the trace name.',\n 'The trace name appear as the legend item and on hover.'\n ].join(' ')\n },\n uid: {\n valType: 'string',\n role: 'info',\n editType: 'plot',\n anim: true,\n description: [\n 'Assign an id to this trace,',\n 'Use this to provide object constancy between traces during animations',\n 'and transitions.'\n ].join(' ')\n },\n ids: {\n valType: 'data_array',\n editType: 'calc',\n anim: true,\n description: [\n 'Assigns id labels to each datum.',\n 'These ids for object constancy of data points during animation.',\n 'Should be an array of strings, not numbers or any other type.'\n ].join(' ')\n },\n customdata: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Assigns extra data each datum.',\n 'This may be useful when listening to hover, click and selection events.',\n 'Note that, *scatter* traces also appends customdata items in the markers',\n 'DOM elements'\n ].join(' ')\n },\n meta: {\n valType: 'any',\n arrayOk: true,\n role: 'info',\n editType: 'plot',\n description: [\n 'Assigns extra meta information associated with this trace',\n 'that can be used in various text attributes.',\n 'Attributes such as trace `name`, graph, axis and colorbar `title.text`, annotation `text`',\n '`rangeselector`, `updatemenues` and `sliders` `label` text',\n 'all support `meta`.',\n 'To access the trace `meta` values in an attribute in the same trace, simply use',\n '`%{meta[i]}` where `i` is the index or key of the `meta`',\n 'item in question.',\n 'To access trace `meta` in layout attributes, use',\n '`%{data[n[.meta[i]}` where `i` is the index or key of the `meta`',\n 'and `n` is the trace index.'\n ].join(' ')\n },\n\n // N.B. these cannot be 'data_array' as they do not have the same length as\n // other data arrays and arrayOk attributes in general\n //\n // Maybe add another valType:\n // https://github.com/plotly/plotly.js/issues/1894\n selectedpoints: {\n valType: 'any',\n role: 'info',\n editType: 'calc',\n description: [\n 'Array containing integer indices of selected points.',\n 'Has an effect only for traces that support selections.',\n 'Note that an empty array means an empty selection where the `unselected`',\n 'are turned on for all points, whereas, any other non-array values means no',\n 'selection all where the `selected` and `unselected` styles have no effect.'\n ].join(' ')\n },\n\n hoverinfo: {\n valType: 'flaglist',\n role: 'info',\n flags: ['x', 'y', 'z', 'text', 'name'],\n extras: ['all', 'none', 'skip'],\n arrayOk: true,\n dflt: 'all',\n editType: 'none',\n description: [\n 'Determines which trace information appear on hover.',\n 'If `none` or `skip` are set, no information is displayed upon hovering.',\n 'But, if `none` is set, click and hover events are still fired.'\n ].join(' ')\n },\n hoverlabel: fxAttrs.hoverlabel,\n stream: {\n token: {\n valType: 'string',\n noBlank: true,\n strict: true,\n role: 'info',\n editType: 'calc',\n description: [\n 'The stream id number links a data trace on a plot with a stream.',\n 'See https://chart-studio.plotly.com/settings for more details.'\n ].join(' ')\n },\n maxpoints: {\n valType: 'number',\n min: 0,\n max: 10000,\n dflt: 500,\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the maximum number of points to keep on the plots from an',\n 'incoming stream.',\n 'If `maxpoints` is set to *50*, only the newest 50 points will',\n 'be displayed on the plot.'\n ].join(' ')\n },\n editType: 'calc'\n },\n transforms: {\n _isLinkedToArray: 'transform',\n editType: 'calc',\n description: [\n 'An array of operations that manipulate the trace data,',\n 'for example filtering or sorting the data arrays.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of some user-driven changes to the trace:',\n '`constraintrange` in `parcoords` traces, as well as some',\n '`editable: true` modifications such as `name` and `colorbar.title`.',\n 'Defaults to `layout.uirevision`.',\n 'Note that other user-driven trace attribute changes are controlled',\n 'by `layout` attributes:',\n '`trace.visible` is controlled by `layout.legend.uirevision`,',\n '`selectedpoints` is controlled by `layout.selectionrevision`,',\n 'and `colorbar.(x|y)` (accessible with `config: {editable: true}`)',\n 'is controlled by `layout.editrevision`.',\n 'Trace changes are tracked by `uid`, which only falls back on trace',\n 'index if no `uid` is provided. So if your app can add/remove traces',\n 'before the end of the `data` array, such that the same trace has a',\n 'different index, you can still preserve user-driven changes if you',\n 'give each trace a `uid` that stays with it as it moves.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar setCursor = require('./setcursor');\n\nvar STASHATTR = 'data-savedcursor';\nvar NO_CURSOR = '!!';\n\n/*\n * works with our CSS cursor classes (see css/_cursor.scss)\n * to override a previous cursor set on d3 single-element selections,\n * by moving the name of the original cursor to the data-savedcursor attr.\n * omit cursor to revert to the previously set value.\n */\nmodule.exports = function overrideCursor(el3, csr) {\n var savedCursor = el3.attr(STASHATTR);\n if(csr) {\n if(!savedCursor) {\n var classes = (el3.attr('class') || '').split(' ');\n for(var i = 0; i < classes.length; i++) {\n var cls = classes[i];\n if(cls.indexOf('cursor-') === 0) {\n el3.attr(STASHATTR, cls.substr(7))\n .classed(cls, false);\n }\n }\n if(!el3.attr(STASHATTR)) {\n el3.attr(STASHATTR, NO_CURSOR);\n }\n }\n setCursor(el3, csr);\n } else if(savedCursor) {\n el3.attr(STASHATTR, null);\n\n if(savedCursor === NO_CURSOR) setCursor(el3);\n else setCursor(el3, savedCursor);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\n\nvar toImage = require('../plot_api/to_image');\n\nvar fileSaver = require('./filesaver');\nvar helpers = require('./helpers');\n\n/**\n * Plotly.downloadImage\n *\n * @param {object | string | HTML div} gd\n * can either be a data/layout/config object\n * or an existing graph
\n * or an id to an existing graph
\n * @param {object} opts (see Plotly.toImage in ../plot_api/to_image)\n * @return {promise}\n */\nfunction downloadImage(gd, opts) {\n var _gd;\n if(!Lib.isPlainObject(gd)) _gd = Lib.getGraphDiv(gd);\n\n opts = opts || {};\n opts.format = opts.format || 'png';\n opts.imageDataOnly = true;\n\n return new Promise(function(resolve, reject) {\n if(_gd && _gd._snapshotInProgress) {\n reject(new Error('Snapshotting already in progress.'));\n }\n\n // see comments within svgtoimg for additional\n // discussion of problems with IE\n // can now draw to canvas, but CORS tainted canvas\n // does not allow toDataURL\n // svg format will work though\n if(Lib.isIE() && opts.format !== 'svg') {\n reject(new Error(helpers.MSG_IE_BAD_FORMAT));\n }\n\n if(_gd) _gd._snapshotInProgress = true;\n var promise = toImage(gd, opts);\n\n var filename = opts.filename || gd.fn || 'newplot';\n filename += '.' + opts.format.replace('-', '.');\n\n promise.then(function(result) {\n if(_gd) _gd._snapshotInProgress = false;\n return fileSaver(result, filename, opts.format);\n }).then(function(name) {\n resolve(name);\n }).catch(function(err) {\n if(_gd) _gd._snapshotInProgress = false;\n reject(err);\n });\n });\n}\n\nmodule.exports = downloadImage;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\nvar isUnifiedHover = require('./helpers').isUnifiedHover;\n\nmodule.exports = function handleHoverLabelDefaults(contIn, contOut, coerce, opts) {\n opts = opts || {};\n\n function inheritFontAttr(attr) {\n if(!opts.font[attr]) {\n opts.font[attr] = contOut.legend ? contOut.legend.font[attr] : contOut.font[attr];\n }\n }\n\n // In unified hover, inherit from layout.legend if available or layout\n if(contOut && isUnifiedHover(contOut.hovermode)) {\n if(!opts.font) opts.font = {};\n inheritFontAttr('size');\n inheritFontAttr('family');\n inheritFontAttr('color');\n\n if(contOut.legend) {\n if(!opts.bgcolor) opts.bgcolor = Color.combine(contOut.legend.bgcolor, contOut.paper_bgcolor);\n if(!opts.bordercolor) opts.bordercolor = contOut.legend.bordercolor;\n } else {\n if(!opts.bgcolor) opts.bgcolor = contOut.paper_bgcolor;\n }\n }\n\n coerce('hoverlabel.bgcolor', opts.bgcolor);\n coerce('hoverlabel.bordercolor', opts.bordercolor);\n coerce('hoverlabel.namelength', opts.namelength);\n Lib.coerceFont(coerce, 'hoverlabel.font', opts.font);\n coerce('hoverlabel.align', opts.align);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Fx = require('../../components/fx');\nvar dragElement = require('../../components/dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar makeDragBox = require('./dragbox').makeDragBox;\nvar DRAGGERSIZE = require('./constants').DRAGGERSIZE;\n\nexports.initInteractions = function initInteractions(gd) {\n var fullLayout = gd._fullLayout;\n\n if(gd._context.staticPlot) {\n // this sweeps up more than just cartesian drag elements...\n d3.select(gd).selectAll('.drag').remove();\n return;\n }\n\n if(!fullLayout._has('cartesian') && !fullLayout._has('splom')) return;\n\n var subplots = Object.keys(fullLayout._plots || {}).sort(function(a, b) {\n // sort overlays last, then by x axis number, then y axis number\n if((fullLayout._plots[a].mainplot && true) ===\n (fullLayout._plots[b].mainplot && true)) {\n var aParts = a.split('y');\n var bParts = b.split('y');\n return (aParts[0] === bParts[0]) ?\n (Number(aParts[1] || 1) - Number(bParts[1] || 1)) :\n (Number(aParts[0] || 1) - Number(bParts[0] || 1));\n }\n return fullLayout._plots[a].mainplot ? 1 : -1;\n });\n\n subplots.forEach(function(subplot) {\n var plotinfo = fullLayout._plots[subplot];\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n // main and corner draggers need not be repeated for\n // overlaid subplots - these draggers drag them all\n if(!plotinfo.mainplot) {\n // main dragger goes over the grids and data, so we use its\n // mousemove events for all data hover effects\n var maindrag = makeDragBox(gd, plotinfo, xa._offset, ya._offset,\n xa._length, ya._length, 'ns', 'ew');\n\n maindrag.onmousemove = function(evt) {\n // This is on `gd._fullLayout`, *not* fullLayout because the reference\n // changes by the time this is called again.\n gd._fullLayout._rehover = function() {\n if((gd._fullLayout._hoversubplot === subplot) && gd._fullLayout._plots[subplot]) {\n Fx.hover(gd, evt, subplot);\n }\n };\n\n Fx.hover(gd, evt, subplot);\n\n // Note that we have *not* used the cached fullLayout variable here\n // since that may be outdated when this is called as a callback later on\n gd._fullLayout._lasthover = maindrag;\n gd._fullLayout._hoversubplot = subplot;\n };\n\n /*\n * IMPORTANT:\n * We must check for the presence of the drag cover here.\n * If we don't, a 'mouseout' event is triggered on the\n * maindrag before each 'click' event, which has the effect\n * of clearing the hoverdata; thus, cancelling the click event.\n */\n maindrag.onmouseout = function(evt) {\n if(gd._dragging) return;\n\n // When the mouse leaves this maindrag, unset the hovered subplot.\n // This may cause problems if it leaves the subplot directly *onto*\n // another subplot, but that's a tiny corner case at the moment.\n gd._fullLayout._hoversubplot = null;\n\n dragElement.unhover(gd, evt);\n };\n\n // corner draggers\n if(gd._context.showAxisDragHandles) {\n makeDragBox(gd, plotinfo, xa._offset - DRAGGERSIZE, ya._offset - DRAGGERSIZE,\n DRAGGERSIZE, DRAGGERSIZE, 'n', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length, ya._offset - DRAGGERSIZE,\n DRAGGERSIZE, DRAGGERSIZE, 'n', 'e');\n makeDragBox(gd, plotinfo, xa._offset - DRAGGERSIZE, ya._offset + ya._length,\n DRAGGERSIZE, DRAGGERSIZE, 's', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length, ya._offset + ya._length,\n DRAGGERSIZE, DRAGGERSIZE, 's', 'e');\n }\n }\n if(gd._context.showAxisDragHandles) {\n // x axis draggers - if you have overlaid plots,\n // these drag each axis separately\n if(subplot === xa._mainSubplot) {\n // the y position of the main x axis line\n var y0 = xa._mainLinePosition;\n if(xa.side === 'top') y0 -= DRAGGERSIZE;\n makeDragBox(gd, plotinfo, xa._offset + xa._length * 0.1, y0,\n xa._length * 0.8, DRAGGERSIZE, '', 'ew');\n makeDragBox(gd, plotinfo, xa._offset, y0,\n xa._length * 0.1, DRAGGERSIZE, '', 'w');\n makeDragBox(gd, plotinfo, xa._offset + xa._length * 0.9, y0,\n xa._length * 0.1, DRAGGERSIZE, '', 'e');\n }\n // y axis draggers\n if(subplot === ya._mainSubplot) {\n // the x position of the main y axis line\n var x0 = ya._mainLinePosition;\n if(ya.side !== 'right') x0 -= DRAGGERSIZE;\n makeDragBox(gd, plotinfo, x0, ya._offset + ya._length * 0.1,\n DRAGGERSIZE, ya._length * 0.8, 'ns', '');\n makeDragBox(gd, plotinfo, x0, ya._offset + ya._length * 0.9,\n DRAGGERSIZE, ya._length * 0.1, 's', '');\n makeDragBox(gd, plotinfo, x0, ya._offset,\n DRAGGERSIZE, ya._length * 0.1, 'n', '');\n }\n }\n });\n\n // In case you mousemove over some hovertext, send it to Fx.hover too\n // we do this so that we can put the hover text in front of everything,\n // but still be able to interact with everything as if it isn't there\n var hoverLayer = fullLayout._hoverlayer.node();\n\n hoverLayer.onmousemove = function(evt) {\n evt.target = gd._fullLayout._lasthover;\n Fx.hover(gd, evt, fullLayout._hoversubplot);\n };\n\n hoverLayer.onclick = function(evt) {\n evt.target = gd._fullLayout._lasthover;\n Fx.click(gd, evt);\n };\n\n // also delegate mousedowns... TODO: does this actually work?\n hoverLayer.onmousedown = function(evt) {\n gd._fullLayout._lasthover.onmousedown(evt);\n };\n\n exports.updateFx(gd);\n};\n\n// Minimal set of update needed on 'modebar' edits.\n// We only need to update the cursor style.\n//\n// Note that changing the axis configuration and/or the fixedrange attribute\n// should trigger a full initInteractions.\nexports.updateFx = function(gd) {\n var fullLayout = gd._fullLayout;\n var cursor = fullLayout.dragmode === 'pan' ? 'move' : 'crosshair';\n setCursor(fullLayout._draggers, cursor);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar tinycolor = require('tinycolor2');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar makeColorScaleFuncFromTrace = require('../../components/colorscale').makeColorScaleFuncFromTrace;\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nmodule.exports = function(gd, plotinfo, cdheatmaps, heatmapLayer) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n Lib.makeTraceGroups(heatmapLayer, cdheatmaps, 'hm').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n var z = cd0.z;\n var x = cd0.x;\n var y = cd0.y;\n var xc = cd0.xCenter;\n var yc = cd0.yCenter;\n var isContour = Registry.traceIs(trace, 'contour');\n var zsmooth = isContour ? 'best' : trace.zsmooth;\n\n // get z dims\n var m = z.length;\n var n = Lib.maxRowLength(z);\n var xrev = false;\n var yrev = false;\n\n var left, right, temp, top, bottom, i;\n\n // TODO: if there are multiple overlapping categorical heatmaps,\n // or if we allow category sorting, then the categories may not be\n // sequential... may need to reorder and/or expand z\n\n // Get edges of png in pixels (xa.c2p() maps axes coordinates to pixel coordinates)\n // figure out if either axis is reversed (y is usually reversed, in pixel coords)\n // also clip the image to maximum 50% outside the visible plot area\n // bigger image lets you pan more naturally, but slows performance.\n // TODO: use low-resolution images outside the visible plot for panning\n // these while loops find the first and last brick bounds that are defined\n // (in case of log of a negative)\n i = 0;\n while(left === undefined && i < x.length - 1) {\n left = xa.c2p(x[i]);\n i++;\n }\n i = x.length - 1;\n while(right === undefined && i > 0) {\n right = xa.c2p(x[i]);\n i--;\n }\n\n if(right < left) {\n temp = right;\n right = left;\n left = temp;\n xrev = true;\n }\n\n i = 0;\n while(top === undefined && i < y.length - 1) {\n top = ya.c2p(y[i]);\n i++;\n }\n i = y.length - 1;\n while(bottom === undefined && i > 0) {\n bottom = ya.c2p(y[i]);\n i--;\n }\n\n if(bottom < top) {\n temp = top;\n top = bottom;\n bottom = temp;\n yrev = true;\n }\n\n // for contours with heatmap fill, we generate the boundaries based on\n // brick centers but then use the brick edges for drawing the bricks\n if(isContour) {\n xc = x;\n yc = y;\n x = cd0.xfill;\n y = cd0.yfill;\n }\n\n // make an image that goes at most half a screen off either side, to keep\n // time reasonable when you zoom in. if zsmooth is true/fast, don't worry\n // about this, because zooming doesn't increase number of pixels\n // if zsmooth is best, don't include anything off screen because it takes too long\n if(zsmooth !== 'fast') {\n var extra = zsmooth === 'best' ? 0 : 0.5;\n left = Math.max(-extra * xa._length, left);\n right = Math.min((1 + extra) * xa._length, right);\n top = Math.max(-extra * ya._length, top);\n bottom = Math.min((1 + extra) * ya._length, bottom);\n }\n\n var imageWidth = Math.round(right - left);\n var imageHeight = Math.round(bottom - top);\n\n // setup image nodes\n\n // if image is entirely off-screen, don't even draw it\n var isOffScreen = (imageWidth <= 0 || imageHeight <= 0);\n\n if(isOffScreen) {\n var noImage = plotGroup.selectAll('image').data([]);\n noImage.exit().remove();\n return;\n }\n\n // generate image data\n\n var canvasW, canvasH;\n if(zsmooth === 'fast') {\n canvasW = n;\n canvasH = m;\n } else {\n canvasW = imageWidth;\n canvasH = imageHeight;\n }\n\n var canvas = document.createElement('canvas');\n canvas.width = canvasW;\n canvas.height = canvasH;\n var context = canvas.getContext('2d');\n\n var sclFunc = makeColorScaleFuncFromTrace(trace, {noNumericCheck: true, returnArray: true});\n\n // map brick boundaries to image pixels\n var xpx,\n ypx;\n if(zsmooth === 'fast') {\n xpx = xrev ?\n function(index) { return n - 1 - index; } :\n Lib.identity;\n ypx = yrev ?\n function(index) { return m - 1 - index; } :\n Lib.identity;\n } else {\n xpx = function(index) {\n return Lib.constrain(Math.round(xa.c2p(x[index]) - left),\n 0, imageWidth);\n };\n ypx = function(index) {\n return Lib.constrain(Math.round(ya.c2p(y[index]) - top),\n 0, imageHeight);\n };\n }\n\n // build the pixel map brick-by-brick\n // cruise through z-matrix row-by-row\n // build a brick at each z-matrix value\n var yi = ypx(0);\n var yb = [yi, yi];\n var xbi = xrev ? 0 : 1;\n var ybi = yrev ? 0 : 1;\n // for collecting an average luminosity of the heatmap\n var pixcount = 0;\n var rcount = 0;\n var gcount = 0;\n var bcount = 0;\n\n var xb, j, xi, v, row, c;\n\n function setColor(v, pixsize) {\n if(v !== undefined) {\n var c = sclFunc(v);\n c[0] = Math.round(c[0]);\n c[1] = Math.round(c[1]);\n c[2] = Math.round(c[2]);\n\n pixcount += pixsize;\n rcount += c[0] * pixsize;\n gcount += c[1] * pixsize;\n bcount += c[2] * pixsize;\n return c;\n }\n return [0, 0, 0, 0];\n }\n\n function interpColor(r0, r1, xinterp, yinterp) {\n var z00 = r0[xinterp.bin0];\n if(z00 === undefined) return setColor(undefined, 1);\n\n var z01 = r0[xinterp.bin1];\n var z10 = r1[xinterp.bin0];\n var z11 = r1[xinterp.bin1];\n var dx = (z01 - z00) || 0;\n var dy = (z10 - z00) || 0;\n var dxy;\n\n // the bilinear interpolation term needs different calculations\n // for all the different permutations of missing data\n // among the neighbors of the main point, to ensure\n // continuity across brick boundaries.\n if(z01 === undefined) {\n if(z11 === undefined) dxy = 0;\n else if(z10 === undefined) dxy = 2 * (z11 - z00);\n else dxy = (2 * z11 - z10 - z00) * 2 / 3;\n } else if(z11 === undefined) {\n if(z10 === undefined) dxy = 0;\n else dxy = (2 * z00 - z01 - z10) * 2 / 3;\n } else if(z10 === undefined) dxy = (2 * z11 - z01 - z00) * 2 / 3;\n else dxy = (z11 + z00 - z01 - z10);\n\n return setColor(z00 + xinterp.frac * dx + yinterp.frac * (dy + xinterp.frac * dxy));\n }\n\n if(zsmooth) { // best or fast, works fastest with imageData\n var pxIndex = 0;\n var pixels;\n\n try {\n pixels = new Uint8Array(imageWidth * imageHeight * 4);\n } catch(e) {\n pixels = new Array(imageWidth * imageHeight * 4);\n }\n\n if(zsmooth === 'best') {\n var xForPx = xc || x;\n var yForPx = yc || y;\n var xPixArray = new Array(xForPx.length);\n var yPixArray = new Array(yForPx.length);\n var xinterpArray = new Array(imageWidth);\n var findInterpX = xc ? findInterpFromCenters : findInterp;\n var findInterpY = yc ? findInterpFromCenters : findInterp;\n var yinterp, r0, r1;\n\n // first make arrays of x and y pixel locations of brick boundaries\n for(i = 0; i < xForPx.length; i++) xPixArray[i] = Math.round(xa.c2p(xForPx[i]) - left);\n for(i = 0; i < yForPx.length; i++) yPixArray[i] = Math.round(ya.c2p(yForPx[i]) - top);\n\n // then make arrays of interpolations\n // (bin0=closest, bin1=next, frac=fractional dist.)\n for(i = 0; i < imageWidth; i++) xinterpArray[i] = findInterpX(i, xPixArray);\n\n // now do the interpolations and fill the png\n for(j = 0; j < imageHeight; j++) {\n yinterp = findInterpY(j, yPixArray);\n r0 = z[yinterp.bin0];\n r1 = z[yinterp.bin1];\n for(i = 0; i < imageWidth; i++, pxIndex += 4) {\n c = interpColor(r0, r1, xinterpArray[i], yinterp);\n putColor(pixels, pxIndex, c);\n }\n }\n } else { // zsmooth = fast\n for(j = 0; j < m; j++) {\n row = z[j];\n yb = ypx(j);\n for(i = 0; i < imageWidth; i++) {\n c = setColor(row[i], 1);\n pxIndex = (yb * imageWidth + xpx(i)) * 4;\n putColor(pixels, pxIndex, c);\n }\n }\n }\n\n var imageData = context.createImageData(imageWidth, imageHeight);\n try {\n imageData.data.set(pixels);\n } catch(e) {\n var pxArray = imageData.data;\n var dlen = pxArray.length;\n for(j = 0; j < dlen; j ++) {\n pxArray[j] = pixels[j];\n }\n }\n\n context.putImageData(imageData, 0, 0);\n } else { // zsmooth = false -> filling potentially large bricks works fastest with fillRect\n // gaps do not need to be exact integers, but if they *are* we will get\n // cleaner edges by rounding at least one edge\n var xGap = trace.xgap;\n var yGap = trace.ygap;\n var xGapLeft = Math.floor(xGap / 2);\n var yGapTop = Math.floor(yGap / 2);\n\n for(j = 0; j < m; j++) {\n row = z[j];\n yb.reverse();\n yb[ybi] = ypx(j + 1);\n if(yb[0] === yb[1] || yb[0] === undefined || yb[1] === undefined) {\n continue;\n }\n xi = xpx(0);\n xb = [xi, xi];\n for(i = 0; i < n; i++) {\n // build one color brick!\n xb.reverse();\n xb[xbi] = xpx(i + 1);\n if(xb[0] === xb[1] || xb[0] === undefined || xb[1] === undefined) {\n continue;\n }\n v = row[i];\n c = setColor(v, (xb[1] - xb[0]) * (yb[1] - yb[0]));\n context.fillStyle = 'rgba(' + c.join(',') + ')';\n\n context.fillRect(xb[0] + xGapLeft, yb[0] + yGapTop,\n xb[1] - xb[0] - xGap, yb[1] - yb[0] - yGap);\n }\n }\n }\n\n rcount = Math.round(rcount / pixcount);\n gcount = Math.round(gcount / pixcount);\n bcount = Math.round(bcount / pixcount);\n var avgColor = tinycolor('rgb(' + rcount + ',' + gcount + ',' + bcount + ')');\n\n gd._hmpixcount = (gd._hmpixcount||0) + pixcount;\n gd._hmlumcount = (gd._hmlumcount||0) + pixcount * avgColor.getLuminance();\n\n var image3 = plotGroup.selectAll('image')\n .data(cd);\n\n image3.enter().append('svg:image').attr({\n xmlns: xmlnsNamespaces.svg,\n preserveAspectRatio: 'none'\n });\n\n image3.attr({\n height: imageHeight,\n width: imageWidth,\n x: left,\n y: top,\n 'xlink:href': canvas.toDataURL('image/png')\n });\n });\n};\n\n// get interpolated bin value. Returns {bin0:closest bin, frac:fractional dist to next, bin1:next bin}\nfunction findInterp(pixel, pixArray) {\n var maxBin = pixArray.length - 2;\n var bin = Lib.constrain(Lib.findBin(pixel, pixArray), 0, maxBin);\n var pix0 = pixArray[bin];\n var pix1 = pixArray[bin + 1];\n var interp = Lib.constrain(bin + (pixel - pix0) / (pix1 - pix0) - 0.5, 0, maxBin);\n var bin0 = Math.round(interp);\n var frac = Math.abs(interp - bin0);\n\n if(!interp || interp === maxBin || !frac) {\n return {\n bin0: bin0,\n bin1: bin0,\n frac: 0\n };\n }\n return {\n bin0: bin0,\n frac: frac,\n bin1: Math.round(bin0 + frac / (interp - bin0))\n };\n}\n\nfunction findInterpFromCenters(pixel, centerPixArray) {\n var maxBin = centerPixArray.length - 1;\n var bin = Lib.constrain(Lib.findBin(pixel, centerPixArray), 0, maxBin);\n var pix0 = centerPixArray[bin];\n var pix1 = centerPixArray[bin + 1];\n var frac = ((pixel - pix0) / (pix1 - pix0)) || 0;\n if(frac <= 0) {\n return {\n bin0: bin,\n bin1: bin,\n frac: 0\n };\n }\n if(frac < 0.5) {\n return {\n bin0: bin,\n bin1: bin + 1,\n frac: frac\n };\n }\n return {\n bin0: bin + 1,\n bin1: bin,\n frac: 1 - frac\n };\n}\n\nfunction putColor(pixels, pxIndex, c) {\n pixels[pxIndex] = c[0];\n pixels[pxIndex + 1] = c[1];\n pixels[pxIndex + 2] = c[2];\n pixels[pxIndex + 3] = Math.round(c[3] * 255);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar baseAttrs = require('../../plots/attributes');\nvar domainAttrs = require('../../plots/domain').attributes;\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar textFontAttrs = fontAttrs({\n editType: 'plot',\n arrayOk: true,\n colorEditType: 'plot',\n description: 'Sets the font used for `textinfo`.'\n});\n\nmodule.exports = {\n labels: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the sector labels.',\n 'If `labels` entries are duplicated, we sum associated `values`',\n 'or simply count occurrences if `values` is not provided.',\n 'For other array attributes (including color) we use the first',\n 'non-empty entry among all occurrences of the label.'\n ].join(' ')\n },\n // equivalent of x0 and dx, if label is missing\n label0: {\n valType: 'number',\n role: 'info',\n dflt: 0,\n editType: 'calc',\n description: [\n 'Alternate to `labels`.',\n 'Builds a numeric set of labels.',\n 'Use with `dlabel`',\n 'where `label0` is the starting label and `dlabel` the step.'\n ].join(' ')\n },\n dlabel: {\n valType: 'number',\n role: 'info',\n dflt: 1,\n editType: 'calc',\n description: 'Sets the label step. See `label0` for more info.'\n },\n\n values: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the values of the sectors.',\n 'If omitted, we count occurrences of each label.'\n ].join(' ')\n },\n\n marker: {\n colors: {\n valType: 'data_array', // TODO 'color_array' ?\n editType: 'calc',\n description: [\n 'Sets the color of each sector.',\n 'If not specified, the default trace color set is used',\n 'to pick the sector colors.'\n ].join(' ')\n },\n\n line: {\n color: {\n valType: 'color',\n role: 'style',\n dflt: colorAttrs.defaultLine,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the color of the line enclosing each sector.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n role: 'style',\n min: 0,\n dflt: 0,\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets the width (in px) of the line enclosing each sector.'\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'calc'\n },\n\n text: {\n valType: 'data_array',\n editType: 'plot',\n description: [\n 'Sets text elements associated with each sector.',\n 'If trace `textinfo` contains a *text* flag, these elements will be seen',\n 'on the chart.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n role: 'info',\n dflt: '',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets hover text elements associated with each sector.',\n 'If a single string, the same string appears for',\n 'all data points.',\n 'If an array of string, the items are mapped in order of',\n 'this trace\\'s sectors.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n },\n\n// 'see eg:'\n// 'https://www.e-education.psu.edu/natureofgeoinfo/sites/www.e-education.psu.edu.natureofgeoinfo/files/image/hisp_pies.gif',\n// '(this example involves a map too - may someday be a whole trace type',\n// 'of its own. but the point is the size of the whole pie is important.)'\n scalegroup: {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: 'calc',\n description: [\n 'If there are multiple pie charts that should be sized according to',\n 'their totals, link them by providing a non-empty group id here',\n 'shared by every trace in the same group.'\n ].join(' ')\n },\n\n // labels (legend is handled by plots.attributes.showlegend and layout.hiddenlabels)\n textinfo: {\n valType: 'flaglist',\n role: 'info',\n flags: ['label', 'text', 'value', 'percent'],\n extras: ['none'],\n editType: 'calc',\n description: [\n 'Determines which trace information appear on the graph.'\n ].join(' ')\n },\n hoverinfo: extendFlat({}, baseAttrs.hoverinfo, {\n flags: ['label', 'text', 'value', 'percent', 'name']\n }),\n hovertemplate: hovertemplateAttrs({}, {\n keys: ['label', 'color', 'value', 'percent', 'text']\n }),\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: ['label', 'color', 'value', 'percent', 'text']\n }),\n textposition: {\n valType: 'enumerated',\n role: 'info',\n values: ['inside', 'outside', 'auto', 'none'],\n dflt: 'auto',\n arrayOk: true,\n editType: 'plot',\n description: [\n 'Specifies the location of the `textinfo`.'\n ].join(' ')\n },\n textfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo`.'\n }),\n insidetextorientation: {\n valType: 'enumerated',\n role: 'info',\n values: ['horizontal', 'radial', 'tangential', 'auto'],\n dflt: 'auto',\n editType: 'plot',\n description: [\n 'Controls the orientation of the text inside chart sectors.',\n 'When set to *auto*, text may be oriented in any direction in order',\n 'to be as big as possible in the middle of a sector.',\n 'The *horizontal* option orients text to be parallel with the bottom',\n 'of the chart, and may make text smaller in order to achieve that goal.',\n 'The *radial* option orients text along the radius of the sector.',\n 'The *tangential* option orients text perpendicular to the radius of the sector.'\n ].join(' ')\n },\n insidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo` lying inside the sector.'\n }),\n outsidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `textinfo` lying outside the sector.'\n }),\n automargin: {\n valType: 'boolean',\n dflt: false,\n role: 'info',\n editType: 'plot',\n description: [\n 'Determines whether outside text labels can push the margins.'\n ].join(' ')\n },\n\n title: {\n text: {\n valType: 'string',\n dflt: '',\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets the title of the chart.',\n 'If it is empty, no title is displayed.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: extendFlat({}, textFontAttrs, {\n description: [\n 'Sets the font used for `title`.',\n 'Note that the title\\'s font used to be set',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n position: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle center',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n role: 'info',\n editType: 'plot',\n description: [\n 'Specifies the location of the `title`.',\n 'Note that the title\\'s position used to be set',\n 'by the now deprecated `titleposition` attribute.'\n ].join(' ')\n },\n\n editType: 'plot'\n },\n\n // position and shape\n domain: domainAttrs({name: 'pie', trace: true, editType: 'calc'}),\n\n hole: {\n valType: 'number',\n role: 'style',\n min: 0,\n max: 1,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Sets the fraction of the radius to cut out of the pie.',\n 'Use this to make a donut chart.'\n ].join(' ')\n },\n\n // ordering and direction\n sort: {\n valType: 'boolean',\n role: 'style',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether or not the sectors are reordered',\n 'from largest to smallest.'\n ].join(' ')\n },\n direction: {\n /**\n * there are two common conventions, both of which place the first\n * (largest, if sorted) slice with its left edge at 12 o'clock but\n * succeeding slices follow either cw or ccw from there.\n *\n * see http://visage.co/data-visualization-101-pie-charts/\n */\n valType: 'enumerated',\n values: ['clockwise', 'counterclockwise'],\n role: 'style',\n dflt: 'counterclockwise',\n editType: 'calc',\n description: [\n 'Specifies the direction at which succeeding sectors follow',\n 'one another.'\n ].join(' ')\n },\n rotation: {\n valType: 'number',\n role: 'style',\n min: -360,\n max: 360,\n dflt: 0,\n editType: 'calc',\n description: [\n 'Instead of the first slice starting at 12 o\\'clock,',\n 'rotate to some other angle.'\n ].join(' ')\n },\n\n pull: {\n valType: 'number',\n role: 'style',\n min: 0,\n max: 1,\n dflt: 0,\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets the fraction of larger radius to pull the sectors',\n 'out from the center. This can be a constant',\n 'to pull all slices apart from each other equally',\n 'or an array to highlight one or more slices.'\n ].join(' ')\n },\n\n _deprecated: {\n title: {\n valType: 'string',\n dflt: '',\n role: 'info',\n editType: 'calc',\n description: [\n 'Deprecated in favor of `title.text`.',\n 'Note that value of `title` is no longer a simple',\n '*string* but a set of sub-attributes.'\n ].join(' ')\n },\n titlefont: extendFlat({}, textFontAttrs, {\n description: 'Deprecated in favor of `title.font`.'\n }),\n titleposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle center',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n role: 'info',\n editType: 'calc',\n description: 'Deprecated in favor of `title.position`.'\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = {\n\n // layout attribute name\n name: 'sliders',\n\n // class names\n containerClassName: 'slider-container',\n groupClassName: 'slider-group',\n inputAreaClass: 'slider-input-area',\n railRectClass: 'slider-rail-rect',\n railTouchRectClass: 'slider-rail-touch-rect',\n gripRectClass: 'slider-grip-rect',\n tickRectClass: 'slider-tick-rect',\n inputProxyClass: 'slider-input-proxy',\n labelsClass: 'slider-labels',\n labelGroupClass: 'slider-label-group',\n labelClass: 'slider-label',\n currentValueClass: 'slider-current-value',\n\n railHeight: 5,\n\n // DOM attribute name in button group keeping track\n // of active update menu\n menuIndexAttrName: 'slider-active-index',\n\n // id root pass to Plots.autoMargin\n autoMarginIdRoot: 'slider-',\n\n // min item width / height\n minWidth: 30,\n minHeight: 30,\n\n // padding around item text\n textPadX: 40,\n\n // arrow offset off right edge\n arrowOffsetX: 4,\n\n railRadius: 2,\n railWidth: 5,\n railBorder: 4,\n railBorderWidth: 1,\n railBorderColor: '#bec8d9',\n railBgColor: '#f8fafc',\n\n // The distance of the rail from the edge of the touchable area\n // Slightly less than the step inset because of the curved edges\n // of the rail\n railInset: 8,\n\n // The distance from the extremal tick marks to the edge of the\n // touchable area. This is basically the same as the grip radius,\n // but for other styles it wouldn't really need to be.\n stepInset: 10,\n\n gripRadius: 10,\n gripWidth: 20,\n gripHeight: 20,\n gripBorder: 20,\n gripBorderWidth: 1,\n gripBorderColor: '#bec8d9',\n gripBgColor: '#f6f8fa',\n gripBgActiveColor: '#dbdde0',\n\n labelPadding: 8,\n labelOffset: 0,\n\n tickWidth: 1,\n tickColor: '#333',\n tickOffset: 25,\n tickLength: 7,\n\n minorTickOffset: 25,\n minorTickColor: '#333',\n minorTickLength: 4,\n\n // Extra space below the current value label:\n currentValuePadding: 8,\n currentValueInset: 0,\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\nvar Template = require('../../plot_api/plot_template');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\n\nmodule.exports = function handleDefaults(containerIn, containerOut, layout, counterAxes, calendar) {\n var selectorIn = containerIn.rangeselector || {};\n var selectorOut = Template.newContainer(containerOut, 'rangeselector');\n\n function coerce(attr, dflt) {\n return Lib.coerce(selectorIn, selectorOut, attributes, attr, dflt);\n }\n\n var buttons = handleArrayContainerDefaults(selectorIn, selectorOut, {\n name: 'buttons',\n handleItemDefaults: buttonDefaults,\n calendar: calendar\n });\n\n var visible = coerce('visible', buttons.length > 0);\n if(visible) {\n var posDflt = getPosDflt(containerOut, layout, counterAxes);\n coerce('x', posDflt[0]);\n coerce('y', posDflt[1]);\n Lib.noneOrAll(containerIn, containerOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n Lib.coerceFont(coerce, 'font', layout.font);\n\n var bgColor = coerce('bgcolor');\n coerce('activecolor', Color.contrast(bgColor, constants.lightAmount, constants.darkAmount));\n coerce('bordercolor');\n coerce('borderwidth');\n }\n};\n\nfunction buttonDefaults(buttonIn, buttonOut, selectorOut, opts) {\n var calendar = opts.calendar;\n\n function coerce(attr, dflt) {\n return Lib.coerce(buttonIn, buttonOut, attributes.buttons, attr, dflt);\n }\n\n var visible = coerce('visible');\n\n if(visible) {\n var step = coerce('step');\n if(step !== 'all') {\n if(calendar && calendar !== 'gregorian' && (step === 'month' || step === 'year')) {\n buttonOut.stepmode = 'backward';\n } else {\n coerce('stepmode');\n }\n\n coerce('count');\n }\n\n coerce('label');\n }\n}\n\nfunction getPosDflt(containerOut, layout, counterAxes) {\n var anchoredList = counterAxes.filter(function(ax) {\n return layout[ax].anchor === containerOut._id;\n });\n\n var posY = 0;\n for(var i = 0; i < anchoredList.length; i++) {\n var domain = layout[anchoredList[i]].domain;\n if(domain) posY = Math.max(domain[1], posY);\n }\n\n return [containerOut.domain[0], posY + constants.yPad];\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n mode: {\n valType: 'enumerated',\n dflt: 'afterall',\n role: 'info',\n values: ['immediate', 'next', 'afterall'],\n description: [\n 'Describes how a new animate call interacts with currently-running',\n 'animations. If `immediate`, current animations are interrupted and',\n 'the new animation is started. If `next`, the current frame is allowed',\n 'to complete, after which the new animation is started. If `afterall`',\n 'all existing frames are animated to completion before the new animation',\n 'is started.'\n ].join(' ')\n },\n direction: {\n valType: 'enumerated',\n role: 'info',\n values: ['forward', 'reverse'],\n dflt: 'forward',\n description: [\n 'The direction in which to play the frames triggered by the animation call'\n ].join(' ')\n },\n fromcurrent: {\n valType: 'boolean',\n dflt: false,\n role: 'info',\n description: [\n 'Play frames starting at the current frame instead of the beginning.'\n ].join(' ')\n },\n frame: {\n duration: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 500,\n description: [\n 'The duration in milliseconds of each frame. If greater than the frame',\n 'duration, it will be limited to the frame duration.'\n ].join(' ')\n },\n redraw: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n description: [\n 'Redraw the plot at completion of the transition. This is desirable',\n 'for transitions that include properties that cannot be transitioned,',\n 'but may significantly slow down updates that do not require a full',\n 'redraw of the plot'\n ].join(' ')\n },\n },\n transition: {\n duration: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 500,\n editType: 'none',\n description: [\n 'The duration of the transition, in milliseconds. If equal to zero,',\n 'updates are synchronous.'\n ].join(' ')\n },\n easing: {\n valType: 'enumerated',\n dflt: 'cubic-in-out',\n values: [\n 'linear',\n 'quad',\n 'cubic',\n 'sin',\n 'exp',\n 'circle',\n 'elastic',\n 'back',\n 'bounce',\n 'linear-in',\n 'quad-in',\n 'cubic-in',\n 'sin-in',\n 'exp-in',\n 'circle-in',\n 'elastic-in',\n 'back-in',\n 'bounce-in',\n 'linear-out',\n 'quad-out',\n 'cubic-out',\n 'sin-out',\n 'exp-out',\n 'circle-out',\n 'elastic-out',\n 'back-out',\n 'bounce-out',\n 'linear-in-out',\n 'quad-in-out',\n 'cubic-in-out',\n 'sin-in-out',\n 'exp-in-out',\n 'circle-in-out',\n 'elastic-in-out',\n 'back-in-out',\n 'bounce-in-out'\n ],\n role: 'info',\n editType: 'none',\n description: 'The easing function used for the transition'\n },\n ordering: {\n valType: 'enumerated',\n values: ['layout first', 'traces first'],\n dflt: 'layout first',\n role: 'info',\n editType: 'none',\n description: [\n 'Determines whether the figure\\'s layout or traces smoothly transitions',\n 'during updates that make both traces and layout change.'\n ].join(' ')\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n // hover labels for multiple horizontal bars get tilted by this angle\n YANGLE: 60,\n\n // size and display constants for hover text\n\n // pixel size of hover arrows\n HOVERARROWSIZE: 6,\n // pixels padding around text\n HOVERTEXTPAD: 3,\n // hover font\n HOVERFONTSIZE: 13,\n HOVERFONT: 'Arial, sans-serif',\n\n // minimum time (msec) between hover calls\n HOVERMINTIME: 50,\n\n // ID suffix (with fullLayout._uid) for hover events in the throttle cache\n HOVERID: '-hover'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n moduleType: 'locale',\n name: 'en-US',\n dictionary: {\n 'Click to enter Colorscale title': 'Click to enter Colorscale title'\n },\n format: {\n date: '%m/%d/%Y'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar m4FromQuat = require('gl-mat4/fromQuat');\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\nvar Plots = require('../plots/plots');\nvar AxisIds = require('../plots/cartesian/axis_ids');\nvar Color = require('../components/color');\n\nvar cleanId = AxisIds.cleanId;\nvar getFromTrace = AxisIds.getFromTrace;\nvar traceIs = Registry.traceIs;\n\n// clear the promise queue if one of them got rejected\nexports.clearPromiseQueue = function(gd) {\n if(Array.isArray(gd._promises) && gd._promises.length > 0) {\n Lib.log('Clearing previous rejected promises from queue.');\n }\n\n gd._promises = [];\n};\n\n// make a few changes to the layout right away\n// before it gets used for anything\n// backward compatibility and cleanup of nonstandard options\nexports.cleanLayout = function(layout) {\n var i, j;\n\n if(!layout) layout = {};\n\n // cannot have (x|y)axis1, numbering goes axis, axis2, axis3...\n if(layout.xaxis1) {\n if(!layout.xaxis) layout.xaxis = layout.xaxis1;\n delete layout.xaxis1;\n }\n if(layout.yaxis1) {\n if(!layout.yaxis) layout.yaxis = layout.yaxis1;\n delete layout.yaxis1;\n }\n if(layout.scene1) {\n if(!layout.scene) layout.scene = layout.scene1;\n delete layout.scene1;\n }\n\n var axisAttrRegex = (Plots.subplotsRegistry.cartesian || {}).attrRegex;\n var polarAttrRegex = (Plots.subplotsRegistry.polar || {}).attrRegex;\n var ternaryAttrRegex = (Plots.subplotsRegistry.ternary || {}).attrRegex;\n var sceneAttrRegex = (Plots.subplotsRegistry.gl3d || {}).attrRegex;\n\n var keys = Object.keys(layout);\n for(i = 0; i < keys.length; i++) {\n var key = keys[i];\n\n if(axisAttrRegex && axisAttrRegex.test(key)) {\n // modifications to cartesian axes\n\n var ax = layout[key];\n if(ax.anchor && ax.anchor !== 'free') {\n ax.anchor = cleanId(ax.anchor);\n }\n if(ax.overlaying) ax.overlaying = cleanId(ax.overlaying);\n\n // old method of axis type - isdate and islog (before category existed)\n if(!ax.type) {\n if(ax.isdate) ax.type = 'date';\n else if(ax.islog) ax.type = 'log';\n else if(ax.isdate === false && ax.islog === false) ax.type = 'linear';\n }\n if(ax.autorange === 'withzero' || ax.autorange === 'tozero') {\n ax.autorange = true;\n ax.rangemode = 'tozero';\n }\n delete ax.islog;\n delete ax.isdate;\n delete ax.categories; // replaced by _categories\n\n // prune empty domain arrays made before the new nestedProperty\n if(emptyContainer(ax, 'domain')) delete ax.domain;\n\n // autotick -> tickmode\n if(ax.autotick !== undefined) {\n if(ax.tickmode === undefined) {\n ax.tickmode = ax.autotick ? 'auto' : 'linear';\n }\n delete ax.autotick;\n }\n\n cleanTitle(ax);\n } else if(polarAttrRegex && polarAttrRegex.test(key)) {\n // modifications for polar\n\n var polar = layout[key];\n cleanTitle(polar.radialaxis);\n } else if(ternaryAttrRegex && ternaryAttrRegex.test(key)) {\n // modifications for ternary\n\n var ternary = layout[key];\n cleanTitle(ternary.aaxis);\n cleanTitle(ternary.baxis);\n cleanTitle(ternary.caxis);\n } else if(sceneAttrRegex && sceneAttrRegex.test(key)) {\n // modifications for 3D scenes\n\n var scene = layout[key];\n\n // clean old Camera coords\n var cameraposition = scene.cameraposition;\n\n if(Array.isArray(cameraposition) && cameraposition[0].length === 4) {\n var rotation = cameraposition[0];\n var center = cameraposition[1];\n var radius = cameraposition[2];\n var mat = m4FromQuat([], rotation);\n var eye = [];\n\n for(j = 0; j < 3; ++j) {\n eye[j] = center[j] + radius * mat[2 + 4 * j];\n }\n\n scene.camera = {\n eye: {x: eye[0], y: eye[1], z: eye[2]},\n center: {x: center[0], y: center[1], z: center[2]},\n up: {x: 0, y: 0, z: 1} // we just ignore calculating camera z up in this case\n };\n\n delete scene.cameraposition;\n }\n\n // clean axis titles\n cleanTitle(scene.xaxis);\n cleanTitle(scene.yaxis);\n cleanTitle(scene.zaxis);\n }\n }\n\n var annotationsLen = Array.isArray(layout.annotations) ? layout.annotations.length : 0;\n for(i = 0; i < annotationsLen; i++) {\n var ann = layout.annotations[i];\n\n if(!Lib.isPlainObject(ann)) continue;\n\n if(ann.ref) {\n if(ann.ref === 'paper') {\n ann.xref = 'paper';\n ann.yref = 'paper';\n } else if(ann.ref === 'data') {\n ann.xref = 'x';\n ann.yref = 'y';\n }\n delete ann.ref;\n }\n\n cleanAxRef(ann, 'xref');\n cleanAxRef(ann, 'yref');\n }\n\n var shapesLen = Array.isArray(layout.shapes) ? layout.shapes.length : 0;\n for(i = 0; i < shapesLen; i++) {\n var shape = layout.shapes[i];\n\n if(!Lib.isPlainObject(shape)) continue;\n\n cleanAxRef(shape, 'xref');\n cleanAxRef(shape, 'yref');\n }\n\n var legend = layout.legend;\n if(legend) {\n // check for old-style legend positioning (x or y is +/- 100)\n if(legend.x > 3) {\n legend.x = 1.02;\n legend.xanchor = 'left';\n } else if(legend.x < -2) {\n legend.x = -0.02;\n legend.xanchor = 'right';\n }\n\n if(legend.y > 3) {\n legend.y = 1.02;\n legend.yanchor = 'bottom';\n } else if(legend.y < -2) {\n legend.y = -0.02;\n legend.yanchor = 'top';\n }\n }\n\n // clean plot title\n cleanTitle(layout);\n\n /*\n * Moved from rotate -> orbit for dragmode\n */\n if(layout.dragmode === 'rotate') layout.dragmode = 'orbit';\n\n // sanitize rgb(fractions) and rgba(fractions) that old tinycolor\n // supported, but new tinycolor does not because they're not valid css\n Color.clean(layout);\n\n // clean the layout container in layout.template\n if(layout.template && layout.template.layout) {\n exports.cleanLayout(layout.template.layout);\n }\n\n return layout;\n};\n\nfunction cleanAxRef(container, attr) {\n var valIn = container[attr];\n var axLetter = attr.charAt(0);\n if(valIn && valIn !== 'paper') {\n container[attr] = cleanId(valIn, axLetter);\n }\n}\n\n/**\n * Cleans up old title attribute structure (flat) in favor of the new one (nested).\n *\n * @param {Object} titleContainer - an object potentially including deprecated title attributes\n */\nfunction cleanTitle(titleContainer) {\n if(titleContainer) {\n // title -> title.text\n // (although title used to be a string attribute,\n // numbers are accepted as well)\n if(typeof titleContainer.title === 'string' || typeof titleContainer.title === 'number') {\n titleContainer.title = {\n text: titleContainer.title\n };\n }\n\n rewireAttr('titlefont', 'font');\n rewireAttr('titleposition', 'position');\n rewireAttr('titleside', 'side');\n rewireAttr('titleoffset', 'offset');\n }\n\n function rewireAttr(oldAttrName, newAttrName) {\n var oldAttrSet = titleContainer[oldAttrName];\n var newAttrSet = titleContainer.title && titleContainer.title[newAttrName];\n\n if(oldAttrSet && !newAttrSet) {\n // Ensure title object exists\n if(!titleContainer.title) {\n titleContainer.title = {};\n }\n\n titleContainer.title[newAttrName] = titleContainer[oldAttrName];\n delete titleContainer[oldAttrName];\n }\n }\n}\n\n/*\n * cleanData: Make a few changes to the data for backward compatibility\n * before it gets used for anything. Modifies the data traces users provide.\n *\n * Important: if you're going to add something here that modifies a data array,\n * update it in place so the new array === the old one.\n */\nexports.cleanData = function(data) {\n for(var tracei = 0; tracei < data.length; tracei++) {\n var trace = data[tracei];\n var i;\n\n // use xbins to bin data in x, and ybins to bin data in y\n if(trace.type === 'histogramy' && 'xbins' in trace && !('ybins' in trace)) {\n trace.ybins = trace.xbins;\n delete trace.xbins;\n }\n\n // error_y.opacity is obsolete - merge into color\n if(trace.error_y && 'opacity' in trace.error_y) {\n var dc = Color.defaults;\n var yeColor = trace.error_y.color || (traceIs(trace, 'bar') ?\n Color.defaultLine :\n dc[tracei % dc.length]);\n trace.error_y.color = Color.addOpacity(\n Color.rgb(yeColor),\n Color.opacity(yeColor) * trace.error_y.opacity);\n delete trace.error_y.opacity;\n }\n\n // convert bardir to orientation, and put the data into\n // the axes it's eventually going to be used with\n if('bardir' in trace) {\n if(trace.bardir === 'h' && (traceIs(trace, 'bar') ||\n trace.type.substr(0, 9) === 'histogram')) {\n trace.orientation = 'h';\n exports.swapXYData(trace);\n }\n delete trace.bardir;\n }\n\n // now we have only one 1D histogram type, and whether\n // it uses x or y data depends on trace.orientation\n if(trace.type === 'histogramy') exports.swapXYData(trace);\n if(trace.type === 'histogramx' || trace.type === 'histogramy') {\n trace.type = 'histogram';\n }\n\n // scl->scale, reversescl->reversescale\n if('scl' in trace && !('colorscale' in trace)) {\n trace.colorscale = trace.scl;\n delete trace.scl;\n }\n if('reversescl' in trace && !('reversescale' in trace)) {\n trace.reversescale = trace.reversescl;\n delete trace.reversescl;\n }\n\n // axis ids x1 -> x, y1-> y\n if(trace.xaxis) trace.xaxis = cleanId(trace.xaxis, 'x');\n if(trace.yaxis) trace.yaxis = cleanId(trace.yaxis, 'y');\n\n // scene ids scene1 -> scene\n if(traceIs(trace, 'gl3d') && trace.scene) {\n trace.scene = Plots.subplotsRegistry.gl3d.cleanId(trace.scene);\n }\n\n if(!traceIs(trace, 'pie-like') && !traceIs(trace, 'bar-like')) {\n if(Array.isArray(trace.textposition)) {\n for(i = 0; i < trace.textposition.length; i++) {\n trace.textposition[i] = cleanTextPosition(trace.textposition[i]);\n }\n } else if(trace.textposition) {\n trace.textposition = cleanTextPosition(trace.textposition);\n }\n }\n\n // fix typo in colorscale definition\n var _module = Registry.getModule(trace);\n if(_module && _module.colorbar) {\n var containerName = _module.colorbar.container;\n var container = containerName ? trace[containerName] : trace;\n if(container && container.colorscale) {\n if(container.colorscale === 'YIGnBu') container.colorscale = 'YlGnBu';\n if(container.colorscale === 'YIOrRd') container.colorscale = 'YlOrRd';\n }\n }\n\n // fix typo in surface 'highlight*' definitions\n if(trace.type === 'surface' && Lib.isPlainObject(trace.contours)) {\n var dims = ['x', 'y', 'z'];\n\n for(i = 0; i < dims.length; i++) {\n var opts = trace.contours[dims[i]];\n\n if(!Lib.isPlainObject(opts)) continue;\n\n if(opts.highlightColor) {\n opts.highlightcolor = opts.highlightColor;\n delete opts.highlightColor;\n }\n\n if(opts.highlightWidth) {\n opts.highlightwidth = opts.highlightWidth;\n delete opts.highlightWidth;\n }\n }\n }\n\n // fixes from converting finance from transforms to real trace types\n if(trace.type === 'candlestick' || trace.type === 'ohlc') {\n var increasingShowlegend = (trace.increasing || {}).showlegend !== false;\n var decreasingShowlegend = (trace.decreasing || {}).showlegend !== false;\n var increasingName = cleanFinanceDir(trace.increasing);\n var decreasingName = cleanFinanceDir(trace.decreasing);\n\n // now figure out something smart to do with the separate direction\n // names we removed\n if((increasingName !== false) && (decreasingName !== false)) {\n // both sub-names existed: base name previously had no effect\n // so ignore it and try to find a shared part of the sub-names\n\n var newName = commonPrefix(\n increasingName, decreasingName,\n increasingShowlegend, decreasingShowlegend\n );\n // if no common part, leave whatever name was (or wasn't) there\n if(newName) trace.name = newName;\n } else if((increasingName || decreasingName) && !trace.name) {\n // one sub-name existed but not the base name - just use the sub-name\n trace.name = increasingName || decreasingName;\n }\n }\n\n // transforms backward compatibility fixes\n if(Array.isArray(trace.transforms)) {\n var transforms = trace.transforms;\n\n for(i = 0; i < transforms.length; i++) {\n var transform = transforms[i];\n\n if(!Lib.isPlainObject(transform)) continue;\n\n switch(transform.type) {\n case 'filter':\n if(transform.filtersrc) {\n transform.target = transform.filtersrc;\n delete transform.filtersrc;\n }\n\n if(transform.calendar) {\n if(!transform.valuecalendar) {\n transform.valuecalendar = transform.calendar;\n }\n delete transform.calendar;\n }\n break;\n\n case 'groupby':\n // Name has changed from `style` to `styles`, so use `style` but prefer `styles`:\n transform.styles = transform.styles || transform.style;\n\n if(transform.styles && !Array.isArray(transform.styles)) {\n var prevStyles = transform.styles;\n var styleKeys = Object.keys(prevStyles);\n\n transform.styles = [];\n for(var j = 0; j < styleKeys.length; j++) {\n transform.styles.push({\n target: styleKeys[j],\n value: prevStyles[styleKeys[j]]\n });\n }\n }\n break;\n }\n }\n }\n\n // prune empty containers made before the new nestedProperty\n if(emptyContainer(trace, 'line')) delete trace.line;\n if('marker' in trace) {\n if(emptyContainer(trace.marker, 'line')) delete trace.marker.line;\n if(emptyContainer(trace, 'marker')) delete trace.marker;\n }\n\n // sanitize rgb(fractions) and rgba(fractions) that old tinycolor\n // supported, but new tinycolor does not because they're not valid css\n Color.clean(trace);\n\n // remove obsolete autobin(x|y) attributes, but only if true\n // if false, this needs to happen in Histogram.calc because it\n // can be a one-time autobin so we need to know the results before\n // we can push them back into the trace.\n if(trace.autobinx) {\n delete trace.autobinx;\n delete trace.xbins;\n }\n if(trace.autobiny) {\n delete trace.autobiny;\n delete trace.ybins;\n }\n\n cleanTitle(trace);\n if(trace.colorbar) cleanTitle(trace.colorbar);\n if(trace.marker && trace.marker.colorbar) cleanTitle(trace.marker.colorbar);\n if(trace.line && trace.line.colorbar) cleanTitle(trace.line.colorbar);\n if(trace.aaxis) cleanTitle(trace.aaxis);\n if(trace.baxis) cleanTitle(trace.baxis);\n }\n};\n\nfunction cleanFinanceDir(dirContainer) {\n if(!Lib.isPlainObject(dirContainer)) return false;\n\n var dirName = dirContainer.name;\n\n delete dirContainer.name;\n delete dirContainer.showlegend;\n\n return (typeof dirName === 'string' || typeof dirName === 'number') && String(dirName);\n}\n\nfunction commonPrefix(name1, name2, show1, show2) {\n // if only one is shown in the legend, use that\n if(show1 && !show2) return name1;\n if(show2 && !show1) return name2;\n\n // if both or neither are in the legend, check if one is blank (or whitespace)\n // and use the other one\n // note that hover labels can still use the name even if the legend doesn't\n if(!name1.trim()) return name2;\n if(!name2.trim()) return name1;\n\n var minLen = Math.min(name1.length, name2.length);\n var i;\n for(i = 0; i < minLen; i++) {\n if(name1.charAt(i) !== name2.charAt(i)) break;\n }\n\n var out = name1.substr(0, i);\n return out.trim();\n}\n\n// textposition - support partial attributes (ie just 'top')\n// and incorrect use of middle / center etc.\nfunction cleanTextPosition(textposition) {\n var posY = 'middle';\n var posX = 'center';\n\n if(typeof textposition === 'string') {\n if(textposition.indexOf('top') !== -1) posY = 'top';\n else if(textposition.indexOf('bottom') !== -1) posY = 'bottom';\n\n if(textposition.indexOf('left') !== -1) posX = 'left';\n else if(textposition.indexOf('right') !== -1) posX = 'right';\n }\n\n return posY + ' ' + posX;\n}\n\nfunction emptyContainer(outer, innerStr) {\n return (innerStr in outer) &&\n (typeof outer[innerStr] === 'object') &&\n (Object.keys(outer[innerStr]).length === 0);\n}\n\n\n// swap all the data and data attributes associated with x and y\nexports.swapXYData = function(trace) {\n var i;\n Lib.swapAttrs(trace, ['?', '?0', 'd?', '?bins', 'nbins?', 'autobin?', '?src', 'error_?']);\n if(Array.isArray(trace.z) && Array.isArray(trace.z[0])) {\n if(trace.transpose) delete trace.transpose;\n else trace.transpose = true;\n }\n if(trace.error_x && trace.error_y) {\n var errorY = trace.error_y;\n var copyYstyle = ('copy_ystyle' in errorY) ?\n errorY.copy_ystyle :\n !(errorY.color || errorY.thickness || errorY.width);\n Lib.swapAttrs(trace, ['error_?.copy_ystyle']);\n if(copyYstyle) {\n Lib.swapAttrs(trace, ['error_?.color', 'error_?.thickness', 'error_?.width']);\n }\n }\n if(typeof trace.hoverinfo === 'string') {\n var hoverInfoParts = trace.hoverinfo.split('+');\n for(i = 0; i < hoverInfoParts.length; i++) {\n if(hoverInfoParts[i] === 'x') hoverInfoParts[i] = 'y';\n else if(hoverInfoParts[i] === 'y') hoverInfoParts[i] = 'x';\n }\n trace.hoverinfo = hoverInfoParts.join('+');\n }\n};\n\n// coerce traceIndices input to array of trace indices\nexports.coerceTraceIndices = function(gd, traceIndices) {\n if(isNumeric(traceIndices)) {\n return [traceIndices];\n } else if(!Array.isArray(traceIndices) || !traceIndices.length) {\n return gd.data.map(function(_, i) { return i; });\n } else if(Array.isArray(traceIndices)) {\n var traceIndicesOut = [];\n for(var i = 0; i < traceIndices.length; i++) {\n if(Lib.isIndex(traceIndices[i], gd.data.length)) {\n traceIndicesOut.push(traceIndices[i]);\n } else {\n Lib.warn('trace index (', traceIndices[i], ') is not a number or is out of bounds');\n }\n }\n return traceIndicesOut;\n }\n\n return traceIndices;\n};\n\n/**\n * Manages logic around array container item creation / deletion / update\n * that nested property alone can't handle.\n *\n * @param {Object} np\n * nested property of update attribute string about trace or layout object\n * @param {*} newVal\n * update value passed to restyle / relayout / update\n * @param {Object} undoit\n * undo hash (N.B. undoit may be mutated here).\n *\n */\nexports.manageArrayContainers = function(np, newVal, undoit) {\n var obj = np.obj;\n var parts = np.parts;\n var pLength = parts.length;\n var pLast = parts[pLength - 1];\n\n var pLastIsNumber = isNumeric(pLast);\n\n if(pLastIsNumber && newVal === null) {\n // delete item\n\n // Clear item in array container when new value is null\n var contPath = parts.slice(0, pLength - 1).join('.');\n var cont = Lib.nestedProperty(obj, contPath).get();\n cont.splice(pLast, 1);\n\n // Note that nested property clears null / undefined at end of\n // array container, but not within them.\n } else if(pLastIsNumber && np.get() === undefined) {\n // create item\n\n // When adding a new item, make sure undo command will remove it\n if(np.get() === undefined) undoit[np.astr] = null;\n\n np.set(newVal);\n } else {\n // update item\n\n // If the last part of attribute string isn't a number,\n // np.set is all we need.\n np.set(newVal);\n }\n};\n\n/*\n * Match the part to strip off to turn an attribute into its parent\n * really it should be either '.some_characters' or '[number]'\n * but we're a little more permissive here and match either\n * '.not_brackets_or_dot' or '[not_brackets_or_dot]'\n */\nvar ATTR_TAIL_RE = /(\\.[^\\[\\]\\.]+|\\[[^\\[\\]\\.]+\\])$/;\n\nfunction getParent(attr) {\n var tail = attr.search(ATTR_TAIL_RE);\n if(tail > 0) return attr.substr(0, tail);\n}\n\n/*\n * hasParent: does an attribute object contain a parent of the given attribute?\n * for example, given 'images[2].x' do we also have 'images' or 'images[2]'?\n *\n * @param {Object} aobj\n * update object, whose keys are attribute strings and values are their new settings\n * @param {string} attr\n * the attribute string to test against\n * @returns {Boolean}\n * is a parent of attr present in aobj?\n */\nexports.hasParent = function(aobj, attr) {\n var attrParent = getParent(attr);\n while(attrParent) {\n if(attrParent in aobj) return true;\n attrParent = getParent(attrParent);\n }\n return false;\n};\n\n/**\n * Empty out types for all axes containing these traces so we auto-set them again\n *\n * @param {object} gd\n * @param {[integer]} traces: trace indices to search for axes to clear the types of\n * @param {object} layoutUpdate: any update being done concurrently to the layout,\n * which may supercede clearing the axis types\n */\nvar axLetters = ['x', 'y', 'z'];\nexports.clearAxisTypes = function(gd, traces, layoutUpdate) {\n for(var i = 0; i < traces.length; i++) {\n var trace = gd._fullData[i];\n for(var j = 0; j < 3; j++) {\n var ax = getFromTrace(gd, trace, axLetters[j]);\n\n // do not clear log type - that's never an auto result so must have been intentional\n if(ax && ax.type !== 'log') {\n var axAttr = ax._name;\n var sceneName = ax._id.substr(1);\n if(sceneName.substr(0, 5) === 'scene') {\n if(layoutUpdate[sceneName] !== undefined) continue;\n axAttr = sceneName + '.' + axAttr;\n }\n var typeAttr = axAttr + '.type';\n\n if(layoutUpdate[axAttr] === undefined && layoutUpdate[typeAttr] === undefined) {\n Lib.nestedProperty(gd.layout, typeAttr).set(null);\n }\n }\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function convert(scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var anns = fullSceneLayout.annotations;\n\n for(var i = 0; i < anns.length; i++) {\n mockAnnAxes(anns[i], scene);\n }\n\n scene.fullLayout._infolayer\n .selectAll('.annotation-' + scene.id)\n .remove();\n};\n\nfunction mockAnnAxes(ann, scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var domain = fullSceneLayout.domain;\n var size = scene.fullLayout._size;\n\n var base = {\n // this gets fill in on render\n pdata: null,\n\n // to get setConvert to not execute cleanly\n type: 'linear',\n\n // don't try to update them on `editable: true`\n autorange: false,\n\n // set infinite range so that annotation draw routine\n // does not try to remove 'outside-range' annotations,\n // this case is handled in the render loop\n range: [-Infinity, Infinity]\n };\n\n ann._xa = {};\n Lib.extendFlat(ann._xa, base);\n Axes.setConvert(ann._xa);\n ann._xa._offset = size.l + domain.x[0] * size.w;\n ann._xa.l2p = function() {\n return 0.5 * (1 + ann._pdata[0] / ann._pdata[3]) * size.w * (domain.x[1] - domain.x[0]);\n };\n\n ann._ya = {};\n Lib.extendFlat(ann._ya, base);\n Axes.setConvert(ann._ya);\n ann._ya._offset = size.t + (1 - domain.y[1]) * size.h;\n ann._ya.l2p = function() {\n return 0.5 * (1 - ann._pdata[1] / ann._pdata[3]) * size.h * (domain.y[1] - domain.y[0]);\n };\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n barmode: {\n valType: 'enumerated',\n values: ['stack', 'group', 'overlay', 'relative'],\n dflt: 'group',\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines how bars at the same location coordinate',\n 'are displayed on the graph.',\n 'With *stack*, the bars are stacked on top of one another',\n 'With *relative*, the bars are stacked on top of one another,',\n 'with negative values below the axis, positive values above',\n 'With *group*, the bars are plotted next to one another',\n 'centered around the shared location.',\n 'With *overlay*, the bars are plotted over one another,',\n 'you might need to an *opacity* to see multiple bars.'\n ].join(' ')\n },\n barnorm: {\n valType: 'enumerated',\n values: ['', 'fraction', 'percent'],\n dflt: '',\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the normalization for bar traces on the graph.',\n 'With *fraction*, the value of each bar is divided by the sum of all',\n 'values at that location coordinate.',\n '*percent* is the same but multiplied by 100 to show percentages.'\n ].join(' ')\n },\n bargap: {\n valType: 'number',\n min: 0,\n max: 1,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'adjacent location coordinates.'\n ].join(' ')\n },\n bargroupgap: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the gap (in plot fraction) between bars of',\n 'the same location coordinate.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\n\n// defaults common to 'annotations' and 'annotations3d'\nmodule.exports = function handleAnnotationCommonDefaults(annIn, annOut, fullLayout, coerce) {\n coerce('opacity');\n var bgColor = coerce('bgcolor');\n\n var borderColor = coerce('bordercolor');\n var borderOpacity = Color.opacity(borderColor);\n\n coerce('borderpad');\n\n var borderWidth = coerce('borderwidth');\n var showArrow = coerce('showarrow');\n\n coerce('text', showArrow ? ' ' : fullLayout._dfltTitle.annotation);\n coerce('textangle');\n Lib.coerceFont(coerce, 'font', fullLayout.font);\n\n coerce('width');\n coerce('align');\n\n var h = coerce('height');\n if(h) coerce('valign');\n\n if(showArrow) {\n var arrowside = coerce('arrowside');\n var arrowhead;\n var arrowsize;\n\n if(arrowside.indexOf('end') !== -1) {\n arrowhead = coerce('arrowhead');\n arrowsize = coerce('arrowsize');\n }\n\n if(arrowside.indexOf('start') !== -1) {\n coerce('startarrowhead', arrowhead);\n coerce('startarrowsize', arrowsize);\n }\n coerce('arrowcolor', borderOpacity ? annOut.bordercolor : Color.defaultLine);\n coerce('arrowwidth', ((borderOpacity && borderWidth) || 1) * 2);\n coerce('standoff');\n coerce('startstandoff');\n }\n\n var hoverText = coerce('hovertext');\n var globalHoverLabel = fullLayout.hoverlabel || {};\n\n if(hoverText) {\n var hoverBG = coerce('hoverlabel.bgcolor', globalHoverLabel.bgcolor ||\n (Color.opacity(bgColor) ? Color.rgb(bgColor) : Color.defaultLine)\n );\n\n var hoverBorder = coerce('hoverlabel.bordercolor', globalHoverLabel.bordercolor ||\n Color.contrast(hoverBG)\n );\n\n Lib.coerceFont(coerce, 'hoverlabel.font', {\n family: globalHoverLabel.font.family,\n size: globalHoverLabel.font.size,\n color: globalHoverLabel.font.color || hoverBorder\n });\n }\n\n coerce('captureevents', !!hoverText);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n/**\n * Return news array containing only the unique items\n * found in input array.\n *\n * IMPORTANT: Note that items are considered unique\n * if `String({})` is unique. For example;\n *\n * Lib.filterUnique([ { a: 1 }, { b: 2 } ])\n *\n * returns [{ a: 1 }]\n *\n * and\n *\n * Lib.filterUnique([ '1', 1 ])\n *\n * returns ['1']\n *\n *\n * @param {array} array base array\n * @return {array} new filtered array\n */\nmodule.exports = function filterUnique(array) {\n var seen = {};\n var out = [];\n var j = 0;\n\n for(var i = 0; i < array.length; i++) {\n var item = array[i];\n\n if(seen[item] !== 1) {\n seen[item] = 1;\n out[j++] = item;\n }\n }\n\n return out;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar FP_SAFE = require('../../constants/numerical').FP_SAFE;\nvar Registry = require('../../registry');\n\nmodule.exports = {\n getAutoRange: getAutoRange,\n makePadFn: makePadFn,\n doAutoRange: doAutoRange,\n findExtremes: findExtremes,\n concatExtremes: concatExtremes\n};\n\n/**\n * getAutoRange\n *\n * Collects all _extremes values corresponding to a given axis\n * and computes its auto range.\n *\n * Note that getAutoRange uses return values from findExtremes.\n *\n * @param {object} gd:\n * graph div object with filled-in fullData and fullLayout, in particular\n * with filled-in '_extremes' containers:\n * {\n * val: calcdata value,\n * pad: extra pixels beyond this value,\n * extrapad: bool, does this point want 5% extra padding\n * }\n * @param {object} ax:\n * full axis object, in particular with filled-in '_traceIndices'\n * and '_annIndices' / '_shapeIndices' if applicable\n * @return {array}\n * an array of [min, max]. These are calcdata for log and category axes\n * and data for linear and date axes.\n *\n * TODO: we want to change log to data as well, but it's hard to do this\n * maintaining backward compatibility. category will always have to use calcdata\n * though, because otherwise values between categories (or outside all categories)\n * would be impossible.\n */\nfunction getAutoRange(gd, ax) {\n var i, j;\n var newRange = [];\n\n var getPad = makePadFn(ax);\n var extremes = concatExtremes(gd, ax);\n var minArray = extremes.min;\n var maxArray = extremes.max;\n\n if(minArray.length === 0 || maxArray.length === 0) {\n return Lib.simpleMap(ax.range, ax.r2l);\n }\n\n var minmin = minArray[0].val;\n var maxmax = maxArray[0].val;\n\n for(i = 1; i < minArray.length; i++) {\n if(minmin !== maxmax) break;\n minmin = Math.min(minmin, minArray[i].val);\n }\n for(i = 1; i < maxArray.length; i++) {\n if(minmin !== maxmax) break;\n maxmax = Math.max(maxmax, maxArray[i].val);\n }\n\n var axReverse = false;\n\n if(ax.range) {\n var rng = Lib.simpleMap(ax.range, ax.r2l);\n axReverse = rng[1] < rng[0];\n }\n // one-time setting to easily reverse the axis\n // when plotting from code\n if(ax.autorange === 'reversed') {\n axReverse = true;\n ax.autorange = true;\n }\n\n var rangeMode = ax.rangemode;\n var toZero = rangeMode === 'tozero';\n var nonNegative = rangeMode === 'nonnegative';\n var axLen = ax._length;\n // don't allow padding to reduce the data to < 10% of the length\n var minSpan = axLen / 10;\n\n // find axis rangebreaks in [v0,v1] and compute its length in value space\n var calcBreaksLength = function(v0, v1) {\n var lBreaks = 0;\n if(ax.rangebreaks) {\n var rangebreaksOut = ax.locateBreaks(v0, v1);\n for(var i = 0; i < rangebreaksOut.length; i++) {\n var brk = rangebreaksOut[i];\n lBreaks += brk.max - brk.min;\n }\n }\n return lBreaks;\n };\n\n var mbest = 0;\n var minpt, maxpt, minbest, maxbest, dp, dv;\n\n for(i = 0; i < minArray.length; i++) {\n minpt = minArray[i];\n for(j = 0; j < maxArray.length; j++) {\n maxpt = maxArray[j];\n dv = maxpt.val - minpt.val - calcBreaksLength(minpt.val, maxpt.val);\n if(dv > 0) {\n dp = axLen - getPad(minpt) - getPad(maxpt);\n if(dp > minSpan) {\n if(dv / dp > mbest) {\n minbest = minpt;\n maxbest = maxpt;\n mbest = dv / dp;\n }\n } else if(dv / axLen > mbest) {\n // in case of padding longer than the axis\n // at least include the unpadded data values.\n minbest = {val: minpt.val, pad: 0};\n maxbest = {val: maxpt.val, pad: 0};\n mbest = dv / axLen;\n }\n }\n }\n }\n\n function getMaxPad(prev, pt) {\n return Math.max(prev, getPad(pt));\n }\n\n if(minmin === maxmax) {\n var lower = minmin - 1;\n var upper = minmin + 1;\n if(toZero) {\n if(minmin === 0) {\n // The only value we have on this axis is 0, and we want to\n // autorange so zero is one end.\n // In principle this could be [0, 1] or [-1, 0] but usually\n // 'tozero' pins 0 to the low end, so follow that.\n newRange = [0, 1];\n } else {\n var maxPad = (minmin > 0 ? maxArray : minArray).reduce(getMaxPad, 0);\n // we're pushing a single value away from the edge due to its\n // padding, with the other end clamped at zero\n // 0.5 means don't push it farther than the center.\n var rangeEnd = minmin / (1 - Math.min(0.5, maxPad / axLen));\n newRange = minmin > 0 ? [0, rangeEnd] : [rangeEnd, 0];\n }\n } else if(nonNegative) {\n newRange = [Math.max(0, lower), Math.max(1, upper)];\n } else {\n newRange = [lower, upper];\n }\n } else {\n if(toZero) {\n if(minbest.val >= 0) {\n minbest = {val: 0, pad: 0};\n }\n if(maxbest.val <= 0) {\n maxbest = {val: 0, pad: 0};\n }\n } else if(nonNegative) {\n if(minbest.val - mbest * getPad(minbest) < 0) {\n minbest = {val: 0, pad: 0};\n }\n if(maxbest.val <= 0) {\n maxbest = {val: 1, pad: 0};\n }\n }\n\n // in case it changed again...\n mbest = (maxbest.val - minbest.val - calcBreaksLength(minpt.val, maxpt.val)) /\n (axLen - getPad(minbest) - getPad(maxbest));\n\n newRange = [\n minbest.val - mbest * getPad(minbest),\n maxbest.val + mbest * getPad(maxbest)\n ];\n }\n\n // maintain reversal\n if(axReverse) newRange.reverse();\n\n return Lib.simpleMap(newRange, ax.l2r || Number);\n}\n\n/*\n * calculate the pixel padding for ax._min and ax._max entries with\n * optional extrapad as 5% of the total axis length\n */\nfunction makePadFn(ax) {\n // 5% padding for points that specify extrapad: true\n var extrappad = ax._length / 20;\n\n // domain-constrained axes: base extrappad on the unconstrained\n // domain so it's consistent as the domain changes\n if((ax.constrain === 'domain') && ax._inputDomain) {\n extrappad *= (ax._inputDomain[1] - ax._inputDomain[0]) /\n (ax.domain[1] - ax.domain[0]);\n }\n\n return function getPad(pt) { return pt.pad + (pt.extrapad ? extrappad : 0); };\n}\n\nfunction concatExtremes(gd, ax) {\n var axId = ax._id;\n var fullData = gd._fullData;\n var fullLayout = gd._fullLayout;\n var minArray = [];\n var maxArray = [];\n var i, j, d;\n\n function _concat(cont, indices) {\n for(i = 0; i < indices.length; i++) {\n var item = cont[indices[i]];\n var extremes = (item._extremes || {})[axId];\n if(item.visible === true && extremes) {\n for(j = 0; j < extremes.min.length; j++) {\n d = extremes.min[j];\n collapseMinArray(minArray, d.val, d.pad, {extrapad: d.extrapad});\n }\n for(j = 0; j < extremes.max.length; j++) {\n d = extremes.max[j];\n collapseMaxArray(maxArray, d.val, d.pad, {extrapad: d.extrapad});\n }\n }\n }\n }\n\n _concat(fullData, ax._traceIndices);\n _concat(fullLayout.annotations || [], ax._annIndices || []);\n _concat(fullLayout.shapes || [], ax._shapeIndices || []);\n\n return {min: minArray, max: maxArray};\n}\n\nfunction doAutoRange(gd, ax) {\n ax.setScale();\n\n if(ax.autorange) {\n ax.range = getAutoRange(gd, ax);\n\n ax._r = ax.range.slice();\n ax._rl = Lib.simpleMap(ax._r, ax.r2l);\n\n // doAutoRange will get called on fullLayout,\n // but we want to report its results back to layout\n\n var axIn = ax._input;\n\n // before we edit _input, store preGUI values\n var edits = {};\n edits[ax._attr + '.range'] = ax.range;\n edits[ax._attr + '.autorange'] = ax.autorange;\n Registry.call('_storeDirectGUIEdit', gd.layout, gd._fullLayout._preGUI, edits);\n\n axIn.range = ax.range.slice();\n axIn.autorange = ax.autorange;\n }\n\n var anchorAx = ax._anchorAxis;\n\n if(anchorAx && anchorAx.rangeslider) {\n var axeRangeOpts = anchorAx.rangeslider[ax._name];\n if(axeRangeOpts) {\n if(axeRangeOpts.rangemode === 'auto') {\n axeRangeOpts.range = getAutoRange(gd, ax);\n }\n }\n anchorAx._input.rangeslider[ax._name] = Lib.extendFlat({}, axeRangeOpts);\n }\n}\n\n/**\n * findExtremes\n *\n * Find min/max extremes of an array of coordinates on a given axis.\n *\n * Note that findExtremes is called during `calc`, when we don't yet know the axis\n * length; all the inputs should be based solely on the trace data, nothing\n * about the axis layout.\n *\n * Note that `ppad` and `vpad` as well as their asymmetric variants refer to\n * the before and after padding of the passed `data` array, not to the whole axis.\n *\n * @param {object} ax: full axis object\n * relies on\n * - ax.type\n * - ax._m (just its sign)\n * - ax.d2l\n * @param {array} data:\n * array of numbers (i.e. already run though ax.d2c)\n * @param {object} opts:\n * available keys are:\n * vpad: (number or number array) pad values (data value +-vpad)\n * ppad: (number or number array) pad pixels (pixel location +-ppad)\n * ppadplus, ppadminus, vpadplus, vpadminus:\n * separate padding for each side, overrides symmetric\n * padded: (boolean) add 5% padding to both ends\n * (unless one end is overridden by tozero)\n * tozero: (boolean) make sure to include zero if axis is linear,\n * and make it a tight bound if possible\n * vpadLinearized: (boolean) whether or not vpad (or vpadplus/vpadminus)\n * is linearized (for log scale axes)\n *\n * @return {object}\n * - min {array of objects}\n * - max {array of objects}\n * each object item has fields:\n * - val {number}\n * - pad {number}\n * - extrappad {number}\n * - opts {object}: a ref to the passed \"options\" object\n */\nfunction findExtremes(ax, data, opts) {\n if(!opts) opts = {};\n if(!ax._m) ax.setScale();\n\n var minArray = [];\n var maxArray = [];\n\n var len = data.length;\n var extrapad = opts.padded || false;\n var tozero = opts.tozero && (ax.type === 'linear' || ax.type === '-');\n var isLog = ax.type === 'log';\n var hasArrayOption = false;\n var vpadLinearized = opts.vpadLinearized || false;\n var i, v, di, dmin, dmax, ppadiplus, ppadiminus, vmin, vmax;\n\n function makePadAccessor(item) {\n if(Array.isArray(item)) {\n hasArrayOption = true;\n return function(i) { return Math.max(Number(item[i]||0), 0); };\n } else {\n var v = Math.max(Number(item||0), 0);\n return function() { return v; };\n }\n }\n\n var ppadplus = makePadAccessor((ax._m > 0 ?\n opts.ppadplus : opts.ppadminus) || opts.ppad || 0);\n var ppadminus = makePadAccessor((ax._m > 0 ?\n opts.ppadminus : opts.ppadplus) || opts.ppad || 0);\n var vpadplus = makePadAccessor(opts.vpadplus || opts.vpad);\n var vpadminus = makePadAccessor(opts.vpadminus || opts.vpad);\n\n if(!hasArrayOption) {\n // with no arrays other than `data` we don't need to consider\n // every point, only the extreme data points\n vmin = Infinity;\n vmax = -Infinity;\n\n if(isLog) {\n for(i = 0; i < len; i++) {\n v = data[i];\n // data is not linearized yet so we still have to filter out negative logs\n if(v < vmin && v > 0) vmin = v;\n if(v > vmax && v < FP_SAFE) vmax = v;\n }\n } else {\n for(i = 0; i < len; i++) {\n v = data[i];\n if(v < vmin && v > -FP_SAFE) vmin = v;\n if(v > vmax && v < FP_SAFE) vmax = v;\n }\n }\n\n data = [vmin, vmax];\n len = 2;\n }\n\n var collapseOpts = {tozero: tozero, extrapad: extrapad};\n\n function addItem(i) {\n di = data[i];\n if(!isNumeric(di)) return;\n ppadiplus = ppadplus(i);\n ppadiminus = ppadminus(i);\n\n if(vpadLinearized) {\n dmin = ax.c2l(di) - vpadminus(i);\n dmax = ax.c2l(di) + vpadplus(i);\n } else {\n vmin = di - vpadminus(i);\n vmax = di + vpadplus(i);\n // special case for log axes: if vpad makes this object span\n // more than an order of mag, clip it to one order. This is so\n // we don't have non-positive errors or absurdly large lower\n // range due to rounding errors\n if(isLog && vmin < vmax / 10) vmin = vmax / 10;\n\n dmin = ax.c2l(vmin);\n dmax = ax.c2l(vmax);\n }\n\n if(tozero) {\n dmin = Math.min(0, dmin);\n dmax = Math.max(0, dmax);\n }\n if(goodNumber(dmin)) {\n collapseMinArray(minArray, dmin, ppadiminus, collapseOpts);\n }\n if(goodNumber(dmax)) {\n collapseMaxArray(maxArray, dmax, ppadiplus, collapseOpts);\n }\n }\n\n // For efficiency covering monotonic or near-monotonic data,\n // check a few points at both ends first and then sweep\n // through the middle\n var iMax = Math.min(6, len);\n for(i = 0; i < iMax; i++) addItem(i);\n for(i = len - 1; i >= iMax; i--) addItem(i);\n\n return {\n min: minArray,\n max: maxArray,\n opts: opts\n };\n}\n\nfunction collapseMinArray(array, newVal, newPad, opts) {\n collapseArray(array, newVal, newPad, opts, lessOrEqual);\n}\n\nfunction collapseMaxArray(array, newVal, newPad, opts) {\n collapseArray(array, newVal, newPad, opts, greaterOrEqual);\n}\n\n/**\n * collapseArray\n *\n * Takes items from 'array' and compares them to 'newVal', 'newPad'.\n *\n * @param {array} array:\n * current set of min or max extremes\n * @param {number} newVal:\n * new value to compare against\n * @param {number} newPad:\n * pad value associated with 'newVal'\n * @param {object} opts:\n * - tozero {boolean}\n * - extrapad {number}\n * @param {function} atLeastAsExtreme:\n * comparison function, use\n * - lessOrEqual for min 'array' and\n * - greaterOrEqual for max 'array'\n *\n * In practice, 'array' is either\n * - 'extremes[ax._id].min' or\n * - 'extremes[ax._id].max\n * found in traces and layout items that affect autorange.\n *\n * Since we don't yet know the relationship between pixels and values\n * (that's what we're trying to figure out!) AND we don't yet know how\n * many pixels `extrapad` represents (it's going to be 5% of the length,\n * but we don't want to have to redo calc just because length changed)\n * two point must satisfy three criteria simultaneously for one to supersede the other:\n * - at least as extreme a `val`\n * - at least as big a `pad`\n * - an unpadded point cannot supersede a padded point, but any other combination can\n *\n * Then:\n * - If the item supersedes the new point, set includeThis false\n * - If the new pt supersedes the item, delete it from 'array'\n */\nfunction collapseArray(array, newVal, newPad, opts, atLeastAsExtreme) {\n var tozero = opts.tozero;\n var extrapad = opts.extrapad;\n var includeThis = true;\n\n for(var j = 0; j < array.length && includeThis; j++) {\n var v = array[j];\n if(atLeastAsExtreme(v.val, newVal) && v.pad >= newPad && (v.extrapad || !extrapad)) {\n includeThis = false;\n break;\n } else if(atLeastAsExtreme(newVal, v.val) && v.pad <= newPad && (extrapad || !v.extrapad)) {\n array.splice(j, 1);\n j--;\n }\n }\n if(includeThis) {\n var clipAtZero = (tozero && newVal === 0);\n array.push({\n val: newVal,\n pad: clipAtZero ? 0 : newPad,\n extrapad: clipAtZero ? false : extrapad\n });\n }\n}\n\n// In order to stop overflow errors, don't consider points\n// too close to the limits of js floating point\nfunction goodNumber(v) {\n return isNumeric(v) && Math.abs(v) < FP_SAFE;\n}\n\nfunction lessOrEqual(v0, v1) { return v0 <= v1; }\nfunction greaterOrEqual(v0, v1) { return v0 >= v1; }\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar arraysToCalcdata = require('../bar/arrays_to_calcdata');\nvar binFunctions = require('./bin_functions');\nvar normFunctions = require('./norm_functions');\nvar doAvg = require('./average');\nvar getBinSpanLabelRound = require('./bin_label_vals');\n\nfunction calc(gd, trace) {\n var pos = [];\n var size = [];\n var pa = Axes.getFromId(gd, trace.orientation === 'h' ? trace.yaxis : trace.xaxis);\n var mainData = trace.orientation === 'h' ? 'y' : 'x';\n var counterData = {x: 'y', y: 'x'}[mainData];\n var calendar = trace[mainData + 'calendar'];\n var cumulativeSpec = trace.cumulative;\n var i;\n\n var binsAndPos = calcAllAutoBins(gd, trace, pa, mainData);\n var binSpec = binsAndPos[0];\n var pos0 = binsAndPos[1];\n\n var nonuniformBins = typeof binSpec.size === 'string';\n var binEdges = [];\n var bins = nonuniformBins ? binEdges : binSpec;\n // make the empty bin array\n var inc = [];\n var counts = [];\n var inputPoints = [];\n var total = 0;\n var norm = trace.histnorm;\n var func = trace.histfunc;\n var densityNorm = norm.indexOf('density') !== -1;\n var i2, binEnd, n;\n\n if(cumulativeSpec.enabled && densityNorm) {\n // we treat \"cumulative\" like it means \"integral\" if you use a density norm,\n // which in the end means it's the same as without \"density\"\n norm = norm.replace(/ ?density$/, '');\n densityNorm = false;\n }\n\n var extremeFunc = func === 'max' || func === 'min';\n var sizeInit = extremeFunc ? null : 0;\n var binFunc = binFunctions.count;\n var normFunc = normFunctions[norm];\n var isAvg = false;\n var pr2c = function(v) { return pa.r2c(v, 0, calendar); };\n var rawCounterData;\n\n if(Lib.isArrayOrTypedArray(trace[counterData]) && func !== 'count') {\n rawCounterData = trace[counterData];\n isAvg = func === 'avg';\n binFunc = binFunctions[func];\n }\n\n // create the bins (and any extra arrays needed)\n // assume more than 1e6 bins is an error, so we don't crash the browser\n i = pr2c(binSpec.start);\n\n // decrease end a little in case of rounding errors\n binEnd = pr2c(binSpec.end) + (i - Axes.tickIncrement(i, binSpec.size, false, calendar)) / 1e6;\n\n while(i < binEnd && pos.length < 1e6) {\n i2 = Axes.tickIncrement(i, binSpec.size, false, calendar);\n pos.push((i + i2) / 2);\n size.push(sizeInit);\n inputPoints.push([]);\n // nonuniform bins (like months) we need to search,\n // rather than straight calculate the bin we're in\n binEdges.push(i);\n // nonuniform bins also need nonuniform normalization factors\n if(densityNorm) inc.push(1 / (i2 - i));\n if(isAvg) counts.push(0);\n // break to avoid infinite loops\n if(i2 <= i) break;\n i = i2;\n }\n binEdges.push(i);\n\n // for date axes we need bin bounds to be calcdata. For nonuniform bins\n // we already have this, but uniform with start/end/size they're still strings.\n if(!nonuniformBins && pa.type === 'date') {\n bins = {\n start: pr2c(bins.start),\n end: pr2c(bins.end),\n size: bins.size\n };\n }\n\n // stash left and right gaps by group\n if(!gd._fullLayout._roundFnOpts) gd._fullLayout._roundFnOpts = {};\n var groupName = trace['_' + mainData + 'bingroup'];\n var roundFnOpts = {leftGap: Infinity, rightGap: Infinity};\n if(groupName) {\n if(!gd._fullLayout._roundFnOpts[groupName]) gd._fullLayout._roundFnOpts[groupName] = roundFnOpts;\n roundFnOpts = gd._fullLayout._roundFnOpts[groupName];\n }\n\n // bin the data\n // and make histogram-specific pt-number-to-cd-index map object\n var nMax = size.length;\n var uniqueValsPerBin = true;\n var leftGap = roundFnOpts.leftGap;\n var rightGap = roundFnOpts.rightGap;\n var ptNumber2cdIndex = {};\n for(i = 0; i < pos0.length; i++) {\n var posi = pos0[i];\n n = Lib.findBin(posi, bins);\n if(n >= 0 && n < nMax) {\n total += binFunc(n, i, size, rawCounterData, counts);\n if(uniqueValsPerBin && inputPoints[n].length && posi !== pos0[inputPoints[n][0]]) {\n uniqueValsPerBin = false;\n }\n inputPoints[n].push(i);\n ptNumber2cdIndex[i] = n;\n\n leftGap = Math.min(leftGap, posi - binEdges[n]);\n rightGap = Math.min(rightGap, binEdges[n + 1] - posi);\n }\n }\n roundFnOpts.leftGap = leftGap;\n roundFnOpts.rightGap = rightGap;\n\n var roundFn;\n if(!uniqueValsPerBin) {\n roundFn = function(v, isRightEdge) {\n return function() {\n var roundFnOpts = gd._fullLayout._roundFnOpts[groupName];\n return getBinSpanLabelRound(\n roundFnOpts.leftGap,\n roundFnOpts.rightGap,\n binEdges, pa, calendar\n )(v, isRightEdge);\n };\n };\n }\n\n // average and/or normalize the data, if needed\n if(isAvg) total = doAvg(size, counts);\n if(normFunc) normFunc(size, total, inc);\n\n // after all normalization etc, now we can accumulate if desired\n if(cumulativeSpec.enabled) cdf(size, cumulativeSpec.direction, cumulativeSpec.currentbin);\n\n var seriesLen = Math.min(pos.length, size.length);\n var cd = [];\n var firstNonzero = 0;\n var lastNonzero = seriesLen - 1;\n\n // look for empty bins at the ends to remove, so autoscale omits them\n for(i = 0; i < seriesLen; i++) {\n if(size[i]) {\n firstNonzero = i;\n break;\n }\n }\n for(i = seriesLen - 1; i >= firstNonzero; i--) {\n if(size[i]) {\n lastNonzero = i;\n break;\n }\n }\n\n // create the \"calculated data\" to plot\n for(i = firstNonzero; i <= lastNonzero; i++) {\n if((isNumeric(pos[i]) && isNumeric(size[i]))) {\n var cdi = {\n p: pos[i],\n s: size[i],\n b: 0\n };\n\n // setup hover and event data fields,\n // N.B. pts and \"hover\" positions ph0/ph1 don't seem to make much sense\n // for cumulative distributions\n if(!cumulativeSpec.enabled) {\n cdi.pts = inputPoints[i];\n if(uniqueValsPerBin) {\n cdi.ph0 = cdi.ph1 = (inputPoints[i].length) ? pos0[inputPoints[i][0]] : pos[i];\n } else {\n // Defer evaluation of ph(0|1) in crossTraceCalc\n trace._computePh = true;\n cdi.ph0 = roundFn(binEdges[i]);\n cdi.ph1 = roundFn(binEdges[i + 1], true);\n }\n }\n cd.push(cdi);\n }\n }\n\n if(cd.length === 1) {\n // when we collapse to a single bin, calcdata no longer describes bin size\n // so we need to explicitly specify it\n cd[0].width1 = Axes.tickIncrement(cd[0].p, binSpec.size, false, calendar) - cd[0].p;\n }\n\n arraysToCalcdata(cd, trace);\n\n if(Lib.isArrayOrTypedArray(trace.selectedpoints)) {\n Lib.tagSelected(cd, trace, ptNumber2cdIndex);\n }\n\n return cd;\n}\n\n/*\n * calcAllAutoBins: we want all histograms inside the same bingroup\n * (see logic in Histogram.crossTraceDefaults) to share bin specs\n *\n * If the user has explicitly specified differing\n * bin specs, there's nothing we can do, but if possible we will try to use the\n * smallest bins of any of the auto values for all histograms inside the same\n * bingroup.\n */\nfunction calcAllAutoBins(gd, trace, pa, mainData, _overlayEdgeCase) {\n var binAttr = mainData + 'bins';\n var fullLayout = gd._fullLayout;\n var groupName = trace['_' + mainData + 'bingroup'];\n var binOpts = fullLayout._histogramBinOpts[groupName];\n var isOverlay = fullLayout.barmode === 'overlay';\n var i, traces, tracei, calendar, pos0, autoVals, cumulativeSpec;\n\n var r2c = function(v) { return pa.r2c(v, 0, calendar); };\n var c2r = function(v) { return pa.c2r(v, 0, calendar); };\n\n var cleanBound = pa.type === 'date' ?\n function(v) { return (v || v === 0) ? Lib.cleanDate(v, null, calendar) : null; } :\n function(v) { return isNumeric(v) ? Number(v) : null; };\n\n function setBound(attr, bins, newBins) {\n if(bins[attr + 'Found']) {\n bins[attr] = cleanBound(bins[attr]);\n if(bins[attr] === null) bins[attr] = newBins[attr];\n } else {\n autoVals[attr] = bins[attr] = newBins[attr];\n Lib.nestedProperty(traces[0], binAttr + '.' + attr).set(newBins[attr]);\n }\n }\n\n // all but the first trace in this group has already been marked finished\n // clear this flag, so next time we run calc we will run autobin again\n if(trace['_' + mainData + 'autoBinFinished']) {\n delete trace['_' + mainData + 'autoBinFinished'];\n } else {\n traces = binOpts.traces;\n var allPos = [];\n\n // Note: we're including `legendonly` traces here for autobin purposes,\n // so that showing & hiding from the legend won't affect bins.\n // But this complicates things a bit since those traces don't `calc`,\n // hence `isFirstVisible`.\n var isFirstVisible = true;\n var has2dMap = false;\n var hasHist2dContour = false;\n for(i = 0; i < traces.length; i++) {\n tracei = traces[i];\n\n if(tracei.visible) {\n var mainDatai = binOpts.dirs[i];\n pos0 = tracei['_' + mainDatai + 'pos0'] = pa.makeCalcdata(tracei, mainDatai);\n\n allPos = Lib.concat(allPos, pos0);\n delete tracei['_' + mainData + 'autoBinFinished'];\n\n if(trace.visible === true) {\n if(isFirstVisible) {\n isFirstVisible = false;\n } else {\n delete tracei._autoBin;\n tracei['_' + mainData + 'autoBinFinished'] = 1;\n }\n if(Registry.traceIs(tracei, '2dMap')) {\n has2dMap = true;\n }\n if(tracei.type === 'histogram2dcontour') {\n hasHist2dContour = true;\n }\n }\n }\n }\n\n calendar = traces[0][mainData + 'calendar'];\n var newBinSpec = Axes.autoBin(allPos, pa, binOpts.nbins, has2dMap, calendar, binOpts.sizeFound && binOpts.size);\n\n var autoBin = traces[0]._autoBin = {};\n autoVals = autoBin[binOpts.dirs[0]] = {};\n\n if(hasHist2dContour) {\n // the \"true\" 2nd argument reverses the tick direction (which we can't\n // just do with a minus sign because of month bins)\n if(!binOpts.size) {\n newBinSpec.start = c2r(Axes.tickIncrement(\n r2c(newBinSpec.start), newBinSpec.size, true, calendar));\n }\n if(binOpts.end === undefined) {\n newBinSpec.end = c2r(Axes.tickIncrement(\n r2c(newBinSpec.end), newBinSpec.size, false, calendar));\n }\n }\n\n // Edge case: single-valued histogram overlaying others\n // Use them all together to calculate the bin size for the single-valued one\n if(isOverlay && !Registry.traceIs(trace, '2dMap') && newBinSpec._dataSpan === 0 &&\n pa.type !== 'category' && pa.type !== 'multicategory') {\n // Several single-valued histograms! Stop infinite recursion,\n // just return an extra flag that tells handleSingleValueOverlays\n // to sort out this trace too\n if(_overlayEdgeCase) return [newBinSpec, pos0, true];\n\n newBinSpec = handleSingleValueOverlays(gd, trace, pa, mainData, binAttr);\n }\n\n // adjust for CDF edge cases\n cumulativeSpec = tracei.cumulative || {};\n if(cumulativeSpec.enabled && (cumulativeSpec.currentbin !== 'include')) {\n if(cumulativeSpec.direction === 'decreasing') {\n newBinSpec.start = c2r(Axes.tickIncrement(\n r2c(newBinSpec.start), newBinSpec.size, true, calendar));\n } else {\n newBinSpec.end = c2r(Axes.tickIncrement(\n r2c(newBinSpec.end), newBinSpec.size, false, calendar));\n }\n }\n\n binOpts.size = newBinSpec.size;\n if(!binOpts.sizeFound) {\n autoVals.size = newBinSpec.size;\n Lib.nestedProperty(traces[0], binAttr + '.size').set(newBinSpec.size);\n }\n\n setBound('start', binOpts, newBinSpec);\n setBound('end', binOpts, newBinSpec);\n }\n\n pos0 = trace['_' + mainData + 'pos0'];\n delete trace['_' + mainData + 'pos0'];\n\n // Each trace can specify its own start/end, or if omitted\n // we ensure they're beyond the bounds of this trace's data,\n // and we need to make sure start is aligned with the main start\n var traceInputBins = trace._input[binAttr] || {};\n var traceBinOptsCalc = Lib.extendFlat({}, binOpts);\n var mainStart = binOpts.start;\n var startIn = pa.r2l(traceInputBins.start);\n var hasStart = startIn !== undefined;\n if((binOpts.startFound || hasStart) && startIn !== pa.r2l(mainStart)) {\n // We have an explicit start to reconcile across traces\n // if this trace has an explicit start, shift it down to a bin edge\n // if another trace had an explicit start, shift it down to a\n // bin edge past our data\n var traceStart = hasStart ?\n startIn :\n Lib.aggNums(Math.min, null, pos0);\n\n var dummyAx = {\n type: (pa.type === 'category' || pa.type === 'multicategory') ? 'linear' : pa.type,\n r2l: pa.r2l,\n dtick: binOpts.size,\n tick0: mainStart,\n calendar: calendar,\n range: ([traceStart, Axes.tickIncrement(traceStart, binOpts.size, false, calendar)]).map(pa.l2r)\n };\n var newStart = Axes.tickFirst(dummyAx);\n if(newStart > pa.r2l(traceStart)) {\n newStart = Axes.tickIncrement(newStart, binOpts.size, true, calendar);\n }\n traceBinOptsCalc.start = pa.l2r(newStart);\n if(!hasStart) Lib.nestedProperty(trace, binAttr + '.start').set(traceBinOptsCalc.start);\n }\n\n var mainEnd = binOpts.end;\n var endIn = pa.r2l(traceInputBins.end);\n var hasEnd = endIn !== undefined;\n if((binOpts.endFound || hasEnd) && endIn !== pa.r2l(mainEnd)) {\n // Reconciling an explicit end is easier, as it doesn't need to\n // match bin edges\n var traceEnd = hasEnd ?\n endIn :\n Lib.aggNums(Math.max, null, pos0);\n\n traceBinOptsCalc.end = pa.l2r(traceEnd);\n if(!hasEnd) Lib.nestedProperty(trace, binAttr + '.start').set(traceBinOptsCalc.end);\n }\n\n // Backward compatibility for one-time autobinning.\n // autobin: true is handled in cleanData, but autobin: false\n // needs to be here where we have determined the values.\n var autoBinAttr = 'autobin' + mainData;\n if(trace._input[autoBinAttr] === false) {\n trace._input[binAttr] = Lib.extendFlat({}, trace[binAttr] || {});\n delete trace._input[autoBinAttr];\n delete trace[autoBinAttr];\n }\n\n return [traceBinOptsCalc, pos0];\n}\n\n/*\n * Adjust single-value histograms in overlay mode to make as good a\n * guess as we can at autobin values the user would like.\n *\n * Returns the binSpec for the trace that sparked all this\n */\nfunction handleSingleValueOverlays(gd, trace, pa, mainData, binAttr) {\n var fullLayout = gd._fullLayout;\n var overlaidTraceGroup = getConnectedHistograms(gd, trace);\n var pastThisTrace = false;\n var minSize = Infinity;\n var singleValuedTraces = [trace];\n var i, tracei, binOpts;\n\n // first collect all the:\n // - min bin size from all multi-valued traces\n // - single-valued traces\n for(i = 0; i < overlaidTraceGroup.length; i++) {\n tracei = overlaidTraceGroup[i];\n\n if(tracei === trace) {\n pastThisTrace = true;\n } else if(!pastThisTrace) {\n // This trace has already had its autobins calculated, so either:\n // - it is part of a bingroup\n // - it is NOT a single-valued trace\n binOpts = fullLayout._histogramBinOpts[tracei['_' + mainData + 'bingroup']];\n minSize = Math.min(minSize, binOpts.size || tracei[binAttr].size);\n } else {\n var resulti = calcAllAutoBins(gd, tracei, pa, mainData, true);\n var binSpeci = resulti[0];\n var isSingleValued = resulti[2];\n\n // so we can use this result when we get to tracei in the normal\n // course of events, mark it as done and put _pos0 back\n tracei['_' + mainData + 'autoBinFinished'] = 1;\n tracei['_' + mainData + 'pos0'] = resulti[1];\n\n if(isSingleValued) {\n singleValuedTraces.push(tracei);\n } else {\n minSize = Math.min(minSize, binSpeci.size);\n }\n }\n }\n\n // find the real data values for each single-valued trace\n // hunt through pos0 for the first valid value\n var dataVals = new Array(singleValuedTraces.length);\n for(i = 0; i < singleValuedTraces.length; i++) {\n var pos0 = singleValuedTraces[i]['_' + mainData + 'pos0'];\n for(var j = 0; j < pos0.length; j++) {\n if(pos0[j] !== undefined) {\n dataVals[i] = pos0[j];\n break;\n }\n }\n }\n\n // are ALL traces are single-valued? use the min difference between\n // all of their values (which defaults to 1 if there's still only one)\n if(!isFinite(minSize)) {\n minSize = Lib.distinctVals(dataVals).minDiff;\n }\n\n // now apply the min size we found to all single-valued traces\n for(i = 0; i < singleValuedTraces.length; i++) {\n tracei = singleValuedTraces[i];\n var calendar = tracei[mainData + 'calendar'];\n\n var newBins = {\n start: pa.c2r(dataVals[i] - minSize / 2, 0, calendar),\n end: pa.c2r(dataVals[i] + minSize / 2, 0, calendar),\n size: minSize\n };\n\n tracei._input[binAttr] = tracei[binAttr] = newBins;\n\n binOpts = fullLayout._histogramBinOpts[tracei['_' + mainData + 'bingroup']];\n if(binOpts) Lib.extendFlat(binOpts, newBins);\n }\n\n return trace[binAttr];\n}\n\n/*\n * Return an array of histograms that share axes and orientation.\n *\n * Only considers histograms. In principle we could include bars in a\n * similar way to how we do manually binned histograms, though this\n * would have tons of edge cases and value judgments to make.\n */\nfunction getConnectedHistograms(gd, trace) {\n var xid = trace.xaxis;\n var yid = trace.yaxis;\n var orientation = trace.orientation;\n\n var out = [];\n var fullData = gd._fullData;\n for(var i = 0; i < fullData.length; i++) {\n var tracei = fullData[i];\n if(tracei.type === 'histogram' &&\n tracei.visible === true &&\n tracei.orientation === orientation &&\n tracei.xaxis === xid && tracei.yaxis === yid\n ) {\n out.push(tracei);\n }\n }\n\n return out;\n}\n\nfunction cdf(size, direction, currentBin) {\n var i, vi, prevSum;\n\n function firstHalfPoint(i) {\n prevSum = size[i];\n size[i] /= 2;\n }\n\n function nextHalfPoint(i) {\n vi = size[i];\n size[i] = prevSum + vi / 2;\n prevSum += vi;\n }\n\n if(currentBin === 'half') {\n if(direction === 'increasing') {\n firstHalfPoint(0);\n for(i = 1; i < size.length; i++) {\n nextHalfPoint(i);\n }\n } else {\n firstHalfPoint(size.length - 1);\n for(i = size.length - 2; i >= 0; i--) {\n nextHalfPoint(i);\n }\n }\n } else if(direction === 'increasing') {\n for(i = 1; i < size.length; i++) {\n size[i] += size[i - 1];\n }\n\n // 'exclude' is identical to 'include' just shifted one bin over\n if(currentBin === 'exclude') {\n size.unshift(0);\n size.pop();\n }\n } else {\n for(i = size.length - 2; i >= 0; i--) {\n size[i] += size[i + 1];\n }\n\n if(currentBin === 'exclude') {\n size.push(0);\n size.shift();\n }\n }\n}\n\nmodule.exports = {\n calc: calc,\n calcAllAutoBins: calcAllAutoBins\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n _isLinkedToArray: 'frames_entry',\n\n group: {\n valType: 'string',\n role: 'info',\n description: [\n 'An identifier that specifies the group to which the frame belongs,',\n 'used by animate to select a subset of frames.'\n ].join(' ')\n },\n name: {\n valType: 'string',\n role: 'info',\n description: 'A label by which to identify the frame'\n },\n traces: {\n valType: 'any',\n role: 'info',\n description: [\n 'A list of trace indices that identify the respective traces in the',\n 'data attribute'\n ].join(' ')\n },\n baseframe: {\n valType: 'string',\n role: 'info',\n description: [\n 'The name of the frame into which this frame\\'s properties are merged',\n 'before applying. This is used to unify properties and avoid needing',\n 'to specify the same values for the same properties in multiple frames.'\n ].join(' ')\n },\n data: {\n valType: 'any',\n role: 'object',\n description: [\n 'A list of traces this frame modifies. The format is identical to the',\n 'normal trace definition.'\n ].join(' ')\n },\n layout: {\n valType: 'any',\n role: 'object',\n description: [\n 'Layout properties which this frame modifies. The format is identical',\n 'to the normal layout definition.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar histogram2dCalc = require('../histogram2d/calc');\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar convertColumnData = require('./convert_column_xyz');\nvar clean2dArray = require('./clean_2d_array');\nvar interp2d = require('./interp2d');\nvar findEmpties = require('./find_empties');\nvar makeBoundArray = require('./make_bound_array');\n\nmodule.exports = function calc(gd, trace) {\n // prepare the raw data\n // run makeCalcdata on x and y even for heatmaps, in case of category mappings\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var isContour = Registry.traceIs(trace, 'contour');\n var isHist = Registry.traceIs(trace, 'histogram');\n var isGL2D = Registry.traceIs(trace, 'gl2d');\n var zsmooth = isContour ? 'best' : trace.zsmooth;\n var x;\n var x0;\n var dx;\n var y;\n var y0;\n var dy;\n var z;\n var i;\n var binned;\n\n // cancel minimum tick spacings (only applies to bars and boxes)\n xa._minDtick = 0;\n ya._minDtick = 0;\n\n if(isHist) {\n binned = histogram2dCalc(gd, trace);\n x = binned.x;\n x0 = binned.x0;\n dx = binned.dx;\n y = binned.y;\n y0 = binned.y0;\n dy = binned.dy;\n z = binned.z;\n } else {\n var zIn = trace.z;\n if(Lib.isArray1D(zIn)) {\n convertColumnData(trace, xa, ya, 'x', 'y', ['z']);\n x = trace._x;\n y = trace._y;\n zIn = trace._z;\n } else {\n x = trace._x = trace.x ? xa.makeCalcdata(trace, 'x') : [];\n y = trace._y = trace.y ? ya.makeCalcdata(trace, 'y') : [];\n }\n\n x0 = trace.x0;\n dx = trace.dx;\n y0 = trace.y0;\n dy = trace.dy;\n\n z = clean2dArray(zIn, trace, xa, ya);\n\n if(isContour || trace.connectgaps) {\n trace._emptypoints = findEmpties(z);\n interp2d(z, trace._emptypoints);\n }\n }\n\n function noZsmooth(msg) {\n zsmooth = trace._input.zsmooth = trace.zsmooth = false;\n Lib.warn('cannot use zsmooth: \"fast\": ' + msg);\n }\n\n // check whether we really can smooth (ie all boxes are about the same size)\n if(zsmooth === 'fast') {\n if(xa.type === 'log' || ya.type === 'log') {\n noZsmooth('log axis found');\n } else if(!isHist) {\n if(x.length) {\n var avgdx = (x[x.length - 1] - x[0]) / (x.length - 1);\n var maxErrX = Math.abs(avgdx / 100);\n for(i = 0; i < x.length - 1; i++) {\n if(Math.abs(x[i + 1] - x[i] - avgdx) > maxErrX) {\n noZsmooth('x scale is not linear');\n break;\n }\n }\n }\n if(y.length && zsmooth === 'fast') {\n var avgdy = (y[y.length - 1] - y[0]) / (y.length - 1);\n var maxErrY = Math.abs(avgdy / 100);\n for(i = 0; i < y.length - 1; i++) {\n if(Math.abs(y[i + 1] - y[i] - avgdy) > maxErrY) {\n noZsmooth('y scale is not linear');\n break;\n }\n }\n }\n }\n }\n\n // create arrays of brick boundaries, to be used by autorange and heatmap.plot\n var xlen = Lib.maxRowLength(z);\n var xIn = trace.xtype === 'scaled' ? '' : x;\n var xArray = makeBoundArray(trace, xIn, x0, dx, xlen, xa);\n var yIn = trace.ytype === 'scaled' ? '' : y;\n var yArray = makeBoundArray(trace, yIn, y0, dy, z.length, ya);\n\n // handled in gl2d convert step\n if(!isGL2D) {\n trace._extremes[xa._id] = Axes.findExtremes(xa, xArray);\n trace._extremes[ya._id] = Axes.findExtremes(ya, yArray);\n }\n\n var cd0 = {\n x: xArray,\n y: yArray,\n z: z,\n text: trace._text || trace.text,\n hovertext: trace._hovertext || trace.hovertext\n };\n\n if(xIn && xIn.length === xArray.length - 1) cd0.xCenter = xIn;\n if(yIn && yIn.length === yArray.length - 1) cd0.yCenter = yIn;\n\n if(isHist) {\n cd0.xRanges = binned.xRanges;\n cd0.yRanges = binned.yRanges;\n cd0.pts = binned.pts;\n }\n\n if(!isContour) {\n colorscaleCalc(gd, trace, {vals: z, cLetter: 'z'});\n }\n\n if(isContour && trace.contours && trace.contours.coloring === 'heatmap') {\n var dummyTrace = {\n type: trace.type === 'contour' ? 'heatmap' : 'histogram2d',\n xcalendar: trace.xcalendar,\n ycalendar: trace.ycalendar\n };\n cd0.xfill = makeBoundArray(dummyTrace, xIn, x0, dx, xlen, xa);\n cd0.yfill = makeBoundArray(dummyTrace, yIn, y0, dy, z.length, ya);\n }\n\n return [cd0];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nmodule.exports = {\n PTS_LINESONLY: 20,\n\n // fixed parameters of clustering and clipping algorithms\n\n // fraction of clustering tolerance \"so close we don't even consider it a new point\"\n minTolerance: 0.2,\n // how fast does clustering tolerance increase as you get away from the visible region\n toleranceGrowth: 10,\n\n // number of viewport sizes away from the visible region\n // at which we clip all lines to the perimeter\n maxScreensAway: 20,\n\n eventDataKeys: []\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\n\nvar name = constants.name;\nvar buttonAttrs = attributes.buttons;\n\n\nmodule.exports = function updateMenusDefaults(layoutIn, layoutOut) {\n var opts = {\n name: name,\n handleItemDefaults: menuDefaults\n };\n\n handleArrayContainerDefaults(layoutIn, layoutOut, opts);\n};\n\nfunction menuDefaults(menuIn, menuOut, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(menuIn, menuOut, attributes, attr, dflt);\n }\n\n var buttons = handleArrayContainerDefaults(menuIn, menuOut, {\n name: 'buttons',\n handleItemDefaults: buttonDefaults\n });\n\n var visible = coerce('visible', buttons.length > 0);\n if(!visible) return;\n\n coerce('active');\n coerce('direction');\n coerce('type');\n coerce('showactive');\n\n coerce('x');\n coerce('y');\n Lib.noneOrAll(menuIn, menuOut, ['x', 'y']);\n\n coerce('xanchor');\n coerce('yanchor');\n\n coerce('pad.t');\n coerce('pad.r');\n coerce('pad.b');\n coerce('pad.l');\n\n Lib.coerceFont(coerce, 'font', layoutOut.font);\n\n coerce('bgcolor', layoutOut.paper_bgcolor);\n coerce('bordercolor');\n coerce('borderwidth');\n}\n\nfunction buttonDefaults(buttonIn, buttonOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(buttonIn, buttonOut, buttonAttrs, attr, dflt);\n }\n\n var visible = coerce('visible',\n (buttonIn.method === 'skip' || Array.isArray(buttonIn.args)));\n if(visible) {\n coerce('method');\n coerce('args');\n coerce('args2');\n coerce('label');\n coerce('execute');\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\n/**\n * General helper to manage trace groups based on calcdata\n *\n * @param {d3.selection} traceLayer: a selection containing a single group\n * to draw these traces into\n * @param {array} cdModule: array of calcdata items for this\n * module and subplot combination. Assumes the calcdata item for each\n * trace is an array with the fullData trace attached to the first item.\n * @param {string} cls: the class attribute to give each trace group\n * so you can give multiple classes separated by spaces\n */\nmodule.exports = function makeTraceGroups(traceLayer, cdModule, cls) {\n var traces = traceLayer.selectAll('g.' + cls.replace(/\\s/g, '.'))\n .data(cdModule, function(cd) { return cd[0].trace.uid; });\n\n traces.exit().remove();\n\n traces.enter().append('g')\n .attr('class', cls);\n\n traces.order();\n\n // stash ref node to trace group in calcdata,\n // useful for (fast) styleOnSelect\n var k = traceLayer.classed('rangeplot') ? 'nodeRangePlot3' : 'node3';\n traces.each(function(cd) { cd[0][k] = d3.select(this); });\n\n return traces;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('./font_attributes');\nvar animationAttrs = require('./animation_attributes');\nvar colorAttrs = require('../components/color/attributes');\nvar padAttrs = require('./pad_attributes');\nvar extendFlat = require('../lib/extend').extendFlat;\n\nvar globalFont = fontAttrs({\n editType: 'calc',\n description: [\n 'Sets the global font.',\n 'Note that fonts used in traces and other',\n 'layout components inherit from the global font.'\n ].join(' ')\n});\nglobalFont.family.dflt = '\"Open Sans\", verdana, arial, sans-serif';\nglobalFont.size.dflt = 12;\nglobalFont.color.dflt = colorAttrs.defaultLine;\n\nmodule.exports = {\n font: globalFont,\n title: {\n text: {\n valType: 'string',\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Sets the plot\\'s title.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'layoutstyle',\n description: [\n 'Sets the title font.',\n 'Note that the title\\'s font used to be customized',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n xref: {\n valType: 'enumerated',\n dflt: 'container',\n values: ['container', 'paper'],\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Sets the container `x` refers to.',\n '*container* spans the entire `width` of the plot.',\n '*paper* refers to the width of the plotting area only.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n dflt: 'container',\n values: ['container', 'paper'],\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Sets the container `y` refers to.',\n '*container* spans the entire `height` of the plot.',\n '*paper* refers to the height of the plotting area only.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0.5,\n role: 'style',\n editType: 'layoutstyle',\n description: [\n 'Sets the x position with respect to `xref` in normalized',\n 'coordinates from *0* (left) to *1* (right).'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 'auto',\n role: 'style',\n editType: 'layoutstyle',\n description: [\n 'Sets the y position with respect to `yref` in normalized',\n 'coordinates from *0* (bottom) to *1* (top).',\n '*auto* places the baseline of the title onto the',\n 'vertical center of the top margin.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n dflt: 'auto',\n values: ['auto', 'left', 'center', 'right'],\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Sets the title\\'s horizontal alignment with respect to its x position.',\n '*left* means that the title starts at x,',\n '*right* means that the title ends at x',\n 'and *center* means that the title\\'s center is at x.',\n '*auto* divides `xref` by three and calculates the `xanchor`',\n 'value automatically based on the value of `x`.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n dflt: 'auto',\n values: ['auto', 'top', 'middle', 'bottom'],\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Sets the title\\'s vertical alignment with respect to its y position.',\n '*top* means that the title\\'s cap line is at y,',\n '*bottom* means that the title\\'s baseline is at y',\n 'and *middle* means that the title\\'s midline is at y.',\n '*auto* divides `yref` by three and calculates the `yanchor`',\n 'value automatically based on the value of `y`.'\n ].join(' ')\n },\n pad: extendFlat(padAttrs({editType: 'layoutstyle'}), {\n description: [\n 'Sets the padding of the title.',\n 'Each padding value only applies when the corresponding',\n '`xanchor`/`yanchor` value is set accordingly. E.g. for left',\n 'padding to take effect, `xanchor` must be set to *left*.',\n 'The same rule applies if `xanchor`/`yanchor` is determined automatically.',\n 'Padding is muted if the respective anchor value is *middle*/*center*.'\n ].join(' ')\n }),\n editType: 'layoutstyle'\n },\n uniformtext: {\n mode: {\n valType: 'enumerated',\n values: [false, 'hide', 'show'],\n dflt: false,\n role: 'info',\n editType: 'plot',\n description: [\n 'Determines how the font size for various text',\n 'elements are uniformed between each trace type.',\n 'If the computed text sizes were smaller than',\n 'the minimum size defined by `uniformtext.minsize`',\n 'using *hide* option hides the text; and',\n 'using *show* option shows the text without further downscaling.',\n 'Please note that if the size defined by `minsize` is greater than',\n 'the font size defined by trace, then the `minsize` is used.'\n ].join(' ')\n },\n minsize: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets the minimum text size between traces of the same type.'\n ].join(' ')\n },\n editType: 'plot'\n },\n autosize: {\n valType: 'boolean',\n role: 'info',\n dflt: false,\n // autosize, width, and height get special editType treatment in _relayout\n // so we can handle noop resizes more efficiently\n editType: 'none',\n description: [\n 'Determines whether or not a layout width or height',\n 'that has been left undefined by the user',\n 'is initialized on each relayout.',\n\n 'Note that, regardless of this attribute,',\n 'an undefined layout width or height',\n 'is always initialized on the first call to plot.'\n ].join(' ')\n },\n width: {\n valType: 'number',\n role: 'info',\n min: 10,\n dflt: 700,\n editType: 'plot',\n description: [\n 'Sets the plot\\'s width (in px).'\n ].join(' ')\n },\n height: {\n valType: 'number',\n role: 'info',\n min: 10,\n dflt: 450,\n editType: 'plot',\n description: [\n 'Sets the plot\\'s height (in px).'\n ].join(' ')\n },\n margin: {\n l: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the left margin (in px).'\n },\n r: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the right margin (in px).'\n },\n t: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 100,\n editType: 'plot',\n description: 'Sets the top margin (in px).'\n },\n b: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 80,\n editType: 'plot',\n description: 'Sets the bottom margin (in px).'\n },\n pad: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 0,\n editType: 'plot',\n description: [\n 'Sets the amount of padding (in px)',\n 'between the plotting area and the axis lines'\n ].join(' ')\n },\n autoexpand: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'plot',\n description: [\n 'Turns on/off margin expansion computations.',\n 'Legends, colorbars, updatemenus, sliders, axis rangeselector and rangeslider',\n 'are allowed to push the margins by defaults.'\n ].join(' ')\n },\n editType: 'plot'\n },\n paper_bgcolor: {\n valType: 'color',\n role: 'style',\n dflt: colorAttrs.background,\n editType: 'plot',\n description: 'Sets the background color of the paper where the graph is drawn.'\n },\n plot_bgcolor: {\n // defined here, but set in cartesian.supplyLayoutDefaults\n // because it needs to know if there are (2D) axes or not\n valType: 'color',\n role: 'style',\n dflt: colorAttrs.background,\n editType: 'layoutstyle',\n description: [\n 'Sets the background color of the plotting area in-between x and y axes.'\n ].join(' ')\n },\n separators: {\n valType: 'string',\n role: 'style',\n editType: 'plot',\n description: [\n 'Sets the decimal and thousand separators.',\n 'For example, *. * puts a \\'.\\' before decimals and a space',\n 'between thousands. In English locales, dflt is *.,* but',\n 'other locales may alter this default.'\n ].join(' ')\n },\n hidesources: {\n valType: 'boolean',\n role: 'info',\n dflt: false,\n editType: 'plot',\n description: [\n 'Determines whether or not a text link citing the data source is',\n 'placed at the bottom-right cored of the figure.',\n 'Has only an effect only on graphs that have been generated via',\n 'forked graphs from the Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise).'\n ].join(' ')\n },\n showlegend: {\n // handled in legend.supplyLayoutDefaults\n // but included here because it's not in the legend object\n valType: 'boolean',\n role: 'info',\n editType: 'legend',\n description: [\n 'Determines whether or not a legend is drawn.',\n 'Default is `true` if there is a trace to show and any of these:',\n 'a) Two or more traces would by default be shown in the legend.',\n 'b) One pie trace is shown in the legend.',\n 'c) One trace is explicitly given with `showlegend: true`.'\n ].join(' ')\n },\n colorway: {\n valType: 'colorlist',\n dflt: colorAttrs.defaults,\n role: 'style',\n editType: 'calc',\n description: 'Sets the default trace colors.'\n },\n datarevision: {\n valType: 'any',\n role: 'info',\n editType: 'calc',\n description: [\n 'If provided, a changed value tells `Plotly.react` that',\n 'one or more data arrays has changed. This way you can modify',\n 'arrays in-place rather than making a complete new copy for an',\n 'incremental change.',\n 'If NOT provided, `Plotly.react` assumes that data arrays are',\n 'being treated as immutable, thus any data array with a',\n 'different identity from its predecessor contains new data.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Used to allow user interactions with the plot to persist after',\n '`Plotly.react` calls that are unaware of these interactions.',\n 'If `uirevision` is omitted, or if it is given and it changed from',\n 'the previous `Plotly.react` call, the exact new figure is used.',\n 'If `uirevision` is truthy and did NOT change, any attribute',\n 'that has been affected by user interactions and did not receive a',\n 'different value in the new figure will keep the interaction value.',\n '`layout.uirevision` attribute serves as the default for',\n '`uirevision` attributes in various sub-containers. For finer',\n 'control you can set these sub-attributes directly. For example,',\n 'if your app separately controls the data on the x and y axes you',\n 'might set `xaxis.uirevision=*time*` and `yaxis.uirevision=*cost*`.',\n 'Then if only the y data is changed, you can update',\n '`yaxis.uirevision=*quantity*` and the y axis range will reset but',\n 'the x axis range will retain any user-driven zoom.'\n ].join(' ')\n },\n editrevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in `editable: true`',\n 'configuration, other than trace names and axis titles.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n selectionrevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in selected points',\n 'from all traces.'\n ].join(' ')\n },\n template: {\n valType: 'any',\n role: 'info',\n editType: 'calc',\n description: [\n 'Default attributes to be applied to the plot. Templates can be',\n 'created from existing plots using `Plotly.makeTemplate`, or',\n 'created manually. They should be objects with format:',\n '`{layout: layoutTemplate, data: {[type]: [traceTemplate, ...]}, ...}`',\n '`layoutTemplate` and `traceTemplate` are objects matching the',\n 'attribute structure of `layout` and a data trace. ',\n 'Trace templates are applied cyclically to traces of each type.',\n 'Container arrays (eg `annotations`) have special handling:',\n 'An object ending in `defaults` (eg `annotationdefaults`) is applied',\n 'to each array item. But if an item has a `templateitemname` key',\n 'we look in the template array for an item with matching `name` and',\n 'apply that instead. If no matching `name` is found we mark the item',\n 'invisible. Any named template item not referenced is appended to',\n 'the end of the array, so you can use this for a watermark annotation',\n 'or a logo image, for example. To omit one of these items on the plot,',\n 'make an item with matching `templateitemname` and `visible: false`.'\n ].join(' ')\n },\n modebar: {\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'h',\n role: 'info',\n editType: 'modebar',\n description: 'Sets the orientation of the modebar.'\n },\n bgcolor: {\n valType: 'color',\n role: 'style',\n editType: 'modebar',\n description: 'Sets the background color of the modebar.'\n },\n color: {\n valType: 'color',\n role: 'style',\n editType: 'modebar',\n description: 'Sets the color of the icons in the modebar.'\n },\n activecolor: {\n valType: 'color',\n role: 'style',\n editType: 'modebar',\n description: 'Sets the color of the active or hovered on icons in the modebar.'\n },\n uirevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes related to the modebar,',\n 'including `hovermode`, `dragmode`, and `showspikes` at both the',\n 'root level and inside subplots. Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n editType: 'modebar'\n },\n\n meta: {\n valType: 'any',\n arrayOk: true,\n role: 'info',\n editType: 'plot',\n description: [\n 'Assigns extra meta information that can be used in various `text` attributes.',\n 'Attributes such as the graph, axis and colorbar `title.text`, annotation `text`',\n '`trace.name` in legend items, `rangeselector`, `updatemenus` and `sliders` `label` text',\n 'all support `meta`. One can access `meta` fields using template strings:',\n '`%{meta[i]}` where `i` is the index of the `meta`',\n 'item in question.',\n '`meta` can also be an object for example `{key: value}` which can be accessed',\n '%{meta[key]}.'\n ].join(' ')\n },\n\n transition: extendFlat({}, animationAttrs.transition, {\n description: [\n 'Sets transition options used during Plotly.react updates.'\n ].join(' '),\n editType: 'none'\n }),\n _deprecated: {\n title: {\n valType: 'string',\n role: 'info',\n editType: 'layoutstyle',\n description: [\n 'Value of `title` is no longer a simple *string* but a set of sub-attributes.',\n 'To set the contents of the title, please use `title.text` now.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n editType: 'layoutstyle',\n description: [\n 'Former `titlefont` is now the sub-attribute `font` of `title`.',\n 'To customize title font properties, please use `title.font` now.'\n ].join(' ')\n })\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar appendArrayMultiPointValues = require('../../components/fx/helpers').appendArrayMultiPointValues;\n\n// Note: like other eventData routines, this creates the data for hover/unhover/click events\n// but it has a different API and goes through a totally different pathway.\n// So to ensure it doesn't get misused, it's not attached to the Pie module.\nmodule.exports = function eventData(pt, trace) {\n var out = {\n curveNumber: trace.index,\n pointNumbers: pt.pts,\n data: trace._input,\n fullData: trace,\n label: pt.label,\n color: pt.color,\n value: pt.v,\n percent: pt.percent,\n text: pt.text,\n\n // pt.v (and pt.i below) for backward compatibility\n v: pt.v\n };\n\n // Only include pointNumber if it's unambiguous\n if(pt.pts.length === 1) out.pointNumber = out.i = pt.pts[0];\n\n // Add extra data arrays to the output\n // notice that this is the multi-point version ('s' on the end!)\n // so added data will be arrays matching the pointNumbers array.\n appendArrayMultiPointValues(out, trace, pt.pts);\n\n // don't include obsolete fields in new funnelarea traces\n if(trace.type === 'funnelarea') {\n delete out.v;\n delete out.i;\n }\n\n return out;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * All paths are tuned for maximum scalability of the arrowhead,\n * ie throughout arrowwidth=0.3..3 the head is joined smoothly\n * to the line, with the line coming from the left and ending at (0, 0).\n *\n * `backoff` is the distance to move the arrowhead and the end of the line,\n * in order that the arrowhead points to the desired place, either at\n * the tip of the arrow or (in the case of circle or square)\n * the center of the symbol.\n *\n * `noRotate`, if truthy, says that this arrowhead should not rotate with the\n * arrow. That's the case for squares, which should always be straight, and\n * circles, for which it's irrelevant.\n */\n\nmodule.exports = [\n // no arrow\n {\n path: '',\n backoff: 0\n },\n // wide with flat back\n {\n path: 'M-2.4,-3V3L0.6,0Z',\n backoff: 0.6\n },\n // narrower with flat back\n {\n path: 'M-3.7,-2.5V2.5L1.3,0Z',\n backoff: 1.3\n },\n // barbed\n {\n path: 'M-4.45,-3L-1.65,-0.2V0.2L-4.45,3L1.55,0Z',\n backoff: 1.55\n },\n // wide line-drawn\n {\n path: 'M-2.2,-2.2L-0.2,-0.2V0.2L-2.2,2.2L-1.4,3L1.6,0L-1.4,-3Z',\n backoff: 1.6\n },\n // narrower line-drawn\n {\n path: 'M-4.4,-2.1L-0.6,-0.2V0.2L-4.4,2.1L-4,3L2,0L-4,-3Z',\n backoff: 2\n },\n // circle\n {\n path: 'M2,0A2,2 0 1,1 0,-2A2,2 0 0,1 2,0Z',\n backoff: 0,\n noRotate: true\n },\n // square\n {\n path: 'M2,2V-2H-2V2Z',\n backoff: 0,\n noRotate: true\n }\n];\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar Template = require('../plot_api/plot_template');\n\n/** Convenience wrapper for making array container logic DRY and consistent\n *\n * @param {object} parentObjIn\n * user input object where the container in question is linked\n * (i.e. either a user trace object or the user layout object)\n *\n * @param {object} parentObjOut\n * full object where the coerced container will be linked\n * (i.e. either a full trace object or the full layout object)\n *\n * @param {object} opts\n * options object:\n * - name {string}\n * name of the key linking the container in question\n * - inclusionAttr {string}\n * name of the item attribute for inclusion/exclusion. Default is 'visible'.\n * Since inclusion is true, use eg 'enabled' instead of 'disabled'.\n * - handleItemDefaults {function}\n * defaults method to be called on each item in the array container in question\n *\n * Its arguments are:\n * - itemIn {object} item in user layout\n * - itemOut {object} item in full layout\n * - parentObj {object} (as in closure)\n * - opts {object} (as in closure)\n * N.B.\n *\n * - opts is passed to handleItemDefaults so it can also store\n * links to supplementary data (e.g. fullData for layout components)\n *\n */\nmodule.exports = function handleArrayContainerDefaults(parentObjIn, parentObjOut, opts) {\n var name = opts.name;\n var inclusionAttr = opts.inclusionAttr || 'visible';\n\n var previousContOut = parentObjOut[name];\n\n var contIn = Lib.isArrayOrTypedArray(parentObjIn[name]) ? parentObjIn[name] : [];\n var contOut = parentObjOut[name] = [];\n var templater = Template.arrayTemplater(parentObjOut, name, inclusionAttr);\n var i, itemOut;\n\n for(i = 0; i < contIn.length; i++) {\n var itemIn = contIn[i];\n\n if(!Lib.isPlainObject(itemIn)) {\n itemOut = templater.newItem({});\n itemOut[inclusionAttr] = false;\n } else {\n itemOut = templater.newItem(itemIn);\n }\n\n itemOut._index = i;\n\n if(itemOut[inclusionAttr] !== false) {\n opts.handleItemDefaults(itemIn, itemOut, parentObjOut, opts);\n }\n\n contOut.push(itemOut);\n }\n\n var defaultItems = templater.defaultItems();\n for(i = 0; i < defaultItems.length; i++) {\n itemOut = defaultItems[i];\n itemOut._index = contOut.length;\n opts.handleItemDefaults({}, itemOut, parentObjOut, opts, {});\n contOut.push(itemOut);\n }\n\n // in case this array gets its defaults rebuilt independent of the whole layout,\n // relink the private keys just for this array.\n if(Lib.isArrayOrTypedArray(previousContOut)) {\n var len = Math.min(previousContOut.length, contOut.length);\n for(i = 0; i < len; i++) {\n Lib.relinkPrivateKeys(contOut[i], previousContOut[i]);\n }\n }\n\n return contOut;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../registry');\nvar SUBPLOT_PATTERN = require('./cartesian/constants').SUBPLOT_PATTERN;\n\n/**\n * Get calcdata trace(s) associated with a given subplot\n *\n * @param {array} calcData: as in gd.calcdata\n * @param {string} type: subplot type\n * @param {string} subplotId: subplot id to look for\n *\n * @return {array} array of calcdata traces\n */\nexports.getSubplotCalcData = function(calcData, type, subplotId) {\n var basePlotModule = Registry.subplotsRegistry[type];\n if(!basePlotModule) return [];\n\n var attr = basePlotModule.attr;\n var subplotCalcData = [];\n\n for(var i = 0; i < calcData.length; i++) {\n var calcTrace = calcData[i];\n var trace = calcTrace[0].trace;\n\n if(trace[attr] === subplotId) subplotCalcData.push(calcTrace);\n }\n\n return subplotCalcData;\n};\n/**\n * Get calcdata trace(s) that can be plotted with a given module\n * NOTE: this isn't necessarily just exactly matching trace type,\n * if multiple trace types use the same plotting routine, they will be\n * collected here.\n * In order to not plot the same thing multiple times, we return two arrays,\n * the calcdata we *will* plot with this module, and the ones we *won't*\n *\n * @param {array} calcdata: as in gd.calcdata\n * @param {object|string|fn} arg1:\n * the plotting module, or its name, or its plot method\n *\n * @return {array[array]} [foundCalcdata, remainingCalcdata]\n */\nexports.getModuleCalcData = function(calcdata, arg1) {\n var moduleCalcData = [];\n var remainingCalcData = [];\n\n var plotMethod;\n if(typeof arg1 === 'string') {\n plotMethod = Registry.getModule(arg1).plot;\n } else if(typeof arg1 === 'function') {\n plotMethod = arg1;\n } else {\n plotMethod = arg1.plot;\n }\n if(!plotMethod) {\n return [moduleCalcData, calcdata];\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var trace = cd[0].trace;\n // N.B.\n // - 'legendonly' traces do not make it past here\n // - skip over 'visible' traces that got trimmed completely during calc transforms\n if(trace.visible !== true || trace._length === 0) continue;\n\n // group calcdata trace not by 'module' (as the name of this function\n // would suggest), but by 'module plot method' so that if some traces\n // share the same module plot method (e.g. bar and histogram), we\n // only call it one!\n if(trace._module.plot === plotMethod) {\n moduleCalcData.push(cd);\n } else {\n remainingCalcData.push(cd);\n }\n }\n\n return [moduleCalcData, remainingCalcData];\n};\n\n/**\n * Get the data trace(s) associated with a given subplot.\n *\n * @param {array} data plotly full data array.\n * @param {string} type subplot type to look for.\n * @param {string} subplotId subplot id to look for.\n *\n * @return {array} list of trace objects.\n *\n */\nexports.getSubplotData = function getSubplotData(data, type, subplotId) {\n if(!Registry.subplotsRegistry[type]) return [];\n\n var attr = Registry.subplotsRegistry[type].attr;\n var subplotData = [];\n var trace, subplotX, subplotY;\n\n if(type === 'gl2d') {\n var spmatch = subplotId.match(SUBPLOT_PATTERN);\n subplotX = 'x' + spmatch[1];\n subplotY = 'y' + spmatch[2];\n }\n\n for(var i = 0; i < data.length; i++) {\n trace = data[i];\n\n if(type === 'gl2d' && Registry.traceIs(trace, 'gl2d')) {\n if(trace[attr[0]] === subplotX && trace[attr[1]] === subplotY) {\n subplotData.push(trace);\n }\n } else {\n if(trace[attr] === subplotId) subplotData.push(trace);\n }\n }\n\n return subplotData;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n hiddenlabels: {\n valType: 'data_array',\n role: 'info',\n editType: 'calc',\n description: [\n 'hiddenlabels is the funnelarea & pie chart analog of',\n 'visible:\\'legendonly\\'',\n 'but it can contain many labels, and can simultaneously',\n 'hide slices from several pies/funnelarea charts'\n ].join(' ')\n },\n piecolorway: {\n valType: 'colorlist',\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the default pie slice colors. Defaults to the main',\n '`colorway` used for trace colors. If you specify a new',\n 'list here it can still be extended with lighter and darker',\n 'colors, see `extendpiecolors`.'\n ].join(' ')\n },\n extendpiecolors: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'calc',\n description: [\n 'If `true`, the pie slice colors (whether given by `piecolorway` or',\n 'inherited from `colorway`) will be extended to three times its',\n 'original length by first repeating every color 20% lighter then',\n 'each color 20% darker. This is intended to reduce the likelihood',\n 'of reusing the same color when you have many slices, but you can',\n 'set `false` to disable.',\n 'Colors provided in the trace, using `marker.colors`, are never',\n 'extended.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar colorScaleAttrs = require('./layout_attributes');\nvar colorScaleDefaults = require('./defaults');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, colorScaleAttrs, attr, dflt);\n }\n\n coerce('colorscale.sequential');\n coerce('colorscale.sequentialminus');\n coerce('colorscale.diverging');\n\n var colorAxes = layoutOut._colorAxes;\n var colorAxIn, colorAxOut;\n\n function coerceAx(attr, dflt) {\n return Lib.coerce(colorAxIn, colorAxOut, colorScaleAttrs.coloraxis, attr, dflt);\n }\n\n for(var k in colorAxes) {\n var stash = colorAxes[k];\n\n if(stash[0]) {\n colorAxIn = layoutIn[k] || {};\n colorAxOut = Template.newContainer(layoutOut, k, 'coloraxis');\n colorAxOut._name = k;\n colorScaleDefaults(colorAxIn, colorAxOut, layoutOut, coerceAx, {prefix: '', cLetter: 'c'});\n } else {\n // re-coerce colorscale attributes w/o coloraxis\n for(var i = 0; i < stash[2].length; i++) {\n stash[2][i]();\n }\n delete layoutOut._colorAxes[k];\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\n\nvar Registry = require('../../registry');\n\nmodule.exports = function handleXYZDefaults(traceIn, traceOut, coerce, layout, xName, yName) {\n var z = coerce('z');\n xName = xName || 'x';\n yName = yName || 'y';\n var x, y;\n\n if(z === undefined || !z.length) return 0;\n\n if(Lib.isArray1D(traceIn.z)) {\n x = coerce(xName);\n y = coerce(yName);\n\n var xlen = Lib.minRowLength(x);\n var ylen = Lib.minRowLength(y);\n\n // column z must be accompanied by xName and yName arrays\n if(xlen === 0 || ylen === 0) return 0;\n\n traceOut._length = Math.min(xlen, ylen, z.length);\n } else {\n x = coordDefaults(xName, coerce);\n y = coordDefaults(yName, coerce);\n\n // TODO put z validation elsewhere\n if(!isValidZ(z)) return 0;\n\n coerce('transpose');\n\n traceOut._length = null;\n }\n\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleTraceDefaults');\n handleCalendarDefaults(traceIn, traceOut, [xName, yName], layout);\n\n return true;\n};\n\nfunction coordDefaults(coordStr, coerce) {\n var coord = coerce(coordStr);\n var coordType = coord ? coerce(coordStr + 'type', 'array') : 'scaled';\n\n if(coordType === 'scaled') {\n coerce(coordStr + '0');\n coerce('d' + coordStr);\n }\n\n return coord;\n}\n\nfunction isValidZ(z) {\n var allRowsAreArrays = true;\n var oneRowIsFilled = false;\n var hasOneNumber = false;\n var zi;\n\n /*\n * Without this step:\n *\n * hasOneNumber = false breaks contour but not heatmap\n * allRowsAreArrays = false breaks contour but not heatmap\n * oneRowIsFilled = false breaks both\n */\n\n for(var i = 0; i < z.length; i++) {\n zi = z[i];\n if(!Lib.isArrayOrTypedArray(zi)) {\n allRowsAreArrays = false;\n break;\n }\n if(zi.length > 0) oneRowIsFilled = true;\n for(var j = 0; j < zi.length; j++) {\n if(isNumeric(zi[j])) {\n hasOneNumber = true;\n break;\n }\n }\n }\n\n return (allRowsAreArrays && oneRowIsFilled && hasOneNumber);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = require('../src/traces/pie');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\n// IMPORTANT - default colors should be in hex for compatibility\nexports.defaults = [\n '#1f77b4', // muted blue\n '#ff7f0e', // safety orange\n '#2ca02c', // cooked asparagus green\n '#d62728', // brick red\n '#9467bd', // muted purple\n '#8c564b', // chestnut brown\n '#e377c2', // raspberry yogurt pink\n '#7f7f7f', // middle gray\n '#bcbd22', // curry yellow-green\n '#17becf' // blue-teal\n];\n\nexports.defaultLine = '#444';\n\nexports.lightLine = '#eee';\n\nexports.background = '#fff';\n\nexports.borderLine = '#BEC8D9';\n\n// with axis.color and Color.interp we aren't using lightLine\n// itself anymore, instead interpolating between axis.color\n// and the background color using tinycolor.mix. lightFraction\n// gives back exactly lightLine if the other colors are defaults.\nexports.lightFraction = 100 * (0xe - 0x4) / (0xf - 0x4);\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Loggers = require('./loggers');\nvar mod = require('./mod').mod;\n\nvar constants = require('../constants/numerical');\nvar BADNUM = constants.BADNUM;\nvar ONEDAY = constants.ONEDAY;\nvar ONEHOUR = constants.ONEHOUR;\nvar ONEMIN = constants.ONEMIN;\nvar ONESEC = constants.ONESEC;\nvar EPOCHJD = constants.EPOCHJD;\n\nvar Registry = require('../registry');\n\nvar utcFormat = d3.time.format.utc;\n\nvar DATETIME_REGEXP = /^\\s*(-?\\d\\d\\d\\d|\\d\\d)(-(\\d?\\d)(-(\\d?\\d)([ Tt]([01]?\\d|2[0-3])(:([0-5]\\d)(:([0-5]\\d(\\.\\d+)?))?(Z|z|[+\\-]\\d\\d:?\\d\\d)?)?)?)?)?\\s*$/m;\n// special regex for chinese calendars to support yyyy-mmi-dd etc for intercalary months\nvar DATETIME_REGEXP_CN = /^\\s*(-?\\d\\d\\d\\d|\\d\\d)(-(\\d?\\di?)(-(\\d?\\d)([ Tt]([01]?\\d|2[0-3])(:([0-5]\\d)(:([0-5]\\d(\\.\\d+)?))?(Z|z|[+\\-]\\d\\d:?\\d\\d)?)?)?)?)?\\s*$/m;\n\n// for 2-digit years, the first year we map them onto\nvar YFIRST = new Date().getFullYear() - 70;\n\nfunction isWorldCalendar(calendar) {\n return (\n calendar &&\n Registry.componentsRegistry.calendars &&\n typeof calendar === 'string' && calendar !== 'gregorian'\n );\n}\n\n/*\n * dateTick0: get the canonical tick for this calendar\n *\n * bool sunday is for week ticks, shift it to a Sunday.\n */\nexports.dateTick0 = function(calendar, sunday) {\n if(isWorldCalendar(calendar)) {\n return sunday ?\n Registry.getComponentMethod('calendars', 'CANONICAL_SUNDAY')[calendar] :\n Registry.getComponentMethod('calendars', 'CANONICAL_TICK')[calendar];\n } else {\n return sunday ? '2000-01-02' : '2000-01-01';\n }\n};\n\n/*\n * dfltRange: for each calendar, give a valid default range\n */\nexports.dfltRange = function(calendar) {\n if(isWorldCalendar(calendar)) {\n return Registry.getComponentMethod('calendars', 'DFLTRANGE')[calendar];\n } else {\n return ['2000-01-01', '2001-01-01'];\n }\n};\n\n// is an object a javascript date?\nexports.isJSDate = function(v) {\n return typeof v === 'object' && v !== null && typeof v.getTime === 'function';\n};\n\n// The absolute limits of our date-time system\n// This is a little weird: we use MIN_MS and MAX_MS in dateTime2ms\n// but we use dateTime2ms to calculate them (after defining it!)\nvar MIN_MS, MAX_MS;\n\n/**\n * dateTime2ms - turn a date object or string s into milliseconds\n * (relative to 1970-01-01, per javascript standard)\n * optional calendar (string) to use a non-gregorian calendar\n *\n * Returns BADNUM if it doesn't find a date\n *\n * strings should have the form:\n *\n * -?YYYY-mm-ddHH:MM:SS.sss?\n *\n * : space (our normal standard) or T or t (ISO-8601)\n * : Z, z, or [+\\-]HH:?MM and we THROW IT AWAY\n * this format comes from https://tools.ietf.org/html/rfc3339#section-5.6\n * but we allow it even with a space as the separator\n *\n * May truncate after any full field, and sss can be any length\n * even >3 digits, though javascript dates truncate to milliseconds,\n * we keep as much as javascript numeric precision can hold, but we only\n * report back up to 100 microsecond precision, because most dates support\n * this precision (close to 1970 support more, very far away support less)\n *\n * Expanded to support negative years to -9999 but you must always\n * give 4 digits, except for 2-digit positive years which we assume are\n * near the present time.\n * Note that we follow ISO 8601:2004: there *is* a year 0, which\n * is 1BC/BCE, and -1===2BC etc.\n *\n * World calendars: not all of these *have* agreed extensions to this full range,\n * if you have another calendar system but want a date range outside its validity,\n * you can use a gregorian date string prefixed with 'G' or 'g'.\n *\n * Where to cut off 2-digit years between 1900s and 2000s?\n * from http://support.microsoft.com/kb/244664:\n * 1930-2029 (the most retro of all...)\n * but in my mac chrome from eg. d=new Date(Date.parse('8/19/50')):\n * 1950-2049\n * by Java, from http://stackoverflow.com/questions/2024273/:\n * now-80 - now+19\n * or FileMaker Pro, from\n * http://www.filemaker.com/12help/html/add_view_data.4.21.html:\n * now-70 - now+29\n * but python strptime etc, via\n * http://docs.python.org/py3k/library/time.html:\n * 1969-2068 (super forward-looking, but static, not sliding!)\n *\n * lets go with now-70 to now+29, and if anyone runs into this problem\n * they can learn the hard way not to use 2-digit years, as no choice we\n * make now will cover all possibilities. mostly this will all be taken\n * care of in initial parsing, should only be an issue for hand-entered data\n * currently (2016) this range is:\n * 1946-2045\n */\nexports.dateTime2ms = function(s, calendar) {\n // first check if s is a date object\n if(exports.isJSDate(s)) {\n // Convert to the UTC milliseconds that give the same\n // hours as this date has in the local timezone\n var tzOffset = s.getTimezoneOffset() * ONEMIN;\n var offsetTweak = (s.getUTCMinutes() - s.getMinutes()) * ONEMIN +\n (s.getUTCSeconds() - s.getSeconds()) * ONESEC +\n (s.getUTCMilliseconds() - s.getMilliseconds());\n\n if(offsetTweak) {\n var comb = 3 * ONEMIN;\n tzOffset = tzOffset - comb / 2 + mod(offsetTweak - tzOffset + comb / 2, comb);\n }\n s = Number(s) - tzOffset;\n if(s >= MIN_MS && s <= MAX_MS) return s;\n return BADNUM;\n }\n // otherwise only accept strings and numbers\n if(typeof s !== 'string' && typeof s !== 'number') return BADNUM;\n\n s = String(s);\n\n var isWorld = isWorldCalendar(calendar);\n\n // to handle out-of-range dates in international calendars, accept\n // 'G' as a prefix to force the built-in gregorian calendar.\n var s0 = s.charAt(0);\n if(isWorld && (s0 === 'G' || s0 === 'g')) {\n s = s.substr(1);\n calendar = '';\n }\n\n var isChinese = isWorld && calendar.substr(0, 7) === 'chinese';\n\n var match = s.match(isChinese ? DATETIME_REGEXP_CN : DATETIME_REGEXP);\n if(!match) return BADNUM;\n var y = match[1];\n var m = match[3] || '1';\n var d = Number(match[5] || 1);\n var H = Number(match[7] || 0);\n var M = Number(match[9] || 0);\n var S = Number(match[11] || 0);\n\n if(isWorld) {\n // disallow 2-digit years for world calendars\n if(y.length === 2) return BADNUM;\n y = Number(y);\n\n var cDate;\n try {\n var calInstance = Registry.getComponentMethod('calendars', 'getCal')(calendar);\n if(isChinese) {\n var isIntercalary = m.charAt(m.length - 1) === 'i';\n m = parseInt(m, 10);\n cDate = calInstance.newDate(y, calInstance.toMonthIndex(y, m, isIntercalary), d);\n } else {\n cDate = calInstance.newDate(y, Number(m), d);\n }\n } catch(e) { return BADNUM; } // Invalid ... date\n\n if(!cDate) return BADNUM;\n\n return ((cDate.toJD() - EPOCHJD) * ONEDAY) +\n (H * ONEHOUR) + (M * ONEMIN) + (S * ONESEC);\n }\n\n if(y.length === 2) {\n y = (Number(y) + 2000 - YFIRST) % 100 + YFIRST;\n } else y = Number(y);\n\n // new Date uses months from 0; subtract 1 here just so we\n // don't have to do it again during the validity test below\n m -= 1;\n\n // javascript takes new Date(0..99,m,d) to mean 1900-1999, so\n // to support years 0-99 we need to use setFullYear explicitly\n // Note that 2000 is a leap year.\n var date = new Date(Date.UTC(2000, m, d, H, M));\n date.setUTCFullYear(y);\n\n if(date.getUTCMonth() !== m) return BADNUM;\n if(date.getUTCDate() !== d) return BADNUM;\n\n return date.getTime() + S * ONESEC;\n};\n\nMIN_MS = exports.MIN_MS = exports.dateTime2ms('-9999');\nMAX_MS = exports.MAX_MS = exports.dateTime2ms('9999-12-31 23:59:59.9999');\n\n// is string s a date? (see above)\nexports.isDateTime = function(s, calendar) {\n return (exports.dateTime2ms(s, calendar) !== BADNUM);\n};\n\n// pad a number with zeroes, to given # of digits before the decimal point\nfunction lpad(val, digits) {\n return String(val + Math.pow(10, digits)).substr(1);\n}\n\n/**\n * Turn ms into string of the form YYYY-mm-dd HH:MM:SS.ssss\n * Crop any trailing zeros in time, except never stop right after hours\n * (we could choose to crop '-01' from date too but for now we always\n * show the whole date)\n * Optional range r is the data range that applies, also in ms.\n * If rng is big, the later parts of time will be omitted\n */\nvar NINETYDAYS = 90 * ONEDAY;\nvar THREEHOURS = 3 * ONEHOUR;\nvar FIVEMIN = 5 * ONEMIN;\nexports.ms2DateTime = function(ms, r, calendar) {\n if(typeof ms !== 'number' || !(ms >= MIN_MS && ms <= MAX_MS)) return BADNUM;\n\n if(!r) r = 0;\n\n var msecTenths = Math.floor(mod(ms + 0.05, 1) * 10);\n var msRounded = Math.round(ms - msecTenths / 10);\n var dateStr, h, m, s, msec10, d;\n\n if(isWorldCalendar(calendar)) {\n var dateJD = Math.floor(msRounded / ONEDAY) + EPOCHJD;\n var timeMs = Math.floor(mod(ms, ONEDAY));\n try {\n dateStr = Registry.getComponentMethod('calendars', 'getCal')(calendar)\n .fromJD(dateJD).formatDate('yyyy-mm-dd');\n } catch(e) {\n // invalid date in this calendar - fall back to Gyyyy-mm-dd\n dateStr = utcFormat('G%Y-%m-%d')(new Date(msRounded));\n }\n\n // yyyy does NOT guarantee 4-digit years. YYYY mostly does, but does\n // other things for a few calendars, so we can't trust it. Just pad\n // it manually (after the '-' if there is one)\n if(dateStr.charAt(0) === '-') {\n while(dateStr.length < 11) dateStr = '-0' + dateStr.substr(1);\n } else {\n while(dateStr.length < 10) dateStr = '0' + dateStr;\n }\n\n // TODO: if this is faster, we could use this block for extracting\n // the time components of regular gregorian too\n h = (r < NINETYDAYS) ? Math.floor(timeMs / ONEHOUR) : 0;\n m = (r < NINETYDAYS) ? Math.floor((timeMs % ONEHOUR) / ONEMIN) : 0;\n s = (r < THREEHOURS) ? Math.floor((timeMs % ONEMIN) / ONESEC) : 0;\n msec10 = (r < FIVEMIN) ? (timeMs % ONESEC) * 10 + msecTenths : 0;\n } else {\n d = new Date(msRounded);\n\n dateStr = utcFormat('%Y-%m-%d')(d);\n\n // <90 days: add hours and minutes - never *only* add hours\n h = (r < NINETYDAYS) ? d.getUTCHours() : 0;\n m = (r < NINETYDAYS) ? d.getUTCMinutes() : 0;\n // <3 hours: add seconds\n s = (r < THREEHOURS) ? d.getUTCSeconds() : 0;\n // <5 minutes: add ms (plus one extra digit, this is msec*10)\n msec10 = (r < FIVEMIN) ? d.getUTCMilliseconds() * 10 + msecTenths : 0;\n }\n\n return includeTime(dateStr, h, m, s, msec10);\n};\n\n// For converting old-style milliseconds to date strings,\n// we use the local timezone rather than UTC like we use\n// everywhere else, both for backward compatibility and\n// because that's how people mostly use javasript date objects.\n// Clip one extra day off our date range though so we can't get\n// thrown beyond the range by the timezone shift.\nexports.ms2DateTimeLocal = function(ms) {\n if(!(ms >= MIN_MS + ONEDAY && ms <= MAX_MS - ONEDAY)) return BADNUM;\n\n var msecTenths = Math.floor(mod(ms + 0.05, 1) * 10);\n var d = new Date(Math.round(ms - msecTenths / 10));\n var dateStr = d3.time.format('%Y-%m-%d')(d);\n var h = d.getHours();\n var m = d.getMinutes();\n var s = d.getSeconds();\n var msec10 = d.getUTCMilliseconds() * 10 + msecTenths;\n\n return includeTime(dateStr, h, m, s, msec10);\n};\n\nfunction includeTime(dateStr, h, m, s, msec10) {\n // include each part that has nonzero data in or after it\n if(h || m || s || msec10) {\n dateStr += ' ' + lpad(h, 2) + ':' + lpad(m, 2);\n if(s || msec10) {\n dateStr += ':' + lpad(s, 2);\n if(msec10) {\n var digits = 4;\n while(msec10 % 10 === 0) {\n digits -= 1;\n msec10 /= 10;\n }\n dateStr += '.' + lpad(msec10, digits);\n }\n }\n }\n return dateStr;\n}\n\n// normalize date format to date string, in case it starts as\n// a Date object or milliseconds\n// optional dflt is the return value if cleaning fails\nexports.cleanDate = function(v, dflt, calendar) {\n // let us use cleanDate to provide a missing default without an error\n if(v === BADNUM) return dflt;\n if(exports.isJSDate(v) || (typeof v === 'number' && isFinite(v))) {\n // do not allow milliseconds (old) or jsdate objects (inherently\n // described as gregorian dates) with world calendars\n if(isWorldCalendar(calendar)) {\n Loggers.error('JS Dates and milliseconds are incompatible with world calendars', v);\n return dflt;\n }\n\n // NOTE: if someone puts in a year as a number rather than a string,\n // this will mistakenly convert it thinking it's milliseconds from 1970\n // that is: '2012' -> Jan. 1, 2012, but 2012 -> 2012 epoch milliseconds\n v = exports.ms2DateTimeLocal(+v);\n if(!v && dflt !== undefined) return dflt;\n } else if(!exports.isDateTime(v, calendar)) {\n Loggers.error('unrecognized date', v);\n return dflt;\n }\n return v;\n};\n\n/*\n * Date formatting for ticks and hovertext\n */\n\n/*\n * modDateFormat: Support world calendars, and add one item to\n * d3's vocabulary:\n * %{n}f where n is the max number of digits of fractional seconds\n */\nvar fracMatch = /%\\d?f/g;\nfunction modDateFormat(fmt, x, formatter, calendar) {\n fmt = fmt.replace(fracMatch, function(match) {\n var digits = Math.min(+(match.charAt(1)) || 6, 6);\n var fracSecs = ((x / 1000 % 1) + 2)\n .toFixed(digits)\n .substr(2).replace(/0+$/, '') || '0';\n return fracSecs;\n });\n\n var d = new Date(Math.floor(x + 0.05));\n\n if(isWorldCalendar(calendar)) {\n try {\n fmt = Registry.getComponentMethod('calendars', 'worldCalFmt')(fmt, x, calendar);\n } catch(e) {\n return 'Invalid';\n }\n }\n return formatter(fmt)(d);\n}\n\n/*\n * formatTime: create a time string from:\n * x: milliseconds\n * tr: tickround ('M', 'S', or # digits)\n * only supports UTC times (where every day is 24 hours and 0 is at midnight)\n */\nvar MAXSECONDS = [59, 59.9, 59.99, 59.999, 59.9999];\nfunction formatTime(x, tr) {\n var timePart = mod(x + 0.05, ONEDAY);\n\n var timeStr = lpad(Math.floor(timePart / ONEHOUR), 2) + ':' +\n lpad(mod(Math.floor(timePart / ONEMIN), 60), 2);\n\n if(tr !== 'M') {\n if(!isNumeric(tr)) tr = 0; // should only be 'S'\n\n /*\n * this is a weird one - and shouldn't come up unless people\n * monkey with tick0 in weird ways, but we need to do something!\n * IN PARTICULAR we had better not display garbage (see below)\n * for numbers we always round to the nearest increment of the\n * precision we're showing, and this seems like the right way to\n * handle seconds and milliseconds, as they have a decimal point\n * and people will interpret that to mean rounding like numbers.\n * but for larger increments we floor the value: it's always\n * 2013 until the ball drops on the new year. We could argue about\n * which field it is where we start rounding (should 12:08:59\n * round to 12:09 if we're stopping at minutes?) but for now I'll\n * say we round seconds but floor everything else. BUT that means\n * we need to never round up to 60 seconds, ie 23:59:60\n */\n var sec = Math.min(mod(x / ONESEC, 60), MAXSECONDS[tr]);\n\n var secStr = (100 + sec).toFixed(tr).substr(1);\n if(tr > 0) {\n secStr = secStr.replace(/0+$/, '').replace(/[\\.]$/, '');\n }\n\n timeStr += ':' + secStr;\n }\n return timeStr;\n}\n\n/*\n * formatDate: turn a date into tick or hover label text.\n *\n * x: milliseconds, the value to convert\n * fmt: optional, an explicit format string (d3 format, even for world calendars)\n * tr: tickround ('y', 'm', 'd', 'M', 'S', or # digits)\n * used if no explicit fmt is provided\n * formatter: locale-aware d3 date formatter for standard gregorian calendars\n * should be the result of exports.getD3DateFormat(gd)\n * calendar: optional string, the world calendar system to use\n *\n * returns the date/time as a string, potentially with the leading portion\n * on a separate line (after '\\n')\n * Note that this means if you provide an explicit format which includes '\\n'\n * the axis may choose to strip things after it when they don't change from\n * one tick to the next (as it does with automatic formatting)\n */\nexports.formatDate = function(x, fmt, tr, formatter, calendar, extraFormat) {\n calendar = isWorldCalendar(calendar) && calendar;\n\n if(!fmt) {\n if(tr === 'y') fmt = extraFormat.year;\n else if(tr === 'm') fmt = extraFormat.month;\n else if(tr === 'd') {\n fmt = extraFormat.dayMonth + '\\n' + extraFormat.year;\n } else {\n return formatTime(x, tr) + '\\n' + modDateFormat(extraFormat.dayMonthYear, x, formatter, calendar);\n }\n }\n\n return modDateFormat(fmt, x, formatter, calendar);\n};\n\n/*\n * incrementMonth: make a new milliseconds value from the given one,\n * having changed the month\n *\n * special case for world calendars: multiples of 12 are treated as years,\n * even for calendar systems that don't have (always or ever) 12 months/year\n * TODO: perhaps we need a different code for year increments to support this?\n *\n * ms (number): the initial millisecond value\n * dMonth (int): the (signed) number of months to shift\n * calendar (string): the calendar system to use\n *\n * changing month does not (and CANNOT) always preserve day, since\n * months have different lengths. The worst example of this is:\n * d = new Date(1970,0,31); d.setMonth(1) -> Feb 31 turns into Mar 3\n *\n * But we want to be able to iterate over the last day of each month,\n * regardless of what its number is.\n * So shift 3 days forward, THEN set the new month, then unshift:\n * 1/31 -> 2/28 (or 29) -> 3/31 -> 4/30 -> ...\n *\n * Note that odd behavior still exists if you start from the 26th-28th:\n * 1/28 -> 2/28 -> 3/31\n * but at least you can't shift any dates into the wrong month,\n * and ticks on these days incrementing by month would be very unusual\n */\nvar THREEDAYS = 3 * ONEDAY;\nexports.incrementMonth = function(ms, dMonth, calendar) {\n calendar = isWorldCalendar(calendar) && calendar;\n\n // pull time out and operate on pure dates, then add time back at the end\n // this gives maximum precision - not that we *normally* care if we're\n // incrementing by month, but better to be safe!\n var timeMs = mod(ms, ONEDAY);\n ms = Math.round(ms - timeMs);\n\n if(calendar) {\n try {\n var dateJD = Math.round(ms / ONEDAY) + EPOCHJD;\n var calInstance = Registry.getComponentMethod('calendars', 'getCal')(calendar);\n var cDate = calInstance.fromJD(dateJD);\n\n if(dMonth % 12) calInstance.add(cDate, dMonth, 'm');\n else calInstance.add(cDate, dMonth / 12, 'y');\n\n return (cDate.toJD() - EPOCHJD) * ONEDAY + timeMs;\n } catch(e) {\n Loggers.error('invalid ms ' + ms + ' in calendar ' + calendar);\n // then keep going in gregorian even though the result will be 'Invalid'\n }\n }\n\n var y = new Date(ms + THREEDAYS);\n return y.setUTCMonth(y.getUTCMonth() + dMonth) + timeMs - THREEDAYS;\n};\n\n/*\n * findExactDates: what fraction of data is exact days, months, or years?\n *\n * data: array of millisecond values\n * calendar (string) the calendar to test against\n */\nexports.findExactDates = function(data, calendar) {\n var exactYears = 0;\n var exactMonths = 0;\n var exactDays = 0;\n var blankCount = 0;\n var d;\n var di;\n\n var calInstance = (\n isWorldCalendar(calendar) &&\n Registry.getComponentMethod('calendars', 'getCal')(calendar)\n );\n\n for(var i = 0; i < data.length; i++) {\n di = data[i];\n\n // not date data at all\n if(!isNumeric(di)) {\n blankCount ++;\n continue;\n }\n\n // not an exact date\n if(di % ONEDAY) continue;\n\n if(calInstance) {\n try {\n d = calInstance.fromJD(di / ONEDAY + EPOCHJD);\n if(d.day() === 1) {\n if(d.month() === 1) exactYears++;\n else exactMonths++;\n } else exactDays++;\n } catch(e) {\n // invalid date in this calendar - ignore it here.\n }\n } else {\n d = new Date(di);\n if(d.getUTCDate() === 1) {\n if(d.getUTCMonth() === 0) exactYears++;\n else exactMonths++;\n } else exactDays++;\n }\n }\n exactMonths += exactYears;\n exactDays += exactMonths;\n\n var dataCount = data.length - blankCount;\n\n return {\n exactYears: exactYears / dataCount,\n exactMonths: exactMonths / dataCount,\n exactDays: exactDays / dataCount\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar colorScaleAttrs = require('./attributes');\nvar scales = require('./scales').scales;\n\nvar msg = 'Note that `autocolorscale` must be true for this attribute to work.';\n\nmodule.exports = {\n editType: 'calc',\n\n colorscale: {\n editType: 'calc',\n\n sequential: {\n valType: 'colorscale',\n dflt: scales.Reds,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the default sequential colorscale for positive values.',\n msg\n ].join(' ')\n },\n sequentialminus: {\n valType: 'colorscale',\n dflt: scales.Blues,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the default sequential colorscale for negative values.',\n msg\n ].join(' ')\n },\n diverging: {\n valType: 'colorscale',\n dflt: scales.RdBu,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the default diverging colorscale.',\n msg\n ].join(' ')\n }\n },\n\n coloraxis: extendFlat({\n // not really a 'subplot' attribute container,\n // but this is the flag we use to denote attributes that\n // support yaxis, yaxis2, yaxis3, ... counters\n _isSubplotObj: true,\n editType: 'calc',\n description: [\n ''\n ].join(' ')\n }, colorScaleAttrs('', {\n colorAttr: 'corresponding trace color array(s)',\n noColorAxis: true,\n showScaleDflt: true\n }))\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar hasColorscale = require('./helpers').hasColorscale;\nvar extractOpts = require('./helpers').extractOpts;\n\nmodule.exports = function crossTraceDefaults(fullData, fullLayout) {\n function replace(cont, k) {\n var val = cont['_' + k];\n if(val !== undefined) {\n cont[k] = val;\n }\n }\n\n function relinkColorAttrs(outerCont, cbOpt) {\n var cont = cbOpt.container ?\n Lib.nestedProperty(outerCont, cbOpt.container).get() :\n outerCont;\n\n if(cont) {\n if(cont.coloraxis) {\n // stash ref to color axis\n cont._colorAx = fullLayout[cont.coloraxis];\n } else {\n var cOpts = extractOpts(cont);\n var isAuto = cOpts.auto;\n\n if(isAuto || cOpts.min === undefined) {\n replace(cont, cbOpt.min);\n }\n if(isAuto || cOpts.max === undefined) {\n replace(cont, cbOpt.max);\n }\n if(cOpts.autocolorscale) {\n replace(cont, 'colorscale');\n }\n }\n }\n }\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n var cbOpts = trace._module.colorbar;\n\n if(cbOpts) {\n if(Array.isArray(cbOpts)) {\n for(var j = 0; j < cbOpts.length; j++) {\n relinkColorAttrs(trace, cbOpts[j]);\n }\n } else {\n relinkColorAttrs(trace, cbOpts);\n }\n }\n\n if(hasColorscale(trace, 'marker.line')) {\n relinkColorAttrs(trace, {\n container: 'marker.line',\n min: 'cmin',\n max: 'cmax'\n });\n }\n }\n\n for(var k in fullLayout._colorAxes) {\n relinkColorAttrs(fullLayout[k], {min: 'cmin', max: 'cmax'});\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar ARROWPATHS = require('./arrow_paths');\nvar fontAttrs = require('../../plots/font_attributes');\nvar cartesianConstants = require('../../plots/cartesian/constants');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\n\nmodule.exports = templatedArray('annotation', {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not this annotation is visible.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text associated with this annotation.',\n 'Plotly uses a subset of HTML tags to do things like',\n 'newline (
), bold (), italics (),',\n 'hyperlinks (). Tags , , ',\n ' are also supported.'\n ].join(' ')\n },\n textangle: {\n valType: 'angle',\n dflt: 0,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the angle at which the `text` is drawn',\n 'with respect to the horizontal.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'calc+arraydraw',\n colorEditType: 'arraydraw',\n description: 'Sets the annotation text font.'\n }),\n width: {\n valType: 'number',\n min: 1,\n dflt: null,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets an explicit width for the text box. null (default) lets the',\n 'text set the box width. Wider text will be clipped.',\n 'There is no automatic wrapping; use
to start a new line.'\n ].join(' ')\n },\n height: {\n valType: 'number',\n min: 1,\n dflt: null,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets an explicit height for the text box. null (default) lets the',\n 'text set the box height. Taller text will be clipped.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the opacity of the annotation (text + arrow).'\n },\n align: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'center',\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Sets the horizontal alignment of the `text` within the box.',\n 'Has an effect only if `text` spans two or more lines',\n '(i.e. `text` contains one or more
HTML tags) or if an',\n 'explicit width is set to override the text width.'\n ].join(' ')\n },\n valign: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'middle',\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Sets the vertical alignment of the `text` within the box.',\n 'Has an effect only if an explicit height is set to override',\n 'the text height.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the background color of the annotation.'\n },\n bordercolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Sets the color of the border enclosing the annotation `text`.'\n ].join(' ')\n },\n borderpad: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the padding (in px) between the `text`',\n 'and the enclosing border.'\n ].join(' ')\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the width (in px) of the border enclosing',\n 'the annotation `text`.'\n ].join(' ')\n },\n // arrow\n showarrow: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not the annotation is drawn with an arrow.',\n 'If *true*, `text` is placed near the arrow\\'s tail.',\n 'If *false*, `text` lines up with the `x` and `y` provided.'\n ].join(' ')\n },\n arrowcolor: {\n valType: 'color',\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the color of the annotation arrow.'\n },\n arrowhead: {\n valType: 'integer',\n min: 0,\n max: ARROWPATHS.length,\n dflt: 1,\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the end annotation arrow head style.'\n },\n startarrowhead: {\n valType: 'integer',\n min: 0,\n max: ARROWPATHS.length,\n dflt: 1,\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the start annotation arrow head style.'\n },\n arrowside: {\n valType: 'flaglist',\n flags: ['end', 'start'],\n extras: ['none'],\n dflt: 'end',\n role: 'style',\n editType: 'arraydraw',\n description: 'Sets the annotation arrow head position.'\n },\n arrowsize: {\n valType: 'number',\n min: 0.3,\n dflt: 1,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the size of the end annotation arrow head, relative to `arrowwidth`.',\n 'A value of 1 (default) gives a head about 3x as wide as the line.'\n ].join(' ')\n },\n startarrowsize: {\n valType: 'number',\n min: 0.3,\n dflt: 1,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the size of the start annotation arrow head, relative to `arrowwidth`.',\n 'A value of 1 (default) gives a head about 3x as wide as the line.'\n ].join(' ')\n },\n arrowwidth: {\n valType: 'number',\n min: 0.1,\n role: 'style',\n editType: 'calc+arraydraw',\n description: 'Sets the width (in px) of annotation arrow line.'\n },\n standoff: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets a distance, in pixels, to move the end arrowhead away from the',\n 'position it is pointing at, for example to point at the edge of',\n 'a marker independent of zoom. Note that this shortens the arrow',\n 'from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`',\n 'which moves everything by this amount.'\n ].join(' ')\n },\n startstandoff: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Sets a distance, in pixels, to move the start arrowhead away from the',\n 'position it is pointing at, for example to point at the edge of',\n 'a marker independent of zoom. Note that this shortens the arrow',\n 'from the `ax` / `ay` vector, in contrast to `xshift` / `yshift`',\n 'which moves everything by this amount.'\n ].join(' ')\n },\n ax: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the x component of the arrow tail about the arrow head.',\n 'If `axref` is `pixel`, a positive (negative) ',\n 'component corresponds to an arrow pointing',\n 'from right to left (left to right).',\n 'If `axref` is an axis, this is an absolute value on that axis,',\n 'like `x`, NOT a relative value.'\n ].join(' ')\n },\n ay: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the y component of the arrow tail about the arrow head.',\n 'If `ayref` is `pixel`, a positive (negative) ',\n 'component corresponds to an arrow pointing',\n 'from bottom to top (top to bottom).',\n 'If `ayref` is an axis, this is an absolute value on that axis,',\n 'like `y`, NOT a relative value.'\n ].join(' ')\n },\n axref: {\n valType: 'enumerated',\n dflt: 'pixel',\n values: [\n 'pixel',\n cartesianConstants.idRegex.x.toString()\n ],\n role: 'info',\n editType: 'calc',\n description: [\n 'Indicates in what terms the tail of the annotation (ax,ay) ',\n 'is specified. If `pixel`, `ax` is a relative offset in pixels ',\n 'from `x`. If set to an x axis id (e.g. *x* or *x2*), `ax` is ',\n 'specified in the same terms as that axis. This is useful ',\n 'for trendline annotations which should continue to indicate ',\n 'the correct trend when zoomed.'\n ].join(' ')\n },\n ayref: {\n valType: 'enumerated',\n dflt: 'pixel',\n values: [\n 'pixel',\n cartesianConstants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'calc',\n description: [\n 'Indicates in what terms the tail of the annotation (ax,ay) ',\n 'is specified. If `pixel`, `ay` is a relative offset in pixels ',\n 'from `y`. If set to a y axis id (e.g. *y* or *y2*), `ay` is ',\n 'specified in the same terms as that axis. This is useful ',\n 'for trendline annotations which should continue to indicate ',\n 'the correct trend when zoomed.'\n ].join(' ')\n },\n // positioning\n xref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.x.toString()\n ],\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the annotation\\'s x coordinate axis.',\n 'If set to an x axis id (e.g. *x* or *x2*), the `x` position',\n 'refers to an x coordinate',\n 'If set to *paper*, the `x` position refers to the distance from',\n 'the left side of the plotting area in normalized coordinates',\n 'where 0 (1) corresponds to the left (right) side.'\n ].join(' ')\n },\n x: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the annotation\\'s x position.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'auto',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text box\\'s horizontal position anchor',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the annotation.',\n 'For example, if `x` is set to 1, `xref` to *paper* and',\n '`xanchor` to *right* then the right-most portion of the',\n 'annotation lines up with the right-most edge of the',\n 'plotting area.',\n 'If *auto*, the anchor is equivalent to *center* for',\n 'data-referenced annotations or if there is an arrow,',\n 'whereas for paper-referenced with no arrow, the anchor picked',\n 'corresponds to the closest side.'\n ].join(' ')\n },\n xshift: {\n valType: 'number',\n dflt: 0,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Shifts the position of the whole annotation and arrow to the',\n 'right (positive) or left (negative) by this many pixels.'\n ].join(' ')\n },\n yref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the annotation\\'s y coordinate axis.',\n 'If set to an y axis id (e.g. *y* or *y2*), the `y` position',\n 'refers to an y coordinate',\n 'If set to *paper*, the `y` position refers to the distance from',\n 'the bottom of the plotting area in normalized coordinates',\n 'where 0 (1) corresponds to the bottom (top).'\n ].join(' ')\n },\n y: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the annotation\\'s y position.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'auto',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the text box\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the annotation.',\n 'For example, if `y` is set to 1, `yref` to *paper* and',\n '`yanchor` to *top* then the top-most portion of the',\n 'annotation lines up with the top-most edge of the',\n 'plotting area.',\n 'If *auto*, the anchor is equivalent to *middle* for',\n 'data-referenced annotations or if there is an arrow,',\n 'whereas for paper-referenced with no arrow, the anchor picked',\n 'corresponds to the closest side.'\n ].join(' ')\n },\n yshift: {\n valType: 'number',\n dflt: 0,\n role: 'style',\n editType: 'calc+arraydraw',\n description: [\n 'Shifts the position of the whole annotation and arrow up',\n '(positive) or down (negative) by this many pixels.'\n ].join(' ')\n },\n clicktoshow: {\n valType: 'enumerated',\n values: [false, 'onoff', 'onout'],\n dflt: false,\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Makes this annotation respond to clicks on the plot.',\n 'If you click a data point that exactly matches the `x` and `y`',\n 'values of this annotation, and it is hidden (visible: false),',\n 'it will appear. In *onoff* mode, you must click the same point',\n 'again to make it disappear, so if you click multiple points,',\n 'you can show multiple annotations. In *onout* mode, a click',\n 'anywhere else in the plot (on another data point or not) will',\n 'hide this annotation.',\n 'If you need to show/hide this annotation in response to different',\n '`x` or `y` values, you can set `xclick` and/or `yclick`. This is',\n 'useful for example to label the side of a bar. To label markers',\n 'though, `standoff` is preferred over `xclick` and `yclick`.'\n ].join(' ')\n },\n xclick: {\n valType: 'any',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Toggle this annotation when clicking a data point whose `x` value',\n 'is `xclick` rather than the annotation\\'s `x` value.'\n ].join(' ')\n },\n yclick: {\n valType: 'any',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Toggle this annotation when clicking a data point whose `y` value',\n 'is `yclick` rather than the annotation\\'s `y` value.'\n ].join(' ')\n },\n hovertext: {\n valType: 'string',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Sets text to appear when hovering over this annotation.',\n 'If omitted or blank, no hover label will appear.'\n ].join(' ')\n },\n hoverlabel: {\n bgcolor: {\n valType: 'color',\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Sets the background color of the hover label.',\n 'By default uses the annotation\\'s `bgcolor` made opaque,',\n 'or white if it was transparent.'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n role: 'style',\n editType: 'arraydraw',\n description: [\n 'Sets the border color of the hover label.',\n 'By default uses either dark grey or white, for maximum',\n 'contrast with `hoverlabel.bgcolor`.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'arraydraw',\n description: [\n 'Sets the hover label text font.',\n 'By default uses the global hover font and size,',\n 'with color from `hoverlabel.bordercolor`.'\n ].join(' ')\n }),\n editType: 'arraydraw'\n },\n captureevents: {\n valType: 'boolean',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Determines whether the annotation text box captures mouse move',\n 'and click events, or allows those events to pass through to data',\n 'points in the plot that may be behind the annotation. By default',\n '`captureevents` is *false* unless `hovertext` is provided.',\n 'If you use the event `plotly_clickannotation` without `hovertext`',\n 'you must explicitly enable `captureevents`.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n ref: {\n valType: 'string',\n role: 'info',\n editType: 'calc',\n description: [\n 'Obsolete. Set `xref` and `yref` separately instead.'\n ].join(' ')\n }\n }\n});\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nexports.dash = {\n valType: 'string',\n // string type usually doesn't take values... this one should really be\n // a special type or at least a special coercion function, from the GUI\n // you only get these values but elsewhere the user can supply a list of\n // dash lengths in px, and it will be honored\n values: ['solid', 'dot', 'dash', 'longdash', 'dashdot', 'longdashdot'],\n dflt: 'solid',\n role: 'style',\n editType: 'style',\n description: [\n 'Sets the dash style of lines. Set to a dash type string',\n '(*solid*, *dot*, *dash*, *longdash*, *dashdot*, or *longdashdot*)',\n 'or a dash length list in px (eg *5px,10px,2px,2px*).'\n ].join(' ')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n coerce('hiddenlabels');\n coerce('piecolorway', layoutOut.colorway);\n coerce('extendpiecolors');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar toLogRange = require('../../lib/to_log_range');\n\n/*\n * convertCoords: when converting an axis between log and linear\n * you need to alter any images on that axis to keep them\n * pointing at the same data point.\n * In v2.0 this will become obsolete (or perhaps size will still need conversion?)\n * we convert size by declaring that the maximum extent *in data units* should be\n * the same, assuming the image is anchored by its center (could remove that restriction\n * if we think it's important) even though the actual left and right values will not be\n * quite the same since the scale becomes nonlinear (and central anchor means the pixel\n * center of the image, not the data units center)\n *\n * gd: the plot div\n * ax: the axis being changed\n * newType: the type it's getting\n * doExtra: function(attr, val) from inside relayout that sets the attribute.\n * Use this to make the changes as it's aware if any other changes in the\n * same relayout call should override this conversion.\n */\nmodule.exports = function convertCoords(gd, ax, newType, doExtra) {\n ax = ax || {};\n\n var toLog = (newType === 'log') && (ax.type === 'linear');\n var fromLog = (newType === 'linear') && (ax.type === 'log');\n\n if(!(toLog || fromLog)) return;\n\n var images = gd._fullLayout.images;\n var axLetter = ax._id.charAt(0);\n var image;\n var attrPrefix;\n\n for(var i = 0; i < images.length; i++) {\n image = images[i];\n attrPrefix = 'images[' + i + '].';\n\n if(image[axLetter + 'ref'] === ax._id) {\n var currentPos = image[axLetter];\n var currentSize = image['size' + axLetter];\n var newPos = null;\n var newSize = null;\n\n if(toLog) {\n newPos = toLogRange(currentPos, ax.range);\n\n // this is the inverse of the conversion we do in fromLog below\n // so that the conversion is reversible (notice the fromLog conversion\n // is like sinh, and this one looks like arcsinh)\n var dx = currentSize / Math.pow(10, newPos) / 2;\n newSize = 2 * Math.log(dx + Math.sqrt(1 + dx * dx)) / Math.LN10;\n } else {\n newPos = Math.pow(10, currentPos);\n newSize = newPos * (Math.pow(10, currentSize / 2) - Math.pow(10, -currentSize / 2));\n }\n\n // if conversion failed, delete the value so it can get a default later on\n if(!isNumeric(newPos)) {\n newPos = null;\n newSize = null;\n } else if(!isNumeric(newSize)) newSize = null;\n\n doExtra(attrPrefix + axLetter, newPos);\n doExtra(attrPrefix + 'size' + axLetter, newSize);\n }\n }\n};\n","/*!\n * @overview es6-promise - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE\n * @version 3.3.1\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.ES6Promise = factory());\n}(this, (function () { 'use strict';\n\nfunction objectOrFunction(x) {\n return typeof x === 'function' || typeof x === 'object' && x !== null;\n}\n\nfunction isFunction(x) {\n return typeof x === 'function';\n}\n\nvar _isArray = undefined;\nif (!Array.isArray) {\n _isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n} else {\n _isArray = Array.isArray;\n}\n\nvar isArray = _isArray;\n\nvar len = 0;\nvar vertxNext = undefined;\nvar customSchedulerFn = undefined;\n\nvar asap = function asap(callback, arg) {\n queue[len] = callback;\n queue[len + 1] = arg;\n len += 2;\n if (len === 2) {\n // If len is 2, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n if (customSchedulerFn) {\n customSchedulerFn(flush);\n } else {\n scheduleFlush();\n }\n }\n};\n\nfunction setScheduler(scheduleFn) {\n customSchedulerFn = scheduleFn;\n}\n\nfunction setAsap(asapFn) {\n asap = asapFn;\n}\n\nvar browserWindow = typeof window !== 'undefined' ? window : undefined;\nvar browserGlobal = browserWindow || {};\nvar BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;\nvar isNode = typeof self === 'undefined' && typeof process !== 'undefined' && ({}).toString.call(process) === '[object process]';\n\n// test for web worker but not in IE10\nvar isWorker = typeof Uint8ClampedArray !== 'undefined' && typeof importScripts !== 'undefined' && typeof MessageChannel !== 'undefined';\n\n// node\nfunction useNextTick() {\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // see https://github.com/cujojs/when/issues/410 for details\n return function () {\n return process.nextTick(flush);\n };\n}\n\n// vertx\nfunction useVertxTimer() {\n return function () {\n vertxNext(flush);\n };\n}\n\nfunction useMutationObserver() {\n var iterations = 0;\n var observer = new BrowserMutationObserver(flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function () {\n node.data = iterations = ++iterations % 2;\n };\n}\n\n// web worker\nfunction useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = flush;\n return function () {\n return channel.port2.postMessage(0);\n };\n}\n\nfunction useSetTimeout() {\n // Store setTimeout reference so es6-promise will be unaffected by\n // other code modifying setTimeout (like sinon.useFakeTimers())\n var globalSetTimeout = setTimeout;\n return function () {\n return globalSetTimeout(flush, 1);\n };\n}\n\nvar queue = new Array(1000);\nfunction flush() {\n for (var i = 0; i < len; i += 2) {\n var callback = queue[i];\n var arg = queue[i + 1];\n\n callback(arg);\n\n queue[i] = undefined;\n queue[i + 1] = undefined;\n }\n\n len = 0;\n}\n\nfunction attemptVertx() {\n try {\n var r = require;\n var vertx = r('vertx');\n vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return useVertxTimer();\n } catch (e) {\n return useSetTimeout();\n }\n}\n\nvar scheduleFlush = undefined;\n// Decide what async method to use to triggering processing of queued callbacks:\nif (isNode) {\n scheduleFlush = useNextTick();\n} else if (BrowserMutationObserver) {\n scheduleFlush = useMutationObserver();\n} else if (isWorker) {\n scheduleFlush = useMessageChannel();\n} else if (browserWindow === undefined && typeof require === 'function') {\n scheduleFlush = attemptVertx();\n} else {\n scheduleFlush = useSetTimeout();\n}\n\nfunction then(onFulfillment, onRejection) {\n var _arguments = arguments;\n\n var parent = this;\n\n var child = new this.constructor(noop);\n\n if (child[PROMISE_ID] === undefined) {\n makePromise(child);\n }\n\n var _state = parent._state;\n\n if (_state) {\n (function () {\n var callback = _arguments[_state - 1];\n asap(function () {\n return invokeCallback(_state, child, callback, parent._result);\n });\n })();\n } else {\n subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n}\n\n/**\n `Promise.resolve` returns a promise that will become resolved with the\n passed `value`. It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n resolve(1);\n });\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.resolve(1);\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n @method resolve\n @static\n @param {Any} value value that the returned promise will be resolved with\n Useful for tooling.\n @return {Promise} a promise that will become fulfilled with the given\n `value`\n*/\nfunction resolve(object) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(noop);\n _resolve(promise, object);\n return promise;\n}\n\nvar PROMISE_ID = Math.random().toString(36).substring(16);\n\nfunction noop() {}\n\nvar PENDING = void 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\n\nvar GET_THEN_ERROR = new ErrorObject();\n\nfunction selfFulfillment() {\n return new TypeError(\"You cannot resolve a promise with itself\");\n}\n\nfunction cannotReturnOwn() {\n return new TypeError('A promises callback cannot return that same promise.');\n}\n\nfunction getThen(promise) {\n try {\n return promise.then;\n } catch (error) {\n GET_THEN_ERROR.error = error;\n return GET_THEN_ERROR;\n }\n}\n\nfunction tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch (e) {\n return e;\n }\n}\n\nfunction handleForeignThenable(promise, thenable, then) {\n asap(function (promise) {\n var sealed = false;\n var error = tryThen(then, thenable, function (value) {\n if (sealed) {\n return;\n }\n sealed = true;\n if (thenable !== value) {\n _resolve(promise, value);\n } else {\n fulfill(promise, value);\n }\n }, function (reason) {\n if (sealed) {\n return;\n }\n sealed = true;\n\n _reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n _reject(promise, error);\n }\n }, promise);\n}\n\nfunction handleOwnThenable(promise, thenable) {\n if (thenable._state === FULFILLED) {\n fulfill(promise, thenable._result);\n } else if (thenable._state === REJECTED) {\n _reject(promise, thenable._result);\n } else {\n subscribe(thenable, undefined, function (value) {\n return _resolve(promise, value);\n }, function (reason) {\n return _reject(promise, reason);\n });\n }\n}\n\nfunction handleMaybeThenable(promise, maybeThenable, then$$) {\n if (maybeThenable.constructor === promise.constructor && then$$ === then && maybeThenable.constructor.resolve === resolve) {\n handleOwnThenable(promise, maybeThenable);\n } else {\n if (then$$ === GET_THEN_ERROR) {\n _reject(promise, GET_THEN_ERROR.error);\n } else if (then$$ === undefined) {\n fulfill(promise, maybeThenable);\n } else if (isFunction(then$$)) {\n handleForeignThenable(promise, maybeThenable, then$$);\n } else {\n fulfill(promise, maybeThenable);\n }\n }\n}\n\nfunction _resolve(promise, value) {\n if (promise === value) {\n _reject(promise, selfFulfillment());\n } else if (objectOrFunction(value)) {\n handleMaybeThenable(promise, value, getThen(value));\n } else {\n fulfill(promise, value);\n }\n}\n\nfunction publishRejection(promise) {\n if (promise._onerror) {\n promise._onerror(promise._result);\n }\n\n publish(promise);\n}\n\nfunction fulfill(promise, value) {\n if (promise._state !== PENDING) {\n return;\n }\n\n promise._result = value;\n promise._state = FULFILLED;\n\n if (promise._subscribers.length !== 0) {\n asap(publish, promise);\n }\n}\n\nfunction _reject(promise, reason) {\n if (promise._state !== PENDING) {\n return;\n }\n promise._state = REJECTED;\n promise._result = reason;\n\n asap(publishRejection, promise);\n}\n\nfunction subscribe(parent, child, onFulfillment, onRejection) {\n var _subscribers = parent._subscribers;\n var length = _subscribers.length;\n\n parent._onerror = null;\n\n _subscribers[length] = child;\n _subscribers[length + FULFILLED] = onFulfillment;\n _subscribers[length + REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n asap(publish, parent);\n }\n}\n\nfunction publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (subscribers.length === 0) {\n return;\n }\n\n var child = undefined,\n callback = undefined,\n detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n}\n\nfunction ErrorObject() {\n this.error = null;\n}\n\nvar TRY_CATCH_ERROR = new ErrorObject();\n\nfunction tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch (e) {\n TRY_CATCH_ERROR.error = e;\n return TRY_CATCH_ERROR;\n }\n}\n\nfunction invokeCallback(settled, promise, callback, detail) {\n var hasCallback = isFunction(callback),\n value = undefined,\n error = undefined,\n succeeded = undefined,\n failed = undefined;\n\n if (hasCallback) {\n value = tryCatch(callback, detail);\n\n if (value === TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n _reject(promise, cannotReturnOwn());\n return;\n }\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n _resolve(promise, value);\n } else if (failed) {\n _reject(promise, error);\n } else if (settled === FULFILLED) {\n fulfill(promise, value);\n } else if (settled === REJECTED) {\n _reject(promise, value);\n }\n}\n\nfunction initializePromise(promise, resolver) {\n try {\n resolver(function resolvePromise(value) {\n _resolve(promise, value);\n }, function rejectPromise(reason) {\n _reject(promise, reason);\n });\n } catch (e) {\n _reject(promise, e);\n }\n}\n\nvar id = 0;\nfunction nextId() {\n return id++;\n}\n\nfunction makePromise(promise) {\n promise[PROMISE_ID] = id++;\n promise._state = undefined;\n promise._result = undefined;\n promise._subscribers = [];\n}\n\nfunction Enumerator(Constructor, input) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(noop);\n\n if (!this.promise[PROMISE_ID]) {\n makePromise(this.promise);\n }\n\n if (isArray(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._result = new Array(this.length);\n\n if (this.length === 0) {\n fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n fulfill(this.promise, this._result);\n }\n }\n } else {\n _reject(this.promise, validationError());\n }\n}\n\nfunction validationError() {\n return new Error('Array Methods must be provided an Array');\n};\n\nEnumerator.prototype._enumerate = function () {\n var length = this.length;\n var _input = this._input;\n\n for (var i = 0; this._state === PENDING && i < length; i++) {\n this._eachEntry(_input[i], i);\n }\n};\n\nEnumerator.prototype._eachEntry = function (entry, i) {\n var c = this._instanceConstructor;\n var resolve$$ = c.resolve;\n\n if (resolve$$ === resolve) {\n var _then = getThen(entry);\n\n if (_then === then && entry._state !== PENDING) {\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof _then !== 'function') {\n this._remaining--;\n this._result[i] = entry;\n } else if (c === Promise) {\n var promise = new c(noop);\n handleMaybeThenable(promise, entry, _then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function (resolve$$) {\n return resolve$$(entry);\n }), i);\n }\n } else {\n this._willSettleAt(resolve$$(entry), i);\n }\n};\n\nEnumerator.prototype._settledAt = function (state, i, value) {\n var promise = this.promise;\n\n if (promise._state === PENDING) {\n this._remaining--;\n\n if (state === REJECTED) {\n _reject(promise, value);\n } else {\n this._result[i] = value;\n }\n }\n\n if (this._remaining === 0) {\n fulfill(promise, this._result);\n }\n};\n\nEnumerator.prototype._willSettleAt = function (promise, i) {\n var enumerator = this;\n\n subscribe(promise, undefined, function (value) {\n return enumerator._settledAt(FULFILLED, i, value);\n }, function (reason) {\n return enumerator._settledAt(REJECTED, i, reason);\n });\n};\n\n/**\n `Promise.all` accepts an array of promises, and returns a new promise which\n is fulfilled with an array of fulfillment values for the passed promises, or\n rejected with the reason of the first passed promise to be rejected. It casts all\n elements of the passed iterable to promises as it runs this algorithm.\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = resolve(2);\n let promise3 = resolve(3);\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // The array here would be [ 1, 2, 3 ];\n });\n ```\n\n If any of the `promises` given to `all` are rejected, the first promise\n that is rejected will be given as an argument to the returned promises's\n rejection handler. For example:\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = reject(new Error(\"2\"));\n let promise3 = reject(new Error(\"3\"));\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // Code here never runs because there are rejected promises!\n }, function(error) {\n // error.message === \"2\"\n });\n ```\n\n @method all\n @static\n @param {Array} entries array of promises\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise} promise that is fulfilled when all `promises` have been\n fulfilled, or rejected if any of them become rejected.\n @static\n*/\nfunction all(entries) {\n return new Enumerator(this, entries).promise;\n}\n\n/**\n `Promise.race` returns a new promise which is settled in the same way as the\n first passed promise to settle.\n\n Example:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 2');\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // result === 'promise 2' because it was resolved before promise1\n // was resolved.\n });\n ```\n\n `Promise.race` is deterministic in that only the state of the first\n settled promise matters. For example, even if other promises given to the\n `promises` array argument are resolved, but the first settled promise has\n become rejected before the other promises became fulfilled, the returned\n promise will become rejected:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n reject(new Error('promise 2'));\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // Code here never runs\n }, function(reason){\n // reason.message === 'promise 2' because promise 2 became rejected before\n // promise 1 became fulfilled\n });\n ```\n\n An example real-world use case is implementing timeouts:\n\n ```javascript\n Promise.race([ajax('foo.json'), timeout(5000)])\n ```\n\n @method race\n @static\n @param {Array} promises array of promises to observe\n Useful for tooling.\n @return {Promise} a promise which settles in the same way as the first passed\n promise to settle.\n*/\nfunction race(entries) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (!isArray(entries)) {\n return new Constructor(function (_, reject) {\n return reject(new TypeError('You must pass an array to race.'));\n });\n } else {\n return new Constructor(function (resolve, reject) {\n var length = entries.length;\n for (var i = 0; i < length; i++) {\n Constructor.resolve(entries[i]).then(resolve, reject);\n }\n });\n }\n}\n\n/**\n `Promise.reject` returns a promise rejected with the passed `reason`.\n It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n reject(new Error('WHOOPS'));\n });\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.reject(new Error('WHOOPS'));\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n @method reject\n @static\n @param {Any} reason value that the returned promise will be rejected with.\n Useful for tooling.\n @return {Promise} a promise rejected with the given `reason`.\n*/\nfunction reject(reason) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(noop);\n _reject(promise, reason);\n return promise;\n}\n\nfunction needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n}\n\nfunction needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n}\n\n/**\n Promise objects represent the eventual result of an asynchronous operation. The\n primary way of interacting with a promise is through its `then` method, which\n registers callbacks to receive either a promise's eventual value or the reason\n why the promise cannot be fulfilled.\n\n Terminology\n -----------\n\n - `promise` is an object or function with a `then` method whose behavior conforms to this specification.\n - `thenable` is an object or function that defines a `then` method.\n - `value` is any legal JavaScript value (including undefined, a thenable, or a promise).\n - `exception` is a value that is thrown using the throw statement.\n - `reason` is a value that indicates why a promise was rejected.\n - `settled` the final resting state of a promise, fulfilled or rejected.\n\n A promise can be in one of three states: pending, fulfilled, or rejected.\n\n Promises that are fulfilled have a fulfillment value and are in the fulfilled\n state. Promises that are rejected have a rejection reason and are in the\n rejected state. A fulfillment value is never a thenable.\n\n Promises can also be said to *resolve* a value. If this value is also a\n promise, then the original promise's settled state will match the value's\n settled state. So a promise that *resolves* a promise that rejects will\n itself reject, and a promise that *resolves* a promise that fulfills will\n itself fulfill.\n\n\n Basic Usage:\n ------------\n\n ```js\n let promise = new Promise(function(resolve, reject) {\n // on success\n resolve(value);\n\n // on failure\n reject(reason);\n });\n\n promise.then(function(value) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Advanced Usage:\n ---------------\n\n Promises shine when abstracting away asynchronous interactions such as\n `XMLHttpRequest`s.\n\n ```js\n function getJSON(url) {\n return new Promise(function(resolve, reject){\n let xhr = new XMLHttpRequest();\n\n xhr.open('GET', url);\n xhr.onreadystatechange = handler;\n xhr.responseType = 'json';\n xhr.setRequestHeader('Accept', 'application/json');\n xhr.send();\n\n function handler() {\n if (this.readyState === this.DONE) {\n if (this.status === 200) {\n resolve(this.response);\n } else {\n reject(new Error('getJSON: `' + url + '` failed with status: [' + this.status + ']'));\n }\n }\n };\n });\n }\n\n getJSON('/posts.json').then(function(json) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Unlike callbacks, promises are great composable primitives.\n\n ```js\n Promise.all([\n getJSON('/posts'),\n getJSON('/comments')\n ]).then(function(values){\n values[0] // => postsJSON\n values[1] // => commentsJSON\n\n return values;\n });\n ```\n\n @class Promise\n @param {function} resolver\n Useful for tooling.\n @constructor\n*/\nfunction Promise(resolver) {\n this[PROMISE_ID] = nextId();\n this._result = this._state = undefined;\n this._subscribers = [];\n\n if (noop !== resolver) {\n typeof resolver !== 'function' && needsResolver();\n this instanceof Promise ? initializePromise(this, resolver) : needsNew();\n }\n}\n\nPromise.all = all;\nPromise.race = race;\nPromise.resolve = resolve;\nPromise.reject = reject;\nPromise._setScheduler = setScheduler;\nPromise._setAsap = setAsap;\nPromise._asap = asap;\n\nPromise.prototype = {\n constructor: Promise,\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n \n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n \n Chaining\n --------\n \n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n \n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n \n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n \n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n \n Assimilation\n ------------\n \n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n \n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n \n If the assimliated promise rejects, then the downstream promise will also reject.\n \n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n \n Simple Example\n --------------\n \n Synchronous Example\n \n ```javascript\n let result;\n \n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n \n Errback Example\n \n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n \n Promise Example;\n \n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n \n Advanced Example\n --------------\n \n Synchronous Example\n \n ```javascript\n let author, books;\n \n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n \n Errback Example\n \n ```js\n \n function foundBooks(books) {\n \n }\n \n function failure(reason) {\n \n }\n \n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n \n Promise Example;\n \n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n \n @method then\n @param {Function} onFulfilled\n @param {Function} onRejected\n Useful for tooling.\n @return {Promise}\n */\n then: then,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n \n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n \n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n \n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n \n @method catch\n @param {Function} onRejection\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function _catch(onRejection) {\n return this.then(null, onRejection);\n }\n};\n\nfunction polyfill() {\n var local = undefined;\n\n if (typeof global !== 'undefined') {\n local = global;\n } else if (typeof self !== 'undefined') {\n local = self;\n } else {\n try {\n local = Function('return this')();\n } catch (e) {\n throw new Error('polyfill failed because global object is unavailable in this environment');\n }\n }\n\n var P = local.Promise;\n\n if (P) {\n var promiseToString = null;\n try {\n promiseToString = Object.prototype.toString.call(P.resolve());\n } catch (e) {\n // silently ignored\n }\n\n if (promiseToString === '[object Promise]' && !P.cast) {\n return;\n }\n }\n\n local.Promise = Promise;\n}\n\npolyfill();\n// Strange compat..\nPromise.polyfill = polyfill;\nPromise.Promise = Promise;\n\nreturn Promise;\n\n})));\n//# sourceMappingURL=es6-promise.map","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n// works with our CSS cursor classes (see css/_cursor.scss)\n// to apply cursors to d3 single-element selections.\n// omit cursor to revert to the default.\nmodule.exports = function setCursor(el3, csr) {\n (el3.attr('class') || '').split(' ').forEach(function(cls) {\n if(cls.indexOf('cursor-') === 0) el3.classed(cls, false);\n });\n\n if(csr) el3.classed('cursor-' + csr, true);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nexports.coerceString = function(attributeDefinition, value, defaultValue) {\n if(typeof value === 'string') {\n if(value || !attributeDefinition.noBlank) return value;\n } else if(typeof value === 'number' || value === true) {\n if(!attributeDefinition.strict) return String(value);\n }\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceNumber = function(attributeDefinition, value, defaultValue) {\n if(isNumeric(value)) {\n value = +value;\n\n var min = attributeDefinition.min;\n var max = attributeDefinition.max;\n var isOutOfBounds = (min !== undefined && value < min) ||\n (max !== undefined && value > max);\n\n if(!isOutOfBounds) return value;\n }\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceColor = function(attributeDefinition, value, defaultValue) {\n if(tinycolor(value).isValid()) return value;\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.coerceEnumerated = function(attributeDefinition, value, defaultValue) {\n if(attributeDefinition.coerceNumber) value = +value;\n\n if(attributeDefinition.values.indexOf(value) !== -1) return value;\n\n return (defaultValue !== undefined) ?\n defaultValue :\n attributeDefinition.dflt;\n};\n\nexports.getValue = function(arrayOrScalar, index) {\n var value;\n if(!Array.isArray(arrayOrScalar)) value = arrayOrScalar;\n else if(index < arrayOrScalar.length) value = arrayOrScalar[index];\n return value;\n};\n\nexports.getLineWidth = function(trace, di) {\n var w =\n (0 < di.mlw) ? di.mlw :\n !isArrayOrTypedArray(trace.marker.line.width) ? trace.marker.line.width :\n 0;\n\n return w;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/** Filter out object items with visible !== true\n * insider array container.\n *\n * @param {array of objects} container\n * @return {array of objects} of length <= container\n *\n */\nmodule.exports = function filterVisible(container) {\n var filterFn = isCalcData(container) ? calcDataFilter : baseFilter;\n var out = [];\n\n for(var i = 0; i < container.length; i++) {\n var item = container[i];\n if(filterFn(item)) out.push(item);\n }\n\n return out;\n};\n\nfunction baseFilter(item) {\n return item.visible === true;\n}\n\nfunction calcDataFilter(item) {\n var trace = item[0].trace;\n return trace.visible === true && trace._length !== 0;\n}\n\nfunction isCalcData(cont) {\n return (\n Array.isArray(cont) &&\n Array.isArray(cont[0]) &&\n cont[0][0] &&\n cont[0][0].trace\n );\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n scrollBarWidth: 6,\n scrollBarMinHeight: 20,\n scrollBarColor: '#808BA4',\n scrollBarMargin: 4,\n scrollBarEnterAttrs: {rx: 20, ry: 3, width: 0, height: 0},\n\n // number of px between legend title and (left) side of legend (always in x direction and from inner border)\n titlePad: 2,\n // number of px between legend symbol and legend text (always in x direction)\n textGap: 40,\n // number of px between each legend item (x and/or y direction)\n itemGap: 5\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nmodule.exports = {\n // padding in pixels around text\n TEXTPAD: 3,\n // 'value' and 'label' are not really necessary for bar traces,\n // but they were made available to `texttemplate` (maybe by accident)\n // via tokens `%{value}` and `%{label}` starting in 1.50.0,\n // so let's include them in the event data also.\n eventDataKeys: ['value', 'label']\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Registry = require('../registry');\n\n/**\n * localize: translate a string for the current locale\n *\n * @param {object} gd: the graphDiv for context\n * gd._context.locale determines the language (& optional region/country)\n * the dictionary for each locale may either be supplied in\n * gd._context.locales or globally via Plotly.register\n * @param {string} s: the string to translate\n */\nmodule.exports = function localize(gd, s) {\n var locale = gd._context.locale;\n\n /*\n * Priority of lookup:\n * contextDicts[locale],\n * registeredDicts[locale],\n * contextDicts[baseLocale], (if baseLocale is distinct)\n * registeredDicts[baseLocale]\n * Return the first translation we find.\n * This way if you have a regionalization you are allowed to specify\n * only what's different from the base locale, everything else will\n * fall back on the base.\n */\n for(var i = 0; i < 2; i++) {\n var locales = gd._context.locales;\n for(var j = 0; j < 2; j++) {\n var dict = (locales[locale] || {}).dictionary;\n if(dict) {\n var out = dict[s];\n if(out) return out;\n }\n locales = Registry.localeRegistry;\n }\n\n var baseLocale = locale.split('-')[0];\n if(baseLocale === locale) break;\n locale = baseLocale;\n }\n\n return s;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * Clear gl frame (if any). This is a common pattern as\n * we usually set `preserveDrawingBuffer: true` during\n * gl context creation (e.g. via `reglUtils.prepare`).\n *\n * @param {DOM node or object} gd : graph div object\n */\nmodule.exports = function clearGlCanvases(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._glcanvas && fullLayout._glcanvas.size()) {\n fullLayout._glcanvas.each(function(d) {\n if(d.regl) d.regl.clear({color: true, depth: true});\n });\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n\nmodule.exports = function hasColorbar(container) {\n return Lib.isPlainObject(container.colorbar);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar hasColorbar = require('../colorbar/has_colorbar');\nvar colorbarDefaults = require('../colorbar/defaults');\n\nvar isValidScale = require('./scales').isValid;\nvar traceIs = require('../../registry').traceIs;\n\nfunction npMaybe(parentCont, prefix) {\n var containerStr = prefix.slice(0, prefix.length - 1);\n return prefix ?\n Lib.nestedProperty(parentCont, containerStr).get() || {} :\n parentCont;\n}\n\n/**\n * Colorscale / colorbar default handler\n *\n * @param {object} parentContIn : user (input) parent container (e.g. trace or layout coloraxis object)\n * @param {object} parentContOut : full parent container\n * @param {object} layout : (full) layout object\n * @param {fn} coerce : Lib.coerce wrapper\n * @param {object} opts :\n * - prefix {string} : attr string prefix to colorscale container from parent root\n * - cLetter {string} : 'c or 'z' color letter\n */\nmodule.exports = function colorScaleDefaults(parentContIn, parentContOut, layout, coerce, opts) {\n var prefix = opts.prefix;\n var cLetter = opts.cLetter;\n var inTrace = '_module' in parentContOut;\n var containerIn = npMaybe(parentContIn, prefix);\n var containerOut = npMaybe(parentContOut, prefix);\n var template = npMaybe(parentContOut._template || {}, prefix) || {};\n\n // colorScaleDefaults wrapper called if-ever we need to reset the colorscale\n // attributes for containers that were linked to invalid color axes\n var thisFn = function() {\n delete parentContIn.coloraxis;\n delete parentContOut.coloraxis;\n return colorScaleDefaults(parentContIn, parentContOut, layout, coerce, opts);\n };\n\n if(inTrace) {\n var colorAxes = layout._colorAxes || {};\n var colorAx = coerce(prefix + 'coloraxis');\n\n if(colorAx) {\n var colorbarVisuals = (\n traceIs(parentContOut, 'contour') &&\n Lib.nestedProperty(parentContOut, 'contours.coloring').get()\n ) || 'heatmap';\n\n var stash = colorAxes[colorAx];\n\n if(stash) {\n stash[2].push(thisFn);\n\n if(stash[0] !== colorbarVisuals) {\n stash[0] = false;\n Lib.warn([\n 'Ignoring coloraxis:', colorAx, 'setting',\n 'as it is linked to incompatible colorscales.'\n ].join(' '));\n }\n } else {\n // stash:\n // - colorbar visual 'type'\n // - colorbar options to help in Colorbar.draw\n // - list of colorScaleDefaults wrapper functions\n colorAxes[colorAx] = [colorbarVisuals, parentContOut, [thisFn]];\n }\n return;\n }\n }\n\n var minIn = containerIn[cLetter + 'min'];\n var maxIn = containerIn[cLetter + 'max'];\n var validMinMax = isNumeric(minIn) && isNumeric(maxIn) && (minIn < maxIn);\n var auto = coerce(prefix + cLetter + 'auto', !validMinMax);\n\n if(auto) {\n coerce(prefix + cLetter + 'mid');\n } else {\n coerce(prefix + cLetter + 'min');\n coerce(prefix + cLetter + 'max');\n }\n\n // handles both the trace case (autocolorscale is false by default) and\n // the marker and marker.line case (autocolorscale is true by default)\n var sclIn = containerIn.colorscale;\n var sclTemplate = template.colorscale;\n var autoColorscaleDflt;\n if(sclIn !== undefined) autoColorscaleDflt = !isValidScale(sclIn);\n if(sclTemplate !== undefined) autoColorscaleDflt = !isValidScale(sclTemplate);\n coerce(prefix + 'autocolorscale', autoColorscaleDflt);\n\n coerce(prefix + 'colorscale');\n coerce(prefix + 'reversescale');\n\n if(prefix !== 'marker.line.') {\n // handles both the trace case where the dflt is listed in attributes and\n // the marker case where the dflt is determined by hasColorbar\n var showScaleDflt;\n if(prefix && inTrace) showScaleDflt = hasColorbar(containerIn);\n\n var showScale = coerce(prefix + 'showscale', showScaleDflt);\n if(showScale) {\n if(prefix && template) containerOut._template = template;\n colorbarDefaults(containerIn, containerOut, layout);\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\n\n/**\n * options: inherits outerTicks from axes.handleAxisDefaults\n */\nmodule.exports = function handleTickDefaults(containerIn, containerOut, coerce, options) {\n var tickLen = Lib.coerce2(containerIn, containerOut, layoutAttributes, 'ticklen');\n var tickWidth = Lib.coerce2(containerIn, containerOut, layoutAttributes, 'tickwidth');\n var tickColor = Lib.coerce2(containerIn, containerOut, layoutAttributes, 'tickcolor', containerOut.color);\n var showTicks = coerce('ticks', (options.outerTicks || tickLen || tickWidth || tickColor) ? 'outside' : '');\n\n if(!showTicks) {\n delete containerOut.ticklen;\n delete containerOut.tickwidth;\n delete containerOut.tickcolor;\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar EventEmitter = require('events').EventEmitter;\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar helpers = require('./helpers');\nvar clonePlot = require('./cloneplot');\nvar toSVG = require('./tosvg');\nvar svgToImg = require('./svgtoimg');\n\n/**\n * @param {object} gd figure Object\n * @param {object} opts option object\n * @param opts.format 'jpeg' | 'png' | 'webp' | 'svg'\n */\nfunction toImage(gd, opts) {\n // first clone the GD so we can operate in a clean environment\n var ev = new EventEmitter();\n\n var clone = clonePlot(gd, {format: 'png'});\n var clonedGd = clone.gd;\n\n // put the cloned div somewhere off screen before attaching to DOM\n clonedGd.style.position = 'absolute';\n clonedGd.style.left = '-5000px';\n document.body.appendChild(clonedGd);\n\n function wait() {\n var delay = helpers.getDelay(clonedGd._fullLayout);\n\n setTimeout(function() {\n var svg = toSVG(clonedGd);\n\n var canvas = document.createElement('canvas');\n canvas.id = Lib.randstr();\n\n ev = svgToImg({\n format: opts.format,\n width: clonedGd._fullLayout.width,\n height: clonedGd._fullLayout.height,\n canvas: canvas,\n emitter: ev,\n svg: svg\n });\n\n ev.clean = function() {\n if(clonedGd) document.body.removeChild(clonedGd);\n };\n }, delay);\n }\n\n var redrawFunc = helpers.getRedrawFunc(clonedGd);\n\n Registry.call('plot', clonedGd, clone.data, clone.layout, clone.config)\n .then(redrawFunc)\n .then(wait)\n .catch(function(err) {\n ev.emit('error', err);\n });\n\n\n return ev;\n}\n\nmodule.exports = toImage;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar axesAttrs = require('../../cartesian/layout_attributes');\nvar extendFlat = require('../../../lib/extend').extendFlat;\nvar overrideAll = require('../../../plot_api/edit_types').overrideAll;\n\nvar deprecationWarning = [\n 'Legacy polar charts are deprecated!',\n 'Please switch to *polar* subplots.'\n].join(' ');\n\nvar domainAttr = extendFlat({}, axesAttrs.domain, {\n description: [\n 'Polar chart subplots are not supported yet.',\n 'This key has currently no effect.'\n ].join(' ')\n});\n\nfunction mergeAttrs(axisName, nonCommonAttrs) {\n var commonAttrs = {\n showline: {\n valType: 'boolean',\n role: 'style',\n description: [\n deprecationWarning,\n 'Determines whether or not the line bounding this',\n axisName, 'axis',\n 'will be shown on the figure.'\n ].join(' ')\n },\n showticklabels: {\n valType: 'boolean',\n role: 'style',\n description: [\n deprecationWarning,\n 'Determines whether or not the',\n axisName, 'axis ticks',\n 'will feature tick labels.'\n ].join(' ')\n },\n tickorientation: {\n valType: 'enumerated',\n values: ['horizontal', 'vertical'],\n role: 'style',\n description: [\n deprecationWarning,\n 'Sets the orientation (from the paper perspective)',\n 'of the', axisName, 'axis tick labels.'\n ].join(' ')\n },\n ticklen: {\n valType: 'number',\n min: 0,\n role: 'style',\n description: [\n deprecationWarning,\n 'Sets the length of the tick lines on this', axisName, 'axis.'\n ].join(' ')\n },\n tickcolor: {\n valType: 'color',\n role: 'style',\n description: [\n deprecationWarning,\n 'Sets the color of the tick lines on this', axisName, 'axis.'\n ].join(' ')\n },\n ticksuffix: {\n valType: 'string',\n role: 'style',\n description: [\n deprecationWarning,\n 'Sets the length of the tick lines on this', axisName, 'axis.'\n ].join(' ')\n },\n endpadding: {\n valType: 'number',\n role: 'style',\n description: deprecationWarning,\n },\n visible: {\n valType: 'boolean',\n role: 'info',\n description: [\n deprecationWarning,\n 'Determines whether or not this axis will be visible.'\n ].join(' ')\n }\n };\n\n return extendFlat({}, nonCommonAttrs, commonAttrs);\n}\n\nmodule.exports = overrideAll({\n radialaxis: mergeAttrs('radial', {\n range: {\n valType: 'info_array',\n role: 'info',\n items: [\n { valType: 'number' },\n { valType: 'number' }\n ],\n description: [\n deprecationWarning,\n 'Defines the start and end point of this radial axis.'\n ].join(' ')\n },\n domain: domainAttr,\n orientation: {\n valType: 'number',\n role: 'style',\n description: [\n deprecationWarning,\n 'Sets the orientation (an angle with respect to the origin)',\n 'of the radial axis.'\n ].join(' ')\n }\n }),\n\n angularaxis: mergeAttrs('angular', {\n range: {\n valType: 'info_array',\n role: 'info',\n items: [\n { valType: 'number', dflt: 0 },\n { valType: 'number', dflt: 360 }\n ],\n description: [\n deprecationWarning,\n 'Defines the start and end point of this angular axis.'\n ].join(' ')\n },\n domain: domainAttr\n }),\n\n // attributes that appear at layout root\n layout: {\n direction: {\n valType: 'enumerated',\n values: ['clockwise', 'counterclockwise'],\n role: 'info',\n description: [\n deprecationWarning,\n 'Sets the direction corresponding to positive angles',\n 'in legacy polar charts.'\n ].join(' ')\n },\n orientation: {\n valType: 'angle',\n role: 'info',\n description: [\n deprecationWarning,\n 'Rotates the entire polar by the given angle',\n 'in legacy polar charts.'\n ].join(' ')\n }\n }\n}, 'plot', 'nested');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isArray = Array.isArray;\n\n// IE9 fallbacks\n\nvar ab = (typeof ArrayBuffer === 'undefined' || !ArrayBuffer.isView) ?\n {isView: function() { return false; }} :\n ArrayBuffer;\n\nvar dv = (typeof DataView === 'undefined') ?\n function() {} :\n DataView;\n\nfunction isTypedArray(a) {\n return ab.isView(a) && !(a instanceof dv);\n}\nexports.isTypedArray = isTypedArray;\n\nfunction isArrayOrTypedArray(a) {\n return isArray(a) || isTypedArray(a);\n}\nexports.isArrayOrTypedArray = isArrayOrTypedArray;\n\n/*\n * Test whether an input object is 1D.\n *\n * Assumes we already know the object is an array.\n *\n * Looks only at the first element, if the dimensionality is\n * not consistent we won't figure that out here.\n */\nfunction isArray1D(a) {\n return !isArrayOrTypedArray(a[0]);\n}\nexports.isArray1D = isArray1D;\n\n/*\n * Ensures an array has the right amount of storage space. If it doesn't\n * exist, it creates an array. If it does exist, it returns it if too\n * short or truncates it in-place.\n *\n * The goal is to just reuse memory to avoid a bit of excessive garbage\n * collection.\n */\nexports.ensureArray = function(out, n) {\n // TODO: typed array support here? This is only used in\n // traces/carpet/compute_control_points\n if(!isArray(out)) out = [];\n\n // If too long, truncate. (If too short, it will grow\n // automatically so we don't care about that case)\n out.length = n;\n\n return out;\n};\n\n/*\n * TypedArray-compatible concatenation of n arrays\n * if all arrays are the same type it will preserve that type,\n * otherwise it falls back on Array.\n * Also tries to avoid copying, in case one array has zero length\n * But never mutates an existing array\n */\nexports.concat = function() {\n var args = [];\n var allArray = true;\n var totalLen = 0;\n\n var _constructor, arg0, i, argi, posi, leni, out, j;\n\n for(i = 0; i < arguments.length; i++) {\n argi = arguments[i];\n leni = argi.length;\n if(leni) {\n if(arg0) args.push(argi);\n else {\n arg0 = argi;\n posi = leni;\n }\n\n if(isArray(argi)) {\n _constructor = false;\n } else {\n allArray = false;\n if(!totalLen) {\n _constructor = argi.constructor;\n } else if(_constructor !== argi.constructor) {\n // TODO: in principle we could upgrade here,\n // ie keep typed array but convert all to Float64Array?\n _constructor = false;\n }\n }\n\n totalLen += leni;\n }\n }\n\n if(!totalLen) return [];\n if(!args.length) return arg0;\n\n if(allArray) return arg0.concat.apply(arg0, args);\n if(_constructor) {\n // matching typed arrays\n out = new _constructor(totalLen);\n out.set(arg0);\n for(i = 0; i < args.length; i++) {\n argi = args[i];\n out.set(argi, posi);\n posi += argi.length;\n }\n return out;\n }\n\n // mismatched types or Array + typed\n out = new Array(totalLen);\n for(j = 0; j < arg0.length; j++) out[j] = arg0[j];\n for(i = 0; i < args.length; i++) {\n argi = args[i];\n for(j = 0; j < argi.length; j++) out[posi + j] = argi[j];\n posi += j;\n }\n return out;\n};\n\nexports.maxRowLength = function(z) {\n return _rowLength(z, Math.max, 0);\n};\n\nexports.minRowLength = function(z) {\n return _rowLength(z, Math.min, Infinity);\n};\n\nfunction _rowLength(z, fn, len0) {\n if(isArrayOrTypedArray(z)) {\n if(isArrayOrTypedArray(z[0])) {\n var len = len0;\n for(var i = 0; i < z.length; i++) {\n len = fn(len, z[i].length);\n }\n return len;\n } else {\n return z.length;\n }\n }\n return 0;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n/**\n * Error bar computing function generator\n *\n * N.B. The generated function does not clean the dataPt entries. Non-numeric\n * entries result in undefined error magnitudes.\n *\n * @param {object} opts error bar attributes\n *\n * @return {function} :\n * @param {numeric} dataPt data point from where to compute the error magnitude\n * @param {number} index index of dataPt in its corresponding data array\n * @return {array}\n * - error[0] : error magnitude in the negative direction\n * - error[1] : \" \" \" \" positive \"\n */\nmodule.exports = function makeComputeError(opts) {\n var type = opts.type;\n var symmetric = opts.symmetric;\n\n if(type === 'data') {\n var array = opts.array || [];\n\n if(symmetric) {\n return function computeError(dataPt, index) {\n var val = +(array[index]);\n return [val, val];\n };\n } else {\n var arrayminus = opts.arrayminus || [];\n return function computeError(dataPt, index) {\n var val = +array[index];\n var valMinus = +arrayminus[index];\n // in case one is present and the other is missing, fill in 0\n // so we still see the present one. Mostly useful during manual\n // data entry.\n if(!isNaN(val) || !isNaN(valMinus)) {\n return [valMinus || 0, val || 0];\n }\n return [NaN, NaN];\n };\n }\n } else {\n var computeErrorValue = makeComputeErrorValue(type, opts.value);\n var computeErrorValueMinus = makeComputeErrorValue(type, opts.valueminus);\n\n if(symmetric || opts.valueminus === undefined) {\n return function computeError(dataPt) {\n var val = computeErrorValue(dataPt);\n return [val, val];\n };\n } else {\n return function computeError(dataPt) {\n return [\n computeErrorValueMinus(dataPt),\n computeErrorValue(dataPt)\n ];\n };\n }\n }\n};\n\n/**\n * Compute error bar magnitude (for all types except data)\n *\n * @param {string} type error bar type\n * @param {numeric} value error bar value\n *\n * @return {function} :\n * @param {numeric} dataPt\n */\nfunction makeComputeErrorValue(type, value) {\n if(type === 'percent') {\n return function(dataPt) {\n return Math.abs(dataPt * value / 100);\n };\n }\n if(type === 'constant') {\n return function() {\n return Math.abs(value);\n };\n }\n if(type === 'sqrt') {\n return function(dataPt) {\n return Math.sqrt(Math.abs(dataPt));\n };\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar extendFlat = Lib.extendFlat;\nvar isPlainObject = Lib.isPlainObject;\n\nvar traceOpts = {\n valType: 'flaglist',\n extras: ['none'],\n flags: ['calc', 'clearAxisTypes', 'plot', 'style', 'markerSize', 'colorbars'],\n description: [\n 'trace attributes should include an `editType` string matching this flaglist.',\n '*calc* is the most extensive: a full `Plotly.plot` starting by clearing `gd.calcdata`',\n 'to force it to be regenerated',\n '*clearAxisTypes* resets the types of the axes this trace is on, because new data could',\n 'cause the automatic axis type detection to change. Log type will not be cleared, as that',\n 'is never automatically chosen so must have been user-specified.',\n '*plot* calls `Plotly.plot` but without first clearing `gd.calcdata`.',\n '*style* only calls `module.style` (or module.editStyle) for all trace modules and redraws the legend.',\n '*markerSize* is like *style*, but propagate axis-range changes due to scatter `marker.size`',\n '*colorbars* only redraws colorbars.'\n ].join(' ')\n};\n\nvar layoutOpts = {\n valType: 'flaglist',\n extras: ['none'],\n flags: [\n 'calc', 'plot', 'legend', 'ticks', 'axrange',\n 'layoutstyle', 'modebar', 'camera', 'arraydraw', 'colorbars'\n ],\n description: [\n 'layout attributes should include an `editType` string matching this flaglist.',\n '*calc* is the most extensive: a full `Plotly.plot` starting by clearing `gd.calcdata`',\n 'to force it to be regenerated',\n '*plot* calls `Plotly.plot` but without first clearing `gd.calcdata`.',\n '*legend* only redraws the legend.',\n '*ticks* only redraws axis ticks, labels, and gridlines.',\n '*axrange* minimal sequence when updating axis ranges.',\n '*layoutstyle* reapplies global and SVG cartesian axis styles.',\n '*modebar* just updates the modebar.',\n '*camera* just updates the camera settings for gl3d scenes.',\n '*arraydraw* allows component arrays to invoke the redraw routines just for the',\n 'component(s) that changed.',\n '*colorbars* only redraws colorbars.'\n ].join(' ')\n};\n\n// flags for inside restyle/relayout include a few extras\n// that shouldn't be used in attributes, to deal with certain\n// combinations and conditionals efficiently\nvar traceEditTypeFlags = traceOpts.flags.slice()\n .concat(['fullReplot']);\n\nvar layoutEditTypeFlags = layoutOpts.flags.slice()\n .concat('layoutReplot');\n\nmodule.exports = {\n traces: traceOpts,\n layout: layoutOpts,\n /*\n * default (all false) edit flags for restyle (traces)\n * creates a new object each call, so the caller can mutate freely\n */\n traceFlags: function() { return falseObj(traceEditTypeFlags); },\n\n /*\n * default (all false) edit flags for relayout\n * creates a new object each call, so the caller can mutate freely\n */\n layoutFlags: function() { return falseObj(layoutEditTypeFlags); },\n\n /*\n * update `flags` with the `editType` values found in `attr`\n */\n update: function(flags, attr) {\n var editType = attr.editType;\n if(editType && editType !== 'none') {\n var editTypeParts = editType.split('+');\n for(var i = 0; i < editTypeParts.length; i++) {\n flags[editTypeParts[i]] = true;\n }\n }\n },\n\n overrideAll: overrideAll\n};\n\nfunction falseObj(keys) {\n var out = {};\n for(var i = 0; i < keys.length; i++) out[keys[i]] = false;\n return out;\n}\n\n/**\n * For attributes that are largely copied from elsewhere into a plot type that doesn't\n * support partial redraws - overrides the editType field of all attributes in the object\n *\n * @param {object} attrs: the attributes to override. Will not be mutated.\n * @param {string} editTypeOverride: the new editType to use\n * @param {'nested'|'from-root'} overrideContainers:\n * - 'nested' will override editType for nested containers but not the root.\n * - 'from-root' will also override editType of the root container.\n * Containers below the absolute top level (trace or layout root) DO need an\n * editType even if they are not `valObject`s themselves (eg `scatter.marker`)\n * to handle the case where you edit the whole container.\n *\n * @return {object} a new attributes object with `editType` modified as directed\n */\nfunction overrideAll(attrs, editTypeOverride, overrideContainers) {\n var out = extendFlat({}, attrs);\n for(var key in out) {\n var attr = out[key];\n if(isPlainObject(attr)) {\n out[key] = overrideOne(attr, editTypeOverride, overrideContainers, key);\n }\n }\n if(overrideContainers === 'from-root') out.editType = editTypeOverride;\n\n return out;\n}\n\nfunction overrideOne(attr, editTypeOverride, overrideContainers, key) {\n if(attr.valType) {\n var out = extendFlat({}, attr);\n out.editType = editTypeOverride;\n\n if(Array.isArray(attr.items)) {\n out.items = new Array(attr.items.length);\n for(var i = 0; i < attr.items.length; i++) {\n out.items[i] = overrideOne(attr.items[i], editTypeOverride, 'from-root');\n }\n }\n return out;\n } else {\n // don't provide an editType for the _deprecated container\n return overrideAll(attr, editTypeOverride,\n (key.charAt(0) === '_') ? 'nested' : 'from-root');\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\n/** Marker symbol definitions\n * users can specify markers either by number or name\n * add 100 (or '-open') and you get an open marker\n * open markers have no fill and use line color as the stroke color\n * add 200 (or '-dot') and you get a dot in the middle\n * add both and you get both\n */\n\nmodule.exports = {\n circle: {\n n: 0,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs +\n 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z';\n }\n },\n square: {\n n: 1,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z';\n }\n },\n diamond: {\n n: 2,\n f: function(r) {\n var rd = d3.round(r * 1.3, 2);\n return 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z';\n }\n },\n cross: {\n n: 3,\n f: function(r) {\n var rc = d3.round(r * 0.4, 2);\n var rc2 = d3.round(r * 1.2, 2);\n return 'M' + rc2 + ',' + rc + 'H' + rc + 'V' + rc2 + 'H-' + rc +\n 'V' + rc + 'H-' + rc2 + 'V-' + rc + 'H-' + rc + 'V-' + rc2 +\n 'H' + rc + 'V-' + rc + 'H' + rc2 + 'Z';\n }\n },\n x: {\n n: 4,\n f: function(r) {\n var rx = d3.round(r * 0.8 / Math.sqrt(2), 2);\n var ne = 'l' + rx + ',' + rx;\n var se = 'l' + rx + ',-' + rx;\n var sw = 'l-' + rx + ',-' + rx;\n var nw = 'l-' + rx + ',' + rx;\n return 'M0,' + rx + ne + se + sw + se + sw + nw + sw + nw + ne + nw + ne + 'Z';\n }\n },\n 'triangle-up': {\n n: 5,\n f: function(r) {\n var rt = d3.round(r * 2 / Math.sqrt(3), 2);\n var r2 = d3.round(r / 2, 2);\n var rs = d3.round(r, 2);\n return 'M-' + rt + ',' + r2 + 'H' + rt + 'L0,-' + rs + 'Z';\n }\n },\n 'triangle-down': {\n n: 6,\n f: function(r) {\n var rt = d3.round(r * 2 / Math.sqrt(3), 2);\n var r2 = d3.round(r / 2, 2);\n var rs = d3.round(r, 2);\n return 'M-' + rt + ',-' + r2 + 'H' + rt + 'L0,' + rs + 'Z';\n }\n },\n 'triangle-left': {\n n: 7,\n f: function(r) {\n var rt = d3.round(r * 2 / Math.sqrt(3), 2);\n var r2 = d3.round(r / 2, 2);\n var rs = d3.round(r, 2);\n return 'M' + r2 + ',-' + rt + 'V' + rt + 'L-' + rs + ',0Z';\n }\n },\n 'triangle-right': {\n n: 8,\n f: function(r) {\n var rt = d3.round(r * 2 / Math.sqrt(3), 2);\n var r2 = d3.round(r / 2, 2);\n var rs = d3.round(r, 2);\n return 'M-' + r2 + ',-' + rt + 'V' + rt + 'L' + rs + ',0Z';\n }\n },\n 'triangle-ne': {\n n: 9,\n f: function(r) {\n var r1 = d3.round(r * 0.6, 2);\n var r2 = d3.round(r * 1.2, 2);\n return 'M-' + r2 + ',-' + r1 + 'H' + r1 + 'V' + r2 + 'Z';\n }\n },\n 'triangle-se': {\n n: 10,\n f: function(r) {\n var r1 = d3.round(r * 0.6, 2);\n var r2 = d3.round(r * 1.2, 2);\n return 'M' + r1 + ',-' + r2 + 'V' + r1 + 'H-' + r2 + 'Z';\n }\n },\n 'triangle-sw': {\n n: 11,\n f: function(r) {\n var r1 = d3.round(r * 0.6, 2);\n var r2 = d3.round(r * 1.2, 2);\n return 'M' + r2 + ',' + r1 + 'H-' + r1 + 'V-' + r2 + 'Z';\n }\n },\n 'triangle-nw': {\n n: 12,\n f: function(r) {\n var r1 = d3.round(r * 0.6, 2);\n var r2 = d3.round(r * 1.2, 2);\n return 'M-' + r1 + ',' + r2 + 'V-' + r1 + 'H' + r2 + 'Z';\n }\n },\n pentagon: {\n n: 13,\n f: function(r) {\n var x1 = d3.round(r * 0.951, 2);\n var x2 = d3.round(r * 0.588, 2);\n var y0 = d3.round(-r, 2);\n var y1 = d3.round(r * -0.309, 2);\n var y2 = d3.round(r * 0.809, 2);\n return 'M' + x1 + ',' + y1 + 'L' + x2 + ',' + y2 + 'H-' + x2 +\n 'L-' + x1 + ',' + y1 + 'L0,' + y0 + 'Z';\n }\n },\n hexagon: {\n n: 14,\n f: function(r) {\n var y0 = d3.round(r, 2);\n var y1 = d3.round(r / 2, 2);\n var x = d3.round(r * Math.sqrt(3) / 2, 2);\n return 'M' + x + ',-' + y1 + 'V' + y1 + 'L0,' + y0 +\n 'L-' + x + ',' + y1 + 'V-' + y1 + 'L0,-' + y0 + 'Z';\n }\n },\n hexagon2: {\n n: 15,\n f: function(r) {\n var x0 = d3.round(r, 2);\n var x1 = d3.round(r / 2, 2);\n var y = d3.round(r * Math.sqrt(3) / 2, 2);\n return 'M-' + x1 + ',' + y + 'H' + x1 + 'L' + x0 +\n ',0L' + x1 + ',-' + y + 'H-' + x1 + 'L-' + x0 + ',0Z';\n }\n },\n octagon: {\n n: 16,\n f: function(r) {\n var a = d3.round(r * 0.924, 2);\n var b = d3.round(r * 0.383, 2);\n return 'M-' + b + ',-' + a + 'H' + b + 'L' + a + ',-' + b + 'V' + b +\n 'L' + b + ',' + a + 'H-' + b + 'L-' + a + ',' + b + 'V-' + b + 'Z';\n }\n },\n star: {\n n: 17,\n f: function(r) {\n var rs = r * 1.4;\n var x1 = d3.round(rs * 0.225, 2);\n var x2 = d3.round(rs * 0.951, 2);\n var x3 = d3.round(rs * 0.363, 2);\n var x4 = d3.round(rs * 0.588, 2);\n var y0 = d3.round(-rs, 2);\n var y1 = d3.round(rs * -0.309, 2);\n var y3 = d3.round(rs * 0.118, 2);\n var y4 = d3.round(rs * 0.809, 2);\n var y5 = d3.round(rs * 0.382, 2);\n return 'M' + x1 + ',' + y1 + 'H' + x2 + 'L' + x3 + ',' + y3 +\n 'L' + x4 + ',' + y4 + 'L0,' + y5 + 'L-' + x4 + ',' + y4 +\n 'L-' + x3 + ',' + y3 + 'L-' + x2 + ',' + y1 + 'H-' + x1 +\n 'L0,' + y0 + 'Z';\n }\n },\n hexagram: {\n n: 18,\n f: function(r) {\n var y = d3.round(r * 0.66, 2);\n var x1 = d3.round(r * 0.38, 2);\n var x2 = d3.round(r * 0.76, 2);\n return 'M-' + x2 + ',0l-' + x1 + ',-' + y + 'h' + x2 +\n 'l' + x1 + ',-' + y + 'l' + x1 + ',' + y + 'h' + x2 +\n 'l-' + x1 + ',' + y + 'l' + x1 + ',' + y + 'h-' + x2 +\n 'l-' + x1 + ',' + y + 'l-' + x1 + ',-' + y + 'h-' + x2 + 'Z';\n }\n },\n 'star-triangle-up': {\n n: 19,\n f: function(r) {\n var x = d3.round(r * Math.sqrt(3) * 0.8, 2);\n var y1 = d3.round(r * 0.8, 2);\n var y2 = d3.round(r * 1.6, 2);\n var rc = d3.round(r * 4, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return 'M-' + x + ',' + y1 + aPart + x + ',' + y1 +\n aPart + '0,-' + y2 + aPart + '-' + x + ',' + y1 + 'Z';\n }\n },\n 'star-triangle-down': {\n n: 20,\n f: function(r) {\n var x = d3.round(r * Math.sqrt(3) * 0.8, 2);\n var y1 = d3.round(r * 0.8, 2);\n var y2 = d3.round(r * 1.6, 2);\n var rc = d3.round(r * 4, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return 'M' + x + ',-' + y1 + aPart + '-' + x + ',-' + y1 +\n aPart + '0,' + y2 + aPart + x + ',-' + y1 + 'Z';\n }\n },\n 'star-square': {\n n: 21,\n f: function(r) {\n var rp = d3.round(r * 1.1, 2);\n var rc = d3.round(r * 2, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return 'M-' + rp + ',-' + rp + aPart + '-' + rp + ',' + rp +\n aPart + rp + ',' + rp + aPart + rp + ',-' + rp +\n aPart + '-' + rp + ',-' + rp + 'Z';\n }\n },\n 'star-diamond': {\n n: 22,\n f: function(r) {\n var rp = d3.round(r * 1.4, 2);\n var rc = d3.round(r * 1.9, 2);\n var aPart = 'A ' + rc + ',' + rc + ' 0 0 1 ';\n return 'M-' + rp + ',0' + aPart + '0,' + rp +\n aPart + rp + ',0' + aPart + '0,-' + rp +\n aPart + '-' + rp + ',0' + 'Z';\n }\n },\n 'diamond-tall': {\n n: 23,\n f: function(r) {\n var x = d3.round(r * 0.7, 2);\n var y = d3.round(r * 1.4, 2);\n return 'M0,' + y + 'L' + x + ',0L0,-' + y + 'L-' + x + ',0Z';\n }\n },\n 'diamond-wide': {\n n: 24,\n f: function(r) {\n var x = d3.round(r * 1.4, 2);\n var y = d3.round(r * 0.7, 2);\n return 'M0,' + y + 'L' + x + ',0L0,-' + y + 'L-' + x + ',0Z';\n }\n },\n hourglass: {\n n: 25,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M' + rs + ',' + rs + 'H-' + rs + 'L' + rs + ',-' + rs + 'H-' + rs + 'Z';\n },\n noDot: true\n },\n bowtie: {\n n: 26,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M' + rs + ',' + rs + 'V-' + rs + 'L-' + rs + ',' + rs + 'V-' + rs + 'Z';\n },\n noDot: true\n },\n 'circle-cross': {\n n: 27,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M0,' + rs + 'V-' + rs + 'M' + rs + ',0H-' + rs +\n 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs +\n 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z';\n },\n needLine: true,\n noDot: true\n },\n 'circle-x': {\n n: 28,\n f: function(r) {\n var rs = d3.round(r, 2);\n var rc = d3.round(r / Math.sqrt(2), 2);\n return 'M' + rc + ',' + rc + 'L-' + rc + ',-' + rc +\n 'M' + rc + ',-' + rc + 'L-' + rc + ',' + rc +\n 'M' + rs + ',0A' + rs + ',' + rs + ' 0 1,1 0,-' + rs +\n 'A' + rs + ',' + rs + ' 0 0,1 ' + rs + ',0Z';\n },\n needLine: true,\n noDot: true\n },\n 'square-cross': {\n n: 29,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M0,' + rs + 'V-' + rs + 'M' + rs + ',0H-' + rs +\n 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z';\n },\n needLine: true,\n noDot: true\n },\n 'square-x': {\n n: 30,\n f: function(r) {\n var rs = d3.round(r, 2);\n return 'M' + rs + ',' + rs + 'L-' + rs + ',-' + rs +\n 'M' + rs + ',-' + rs + 'L-' + rs + ',' + rs +\n 'M' + rs + ',' + rs + 'H-' + rs + 'V-' + rs + 'H' + rs + 'Z';\n },\n needLine: true,\n noDot: true\n },\n 'diamond-cross': {\n n: 31,\n f: function(r) {\n var rd = d3.round(r * 1.3, 2);\n return 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z' +\n 'M0,-' + rd + 'V' + rd + 'M-' + rd + ',0H' + rd;\n },\n needLine: true,\n noDot: true\n },\n 'diamond-x': {\n n: 32,\n f: function(r) {\n var rd = d3.round(r * 1.3, 2);\n var r2 = d3.round(r * 0.65, 2);\n return 'M' + rd + ',0L0,' + rd + 'L-' + rd + ',0L0,-' + rd + 'Z' +\n 'M-' + r2 + ',-' + r2 + 'L' + r2 + ',' + r2 +\n 'M-' + r2 + ',' + r2 + 'L' + r2 + ',-' + r2;\n },\n needLine: true,\n noDot: true\n },\n 'cross-thin': {\n n: 33,\n f: function(r) {\n var rc = d3.round(r * 1.4, 2);\n return 'M0,' + rc + 'V-' + rc + 'M' + rc + ',0H-' + rc;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'x-thin': {\n n: 34,\n f: function(r) {\n var rx = d3.round(r, 2);\n return 'M' + rx + ',' + rx + 'L-' + rx + ',-' + rx +\n 'M' + rx + ',-' + rx + 'L-' + rx + ',' + rx;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n asterisk: {\n n: 35,\n f: function(r) {\n var rc = d3.round(r * 1.2, 2);\n var rs = d3.round(r * 0.85, 2);\n return 'M0,' + rc + 'V-' + rc + 'M' + rc + ',0H-' + rc +\n 'M' + rs + ',' + rs + 'L-' + rs + ',-' + rs +\n 'M' + rs + ',-' + rs + 'L-' + rs + ',' + rs;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n hash: {\n n: 36,\n f: function(r) {\n var r1 = d3.round(r / 2, 2);\n var r2 = d3.round(r, 2);\n return 'M' + r1 + ',' + r2 + 'V-' + r2 +\n 'm-' + r2 + ',0V' + r2 +\n 'M' + r2 + ',' + r1 + 'H-' + r2 +\n 'm0,-' + r2 + 'H' + r2;\n },\n needLine: true,\n noFill: true\n },\n 'y-up': {\n n: 37,\n f: function(r) {\n var x = d3.round(r * 1.2, 2);\n var y0 = d3.round(r * 1.6, 2);\n var y1 = d3.round(r * 0.8, 2);\n return 'M-' + x + ',' + y1 + 'L0,0M' + x + ',' + y1 + 'L0,0M0,-' + y0 + 'L0,0';\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-down': {\n n: 38,\n f: function(r) {\n var x = d3.round(r * 1.2, 2);\n var y0 = d3.round(r * 1.6, 2);\n var y1 = d3.round(r * 0.8, 2);\n return 'M-' + x + ',-' + y1 + 'L0,0M' + x + ',-' + y1 + 'L0,0M0,' + y0 + 'L0,0';\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-left': {\n n: 39,\n f: function(r) {\n var y = d3.round(r * 1.2, 2);\n var x0 = d3.round(r * 1.6, 2);\n var x1 = d3.round(r * 0.8, 2);\n return 'M' + x1 + ',' + y + 'L0,0M' + x1 + ',-' + y + 'L0,0M-' + x0 + ',0L0,0';\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'y-right': {\n n: 40,\n f: function(r) {\n var y = d3.round(r * 1.2, 2);\n var x0 = d3.round(r * 1.6, 2);\n var x1 = d3.round(r * 0.8, 2);\n return 'M-' + x1 + ',' + y + 'L0,0M-' + x1 + ',-' + y + 'L0,0M' + x0 + ',0L0,0';\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ew': {\n n: 41,\n f: function(r) {\n var rc = d3.round(r * 1.4, 2);\n return 'M' + rc + ',0H-' + rc;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ns': {\n n: 42,\n f: function(r) {\n var rc = d3.round(r * 1.4, 2);\n return 'M0,' + rc + 'V-' + rc;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-ne': {\n n: 43,\n f: function(r) {\n var rx = d3.round(r, 2);\n return 'M' + rx + ',-' + rx + 'L-' + rx + ',' + rx;\n },\n needLine: true,\n noDot: true,\n noFill: true\n },\n 'line-nw': {\n n: 44,\n f: function(r) {\n var rx = d3.round(r, 2);\n return 'M' + rx + ',' + rx + 'L-' + rx + ',-' + rx;\n },\n needLine: true,\n noDot: true,\n noFill: true\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar baseAttrs = require('../../plots/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar FORMAT_LINK = require('../../constants/docs').FORMAT_LINK;\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = extendFlat({\n z: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the z data.'\n },\n x: extendFlat({}, scatterAttrs.x, {impliedEdits: {xtype: 'array'}}),\n x0: extendFlat({}, scatterAttrs.x0, {impliedEdits: {xtype: 'scaled'}}),\n dx: extendFlat({}, scatterAttrs.dx, {impliedEdits: {xtype: 'scaled'}}),\n y: extendFlat({}, scatterAttrs.y, {impliedEdits: {ytype: 'array'}}),\n y0: extendFlat({}, scatterAttrs.y0, {impliedEdits: {ytype: 'scaled'}}),\n dy: extendFlat({}, scatterAttrs.dy, {impliedEdits: {ytype: 'scaled'}}),\n\n text: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Sets the text elements associated with each z value.'\n },\n hovertext: {\n valType: 'data_array',\n editType: 'calc',\n description: 'Same as `text`.'\n },\n transpose: {\n valType: 'boolean',\n dflt: false,\n role: 'info',\n editType: 'calc',\n description: 'Transposes the z data.'\n },\n xtype: {\n valType: 'enumerated',\n values: ['array', 'scaled'],\n role: 'info',\n editType: 'calc+clearAxisTypes',\n description: [\n 'If *array*, the heatmap\\'s x coordinates are given by *x*',\n '(the default behavior when `x` is provided).',\n 'If *scaled*, the heatmap\\'s x coordinates are given by *x0* and *dx*',\n '(the default behavior when `x` is not provided).'\n ].join(' ')\n },\n ytype: {\n valType: 'enumerated',\n values: ['array', 'scaled'],\n role: 'info',\n editType: 'calc+clearAxisTypes',\n description: [\n 'If *array*, the heatmap\\'s y coordinates are given by *y*',\n '(the default behavior when `y` is provided)',\n 'If *scaled*, the heatmap\\'s y coordinates are given by *y0* and *dy*',\n '(the default behavior when `y` is not provided)'\n ].join(' ')\n },\n zsmooth: {\n valType: 'enumerated',\n values: ['fast', 'best', false],\n dflt: false,\n role: 'style',\n editType: 'calc',\n description: [\n 'Picks a smoothing algorithm use to smooth `z` data.'\n ].join(' ')\n },\n hoverongaps: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'none',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data have hover labels associated with them.'\n ].join(' ')\n },\n connectgaps: {\n valType: 'boolean',\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the `z` data are filled in.',\n 'It is defaulted to true if `z` is a',\n 'one dimensional array and `zsmooth` is not false;',\n 'otherwise it is defaulted to false.'\n ].join(' ')\n },\n xgap: {\n valType: 'number',\n dflt: 0,\n min: 0,\n role: 'style',\n editType: 'plot',\n description: 'Sets the horizontal gap (in pixels) between bricks.'\n },\n ygap: {\n valType: 'number',\n dflt: 0,\n min: 0,\n role: 'style',\n editType: 'plot',\n description: 'Sets the vertical gap (in pixels) between bricks.'\n },\n zhoverformat: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the hover text formatting rule using d3 formatting mini-languages',\n 'which are very similar to those in Python. See:',\n FORMAT_LINK\n ].join(' ')\n },\n hovertemplate: hovertemplateAttrs(),\n showlegend: extendFlat({}, baseAttrs.showlegend, {dflt: false})\n}, {\n transforms: undefined\n},\n colorScaleAttrs('', {cLetter: 'z', autoColorDflt: false})\n);\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * This will be transferred over to gd and overridden by\n * config args to Plotly.plot.\n *\n * The defaults are the appropriate settings for plotly.js,\n * so we get the right experience without any config argument.\n *\n * N.B. the config options are not coerced using Lib.coerce so keys\n * like `valType` and `values` are only set for documentation purposes\n * at the moment.\n */\n\nvar configAttributes = {\n staticPlot: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graphs are interactive or not.',\n 'If *false*, no interactivity, for export or image generation.'\n ].join(' ')\n },\n\n plotlyServerURL: {\n valType: 'string',\n dflt: '',\n description: [\n 'When set it determines base URL for',\n 'the \\'Edit in Chart Studio\\' `showEditInChartStudio`/`showSendToCloud` mode bar button',\n 'and the showLink/sendData on-graph link.',\n 'To enable sending your data to Chart Studio Cloud, you need to',\n 'set both `plotlyServerURL` to \\'https://chart-studio.plotly.com\\' and',\n 'also set `showSendToCloud` to true.'\n ].join(' ')\n },\n\n editable: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graph is editable or not.',\n 'Sets all pieces of `edits`',\n 'unless a separate `edits` config item overrides individual parts.'\n ].join(' ')\n },\n edits: {\n annotationPosition: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines if the main anchor of the annotation is editable.',\n 'The main anchor corresponds to the',\n 'text (if no arrow) or the arrow (which drags the whole thing leaving',\n 'the arrow length & direction unchanged).'\n ].join(' ')\n },\n annotationTail: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Has only an effect for annotations with arrows.',\n 'Enables changing the length and direction of the arrow.'\n ].join(' ')\n },\n annotationText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing annotation text.'\n },\n axisTitleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing axis title text.'\n },\n colorbarPosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving colorbars.'\n },\n colorbarTitleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing colorbar title text.'\n },\n legendPosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving the legend.'\n },\n legendText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing the trace name fields from the legend'\n },\n shapePosition: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables moving shapes.'\n },\n titleText: {\n valType: 'boolean',\n dflt: false,\n description: 'Enables editing the global layout title.'\n }\n },\n\n autosizable: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether the graphs are plotted with respect to',\n 'layout.autosize:true and infer its container size.'\n ].join(' ')\n },\n responsive: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether to change the layout size when window is resized.',\n 'In v2, this option will be removed and will always be true.'\n ].join(' ')\n },\n fillFrame: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'When `layout.autosize` is turned on, determines whether the graph',\n 'fills the container (the default) or the screen (if set to *true*).'\n ].join(' ')\n },\n frameMargins: {\n valType: 'number',\n dflt: 0,\n min: 0,\n max: 0.5,\n description: [\n 'When `layout.autosize` is turned on, set the frame margins',\n 'in fraction of the graph size.'\n ].join(' ')\n },\n\n scrollZoom: {\n valType: 'flaglist',\n flags: ['cartesian', 'gl3d', 'geo', 'mapbox'],\n extras: [true, false],\n dflt: 'gl3d+geo+mapbox',\n description: [\n 'Determines whether mouse wheel or two-finger scroll zooms is enable.',\n 'Turned on by default for gl3d, geo and mapbox subplots',\n '(as these subplot types do not have zoombox via pan),',\n 'but turned off by default for cartesian subplots.',\n 'Set `scrollZoom` to *false* to disable scrolling for all subplots.'\n ].join(' ')\n },\n doubleClick: {\n valType: 'enumerated',\n values: [false, 'reset', 'autosize', 'reset+autosize'],\n dflt: 'reset+autosize',\n description: [\n 'Sets the double click interaction mode.',\n 'Has an effect only in cartesian plots.',\n 'If *false*, double click is disable.',\n 'If *reset*, double click resets the axis ranges to their initial values.',\n 'If *autosize*, double click set the axis ranges to their autorange values.',\n 'If *reset+autosize*, the odd double clicks resets the axis ranges',\n 'to their initial values and even double clicks set the axis ranges',\n 'to their autorange values.'\n ].join(' ')\n },\n doubleClickDelay: {\n valType: 'number',\n dflt: 300,\n min: 0,\n description: [\n 'Sets the delay for registering a double-click in ms.',\n 'This is the time interval (in ms) between first mousedown and',\n '2nd mouseup to constitute a double-click.',\n 'This setting propagates to all on-subplot double clicks',\n '(except for geo and mapbox) and on-legend double clicks.'\n ].join(' ')\n },\n\n showAxisDragHandles: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Set to *false* to omit cartesian axis pan/zoom drag handles.'\n ].join(' ')\n },\n showAxisRangeEntryBoxes: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Set to *false* to omit direct range entry at the pan/zoom drag points,',\n 'note that `showAxisDragHandles` must be enabled to have an effect.'\n ].join(' ')\n },\n\n showTips: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not tips are shown while interacting',\n 'with the resulting graphs.'\n ].join(' ')\n },\n\n showLink: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether a link to Chart Studio Cloud is displayed',\n 'at the bottom right corner of resulting graphs.',\n 'Use with `sendData` and `linkText`.'\n ].join(' ')\n },\n linkText: {\n valType: 'string',\n dflt: 'Edit chart',\n noBlank: true,\n description: [\n 'Sets the text appearing in the `showLink` link.'\n ].join(' ')\n },\n sendData: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'If *showLink* is true, does it contain data',\n 'just link to a Chart Studio Cloud file?'\n ].join(' ')\n },\n showSources: {\n valType: 'any',\n dflt: false,\n description: [\n 'Adds a source-displaying function to show sources on',\n 'the resulting graphs.'\n ].join(' ')\n },\n\n displayModeBar: {\n valType: 'enumerated',\n values: ['hover', true, false],\n dflt: 'hover',\n description: [\n 'Determines the mode bar display mode.',\n 'If *true*, the mode bar is always visible.',\n 'If *false*, the mode bar is always hidden.',\n 'If *hover*, the mode bar is visible while the mouse cursor',\n 'is on the graph container.'\n ].join(' ')\n },\n showSendToCloud: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Should we include a ModeBar button, labeled \"Edit in Chart Studio\",',\n 'that sends this chart to chart-studio.plotly.com (formerly plot.ly) or another plotly server',\n 'as specified by `plotlyServerURL` for editing, export, etc? Prior to version 1.43.0',\n 'this button was included by default, now it is opt-in using this flag.',\n 'Note that this button can (depending on `plotlyServerURL` being set) send your data',\n 'to an external server. However that server does not persist your data',\n 'until you arrive at the Chart Studio and explicitly click \"Save\".'\n ].join(' ')\n },\n showEditInChartStudio: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Same as `showSendToCloud`, but use a pencil icon instead of a floppy-disk.',\n 'Note that if both `showSendToCloud` and `showEditInChartStudio` are turned,',\n 'only `showEditInChartStudio` will be honored.'\n ].join(' ')\n },\n modeBarButtonsToRemove: {\n valType: 'any',\n dflt: [],\n description: [\n 'Remove mode bar buttons by name.',\n 'See ./components/modebar/buttons.js for the list of names.'\n ].join(' ')\n },\n modeBarButtonsToAdd: {\n valType: 'any',\n dflt: [],\n description: [\n 'Add mode bar button using config objects',\n 'See ./components/modebar/buttons.js for list of arguments.'\n ].join(' ')\n },\n modeBarButtons: {\n valType: 'any',\n dflt: false,\n description: [\n 'Define fully custom mode bar buttons as nested array,',\n 'where the outer arrays represents button groups, and',\n 'the inner arrays have buttons config objects or names of default buttons',\n 'See ./components/modebar/buttons.js for more info.'\n ].join(' ')\n },\n toImageButtonOptions: {\n valType: 'any',\n dflt: {},\n description: [\n 'Statically override options for toImage modebar button',\n 'allowed keys are format, filename, width, height, scale',\n 'see ../components/modebar/buttons.js'\n ].join(' ')\n },\n displaylogo: {\n valType: 'boolean',\n dflt: true,\n description: [\n 'Determines whether or not the plotly logo is displayed',\n 'on the end of the mode bar.'\n ].join(' ')\n },\n watermark: {\n valType: 'boolean',\n dflt: false,\n description: 'watermark the images with the company\\'s logo'\n },\n\n plotGlPixelRatio: {\n valType: 'number',\n dflt: 2,\n min: 1,\n max: 4,\n description: [\n 'Set the pixel ratio during WebGL image export.',\n 'This config option was formerly named `plot3dPixelRatio`',\n 'which is now deprecated.'\n ].join(' ')\n },\n\n setBackground: {\n valType: 'any',\n dflt: 'transparent',\n description: [\n 'Set function to add the background color (i.e. `layout.paper_color`)',\n 'to a different container.',\n 'This function take the graph div as first argument and the current background',\n 'color as second argument.',\n 'Alternatively, set to string *opaque* to ensure there is white behind it.'\n ].join(' ')\n },\n\n topojsonURL: {\n valType: 'string',\n noBlank: true,\n dflt: 'https://cdn.plot.ly/',\n description: [\n 'Set the URL to topojson used in geo charts.',\n 'By default, the topojson files are fetched from cdn.plot.ly.',\n 'For example, set this option to:',\n '/dist/topojson/',\n 'to render geographical feature using the topojson files',\n 'that ship with the plotly.js module.'\n ].join(' ')\n },\n\n mapboxAccessToken: {\n valType: 'string',\n dflt: null,\n description: [\n 'Mapbox access token (required to plot mapbox trace types)',\n 'If using an Mapbox Atlas server, set this option to \\'\\'',\n 'so that plotly.js won\\'t attempt to authenticate to the public Mapbox server.'\n ].join(' ')\n },\n\n logging: {\n valType: 'integer',\n min: 0,\n max: 2,\n dflt: 1,\n description: [\n 'Turn all console logging on or off (errors will be thrown)',\n 'This should ONLY be set via Plotly.setPlotConfig',\n 'Available levels:',\n '0: no logs',\n '1: warnings and errors, but not informational messages',\n '2: verbose logs'\n ].join(' ')\n },\n\n notifyOnLogging: {\n valType: 'integer',\n min: 0,\n max: 2,\n dflt: 0,\n description: [\n 'Set on-graph logging (notifier) level',\n 'This should ONLY be set via Plotly.setPlotConfig',\n 'Available levels:',\n '0: no on-graph logs',\n '1: warnings and errors, but not informational messages',\n '2: verbose logs'\n ].join(' ')\n },\n\n queueLength: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n description: 'Sets the length of the undo/redo queue.'\n },\n\n globalTransforms: {\n valType: 'any',\n dflt: [],\n description: [\n 'Set global transform to be applied to all traces with no',\n 'specification needed'\n ].join(' ')\n },\n\n locale: {\n valType: 'string',\n dflt: 'en-US',\n description: [\n 'Which localization should we use?',\n 'Should be a string like \\'en\\' or \\'en-US\\'.'\n ].join(' ')\n },\n\n locales: {\n valType: 'any',\n dflt: {},\n description: [\n 'Localization definitions',\n 'Locales can be provided either here (specific to one chart) or globally',\n 'by registering them as modules.',\n 'Should be an object of objects {locale: {dictionary: {...}, format: {...}}}',\n '{',\n ' da: {',\n ' dictionary: {\\'Reset axes\\': \\'Nulstil aksler\\', ...},',\n ' format: {months: [...], shortMonths: [...]}',\n ' },',\n ' ...',\n '}',\n 'All parts are optional. When looking for translation or format fields, we',\n 'look first for an exact match in a config locale, then in a registered',\n 'module. If those fail, we strip off any regionalization (\\'en-US\\' -> \\'en\\')',\n 'and try each (config, registry) again. The final fallback for translation',\n 'is untranslated (which is US English) and for formats is the base English',\n '(the only consequence being the last fallback date format %x is DD/MM/YYYY',\n 'instead of MM/DD/YYYY). Currently `grouping` and `currency` are ignored',\n 'for our automatic number formatting, but can be used in custom formats.'\n ].join(' ')\n }\n};\n\nvar dfltConfig = {};\n\nfunction crawl(src, target) {\n for(var k in src) {\n var obj = src[k];\n if(obj.valType) {\n target[k] = obj.dflt;\n } else {\n if(!target[k]) {\n target[k] = {};\n }\n crawl(obj, target[k]);\n }\n }\n}\n\ncrawl(configAttributes, dfltConfig);\n\nmodule.exports = {\n configAttributes: configAttributes,\n dfltConfig: dfltConfig\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar FORMAT_LINK = require('../constants/docs').FORMAT_LINK;\nvar DATE_FORMAT_LINK = require('../constants/docs').DATE_FORMAT_LINK;\n\nvar templateFormatStringDescription = [\n 'Variables are inserted using %{variable}, for example \"y: %{y}\".',\n 'Numbers are formatted using d3-format\\'s syntax %{variable:d3-format}, for example \"Price: %{y:$.2f}\".',\n FORMAT_LINK,\n 'for details on the formatting syntax.',\n 'Dates are formatted using d3-time-format\\'s syntax %{variable|d3-time-format}, for example \"Day: %{2019-01-01|%A}\".',\n DATE_FORMAT_LINK,\n 'for details on the date formatting syntax.'\n].join(' ');\n\nfunction describeVariables(extra) {\n var descPart = extra.description ? ' ' + extra.description : '';\n var keys = extra.keys || [];\n if(keys.length > 0) {\n var quotedKeys = [];\n for(var i = 0; i < keys.length; i++) {\n quotedKeys[i] = '`' + keys[i] + '`';\n }\n descPart = descPart + 'Finally, the template string has access to ';\n if(keys.length === 1) {\n descPart = 'variable ' + quotedKeys[0];\n } else {\n descPart = 'variables ' + quotedKeys.slice(0, -1).join(', ') + ' and ' + quotedKeys.slice(-1) + '.';\n }\n }\n return descPart;\n}\n\nexports.hovertemplateAttrs = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var descPart = describeVariables(extra);\n\n var hovertemplate = {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: opts.editType || 'none',\n description: [\n 'Template string used for rendering the information that appear on hover box.',\n 'Note that this will override `hoverinfo`.',\n templateFormatStringDescription,\n 'The variables available in `hovertemplate` are the ones emitted as event data described at this link https://plotly.com/javascript/plotlyjs-events/#event-data.',\n 'Additionally, every attributes that can be specified per-point (the ones that are `arrayOk: true`) are available.',\n descPart,\n 'Anything contained in tag `` is displayed in the secondary box, for example \"{fullData.name}\".',\n 'To hide the secondary box completely, use an empty tag ``.'\n ].join(' ')\n };\n\n if(opts.arrayOk !== false) {\n hovertemplate.arrayOk = true;\n }\n\n return hovertemplate;\n};\n\nexports.texttemplateAttrs = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var descPart = describeVariables(extra);\n\n var texttemplate = {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: opts.editType || 'calc',\n description: [\n 'Template string used for rendering the information text that appear on points.',\n 'Note that this will override `textinfo`.',\n templateFormatStringDescription,\n 'Every attributes that can be specified per-point (the ones that are `arrayOk: true`) are available.',\n descPart\n ].join(' ')\n };\n\n if(opts.arrayOk !== false) {\n texttemplate.arrayOk = true;\n }\n return texttemplate;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar EventEmitter = require('events').EventEmitter;\n\nvar helpers = require('./helpers');\n\nfunction svgToImg(opts) {\n var ev = opts.emitter || new EventEmitter();\n\n var promise = new Promise(function(resolve, reject) {\n var Image = window.Image;\n var svg = opts.svg;\n var format = opts.format || 'png';\n\n // IE only support svg\n if(Lib.isIE() && format !== 'svg') {\n var ieSvgError = new Error(helpers.MSG_IE_BAD_FORMAT);\n reject(ieSvgError);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', ieSvgError);\n } else {\n return promise;\n }\n }\n\n var canvas = opts.canvas;\n var scale = opts.scale || 1;\n var w0 = opts.width || 300;\n var h0 = opts.height || 150;\n var w1 = scale * w0;\n var h1 = scale * h0;\n\n var ctx = canvas.getContext('2d');\n var img = new Image();\n var svgBlob, url;\n\n if(format === 'svg' || Lib.isIE9orBelow() || Lib.isSafari()) {\n url = helpers.encodeSVG(svg);\n } else {\n svgBlob = helpers.createBlob(svg, 'svg');\n url = helpers.createObjectURL(svgBlob);\n }\n\n canvas.width = w1;\n canvas.height = h1;\n\n img.onload = function() {\n var imgData;\n\n svgBlob = null;\n helpers.revokeObjectURL(url);\n\n // don't need to draw to canvas if svg\n // save some time and also avoid failure on IE\n if(format !== 'svg') {\n ctx.drawImage(img, 0, 0, w1, h1);\n }\n\n switch(format) {\n case 'jpeg':\n imgData = canvas.toDataURL('image/jpeg');\n break;\n case 'png':\n imgData = canvas.toDataURL('image/png');\n break;\n case 'webp':\n imgData = canvas.toDataURL('image/webp');\n break;\n case 'svg':\n imgData = url;\n break;\n default:\n var errorMsg = 'Image format is not jpeg, png, svg or webp.';\n reject(new Error(errorMsg));\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', errorMsg);\n }\n }\n resolve(imgData);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n ev.emit('success', imgData);\n }\n };\n\n img.onerror = function(err) {\n svgBlob = null;\n helpers.revokeObjectURL(url);\n\n reject(err);\n // eventually remove the ev\n // in favor of promises\n if(!opts.promise) {\n return ev.emit('error', err);\n }\n };\n\n img.src = url;\n });\n\n // temporary for backward compatibility\n // move to only Promise in 2.0.0\n // and eliminate the EventEmitter\n if(opts.promise) {\n return promise;\n }\n\n return ev;\n}\n\nmodule.exports = svgToImg;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar hover = require('./hover').hover;\n\nmodule.exports = function click(gd, evt, subplot) {\n var annotationsDone = Registry.getComponentMethod('annotations', 'onClick')(gd, gd._hoverdata);\n\n // fallback to fail-safe in case the plot type's hover method doesn't pass the subplot.\n // Ternary, for example, didn't, but it was caught because tested.\n if(subplot !== undefined) {\n // The true flag at the end causes it to re-run the hover computation to figure out *which*\n // point is being clicked. Without this, clicking is somewhat unreliable.\n hover(gd, evt, subplot, true);\n }\n\n function emitClick() { gd.emit('plotly_click', {points: gd._hoverdata, event: evt}); }\n\n if(gd._hoverdata && evt && evt.target) {\n if(annotationsDone && annotationsDone.then) {\n annotationsDone.then(emitClick);\n } else emitClick();\n\n // why do we get a double event without this???\n if(evt.stopImmediatePropagation) evt.stopImmediatePropagation();\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar Registry = require('../registry');\nvar Plots = require('../plots/plots');\n\nvar Lib = require('../lib');\nvar clearGlCanvases = require('../lib/clear_gl_canvases');\n\nvar Color = require('../components/color');\nvar Drawing = require('../components/drawing');\nvar Titles = require('../components/titles');\nvar ModeBar = require('../components/modebar');\n\nvar Axes = require('../plots/cartesian/axes');\nvar alignmentConstants = require('../constants/alignment');\nvar axisConstraints = require('../plots/cartesian/constraints');\nvar enforceAxisConstraints = axisConstraints.enforce;\nvar cleanAxisConstraints = axisConstraints.clean;\nvar doAutoRange = require('../plots/cartesian/autorange').doAutoRange;\n\nvar SVG_TEXT_ANCHOR_START = 'start';\nvar SVG_TEXT_ANCHOR_MIDDLE = 'middle';\nvar SVG_TEXT_ANCHOR_END = 'end';\n\nexports.layoutStyles = function(gd) {\n return Lib.syncOrAsync([Plots.doAutoMargin, lsInner], gd);\n};\n\nfunction overlappingDomain(xDomain, yDomain, domains) {\n for(var i = 0; i < domains.length; i++) {\n var existingX = domains[i][0];\n var existingY = domains[i][1];\n\n if(existingX[0] >= xDomain[1] || existingX[1] <= xDomain[0]) {\n continue;\n }\n if(existingY[0] < yDomain[1] && existingY[1] > yDomain[0]) {\n return true;\n }\n }\n return false;\n}\n\nfunction lsInner(gd) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var pad = gs.p;\n var axList = Axes.list(gd, '', true);\n var i, subplot, plotinfo, ax, xa, ya;\n\n fullLayout._paperdiv.style({\n width: (gd._context.responsive && fullLayout.autosize && !gd._context._hasZeroWidth && !gd.layout.width) ? '100%' : fullLayout.width + 'px',\n height: (gd._context.responsive && fullLayout.autosize && !gd._context._hasZeroHeight && !gd.layout.height) ? '100%' : fullLayout.height + 'px'\n })\n .selectAll('.main-svg')\n .call(Drawing.setSize, fullLayout.width, fullLayout.height);\n gd._context.setBackground(gd, fullLayout.paper_bgcolor);\n\n exports.drawMainTitle(gd);\n ModeBar.manage(gd);\n\n // _has('cartesian') means SVG specifically, not GL2D - but GL2D\n // can still get here because it makes some of the SVG structure\n // for shared features like selections.\n if(!fullLayout._has('cartesian')) {\n return Plots.previousPromises(gd);\n }\n\n function getLinePosition(ax, counterAx, side) {\n var lwHalf = ax._lw / 2;\n\n if(ax._id.charAt(0) === 'x') {\n if(!counterAx) return gs.t + gs.h * (1 - (ax.position || 0)) + (lwHalf % 1);\n else if(side === 'top') return counterAx._offset - pad - lwHalf;\n return counterAx._offset + counterAx._length + pad + lwHalf;\n }\n\n if(!counterAx) return gs.l + gs.w * (ax.position || 0) + (lwHalf % 1);\n else if(side === 'right') return counterAx._offset + counterAx._length + pad + lwHalf;\n return counterAx._offset - pad - lwHalf;\n }\n\n // some preparation of axis position info\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n var counterAx = ax._anchorAxis;\n\n // clear axis line positions, to be set in the subplot loop below\n ax._linepositions = {};\n\n // stash crispRounded linewidth so we don't need to pass gd all over the place\n ax._lw = Drawing.crispRound(gd, ax.linewidth, 1);\n\n // figure out the main axis line and main mirror line position.\n // it's easier to follow the logic if we handle these separately from\n // ax._linepositions, which are only used by mirror=allticks\n // for non-main-subplot ticks, and mirror=all(ticks)? for zero line\n // hiding logic\n ax._mainLinePosition = getLinePosition(ax, counterAx, ax.side);\n ax._mainMirrorPosition = (ax.mirror && counterAx) ?\n getLinePosition(ax, counterAx,\n alignmentConstants.OPPOSITE_SIDE[ax.side]) : null;\n }\n\n // figure out which backgrounds we need to draw,\n // and in which layers to put them\n var lowerBackgroundIDs = [];\n var backgroundIds = [];\n var lowerDomains = [];\n // no need to draw background when paper and plot color are the same color,\n // activate mode just for large splom (which benefit the most from this\n // optimization), but this could apply to all cartesian subplots.\n var noNeedForBg = (\n Color.opacity(fullLayout.paper_bgcolor) === 1 &&\n Color.opacity(fullLayout.plot_bgcolor) === 1 &&\n fullLayout.paper_bgcolor === fullLayout.plot_bgcolor\n );\n\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n\n if(plotinfo.mainplot) {\n // mainplot is a reference to the main plot this one is overlaid on\n // so if it exists, this is an overlaid plot and we don't need to\n // give it its own background\n if(plotinfo.bg) {\n plotinfo.bg.remove();\n }\n plotinfo.bg = undefined;\n } else {\n var xDomain = plotinfo.xaxis.domain;\n var yDomain = plotinfo.yaxis.domain;\n var plotgroup = plotinfo.plotgroup;\n\n if(overlappingDomain(xDomain, yDomain, lowerDomains)) {\n var pgNode = plotgroup.node();\n var plotgroupBg = plotinfo.bg = Lib.ensureSingle(plotgroup, 'rect', 'bg');\n pgNode.insertBefore(plotgroupBg.node(), pgNode.childNodes[0]);\n backgroundIds.push(subplot);\n } else {\n plotgroup.select('rect.bg').remove();\n lowerDomains.push([xDomain, yDomain]);\n if(!noNeedForBg) {\n lowerBackgroundIDs.push(subplot);\n backgroundIds.push(subplot);\n }\n }\n }\n }\n\n // now create all the lower-layer backgrounds at once now that\n // we have the list of subplots that need them\n var lowerBackgrounds = fullLayout._bgLayer.selectAll('.bg')\n .data(lowerBackgroundIDs);\n\n lowerBackgrounds.enter().append('rect')\n .classed('bg', true);\n\n lowerBackgrounds.exit().remove();\n\n lowerBackgrounds.each(function(subplot) {\n fullLayout._plots[subplot].bg = d3.select(this);\n });\n\n // style all backgrounds\n for(i = 0; i < backgroundIds.length; i++) {\n plotinfo = fullLayout._plots[backgroundIds[i]];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n if(plotinfo.bg) {\n plotinfo.bg\n .call(Drawing.setRect,\n xa._offset - pad, ya._offset - pad,\n xa._length + 2 * pad, ya._length + 2 * pad)\n .call(Color.fill, fullLayout.plot_bgcolor)\n .style('stroke-width', 0);\n }\n }\n\n if(!fullLayout._hasOnlyLargeSploms) {\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n // Clip so that data only shows up on the plot area.\n var clipId = plotinfo.clipId = 'clip' + fullLayout._uid + subplot + 'plot';\n\n var plotClip = Lib.ensureSingleById(fullLayout._clips, 'clipPath', clipId, function(s) {\n s.classed('plotclip', true)\n .append('rect');\n });\n\n plotinfo.clipRect = plotClip.select('rect').attr({\n width: xa._length,\n height: ya._length\n });\n\n Drawing.setTranslate(plotinfo.plot, xa._offset, ya._offset);\n\n var plotClipId;\n var layerClipId;\n\n if(plotinfo._hasClipOnAxisFalse) {\n plotClipId = null;\n layerClipId = clipId;\n } else {\n plotClipId = clipId;\n layerClipId = null;\n }\n\n Drawing.setClipUrl(plotinfo.plot, plotClipId, gd);\n\n // stash layer clipId value (null or same as clipId)\n // to DRY up Drawing.setClipUrl calls on trace-module and trace layers\n // downstream\n plotinfo.layerClipId = layerClipId;\n }\n }\n\n var xLinesXLeft, xLinesXRight, xLinesYBottom, xLinesYTop,\n leftYLineWidth, rightYLineWidth;\n var yLinesYBottom, yLinesYTop, yLinesXLeft, yLinesXRight,\n connectYBottom, connectYTop;\n var extraSubplot;\n\n function xLinePath(y) {\n return 'M' + xLinesXLeft + ',' + y + 'H' + xLinesXRight;\n }\n\n function xLinePathFree(y) {\n return 'M' + xa._offset + ',' + y + 'h' + xa._length;\n }\n\n function yLinePath(x) {\n return 'M' + x + ',' + yLinesYTop + 'V' + yLinesYBottom;\n }\n\n function yLinePathFree(x) {\n return 'M' + x + ',' + ya._offset + 'v' + ya._length;\n }\n\n function mainPath(ax, pathFn, pathFnFree) {\n if(!ax.showline || subplot !== ax._mainSubplot) return '';\n if(!ax._anchorAxis) return pathFnFree(ax._mainLinePosition);\n var out = pathFn(ax._mainLinePosition);\n if(ax.mirror) out += pathFn(ax._mainMirrorPosition);\n return out;\n }\n\n for(subplot in fullLayout._plots) {\n plotinfo = fullLayout._plots[subplot];\n xa = plotinfo.xaxis;\n ya = plotinfo.yaxis;\n\n /*\n * x lines get longer where they meet y lines, to make a crisp corner.\n * The x lines get the padding (margin.pad) plus the y line width to\n * fill up the corner nicely. Free x lines are excluded - they always\n * span exactly the data area of the plot\n *\n * | XXXXX\n * | XXXXX\n * |\n * +------\n * x1\n * -----\n * x2\n */\n var xPath = 'M0,0';\n if(shouldShowLinesOrTicks(xa, subplot)) {\n leftYLineWidth = findCounterAxisLineWidth(xa, 'left', ya, axList);\n xLinesXLeft = xa._offset - (leftYLineWidth ? (pad + leftYLineWidth) : 0);\n rightYLineWidth = findCounterAxisLineWidth(xa, 'right', ya, axList);\n xLinesXRight = xa._offset + xa._length + (rightYLineWidth ? (pad + rightYLineWidth) : 0);\n xLinesYBottom = getLinePosition(xa, ya, 'bottom');\n xLinesYTop = getLinePosition(xa, ya, 'top');\n\n // save axis line positions for extra ticks to reference\n // each subplot that gets ticks from \"allticks\" gets an entry:\n // [left or bottom, right or top]\n extraSubplot = (!xa._anchorAxis || subplot !== xa._mainSubplot);\n if(extraSubplot && (xa.mirror === 'allticks' || xa.mirror === 'all')) {\n xa._linepositions[subplot] = [xLinesYBottom, xLinesYTop];\n }\n\n xPath = mainPath(xa, xLinePath, xLinePathFree);\n if(extraSubplot && xa.showline && (xa.mirror === 'all' || xa.mirror === 'allticks')) {\n xPath += xLinePath(xLinesYBottom) + xLinePath(xLinesYTop);\n }\n\n plotinfo.xlines\n .style('stroke-width', xa._lw + 'px')\n .call(Color.stroke, xa.showline ?\n xa.linecolor : 'rgba(0,0,0,0)');\n }\n plotinfo.xlines.attr('d', xPath);\n\n /*\n * y lines that meet x axes get longer only by margin.pad, because\n * the x axes fill in the corner space. Free y axes, like free x axes,\n * always span exactly the data area of the plot\n *\n * | | XXXX\n * y2| y1| XXXX\n * | | XXXX\n * |\n * +-----\n */\n var yPath = 'M0,0';\n if(shouldShowLinesOrTicks(ya, subplot)) {\n connectYBottom = findCounterAxisLineWidth(ya, 'bottom', xa, axList);\n yLinesYBottom = ya._offset + ya._length + (connectYBottom ? pad : 0);\n connectYTop = findCounterAxisLineWidth(ya, 'top', xa, axList);\n yLinesYTop = ya._offset - (connectYTop ? pad : 0);\n yLinesXLeft = getLinePosition(ya, xa, 'left');\n yLinesXRight = getLinePosition(ya, xa, 'right');\n\n extraSubplot = (!ya._anchorAxis || subplot !== ya._mainSubplot);\n if(extraSubplot && (ya.mirror === 'allticks' || ya.mirror === 'all')) {\n ya._linepositions[subplot] = [yLinesXLeft, yLinesXRight];\n }\n\n yPath = mainPath(ya, yLinePath, yLinePathFree);\n if(extraSubplot && ya.showline && (ya.mirror === 'all' || ya.mirror === 'allticks')) {\n yPath += yLinePath(yLinesXLeft) + yLinePath(yLinesXRight);\n }\n\n plotinfo.ylines\n .style('stroke-width', ya._lw + 'px')\n .call(Color.stroke, ya.showline ?\n ya.linecolor : 'rgba(0,0,0,0)');\n }\n plotinfo.ylines.attr('d', yPath);\n }\n\n Axes.makeClipPaths(gd);\n\n return Plots.previousPromises(gd);\n}\n\nfunction shouldShowLinesOrTicks(ax, subplot) {\n return (ax.ticks || ax.showline) &&\n (subplot === ax._mainSubplot || ax.mirror === 'all' || ax.mirror === 'allticks');\n}\n\n/*\n * should we draw a line on counterAx at this side of ax?\n * It's assumed that counterAx is known to overlay the subplot we're working on\n * but it may not be its main axis.\n */\nfunction shouldShowLineThisSide(ax, side, counterAx) {\n // does counterAx get a line at all?\n if(!counterAx.showline || !counterAx._lw) return false;\n\n // are we drawing *all* lines for counterAx?\n if(counterAx.mirror === 'all' || counterAx.mirror === 'allticks') return true;\n\n var anchorAx = counterAx._anchorAxis;\n\n // is this a free axis? free axes can only have a subplot side-line with all(ticks)? mirroring\n if(!anchorAx) return false;\n\n // in order to handle cases where the user forgot to anchor this axis correctly\n // (because its default anchor has the same domain on the relevant end)\n // check whether the relevant position is the same.\n var sideIndex = alignmentConstants.FROM_BL[side];\n if(counterAx.side === side) {\n return anchorAx.domain[sideIndex] === ax.domain[sideIndex];\n }\n return counterAx.mirror && anchorAx.domain[1 - sideIndex] === ax.domain[1 - sideIndex];\n}\n\n/*\n * Is there another axis intersecting `side` end of `ax`?\n * First look at `counterAx` (the axis for this subplot),\n * then at all other potential counteraxes on or overlaying this subplot.\n * Take the line width from the first one that has a line.\n */\nfunction findCounterAxisLineWidth(ax, side, counterAx, axList) {\n if(shouldShowLineThisSide(ax, side, counterAx)) {\n return counterAx._lw;\n }\n for(var i = 0; i < axList.length; i++) {\n var axi = axList[i];\n if(axi._mainAxis === counterAx._mainAxis && shouldShowLineThisSide(ax, side, axi)) {\n return axi._lw;\n }\n }\n return 0;\n}\n\nexports.drawMainTitle = function(gd) {\n var fullLayout = gd._fullLayout;\n\n var textAnchor = getMainTitleTextAnchor(fullLayout);\n var dy = getMainTitleDy(fullLayout);\n\n Titles.draw(gd, 'gtitle', {\n propContainer: fullLayout,\n propName: 'title.text',\n placeholder: fullLayout._dfltTitle.plot,\n attributes: {\n x: getMainTitleX(fullLayout, textAnchor),\n y: getMainTitleY(fullLayout, dy),\n 'text-anchor': textAnchor,\n dy: dy\n }\n });\n};\n\nfunction getMainTitleX(fullLayout, textAnchor) {\n var title = fullLayout.title;\n var gs = fullLayout._size;\n var hPadShift = 0;\n\n if(textAnchor === SVG_TEXT_ANCHOR_START) {\n hPadShift = title.pad.l;\n } else if(textAnchor === SVG_TEXT_ANCHOR_END) {\n hPadShift = -title.pad.r;\n }\n\n switch(title.xref) {\n case 'paper':\n return gs.l + gs.w * title.x + hPadShift;\n case 'container':\n default:\n return fullLayout.width * title.x + hPadShift;\n }\n}\n\nfunction getMainTitleY(fullLayout, dy) {\n var title = fullLayout.title;\n var gs = fullLayout._size;\n var vPadShift = 0;\n\n if(dy === '0em' || !dy) {\n vPadShift = -title.pad.b;\n } else if(dy === alignmentConstants.CAP_SHIFT + 'em') {\n vPadShift = title.pad.t;\n }\n\n if(title.y === 'auto') {\n return gs.t / 2;\n } else {\n switch(title.yref) {\n case 'paper':\n return gs.t + gs.h - gs.h * title.y + vPadShift;\n case 'container':\n default:\n return fullLayout.height - fullLayout.height * title.y + vPadShift;\n }\n }\n}\n\nfunction getMainTitleTextAnchor(fullLayout) {\n var title = fullLayout.title;\n\n var textAnchor = SVG_TEXT_ANCHOR_MIDDLE;\n if(Lib.isRightAnchor(title)) {\n textAnchor = SVG_TEXT_ANCHOR_END;\n } else if(Lib.isLeftAnchor(title)) {\n textAnchor = SVG_TEXT_ANCHOR_START;\n }\n\n return textAnchor;\n}\n\nfunction getMainTitleDy(fullLayout) {\n var title = fullLayout.title;\n\n var dy = '0em';\n if(Lib.isTopAnchor(title)) {\n dy = alignmentConstants.CAP_SHIFT + 'em';\n } else if(Lib.isMiddleAnchor(title)) {\n dy = alignmentConstants.MID_SHIFT + 'em';\n }\n\n return dy;\n}\n\nexports.doTraceStyle = function(gd) {\n var calcdata = gd.calcdata;\n var editStyleCalls = [];\n var i;\n\n for(i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var cd0 = cd[0] || {};\n var trace = cd0.trace || {};\n var _module = trace._module || {};\n\n // See if we need to do arraysToCalcdata\n // call it regardless of what change we made, in case\n // supplyDefaults brought in an array that was already\n // in gd.data but not in gd._fullData previously\n var arraysToCalcdata = _module.arraysToCalcdata;\n if(arraysToCalcdata) arraysToCalcdata(cd, trace);\n\n var editStyle = _module.editStyle;\n if(editStyle) editStyleCalls.push({fn: editStyle, cd0: cd0});\n }\n\n if(editStyleCalls.length) {\n for(i = 0; i < editStyleCalls.length; i++) {\n var edit = editStyleCalls[i];\n edit.fn(gd, edit.cd0);\n }\n clearGlCanvases(gd);\n exports.redrawReglTraces(gd);\n }\n\n Plots.style(gd);\n Registry.getComponentMethod('legend', 'draw')(gd);\n\n return Plots.previousPromises(gd);\n};\n\nexports.doColorBars = function(gd) {\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n return Plots.previousPromises(gd);\n};\n\n// force plot() to redo the layout and replot with the modified layout\nexports.layoutReplot = function(gd) {\n var layout = gd.layout;\n gd.layout = undefined;\n return Registry.call('plot', gd, '', layout);\n};\n\nexports.doLegend = function(gd) {\n Registry.getComponentMethod('legend', 'draw')(gd);\n return Plots.previousPromises(gd);\n};\n\nexports.doTicksRelayout = function(gd) {\n Axes.draw(gd, 'redraw');\n\n if(gd._fullLayout._hasOnlyLargeSploms) {\n Registry.subplotsRegistry.splom.updateGrid(gd);\n clearGlCanvases(gd);\n exports.redrawReglTraces(gd);\n }\n\n exports.drawMainTitle(gd);\n return Plots.previousPromises(gd);\n};\n\nexports.doModeBar = function(gd) {\n var fullLayout = gd._fullLayout;\n\n ModeBar.manage(gd);\n\n for(var i = 0; i < fullLayout._basePlotModules.length; i++) {\n var updateFx = fullLayout._basePlotModules[i].updateFx;\n if(updateFx) updateFx(gd);\n }\n\n return Plots.previousPromises(gd);\n};\n\nexports.doCamera = function(gd) {\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d;\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneLayout = fullLayout[sceneIds[i]];\n var scene = sceneLayout._scene;\n\n scene.setViewport(sceneLayout);\n }\n};\n\nexports.drawData = function(gd) {\n var fullLayout = gd._fullLayout;\n\n clearGlCanvases(gd);\n\n // loop over the base plot modules present on graph\n var basePlotModules = fullLayout._basePlotModules;\n for(var i = 0; i < basePlotModules.length; i++) {\n basePlotModules[i].plot(gd);\n }\n\n exports.redrawReglTraces(gd);\n\n // styling separate from drawing\n Plots.style(gd);\n\n // draw components that can be drawn on axes,\n // and that do not push the margins\n Registry.getComponentMethod('shapes', 'draw')(gd);\n Registry.getComponentMethod('annotations', 'draw')(gd);\n Registry.getComponentMethod('images', 'draw')(gd);\n\n // Mark the first render as complete\n fullLayout._replotting = false;\n\n return Plots.previousPromises(gd);\n};\n\n// Draw (or redraw) all regl-based traces in one go,\n// useful during drag and selection where buffers of targeted traces are updated,\n// but all traces need to be redrawn following clearGlCanvases.\n//\n// Note that _module.plot for regl trace does NOT draw things\n// on the canvas, they only update the buffers.\n// Drawing is perform here.\n//\n// TODO try adding per-subplot option using gl.SCISSOR_TEST for\n// non-overlaying, disjoint subplots.\n//\n// TODO try to include parcoords in here.\n// https://github.com/plotly/plotly.js/issues/3069\nexports.redrawReglTraces = function(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._has('regl')) {\n var fullData = gd._fullData;\n var cartesianIds = [];\n var polarIds = [];\n var i, sp;\n\n if(fullLayout._hasOnlyLargeSploms) {\n fullLayout._splomGrid.draw();\n }\n\n // N.B.\n // - Loop over fullData (not _splomScenes) to preserve splom trace-to-trace ordering\n // - Fill list if subplot ids (instead of fullLayout._subplots) to handle cases where all traces\n // of a given module are `visible !== true`\n for(i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(trace.visible === true && trace._length !== 0) {\n if(trace.type === 'splom') {\n fullLayout._splomScenes[trace.uid].draw();\n } else if(trace.type === 'scattergl') {\n Lib.pushUnique(cartesianIds, trace.xaxis + trace.yaxis);\n } else if(trace.type === 'scatterpolargl') {\n Lib.pushUnique(polarIds, trace.subplot);\n }\n }\n }\n\n for(i = 0; i < cartesianIds.length; i++) {\n sp = fullLayout._plots[cartesianIds[i]];\n if(sp._scene) sp._scene.draw();\n }\n\n for(i = 0; i < polarIds.length; i++) {\n sp = fullLayout[polarIds[i]]._subplot;\n if(sp._scene) sp._scene.draw();\n }\n }\n};\n\nexports.doAutoRangeAndConstraints = function(gd) {\n var fullLayout = gd._fullLayout;\n var axList = Axes.list(gd, '', true);\n var matchGroups = fullLayout._axisMatchGroups || [];\n var axLookup = {};\n var ax;\n var axRng;\n\n for(var i = 0; i < axList.length; i++) {\n ax = axList[i];\n cleanAxisConstraints(gd, ax);\n doAutoRange(gd, ax);\n axLookup[ax._id] = 1;\n }\n\n enforceAxisConstraints(gd);\n\n groupLoop:\n for(var j = 0; j < matchGroups.length; j++) {\n var group = matchGroups[j];\n var rng = null;\n var id;\n\n for(id in group) {\n ax = Axes.getFromId(gd, id);\n\n // skip over 'missing' axes which do not pass through doAutoRange\n if(!axLookup[ax._id]) continue;\n // if one axis has autorange false, we're done\n if(ax.autorange === false) continue groupLoop;\n\n axRng = Lib.simpleMap(ax.range, ax.r2l);\n if(rng) {\n if(rng[0] < rng[1]) {\n rng[0] = Math.min(rng[0], axRng[0]);\n rng[1] = Math.max(rng[1], axRng[1]);\n } else {\n rng[0] = Math.max(rng[0], axRng[0]);\n rng[1] = Math.min(rng[1], axRng[1]);\n }\n } else {\n rng = axRng;\n }\n }\n\n for(id in group) {\n ax = Axes.getFromId(gd, id);\n ax.range = Lib.simpleMap(rng, ax.l2r);\n ax._input.range = ax.range.slice();\n ax.setScale();\n }\n }\n};\n\n// An initial paint must be completed before these components can be\n// correctly sized and the whole plot re-margined. fullLayout._replotting must\n// be set to false before these will work properly.\nexports.finalDraw = function(gd) {\n // TODO: rangesliders really belong in marginPushers but they need to be\n // drawn after data - can we at least get the margin pushing part separated\n // out and done earlier?\n Registry.getComponentMethod('rangeslider', 'draw')(gd);\n // TODO: rangeselector only needs to be here (in addition to drawMarginPushers)\n // because the margins need to be fully determined before we can call\n // autorange and update axis ranges (which rangeselector needs to know which\n // button is active). Can we break out its automargin step from its draw step?\n Registry.getComponentMethod('rangeselector', 'draw')(gd);\n};\n\nexports.drawMarginPushers = function(gd) {\n Registry.getComponentMethod('legend', 'draw')(gd);\n Registry.getComponentMethod('rangeselector', 'draw')(gd);\n Registry.getComponentMethod('sliders', 'draw')(gd);\n Registry.getComponentMethod('updatemenus', 'draw')(gd);\n Registry.getComponentMethod('colorbar', 'draw')(gd);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar SHOWISOLATETIP = true;\n\nmodule.exports = function handleClick(g, gd, numClicks) {\n var fullLayout = gd._fullLayout;\n\n if(gd._dragged || gd._editing) return;\n\n var itemClick = fullLayout.legend.itemclick;\n var itemDoubleClick = fullLayout.legend.itemdoubleclick;\n\n if(numClicks === 1 && itemClick === 'toggle' && itemDoubleClick === 'toggleothers' &&\n SHOWISOLATETIP && gd.data && gd._context.showTips\n ) {\n Lib.notifier(Lib._(gd, 'Double-click on legend to isolate one trace'), 'long');\n SHOWISOLATETIP = false;\n } else {\n SHOWISOLATETIP = false;\n }\n\n var mode;\n if(numClicks === 1) mode = itemClick;\n else if(numClicks === 2) mode = itemDoubleClick;\n if(!mode) return;\n\n var hiddenSlices = fullLayout.hiddenlabels ?\n fullLayout.hiddenlabels.slice() :\n [];\n\n var legendItem = g.data()[0][0];\n var fullData = gd._fullData;\n var fullTrace = legendItem.trace;\n var legendgroup = fullTrace.legendgroup;\n\n var i, j, kcont, key, keys, val;\n var attrUpdate = {};\n var attrIndices = [];\n var carrs = [];\n var carrIdx = [];\n\n function insertUpdate(traceIndex, key, value) {\n var attrIndex = attrIndices.indexOf(traceIndex);\n var valueArray = attrUpdate[key];\n if(!valueArray) {\n valueArray = attrUpdate[key] = [];\n }\n\n if(attrIndices.indexOf(traceIndex) === -1) {\n attrIndices.push(traceIndex);\n attrIndex = attrIndices.length - 1;\n }\n\n valueArray[attrIndex] = value;\n\n return attrIndex;\n }\n\n function setVisibility(fullTrace, visibility) {\n var fullInput = fullTrace._fullInput;\n if(Registry.hasTransform(fullInput, 'groupby')) {\n var kcont = carrs[fullInput.index];\n if(!kcont) {\n var groupbyIndices = Registry.getTransformIndices(fullInput, 'groupby');\n var lastGroupbyIndex = groupbyIndices[groupbyIndices.length - 1];\n kcont = Lib.keyedContainer(fullInput, 'transforms[' + lastGroupbyIndex + '].styles', 'target', 'value.visible');\n carrs[fullInput.index] = kcont;\n }\n\n var curState = kcont.get(fullTrace._group);\n\n // If not specified, assume visible. This happens if there are other style\n // properties set for a group but not the visibility. There are many similar\n // ways to do this (e.g. why not just `curState = fullTrace.visible`??? The\n // answer is: because it breaks other things like groupby trace names in\n // subtle ways.)\n if(curState === undefined) {\n curState = true;\n }\n\n if(curState !== false) {\n // true -> legendonly. All others toggle to true:\n kcont.set(fullTrace._group, visibility);\n }\n carrIdx[fullInput.index] = insertUpdate(fullInput.index, 'visible', fullInput.visible === false ? false : true);\n } else {\n // false -> false (not possible since will not be visible in legend)\n // true -> legendonly\n // legendonly -> true\n var nextVisibility = fullInput.visible === false ? false : visibility;\n\n insertUpdate(fullInput.index, 'visible', nextVisibility);\n }\n }\n\n if(Registry.traceIs(fullTrace, 'pie-like')) {\n var thisLabel = legendItem.label;\n var thisLabelIndex = hiddenSlices.indexOf(thisLabel);\n\n if(mode === 'toggle') {\n if(thisLabelIndex === -1) hiddenSlices.push(thisLabel);\n else hiddenSlices.splice(thisLabelIndex, 1);\n } else if(mode === 'toggleothers') {\n hiddenSlices = [];\n gd.calcdata[0].forEach(function(d) {\n if(thisLabel !== d.label) {\n hiddenSlices.push(d.label);\n }\n });\n if(gd._fullLayout.hiddenlabels && gd._fullLayout.hiddenlabels.length === hiddenSlices.length && thisLabelIndex === -1) {\n hiddenSlices = [];\n }\n }\n\n Registry.call('_guiRelayout', gd, 'hiddenlabels', hiddenSlices);\n } else {\n var hasLegendgroup = legendgroup && legendgroup.length;\n var traceIndicesInGroup = [];\n var tracei;\n if(hasLegendgroup) {\n for(i = 0; i < fullData.length; i++) {\n tracei = fullData[i];\n if(!tracei.visible) continue;\n if(tracei.legendgroup === legendgroup) {\n traceIndicesInGroup.push(i);\n }\n }\n }\n\n if(mode === 'toggle') {\n var nextVisibility;\n\n switch(fullTrace.visible) {\n case true:\n nextVisibility = 'legendonly';\n break;\n case false:\n nextVisibility = false;\n break;\n case 'legendonly':\n nextVisibility = true;\n break;\n }\n\n if(hasLegendgroup) {\n for(i = 0; i < fullData.length; i++) {\n if(fullData[i].visible !== false && fullData[i].legendgroup === legendgroup) {\n setVisibility(fullData[i], nextVisibility);\n }\n }\n } else {\n setVisibility(fullTrace, nextVisibility);\n }\n } else if(mode === 'toggleothers') {\n // Compute the clicked index. expandedIndex does what we want for expanded traces\n // but also culls hidden traces. That means we have some work to do.\n var isClicked, isInGroup, notInLegend, otherState;\n var isIsolated = true;\n for(i = 0; i < fullData.length; i++) {\n isClicked = fullData[i] === fullTrace;\n notInLegend = fullData[i].showlegend !== true;\n if(isClicked || notInLegend) continue;\n\n isInGroup = (hasLegendgroup && fullData[i].legendgroup === legendgroup);\n\n if(!isInGroup && fullData[i].visible === true && !Registry.traceIs(fullData[i], 'notLegendIsolatable')) {\n isIsolated = false;\n break;\n }\n }\n\n for(i = 0; i < fullData.length; i++) {\n // False is sticky; we don't change it.\n if(fullData[i].visible === false) continue;\n\n if(Registry.traceIs(fullData[i], 'notLegendIsolatable')) {\n continue;\n }\n\n switch(fullTrace.visible) {\n case 'legendonly':\n setVisibility(fullData[i], true);\n break;\n case true:\n otherState = isIsolated ? true : 'legendonly';\n isClicked = fullData[i] === fullTrace;\n // N.B. consider traces that have a set legendgroup as toggleable\n notInLegend = (fullData[i].showlegend !== true && !fullData[i].legendgroup);\n isInGroup = isClicked || (hasLegendgroup && fullData[i].legendgroup === legendgroup);\n setVisibility(fullData[i], (isInGroup || notInLegend) ? true : otherState);\n break;\n }\n }\n }\n\n for(i = 0; i < carrs.length; i++) {\n kcont = carrs[i];\n if(!kcont) continue;\n var update = kcont.constructUpdate();\n\n var updateKeys = Object.keys(update);\n for(j = 0; j < updateKeys.length; j++) {\n key = updateKeys[j];\n val = attrUpdate[key] = attrUpdate[key] || [];\n val[carrIdx[i]] = update[key];\n }\n }\n\n // The length of the value arrays should be equal and any unspecified\n // values should be explicitly undefined for them to get properly culled\n // as updates and not accidentally reset to the default value. This fills\n // out sparse arrays with the required number of undefined values:\n keys = Object.keys(attrUpdate);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n for(j = 0; j < attrIndices.length; j++) {\n // Use hasOwnPropety to protect against falsey values:\n if(!attrUpdate[key].hasOwnProperty(j)) {\n attrUpdate[key][j] = undefined;\n }\n }\n }\n\n Registry.call('_guiRestyle', gd, attrUpdate, attrIndices);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n cn: {\n colorbar: 'colorbar',\n cbbg: 'cbbg',\n cbfill: 'cbfill',\n cbfills: 'cbfills',\n cbline: 'cbline',\n cblines: 'cblines',\n cbaxis: 'cbaxis',\n cbtitleunshift: 'cbtitleunshift',\n cbtitle: 'cbtitle',\n cboutline: 'cboutline',\n crisp: 'crisp',\n jsPlaceholder: 'js-placeholder'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar styleOne = require('./style_one');\nvar resizeText = require('../bar/uniform_text').resizeText;\n\nmodule.exports = function style(gd) {\n var s = gd._fullLayout._pielayer.selectAll('.trace');\n resizeText(gd, s, 'pie');\n\n s.each(function(cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var traceSelection = d3.select(this);\n\n traceSelection.style({opacity: trace.opacity});\n\n traceSelection.selectAll('path.surface').each(function(pt) {\n d3.select(this).call(styleOne, pt, trace);\n });\n });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\n\nmodule.exports = function formatLabels(cdi, trace, fullLayout) {\n var labels = {};\n\n var mockGd = {_fullLayout: fullLayout};\n var xa = Axes.getFromTrace(mockGd, trace, 'x');\n var ya = Axes.getFromTrace(mockGd, trace, 'y');\n\n labels.xLabel = Axes.tickText(xa, cdi.x, true).text;\n labels.yLabel = Axes.tickText(ya, cdi.y, true).text;\n\n return labels;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar Color = require('../../components/color');\n\nvar extendedColorWayList = {};\n\nfunction calc(gd, trace) {\n var cd = [];\n\n var fullLayout = gd._fullLayout;\n var hiddenLabels = fullLayout.hiddenlabels || [];\n\n var labels = trace.labels;\n var colors = trace.marker.colors || [];\n var vals = trace.values;\n var len = trace._length;\n var hasValues = trace._hasValues && len;\n\n var i, pt;\n\n if(trace.dlabel) {\n labels = new Array(len);\n for(i = 0; i < len; i++) {\n labels[i] = String(trace.label0 + i * trace.dlabel);\n }\n }\n\n var allThisTraceLabels = {};\n var pullColor = makePullColorFn(fullLayout['_' + trace.type + 'colormap']);\n var vTotal = 0;\n var isAggregated = false;\n\n for(i = 0; i < len; i++) {\n var v, label, hidden;\n if(hasValues) {\n v = vals[i];\n if(!isNumeric(v)) continue;\n v = +v;\n if(v < 0) continue;\n } else v = 1;\n\n label = labels[i];\n if(label === undefined || label === '') label = i;\n label = String(label);\n\n var thisLabelIndex = allThisTraceLabels[label];\n if(thisLabelIndex === undefined) {\n allThisTraceLabels[label] = cd.length;\n\n hidden = hiddenLabels.indexOf(label) !== -1;\n\n if(!hidden) vTotal += v;\n\n cd.push({\n v: v,\n label: label,\n color: pullColor(colors[i], label),\n i: i,\n pts: [i],\n hidden: hidden\n });\n } else {\n isAggregated = true;\n\n pt = cd[thisLabelIndex];\n pt.v += v;\n pt.pts.push(i);\n if(!pt.hidden) vTotal += v;\n\n if(pt.color === false && colors[i]) {\n pt.color = pullColor(colors[i], label);\n }\n }\n }\n\n var shouldSort = (trace.type === 'funnelarea') ? isAggregated : trace.sort;\n if(shouldSort) cd.sort(function(a, b) { return b.v - a.v; });\n\n // include the sum of all values in the first point\n if(cd[0]) cd[0].vTotal = vTotal;\n\n return cd;\n}\n\nfunction makePullColorFn(colorMap) {\n return function pullColor(color, id) {\n if(!color) return false;\n\n color = tinycolor(color);\n if(!color.isValid()) return false;\n\n color = Color.addOpacity(color, color.getAlpha());\n if(!colorMap[id]) colorMap[id] = color;\n\n return color;\n };\n}\n\n/*\n * `calc` filled in (and collated) explicit colors.\n * Now we need to propagate these explicit colors to other traces,\n * and fill in default colors.\n * This is done after sorting, so we pick defaults\n * in the order slices will be displayed\n */\nfunction crossTraceCalc(gd, plotinfo) { // TODO: should we name the second argument opts?\n var desiredType = (plotinfo || {}).type;\n if(!desiredType) desiredType = 'pie';\n\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var colorWay = fullLayout[desiredType + 'colorway'];\n var colorMap = fullLayout['_' + desiredType + 'colormap'];\n\n if(fullLayout['extend' + desiredType + 'colors']) {\n colorWay = generateExtendedColors(colorWay, extendedColorWayList);\n }\n var dfltColorCount = 0;\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var traceType = cd[0].trace.type;\n if(traceType !== desiredType) continue;\n\n for(var j = 0; j < cd.length; j++) {\n var pt = cd[j];\n if(pt.color === false) {\n // have we seen this label and assigned a color to it in a previous trace?\n if(colorMap[pt.label]) {\n pt.color = colorMap[pt.label];\n } else {\n colorMap[pt.label] = pt.color = colorWay[dfltColorCount % colorWay.length];\n dfltColorCount++;\n }\n }\n }\n }\n}\n\n/**\n * pick a default color from the main default set, augmented by\n * itself lighter then darker before repeating\n */\nfunction generateExtendedColors(colorList, extendedColorWays) {\n var i;\n var colorString = JSON.stringify(colorList);\n var colors = extendedColorWays[colorString];\n if(!colors) {\n colors = colorList.slice();\n\n for(i = 0; i < colorList.length; i++) {\n colors.push(tinycolor(colorList[i]).lighten(20).toHexString());\n }\n\n for(i = 0; i < colorList.length; i++) {\n colors.push(tinycolor(colorList[i]).darken(20).toHexString());\n }\n extendedColorWays[colorString] = colors;\n }\n\n return colors;\n}\n\nmodule.exports = {\n calc: calc,\n crossTraceCalc: crossTraceCalc,\n\n makePullColorFn: makePullColorFn,\n generateExtendedColors: generateExtendedColors\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n// ASCEND: chop off the last nesting level - either [] or . - to ascend\n// the attribute tree. the remaining attrString is in match[1]\nvar ASCEND = /^(.*)(\\.[^\\.\\[\\]]+|\\[\\d\\])$/;\n\n// SIMPLEATTR: is this an un-nested attribute? (no dots or brackets)\nvar SIMPLEATTR = /^[^\\.\\[\\]]+$/;\n\n/*\n * calculate a relative attribute string, similar to a relative path\n *\n * @param {string} baseAttr:\n * an attribute string, such as 'annotations[3].x'. The \"current location\"\n * is the attribute string minus the last component ('annotations[3]')\n * @param {string} relativeAttr:\n * a route to the desired attribute string, using '^' to ascend\n *\n * @return {string} attrString:\n * for example:\n * relativeAttr('annotations[3].x', 'y') = 'annotations[3].y'\n * relativeAttr('annotations[3].x', '^[2].z') = 'annotations[2].z'\n * relativeAttr('annotations[3].x', '^^margin') = 'margin'\n * relativeAttr('annotations[3].x', '^^margin.r') = 'margin.r'\n */\nmodule.exports = function(baseAttr, relativeAttr) {\n while(relativeAttr) {\n var match = baseAttr.match(ASCEND);\n\n if(match) baseAttr = match[1];\n else if(baseAttr.match(SIMPLEATTR)) baseAttr = '';\n else throw new Error('bad relativeAttr call:' + [baseAttr, relativeAttr]);\n\n if(relativeAttr.charAt(0) === '^') relativeAttr = relativeAttr.slice(1);\n else break;\n }\n\n if(baseAttr && relativeAttr.charAt(0) !== '[') {\n return baseAttr + '.' + relativeAttr;\n }\n return baseAttr + relativeAttr;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n// arrayOk attributes, merge them into calcdata array\nmodule.exports = function arraysToCalcdata(cd, trace) {\n for(var i = 0; i < cd.length; i++) cd[i].i = i;\n\n Lib.mergeArray(trace.text, cd, 'tx');\n Lib.mergeArray(trace.hovertext, cd, 'htx');\n\n var marker = trace.marker;\n if(marker) {\n Lib.mergeArray(marker.opacity, cd, 'mo', true);\n Lib.mergeArray(marker.color, cd, 'mc');\n\n var markerLine = marker.line;\n if(markerLine) {\n Lib.mergeArray(markerLine.color, cd, 'mlc');\n Lib.mergeArrayCastPositive(markerLine.width, cd, 'mlw');\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Color = require('../../components/color');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nvar subTypes = require('./subtypes');\n\n/*\n * opts: object of flags to control features not all marker users support\n * noLine: caller does not support marker lines\n * gradient: caller supports gradients\n * noSelect: caller does not support selected/unselected attribute containers\n */\nmodule.exports = function markerDefaults(traceIn, traceOut, defaultColor, layout, coerce, opts) {\n var isBubble = subTypes.isBubble(traceIn);\n var lineColor = (traceIn.line || {}).color;\n var defaultMLC;\n\n opts = opts || {};\n\n // marker.color inherit from line.color (even if line.color is an array)\n if(lineColor) defaultColor = lineColor;\n\n coerce('marker.symbol');\n coerce('marker.opacity', isBubble ? 0.7 : 1);\n coerce('marker.size');\n\n coerce('marker.color', defaultColor);\n if(hasColorscale(traceIn, 'marker')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'});\n }\n\n if(!opts.noSelect) {\n coerce('selected.marker.color');\n coerce('unselected.marker.color');\n coerce('selected.marker.size');\n coerce('unselected.marker.size');\n }\n\n if(!opts.noLine) {\n // if there's a line with a different color than the marker, use\n // that line color as the default marker line color\n // (except when it's an array)\n // mostly this is for transparent markers to behave nicely\n if(lineColor && !Array.isArray(lineColor) && (traceOut.marker.color !== lineColor)) {\n defaultMLC = lineColor;\n } else if(isBubble) defaultMLC = Color.background;\n else defaultMLC = Color.defaultLine;\n\n coerce('marker.line.color', defaultMLC);\n if(hasColorscale(traceIn, 'marker.line')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'marker.line.', cLetter: 'c'});\n }\n\n coerce('marker.line.width', isBubble ? 1 : 0);\n }\n\n if(isBubble) {\n coerce('marker.sizeref');\n coerce('marker.sizemin');\n coerce('marker.sizemode');\n }\n\n if(opts.gradient) {\n var gradientType = coerce('marker.gradient.type');\n if(gradientType !== 'none') {\n coerce('marker.gradient.color');\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar cleanNumber = Lib.cleanNumber;\nvar ms2DateTime = Lib.ms2DateTime;\nvar dateTime2ms = Lib.dateTime2ms;\nvar ensureNumber = Lib.ensureNumber;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\n\nvar numConstants = require('../../constants/numerical');\nvar FP_SAFE = numConstants.FP_SAFE;\nvar BADNUM = numConstants.BADNUM;\nvar LOG_CLIP = numConstants.LOG_CLIP;\nvar ONEDAY = numConstants.ONEDAY;\nvar ONEHOUR = numConstants.ONEHOUR;\nvar ONEMIN = numConstants.ONEMIN;\nvar ONESEC = numConstants.ONESEC;\n\nvar axisIds = require('./axis_ids');\n\nvar constants = require('./constants');\nvar HOUR_PATTERN = constants.HOUR_PATTERN;\nvar WEEKDAY_PATTERN = constants.WEEKDAY_PATTERN;\n\nfunction fromLog(v) {\n return Math.pow(10, v);\n}\n\nfunction isValidCategory(v) {\n return v !== null && v !== undefined;\n}\n\n/**\n * Define the conversion functions for an axis data is used in 5 ways:\n *\n * d: data, in whatever form it's provided\n * c: calcdata: turned into numbers, but not linearized\n * l: linearized - same as c except for log axes (and other nonlinear\n * mappings later?) this is used when we need to know if it's\n * *possible* to show some data on this axis, without caring about\n * the current range\n * p: pixel value - mapped to the screen with current size and zoom\n * r: ranges, tick0, and annotation positions match one of the above\n * but are handled differently for different types:\n * - linear and date: data format (d)\n * - category: calcdata format (c), and will stay that way because\n * the data format has no continuous mapping\n * - log: linearized (l) format\n * TODO: in v2.0 we plan to change it to data format. At that point\n * shapes will work the same way as ranges, tick0, and annotations\n * so they can use this conversion too.\n *\n * Creates/updates these conversion functions, and a few more utilities\n * like cleanRange, and makeCalcdata\n *\n * also clears the autotick constraints ._minDtick, ._forceTick0\n */\nmodule.exports = function setConvert(ax, fullLayout) {\n fullLayout = fullLayout || {};\n\n var axId = (ax._id || 'x');\n var axLetter = axId.charAt(0);\n\n function toLog(v, clip) {\n if(v > 0) return Math.log(v) / Math.LN10;\n\n else if(v <= 0 && clip && ax.range && ax.range.length === 2) {\n // clip NaN (ie past negative infinity) to LOG_CLIP axis\n // length past the negative edge\n var r0 = ax.range[0];\n var r1 = ax.range[1];\n return 0.5 * (r0 + r1 - 2 * LOG_CLIP * Math.abs(r0 - r1));\n } else return BADNUM;\n }\n\n /*\n * wrapped dateTime2ms that:\n * - accepts ms numbers for backward compatibility\n * - inserts a dummy arg so calendar is the 3rd arg (see notes below).\n * - defaults to ax.calendar\n */\n function dt2ms(v, _, calendar) {\n // NOTE: Changed this behavior: previously we took any numeric value\n // to be a ms, even if it was a string that could be a bare year.\n // Now we convert it as a date if at all possible, and only try\n // as (local) ms if that fails.\n var ms = dateTime2ms(v, calendar || ax.calendar);\n if(ms === BADNUM) {\n if(isNumeric(v)) {\n v = +v;\n // keep track of tenths of ms, that `new Date` will drop\n // same logic as in Lib.ms2DateTime\n var msecTenths = Math.floor(Lib.mod(v + 0.05, 1) * 10);\n var msRounded = Math.round(v - msecTenths / 10);\n ms = dateTime2ms(new Date(msRounded)) + msecTenths / 10;\n } else return BADNUM;\n }\n return ms;\n }\n\n // wrapped ms2DateTime to insert default ax.calendar\n function ms2dt(v, r, calendar) {\n return ms2DateTime(v, r, calendar || ax.calendar);\n }\n\n function getCategoryName(v) {\n return ax._categories[Math.round(v)];\n }\n\n /*\n * setCategoryIndex: return the index of category v,\n * inserting it in the list if it's not already there\n *\n * this will enter the categories in the order it\n * encounters them, ie all the categories from the\n * first data set, then all the ones from the second\n * that aren't in the first etc.\n *\n * it is assumed that this function is being invoked in the\n * already sorted category order; otherwise there would be\n * a disconnect between the array and the index returned\n */\n function setCategoryIndex(v) {\n if(isValidCategory(v)) {\n if(ax._categoriesMap === undefined) {\n ax._categoriesMap = {};\n }\n\n if(ax._categoriesMap[v] !== undefined) {\n return ax._categoriesMap[v];\n } else {\n ax._categories.push(typeof v === 'number' ? String(v) : v);\n\n var curLength = ax._categories.length - 1;\n ax._categoriesMap[v] = curLength;\n\n return curLength;\n }\n }\n return BADNUM;\n }\n\n function setMultiCategoryIndex(arrayIn, len) {\n var arrayOut = new Array(len);\n\n for(var i = 0; i < len; i++) {\n var v0 = (arrayIn[0] || [])[i];\n var v1 = (arrayIn[1] || [])[i];\n arrayOut[i] = getCategoryIndex([v0, v1]);\n }\n\n return arrayOut;\n }\n\n function getCategoryIndex(v) {\n if(ax._categoriesMap) {\n return ax._categoriesMap[v];\n }\n }\n\n function getCategoryPosition(v) {\n // d2l/d2c variant that that won't add categories but will also\n // allow numbers to be mapped to the linearized axis positions\n var index = getCategoryIndex(v);\n if(index !== undefined) return index;\n if(isNumeric(v)) return +v;\n }\n\n // include 2 fractional digits on pixel, for PDF zooming etc\n function _l2p(v, m, b) { return d3.round(b + m * v, 2); }\n\n function _p2l(px, m, b) { return (px - b) / m; }\n\n var l2p = function l2p(v) {\n if(!isNumeric(v)) return BADNUM;\n return _l2p(v, ax._m, ax._b);\n };\n\n var p2l = function(px) {\n return _p2l(px, ax._m, ax._b);\n };\n\n if(ax.rangebreaks) {\n var isY = axLetter === 'y';\n\n l2p = function(v) {\n if(!isNumeric(v)) return BADNUM;\n var len = ax._rangebreaks.length;\n if(!len) return _l2p(v, ax._m, ax._b);\n\n var flip = isY;\n if(ax.range[0] > ax.range[1]) flip = !flip;\n var signAx = flip ? -1 : 1;\n var pos = signAx * v;\n\n var q = 0;\n for(var i = 0; i < len; i++) {\n var min = signAx * ax._rangebreaks[i].min;\n var max = signAx * ax._rangebreaks[i].max;\n\n if(pos < min) break;\n if(pos > max) q = i + 1;\n else {\n // when falls into break, pick 'closest' offset\n q = pos < (min + max) / 2 ? i : i + 1;\n break;\n }\n }\n var b2 = ax._B[q] || 0;\n if(!isFinite(b2)) return 0; // avoid NaN translate e.g. in positionLabels if one keep zooming exactly into a break\n return _l2p(v, ax._m2, b2);\n };\n\n p2l = function(px) {\n var len = ax._rangebreaks.length;\n if(!len) return _p2l(px, ax._m, ax._b);\n\n var q = 0;\n for(var i = 0; i < len; i++) {\n if(px < ax._rangebreaks[i].pmin) break;\n if(px > ax._rangebreaks[i].pmax) q = i + 1;\n }\n return _p2l(px, ax._m2, ax._B[q]);\n };\n }\n\n // conversions among c/l/p are fairly simple - do them together for all axis types\n ax.c2l = (ax.type === 'log') ? toLog : ensureNumber;\n ax.l2c = (ax.type === 'log') ? fromLog : ensureNumber;\n\n ax.l2p = l2p;\n ax.p2l = p2l;\n\n ax.c2p = (ax.type === 'log') ? function(v, clip) { return l2p(toLog(v, clip)); } : l2p;\n ax.p2c = (ax.type === 'log') ? function(px) { return fromLog(p2l(px)); } : p2l;\n\n /*\n * now type-specific conversions for **ALL** other combinations\n * they're all written out, instead of being combinations of each other, for\n * both clarity and speed.\n */\n if(['linear', '-'].indexOf(ax.type) !== -1) {\n // all are data vals, but d and r need cleaning\n ax.d2r = ax.r2d = ax.d2c = ax.r2c = ax.d2l = ax.r2l = cleanNumber;\n ax.c2d = ax.c2r = ax.l2d = ax.l2r = ensureNumber;\n\n ax.d2p = ax.r2p = function(v) { return ax.l2p(cleanNumber(v)); };\n ax.p2d = ax.p2r = p2l;\n\n ax.cleanPos = ensureNumber;\n } else if(ax.type === 'log') {\n // d and c are data vals, r and l are logged (but d and r need cleaning)\n ax.d2r = ax.d2l = function(v, clip) { return toLog(cleanNumber(v), clip); };\n ax.r2d = ax.r2c = function(v) { return fromLog(cleanNumber(v)); };\n\n ax.d2c = ax.r2l = cleanNumber;\n ax.c2d = ax.l2r = ensureNumber;\n\n ax.c2r = toLog;\n ax.l2d = fromLog;\n\n ax.d2p = function(v, clip) { return ax.l2p(ax.d2r(v, clip)); };\n ax.p2d = function(px) { return fromLog(p2l(px)); };\n\n ax.r2p = function(v) { return ax.l2p(cleanNumber(v)); };\n ax.p2r = p2l;\n\n ax.cleanPos = ensureNumber;\n } else if(ax.type === 'date') {\n // r and d are date strings, l and c are ms\n\n /*\n * Any of these functions with r and d on either side, calendar is the\n * **3rd** argument. log has reserved the second argument.\n *\n * Unless you need the special behavior of the second arg (ms2DateTime\n * uses this to limit precision, toLog uses true to clip negatives\n * to offscreen low rather than undefined), it's safe to pass 0.\n */\n ax.d2r = ax.r2d = Lib.identity;\n\n ax.d2c = ax.r2c = ax.d2l = ax.r2l = dt2ms;\n ax.c2d = ax.c2r = ax.l2d = ax.l2r = ms2dt;\n\n ax.d2p = ax.r2p = function(v, _, calendar) { return ax.l2p(dt2ms(v, 0, calendar)); };\n ax.p2d = ax.p2r = function(px, r, calendar) { return ms2dt(p2l(px), r, calendar); };\n\n ax.cleanPos = function(v) { return Lib.cleanDate(v, BADNUM, ax.calendar); };\n } else if(ax.type === 'category') {\n // d is categories (string)\n // c and l are indices (numbers)\n // r is categories or numbers\n\n ax.d2c = ax.d2l = setCategoryIndex;\n ax.r2d = ax.c2d = ax.l2d = getCategoryName;\n\n ax.d2r = ax.d2l_noadd = getCategoryPosition;\n\n ax.r2c = function(v) {\n var index = getCategoryPosition(v);\n return index !== undefined ? index : ax.fraction2r(0.5);\n };\n\n ax.l2r = ax.c2r = ensureNumber;\n ax.r2l = getCategoryPosition;\n\n ax.d2p = function(v) { return ax.l2p(ax.r2c(v)); };\n ax.p2d = function(px) { return getCategoryName(p2l(px)); };\n ax.r2p = ax.d2p;\n ax.p2r = p2l;\n\n ax.cleanPos = function(v) {\n if(typeof v === 'string' && v !== '') return v;\n return ensureNumber(v);\n };\n } else if(ax.type === 'multicategory') {\n // N.B. multicategory axes don't define d2c and d2l,\n // as 'data-to-calcdata' conversion needs to take into\n // account all data array items as in ax.makeCalcdata.\n\n ax.r2d = ax.c2d = ax.l2d = getCategoryName;\n ax.d2r = ax.d2l_noadd = getCategoryPosition;\n\n ax.r2c = function(v) {\n var index = getCategoryPosition(v);\n return index !== undefined ? index : ax.fraction2r(0.5);\n };\n\n ax.r2c_just_indices = getCategoryIndex;\n\n ax.l2r = ax.c2r = ensureNumber;\n ax.r2l = getCategoryPosition;\n\n ax.d2p = function(v) { return ax.l2p(ax.r2c(v)); };\n ax.p2d = function(px) { return getCategoryName(p2l(px)); };\n ax.r2p = ax.d2p;\n ax.p2r = p2l;\n\n ax.cleanPos = function(v) {\n if(Array.isArray(v) || (typeof v === 'string' && v !== '')) return v;\n return ensureNumber(v);\n };\n\n ax.setupMultiCategory = function(fullData) {\n var traceIndices = ax._traceIndices;\n var i, j;\n\n var matchGroups = fullLayout._axisMatchGroups;\n if(matchGroups && matchGroups.length && ax._categories.length === 0) {\n for(i = 0; i < matchGroups.length; i++) {\n var group = matchGroups[i];\n if(group[axId]) {\n for(var axId2 in group) {\n if(axId2 !== axId) {\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n traceIndices = traceIndices.concat(ax2._traceIndices);\n }\n }\n }\n }\n }\n\n // [ [cnt, {$cat: index}], for 1,2 ]\n var seen = [[0, {}], [0, {}]];\n // [ [arrayIn[0][i], arrayIn[1][i]], for i .. N ]\n var list = [];\n\n for(i = 0; i < traceIndices.length; i++) {\n var trace = fullData[traceIndices[i]];\n\n if(axLetter in trace) {\n var arrayIn = trace[axLetter];\n var len = trace._length || Lib.minRowLength(arrayIn);\n\n if(isArrayOrTypedArray(arrayIn[0]) && isArrayOrTypedArray(arrayIn[1])) {\n for(j = 0; j < len; j++) {\n var v0 = arrayIn[0][j];\n var v1 = arrayIn[1][j];\n\n if(isValidCategory(v0) && isValidCategory(v1)) {\n list.push([v0, v1]);\n\n if(!(v0 in seen[0][1])) {\n seen[0][1][v0] = seen[0][0]++;\n }\n if(!(v1 in seen[1][1])) {\n seen[1][1][v1] = seen[1][0]++;\n }\n }\n }\n }\n }\n }\n\n list.sort(function(a, b) {\n var ind0 = seen[0][1];\n var d = ind0[a[0]] - ind0[b[0]];\n if(d) return d;\n\n var ind1 = seen[1][1];\n return ind1[a[1]] - ind1[b[1]];\n });\n\n for(i = 0; i < list.length; i++) {\n setCategoryIndex(list[i]);\n }\n };\n }\n\n // find the range value at the specified (linear) fraction of the axis\n ax.fraction2r = function(v) {\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n return ax.l2r(rl0 + v * (rl1 - rl0));\n };\n\n // find the fraction of the range at the specified range value\n ax.r2fraction = function(v) {\n var rl0 = ax.r2l(ax.range[0]);\n var rl1 = ax.r2l(ax.range[1]);\n return (ax.r2l(v) - rl0) / (rl1 - rl0);\n };\n\n /*\n * cleanRange: make sure range is a couplet of valid & distinct values\n * keep numbers away from the limits of floating point numbers,\n * and dates away from the ends of our date system (+/- 9999 years)\n *\n * optional param rangeAttr: operate on a different attribute, like\n * ax._r, rather than ax.range\n */\n ax.cleanRange = function(rangeAttr, opts) {\n if(!opts) opts = {};\n if(!rangeAttr) rangeAttr = 'range';\n\n var range = Lib.nestedProperty(ax, rangeAttr).get();\n var i, dflt;\n\n if(ax.type === 'date') dflt = Lib.dfltRange(ax.calendar);\n else if(axLetter === 'y') dflt = constants.DFLTRANGEY;\n else dflt = opts.dfltRange || constants.DFLTRANGEX;\n\n // make sure we don't later mutate the defaults\n dflt = dflt.slice();\n\n if(ax.rangemode === 'tozero' || ax.rangemode === 'nonnegative') {\n dflt[0] = 0;\n }\n\n if(!range || range.length !== 2) {\n Lib.nestedProperty(ax, rangeAttr).set(dflt);\n return;\n }\n\n if(ax.type === 'date' && !ax.autorange) {\n // check if milliseconds or js date objects are provided for range\n // and convert to date strings\n range[0] = Lib.cleanDate(range[0], BADNUM, ax.calendar);\n range[1] = Lib.cleanDate(range[1], BADNUM, ax.calendar);\n }\n\n for(i = 0; i < 2; i++) {\n if(ax.type === 'date') {\n if(!Lib.isDateTime(range[i], ax.calendar)) {\n ax[rangeAttr] = dflt;\n break;\n }\n\n if(ax.r2l(range[0]) === ax.r2l(range[1])) {\n // split by +/- 1 second\n var linCenter = Lib.constrain(ax.r2l(range[0]),\n Lib.MIN_MS + 1000, Lib.MAX_MS - 1000);\n range[0] = ax.l2r(linCenter - 1000);\n range[1] = ax.l2r(linCenter + 1000);\n break;\n }\n } else {\n if(!isNumeric(range[i])) {\n if(isNumeric(range[1 - i])) {\n range[i] = range[1 - i] * (i ? 10 : 0.1);\n } else {\n ax[rangeAttr] = dflt;\n break;\n }\n }\n\n if(range[i] < -FP_SAFE) range[i] = -FP_SAFE;\n else if(range[i] > FP_SAFE) range[i] = FP_SAFE;\n\n if(range[0] === range[1]) {\n // somewhat arbitrary: split by 1 or 1ppm, whichever is bigger\n var inc = Math.max(1, Math.abs(range[0] * 1e-6));\n range[0] -= inc;\n range[1] += inc;\n }\n }\n }\n };\n\n // set scaling to pixels\n ax.setScale = function(usePrivateRange) {\n var gs = fullLayout._size;\n\n // make sure we have a domain (pull it in from the axis\n // this one is overlaying if necessary)\n if(ax.overlaying) {\n var ax2 = axisIds.getFromId({ _fullLayout: fullLayout }, ax.overlaying);\n ax.domain = ax2.domain;\n }\n\n // While transitions are occurring, we get a double-transform\n // issue if we transform the drawn layer *and* use the new axis range to\n // draw the data. This allows us to construct setConvert using the pre-\n // interaction values of the range:\n var rangeAttr = (usePrivateRange && ax._r) ? '_r' : 'range';\n var calendar = ax.calendar;\n ax.cleanRange(rangeAttr);\n\n var rl0 = ax.r2l(ax[rangeAttr][0], calendar);\n var rl1 = ax.r2l(ax[rangeAttr][1], calendar);\n\n var isY = axLetter === 'y';\n if(isY) {\n ax._offset = gs.t + (1 - ax.domain[1]) * gs.h;\n ax._length = gs.h * (ax.domain[1] - ax.domain[0]);\n ax._m = ax._length / (rl0 - rl1);\n ax._b = -ax._m * rl1;\n } else {\n ax._offset = gs.l + ax.domain[0] * gs.w;\n ax._length = gs.w * (ax.domain[1] - ax.domain[0]);\n ax._m = ax._length / (rl1 - rl0);\n ax._b = -ax._m * rl0;\n }\n\n // set of \"N\" disjoint rangebreaks inside the range\n ax._rangebreaks = [];\n // length of these rangebreaks in value space - negative on reversed axes\n ax._lBreaks = 0;\n // l2p slope (same for all intervals)\n ax._m2 = 0;\n // set of l2p offsets (one for each of the (N+1) piecewise intervals)\n ax._B = [];\n\n if(ax.rangebreaks) {\n var i, brk;\n\n ax._rangebreaks = ax.locateBreaks(\n Math.min(rl0, rl1),\n Math.max(rl0, rl1)\n );\n\n if(ax._rangebreaks.length) {\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n ax._lBreaks += Math.abs(brk.max - brk.min);\n }\n\n var flip = isY;\n if(rl0 > rl1) flip = !flip;\n if(flip) ax._rangebreaks.reverse();\n var sign = flip ? -1 : 1;\n\n ax._m2 = sign * ax._length / (Math.abs(rl1 - rl0) - ax._lBreaks);\n ax._B.push(-ax._m2 * (isY ? rl1 : rl0));\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n ax._B.push(\n ax._B[ax._B.length - 1] -\n sign * ax._m2 * (brk.max - brk.min)\n );\n }\n\n // fill pixel (i.e. 'p') min/max here,\n // to not have to loop through the _rangebreaks twice during `p2l`\n for(i = 0; i < ax._rangebreaks.length; i++) {\n brk = ax._rangebreaks[i];\n brk.pmin = l2p(brk.min);\n brk.pmax = l2p(brk.max);\n }\n }\n }\n\n if(!isFinite(ax._m) || !isFinite(ax._b) || ax._length < 0) {\n fullLayout._replotting = false;\n throw new Error('Something went wrong with axis scaling');\n }\n };\n\n ax.maskBreaks = function(v) {\n var rangebreaksIn = ax.rangebreaks || [];\n var bnds, b0, b1, vb, vDate;\n\n for(var i = 0; i < rangebreaksIn.length; i++) {\n var brk = rangebreaksIn[i];\n\n if(brk.enabled) {\n if(brk.bounds) {\n var pattern = brk.pattern;\n bnds = Lib.simpleMap(brk.bounds, pattern ?\n cleanNumber :\n ax.d2c // case of pattern: ''\n );\n b0 = bnds[0];\n b1 = bnds[1];\n\n switch(pattern) {\n case WEEKDAY_PATTERN:\n vDate = new Date(v);\n vb = vDate.getUTCDay();\n\n if(b0 > b1) {\n b1 += 7;\n if(vb < b0) vb += 7;\n }\n\n break;\n case HOUR_PATTERN:\n vDate = new Date(v);\n var hours = vDate.getUTCHours();\n var minutes = vDate.getUTCMinutes();\n var seconds = vDate.getUTCSeconds();\n var milliseconds = vDate.getUTCMilliseconds();\n\n vb = hours + (\n minutes / 60 +\n seconds / 3600 +\n milliseconds / 3600000\n );\n\n if(b0 > b1) {\n b1 += 24;\n if(vb < b0) vb += 24;\n }\n\n break;\n case '':\n // N.B. should work on date axes as well!\n // e.g. { bounds: ['2020-01-04', '2020-01-05 23:59'] }\n // TODO should work with reversed-range axes\n vb = v;\n break;\n }\n\n if(vb >= b0 && vb < b1) return BADNUM;\n } else {\n var vals = Lib.simpleMap(brk.values, ax.d2c).sort(Lib.sorterAsc);\n for(var j = 0; j < vals.length; j++) {\n b0 = vals[j];\n b1 = b0 + brk.dvalue;\n if(v >= b0 && v < b1) return BADNUM;\n }\n }\n }\n }\n return v;\n };\n\n ax.locateBreaks = function(r0, r1) {\n var i, bnds, b0, b1;\n\n var rangebreaksOut = [];\n if(!ax.rangebreaks) return rangebreaksOut;\n\n var rangebreaksIn = ax.rangebreaks.slice().sort(function(a, b) {\n if(a.pattern === WEEKDAY_PATTERN && b.pattern === HOUR_PATTERN) return -1;\n if(b.pattern === WEEKDAY_PATTERN && a.pattern === HOUR_PATTERN) return 1;\n return 0;\n });\n\n var addBreak = function(min, max) {\n min = Lib.constrain(min, r0, r1);\n max = Lib.constrain(max, r0, r1);\n if(min === max) return;\n\n var isNewBreak = true;\n for(var j = 0; j < rangebreaksOut.length; j++) {\n var brkj = rangebreaksOut[j];\n if(min > brkj.max || max < brkj.min) {\n // potentially a new break\n } else {\n if(min < brkj.min) {\n brkj.min = min;\n }\n if(max > brkj.max) {\n brkj.max = max;\n }\n isNewBreak = false;\n }\n }\n if(isNewBreak) {\n rangebreaksOut.push({min: min, max: max});\n }\n };\n\n for(i = 0; i < rangebreaksIn.length; i++) {\n var brk = rangebreaksIn[i];\n\n if(brk.enabled) {\n if(brk.bounds) {\n var t0 = r0;\n var t1 = r1;\n if(brk.pattern) {\n // to remove decimal (most often found in auto ranges)\n t0 = Math.floor(t0);\n }\n\n bnds = Lib.simpleMap(brk.bounds, brk.pattern ? cleanNumber : ax.r2l);\n b0 = bnds[0];\n b1 = bnds[1];\n\n // r0 value as date\n var t0Date = new Date(t0);\n // r0 value for break pattern\n var bndDelta;\n // step in ms between rangebreaks\n var step;\n\n switch(brk.pattern) {\n case WEEKDAY_PATTERN:\n step = 7 * ONEDAY;\n\n bndDelta = (\n (b1 < b0 ? 7 : 0) +\n (b1 - b0)\n ) * ONEDAY;\n\n t0 += b0 * ONEDAY - (\n t0Date.getUTCDay() * ONEDAY +\n t0Date.getUTCHours() * ONEHOUR +\n t0Date.getUTCMinutes() * ONEMIN +\n t0Date.getUTCSeconds() * ONESEC +\n t0Date.getUTCMilliseconds()\n );\n break;\n case HOUR_PATTERN:\n step = ONEDAY;\n\n bndDelta = (\n (b1 < b0 ? 24 : 0) +\n (b1 - b0)\n ) * ONEHOUR;\n\n t0 += b0 * ONEHOUR - (\n t0Date.getUTCHours() * ONEHOUR +\n t0Date.getUTCMinutes() * ONEMIN +\n t0Date.getUTCSeconds() * ONESEC +\n t0Date.getUTCMilliseconds()\n );\n break;\n default:\n t0 = Math.min(bnds[0], bnds[1]);\n t1 = Math.max(bnds[0], bnds[1]);\n step = t1 - t0;\n bndDelta = step;\n }\n\n for(var t = t0; t < t1; t += step) {\n addBreak(t, t + bndDelta);\n }\n } else {\n var vals = Lib.simpleMap(brk.values, ax.d2c);\n for(var j = 0; j < vals.length; j++) {\n b0 = vals[j];\n b1 = b0 + brk.dvalue;\n addBreak(b0, b1);\n }\n }\n }\n }\n\n rangebreaksOut.sort(function(a, b) { return a.min - b.min; });\n\n return rangebreaksOut;\n };\n\n // makeCalcdata: takes an x or y array and converts it\n // to a position on the axis object \"ax\"\n // inputs:\n // trace - a data object from gd.data\n // axLetter - a string, either 'x' or 'y', for which item\n // to convert (TODO: is this now always the same as\n // the first letter of ax._id?)\n // in case the expected data isn't there, make a list of\n // integers based on the opposite data\n ax.makeCalcdata = function(trace, axLetter) {\n var arrayIn, arrayOut, i, len;\n\n var axType = ax.type;\n var cal = axType === 'date' && trace[axLetter + 'calendar'];\n\n if(axLetter in trace) {\n arrayIn = trace[axLetter];\n len = trace._length || Lib.minRowLength(arrayIn);\n\n if(Lib.isTypedArray(arrayIn) && (axType === 'linear' || axType === 'log')) {\n if(len === arrayIn.length) {\n return arrayIn;\n } else if(arrayIn.subarray) {\n return arrayIn.subarray(0, len);\n }\n }\n\n if(axType === 'multicategory') {\n return setMultiCategoryIndex(arrayIn, len);\n }\n\n arrayOut = new Array(len);\n for(i = 0; i < len; i++) {\n arrayOut[i] = ax.d2c(arrayIn[i], 0, cal);\n }\n } else {\n var v0 = ((axLetter + '0') in trace) ? ax.d2c(trace[axLetter + '0'], 0, cal) : 0;\n var dv = (trace['d' + axLetter]) ? Number(trace['d' + axLetter]) : 1;\n\n // the opposing data, for size if we have x and dx etc\n arrayIn = trace[{x: 'y', y: 'x'}[axLetter]];\n len = trace._length || arrayIn.length;\n arrayOut = new Array(len);\n\n for(i = 0; i < len; i++) {\n arrayOut[i] = v0 + i * dv;\n }\n }\n\n // mask (i.e. set to BADNUM) coords that fall inside rangebreaks\n if(ax.rangebreaks) {\n for(i = 0; i < len; i++) {\n arrayOut[i] = ax.maskBreaks(arrayOut[i]);\n }\n }\n\n return arrayOut;\n };\n\n ax.isValidRange = function(range) {\n return (\n Array.isArray(range) &&\n range.length === 2 &&\n isNumeric(ax.r2l(range[0])) &&\n isNumeric(ax.r2l(range[1]))\n );\n };\n\n ax.isPtWithinRange = function(d, calendar) {\n var coord = ax.c2l(d[axLetter], null, calendar);\n var r0 = ax.r2l(ax.range[0]);\n var r1 = ax.r2l(ax.range[1]);\n\n if(r0 < r1) {\n return r0 <= coord && coord <= r1;\n } else {\n // Reversed axis case.\n return r1 <= coord && coord <= r0;\n }\n };\n\n // should skip if not category nor multicategory\n ax.clearCalc = function() {\n var emptyCategories = function() {\n ax._categories = [];\n ax._categoriesMap = {};\n };\n\n var matchGroups = fullLayout._axisMatchGroups;\n\n if(matchGroups && matchGroups.length) {\n var found = false;\n\n for(var i = 0; i < matchGroups.length; i++) {\n var group = matchGroups[i];\n\n if(group[axId]) {\n found = true;\n var categories = null;\n var categoriesMap = null;\n\n for(var axId2 in group) {\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n if(ax2._categories) {\n categories = ax2._categories;\n categoriesMap = ax2._categoriesMap;\n break;\n }\n }\n\n if(categories && categoriesMap) {\n ax._categories = categories;\n ax._categoriesMap = categoriesMap;\n } else {\n emptyCategories();\n }\n break;\n }\n }\n if(!found) emptyCategories();\n } else {\n emptyCategories();\n }\n\n if(ax._initialCategories) {\n for(var j = 0; j < ax._initialCategories.length; j++) {\n setCategoryIndex(ax._initialCategories[j]);\n }\n }\n };\n\n // sort the axis (and all the matching ones) by _initialCategories\n // returns the indices of the traces affected by the reordering\n ax.sortByInitialCategories = function() {\n var affectedTraces = [];\n var emptyCategories = function() {\n ax._categories = [];\n ax._categoriesMap = {};\n };\n\n emptyCategories();\n\n if(ax._initialCategories) {\n for(var j = 0; j < ax._initialCategories.length; j++) {\n setCategoryIndex(ax._initialCategories[j]);\n }\n }\n\n affectedTraces = affectedTraces.concat(ax._traceIndices);\n\n // Propagate to matching axes\n var group = ax._matchGroup;\n for(var axId2 in group) {\n if(axId === axId2) continue;\n var ax2 = fullLayout[axisIds.id2name(axId2)];\n ax2._categories = ax._categories;\n ax2._categoriesMap = ax._categoriesMap;\n affectedTraces = affectedTraces.concat(ax2._traceIndices);\n }\n return affectedTraces;\n };\n\n // Propagate localization into the axis so that\n // methods in Axes can use it w/o having to pass fullLayout\n // Default (non-d3) number formatting uses separators directly\n // dates and d3-formatted numbers use the d3 locale\n // Fall back on default format for dummy axes that don't care about formatting\n var locale = fullLayout._d3locale;\n if(ax.type === 'date') {\n ax._dateFormat = locale ? locale.timeFormat.utc : d3.time.format.utc;\n ax._extraFormat = fullLayout._extraFormat;\n }\n // occasionally we need _numFormat to pass through\n // even though it won't be needed by this axis\n ax._separators = fullLayout.separators;\n ax._numFormat = locale ? locale.numberFormat : d3.format;\n\n // and for bar charts and box plots: reset forced minimum tick spacing\n delete ax._minDtick;\n delete ax._forceTick0;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Loggers = require('./lib/loggers');\nvar noop = require('./lib/noop');\nvar pushUnique = require('./lib/push_unique');\nvar isPlainObject = require('./lib/is_plain_object');\nvar addStyleRule = require('./lib/dom').addStyleRule;\nvar ExtendModule = require('./lib/extend');\n\nvar basePlotAttributes = require('./plots/attributes');\nvar baseLayoutAttributes = require('./plots/layout_attributes');\n\nvar extendFlat = ExtendModule.extendFlat;\nvar extendDeepAll = ExtendModule.extendDeepAll;\n\nexports.modules = {};\nexports.allCategories = {};\nexports.allTypes = [];\nexports.subplotsRegistry = {};\nexports.transformsRegistry = {};\nexports.componentsRegistry = {};\nexports.layoutArrayContainers = [];\nexports.layoutArrayRegexes = [];\nexports.traceLayoutAttributes = {};\nexports.localeRegistry = {};\nexports.apiMethodRegistry = {};\nexports.collectableSubplotTypes = null;\n\n/**\n * Top-level register routine, exported as Plotly.register\n *\n * @param {object array or array of objects} _modules :\n * module object or list of module object to register.\n *\n * A valid `moduleType: 'trace'` module has fields:\n * - name {string} : the trace type\n * - categories {array} : categories associated with this trace type,\n * tested with Register.traceIs()\n * - meta {object} : meta info (mostly for plot-schema)\n *\n * A valid `moduleType: 'locale'` module has fields:\n * - name {string} : the locale name. Should be a 2-digit language string ('en', 'de')\n * optionally with a country/region code ('en-GB', 'de-CH'). If a country\n * code is used but the base language locale has not yet been supplied,\n * we will use this locale for the base as well.\n * - dictionary {object} : the dictionary mapping input strings to localized strings\n * generally the keys should be the literal input strings, but\n * if default translations are provided you can use any string as a key.\n * - format {object} : a `d3.locale` format specifier for this locale\n * any omitted keys we'll fall back on en-US.\n *\n * A valid `moduleType: 'transform'` module has fields:\n * - name {string} : transform name\n * - transform {function} : default-level transform function\n * - calcTransform {function} : calc-level transform function\n * - attributes {object} : transform attributes declarations\n * - supplyDefaults {function} : attributes default-supply function\n *\n * A valid `moduleType: 'component'` module has fields:\n * - name {string} : the component name, used it with Register.getComponentMethod()\n * to employ component method.\n *\n * A valid `moduleType: 'apiMethod'` module has fields:\n * - name {string} : the api method name.\n * - fn {function} : the api method called with Register.call();\n *\n */\nexports.register = function register(_modules) {\n exports.collectableSubplotTypes = null;\n\n if(!_modules) {\n throw new Error('No argument passed to Plotly.register.');\n } else if(_modules && !Array.isArray(_modules)) {\n _modules = [_modules];\n }\n\n for(var i = 0; i < _modules.length; i++) {\n var newModule = _modules[i];\n\n if(!newModule) {\n throw new Error('Invalid module was attempted to be registered!');\n }\n\n switch(newModule.moduleType) {\n case 'trace':\n registerTraceModule(newModule);\n break;\n case 'transform':\n registerTransformModule(newModule);\n break;\n case 'component':\n registerComponentModule(newModule);\n break;\n case 'locale':\n registerLocale(newModule);\n break;\n case 'apiMethod':\n var name = newModule.name;\n exports.apiMethodRegistry[name] = newModule.fn;\n break;\n default:\n throw new Error('Invalid module was attempted to be registered!');\n }\n }\n};\n\n/**\n * Get registered module using trace object or trace type\n *\n * @param {object||string} trace\n * trace object with prop 'type' or trace type as a string\n * @return {object}\n * module object corresponding to trace type\n */\nexports.getModule = function(trace) {\n var _module = exports.modules[getTraceType(trace)];\n if(!_module) return false;\n return _module._module;\n};\n\n/**\n * Determine if this trace type is in a given category\n *\n * @param {object||string} traceType\n * a trace (object) or trace type (string)\n * @param {string} category\n * category in question\n * @return {boolean}\n */\nexports.traceIs = function(traceType, category) {\n traceType = getTraceType(traceType);\n\n // old Chart Studio Cloud workspace hack, nothing to see here\n if(traceType === 'various') return false;\n\n var _module = exports.modules[traceType];\n\n if(!_module) {\n if(traceType && traceType !== 'area') {\n Loggers.log('Unrecognized trace type ' + traceType + '.');\n }\n\n _module = exports.modules[basePlotAttributes.type.dflt];\n }\n\n return !!_module.categories[category];\n};\n\n/**\n * Determine if this trace has a transform of the given type and return\n * array of matching indices.\n *\n * @param {object} data\n * a trace object (member of data or fullData)\n * @param {string} type\n * type of trace to test\n * @return {array}\n * array of matching indices. If none found, returns []\n */\nexports.getTransformIndices = function(data, type) {\n var indices = [];\n var transforms = data.transforms || [];\n for(var i = 0; i < transforms.length; i++) {\n if(transforms[i].type === type) {\n indices.push(i);\n }\n }\n return indices;\n};\n\n/**\n * Determine if this trace has a transform of the given type\n *\n * @param {object} data\n * a trace object (member of data or fullData)\n * @param {string} type\n * type of trace to test\n * @return {boolean}\n */\nexports.hasTransform = function(data, type) {\n var transforms = data.transforms || [];\n for(var i = 0; i < transforms.length; i++) {\n if(transforms[i].type === type) {\n return true;\n }\n }\n return false;\n};\n\n/**\n * Retrieve component module method. Falls back on noop if either the\n * module or the method is missing, so the result can always be safely called\n *\n * @param {string} name\n * name of component (as declared in component module)\n * @param {string} method\n * name of component module method\n * @return {function}\n */\nexports.getComponentMethod = function(name, method) {\n var _module = exports.componentsRegistry[name];\n\n if(!_module) return noop;\n return _module[method] || noop;\n};\n\n/**\n * Call registered api method.\n *\n * @param {string} name : api method name\n * @param {...array} args : arguments passed to api method\n * @return {any} : returns api method output\n */\nexports.call = function() {\n var name = arguments[0];\n var args = [].slice.call(arguments, 1);\n return exports.apiMethodRegistry[name].apply(null, args);\n};\n\nfunction registerTraceModule(_module) {\n var thisType = _module.name;\n var categoriesIn = _module.categories;\n var meta = _module.meta;\n\n if(exports.modules[thisType]) {\n Loggers.log('Type ' + thisType + ' already registered');\n return;\n }\n\n if(!exports.subplotsRegistry[_module.basePlotModule.name]) {\n registerSubplot(_module.basePlotModule);\n }\n\n var categoryObj = {};\n for(var i = 0; i < categoriesIn.length; i++) {\n categoryObj[categoriesIn[i]] = true;\n exports.allCategories[categoriesIn[i]] = true;\n }\n\n exports.modules[thisType] = {\n _module: _module,\n categories: categoryObj\n };\n\n if(meta && Object.keys(meta).length) {\n exports.modules[thisType].meta = meta;\n }\n\n exports.allTypes.push(thisType);\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToTrace(componentName, thisType);\n }\n\n /*\n * Collect all trace layout attributes in one place for easier lookup later\n * but don't merge them into the base schema as it would confuse the docs\n * (at least after https://github.com/plotly/documentation/issues/202 gets done!)\n */\n if(_module.layoutAttributes) {\n extendFlat(exports.traceLayoutAttributes, _module.layoutAttributes);\n }\n\n var basePlotModule = _module.basePlotModule;\n var bpmName = basePlotModule.name;\n\n // add mapbox-gl CSS here to avoid console warning on instantiation\n if(bpmName === 'mapbox') {\n var styleRules = basePlotModule.constants.styleRules;\n for(var k in styleRules) {\n addStyleRule('.js-plotly-plot .plotly .mapboxgl-' + k, styleRules[k]);\n }\n }\n\n // if `plotly-geo-assets.js` is not included,\n // add `PlotlyGeoAssets` global to stash references to all fetched\n // topojson / geojson data\n if((bpmName === 'geo' || bpmName === 'mapbox') &&\n (typeof window !== undefined && window.PlotlyGeoAssets === undefined)\n ) {\n window.PlotlyGeoAssets = {topojson: {}};\n }\n}\n\nfunction registerSubplot(_module) {\n var plotType = _module.name;\n\n if(exports.subplotsRegistry[plotType]) {\n Loggers.log('Plot type ' + plotType + ' already registered.');\n return;\n }\n\n // relayout array handling will look for component module methods with this\n // name and won't find them because this is a subplot module... but that\n // should be fine, it will just fall back on redrawing the plot.\n findArrayRegexps(_module);\n\n // not sure what's best for the 'cartesian' type at this point\n exports.subplotsRegistry[plotType] = _module;\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToSubplot(componentName, _module.name);\n }\n}\n\nfunction registerComponentModule(_module) {\n if(typeof _module.name !== 'string') {\n throw new Error('Component module *name* must be a string.');\n }\n\n var name = _module.name;\n exports.componentsRegistry[name] = _module;\n\n if(_module.layoutAttributes) {\n if(_module.layoutAttributes._isLinkedToArray) {\n pushUnique(exports.layoutArrayContainers, name);\n }\n findArrayRegexps(_module);\n }\n\n for(var traceType in exports.modules) {\n mergeComponentAttrsToTrace(name, traceType);\n }\n\n for(var subplotName in exports.subplotsRegistry) {\n mergeComponentAttrsToSubplot(name, subplotName);\n }\n\n for(var transformType in exports.transformsRegistry) {\n mergeComponentAttrsToTransform(name, transformType);\n }\n\n if(_module.schema && _module.schema.layout) {\n extendDeepAll(baseLayoutAttributes, _module.schema.layout);\n }\n}\n\nfunction registerTransformModule(_module) {\n if(typeof _module.name !== 'string') {\n throw new Error('Transform module *name* must be a string.');\n }\n\n var prefix = 'Transform module ' + _module.name;\n var hasTransform = typeof _module.transform === 'function';\n var hasCalcTransform = typeof _module.calcTransform === 'function';\n\n if(!hasTransform && !hasCalcTransform) {\n throw new Error(prefix + ' is missing a *transform* or *calcTransform* method.');\n }\n if(hasTransform && hasCalcTransform) {\n Loggers.log([\n prefix + ' has both a *transform* and *calcTransform* methods.',\n 'Please note that all *transform* methods are executed',\n 'before all *calcTransform* methods.'\n ].join(' '));\n }\n if(!isPlainObject(_module.attributes)) {\n Loggers.log(prefix + ' registered without an *attributes* object.');\n }\n if(typeof _module.supplyDefaults !== 'function') {\n Loggers.log(prefix + ' registered without a *supplyDefaults* method.');\n }\n\n exports.transformsRegistry[_module.name] = _module;\n\n for(var componentName in exports.componentsRegistry) {\n mergeComponentAttrsToTransform(componentName, _module.name);\n }\n}\n\nfunction registerLocale(_module) {\n var locale = _module.name;\n var baseLocale = locale.split('-')[0];\n\n var newDict = _module.dictionary;\n var newFormat = _module.format;\n var hasDict = newDict && Object.keys(newDict).length;\n var hasFormat = newFormat && Object.keys(newFormat).length;\n\n var locales = exports.localeRegistry;\n\n var localeObj = locales[locale];\n if(!localeObj) locales[locale] = localeObj = {};\n\n // Should we use this dict for the base locale?\n // In case we're overwriting a previous dict for this locale, check\n // whether the base matches the full locale dict now. If we're not\n // overwriting, locales[locale] is undefined so this just checks if\n // baseLocale already had a dict or not.\n // Same logic for dateFormats\n if(baseLocale !== locale) {\n var baseLocaleObj = locales[baseLocale];\n if(!baseLocaleObj) locales[baseLocale] = baseLocaleObj = {};\n\n if(hasDict && baseLocaleObj.dictionary === localeObj.dictionary) {\n baseLocaleObj.dictionary = newDict;\n }\n if(hasFormat && baseLocaleObj.format === localeObj.format) {\n baseLocaleObj.format = newFormat;\n }\n }\n\n if(hasDict) localeObj.dictionary = newDict;\n if(hasFormat) localeObj.format = newFormat;\n}\n\nfunction findArrayRegexps(_module) {\n if(_module.layoutAttributes) {\n var arrayAttrRegexps = _module.layoutAttributes._arrayAttrRegexps;\n if(arrayAttrRegexps) {\n for(var i = 0; i < arrayAttrRegexps.length; i++) {\n pushUnique(exports.layoutArrayRegexes, arrayAttrRegexps[i]);\n }\n }\n }\n}\n\nfunction mergeComponentAttrsToTrace(componentName, traceType) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.traces) return;\n\n var traceAttrs = componentSchema.traces[traceType];\n if(traceAttrs) {\n extendDeepAll(exports.modules[traceType]._module.attributes, traceAttrs);\n }\n}\n\nfunction mergeComponentAttrsToTransform(componentName, transformType) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.transforms) return;\n\n var transformAttrs = componentSchema.transforms[transformType];\n if(transformAttrs) {\n extendDeepAll(exports.transformsRegistry[transformType].attributes, transformAttrs);\n }\n}\n\nfunction mergeComponentAttrsToSubplot(componentName, subplotName) {\n var componentSchema = exports.componentsRegistry[componentName].schema;\n if(!componentSchema || !componentSchema.subplots) return;\n\n var subplotModule = exports.subplotsRegistry[subplotName];\n var subplotAttrs = subplotModule.layoutAttributes;\n var subplotAttr = subplotModule.attr === 'subplot' ? subplotModule.name : subplotModule.attr;\n if(Array.isArray(subplotAttr)) subplotAttr = subplotAttr[0];\n\n var componentLayoutAttrs = componentSchema.subplots[subplotAttr];\n if(subplotAttrs && componentLayoutAttrs) {\n extendDeepAll(subplotAttrs, componentLayoutAttrs);\n }\n}\n\nfunction getTraceType(traceType) {\n if(typeof traceType === 'object') traceType = traceType.type;\n return traceType;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function convertColumnData(trace, ax1, ax2, var1Name, var2Name, arrayVarNames) {\n var colLen = trace._length;\n var col1 = ax1.makeCalcdata(trace, var1Name);\n var col2 = ax2.makeCalcdata(trace, var2Name);\n var textCol = trace.text;\n var hasColumnText = (textCol !== undefined && Lib.isArray1D(textCol));\n var hoverTextCol = trace.hovertext;\n var hasColumnHoverText = (hoverTextCol !== undefined && Lib.isArray1D(hoverTextCol));\n var i, j;\n\n var col1dv = Lib.distinctVals(col1);\n var col1vals = col1dv.vals;\n var col2dv = Lib.distinctVals(col2);\n var col2vals = col2dv.vals;\n var newArrays = [];\n var text;\n var hovertext;\n\n for(i = 0; i < arrayVarNames.length; i++) {\n newArrays[i] = Lib.init2dArray(col2vals.length, col1vals.length);\n }\n\n if(hasColumnText) {\n text = Lib.init2dArray(col2vals.length, col1vals.length);\n }\n if(hasColumnHoverText) {\n hovertext = Lib.init2dArray(col2vals.length, col1vals.length);\n }\n\n var after2before = Lib.init2dArray(col2vals.length, col1vals.length);\n\n for(i = 0; i < colLen; i++) {\n if(col1[i] !== BADNUM && col2[i] !== BADNUM) {\n var i1 = Lib.findBin(col1[i] + col1dv.minDiff / 2, col1vals);\n var i2 = Lib.findBin(col2[i] + col2dv.minDiff / 2, col2vals);\n\n for(j = 0; j < arrayVarNames.length; j++) {\n var arrayVarName = arrayVarNames[j];\n var arrayVar = trace[arrayVarName];\n var newArray = newArrays[j];\n newArray[i2][i1] = arrayVar[i];\n after2before[i2][i1] = i;\n }\n\n if(hasColumnText) text[i2][i1] = textCol[i];\n if(hasColumnHoverText) hovertext[i2][i1] = hoverTextCol[i];\n }\n }\n\n trace['_' + var1Name] = col1vals;\n trace['_' + var2Name] = col2vals;\n for(j = 0; j < arrayVarNames.length; j++) {\n trace['_' + arrayVarNames[j]] = newArrays[j];\n }\n if(hasColumnText) trace._text = text;\n if(hasColumnHoverText) trace._hovertext = hovertext;\n\n if(ax1 && ax1.type === 'category') {\n trace['_' + var1Name + 'CategoryMap'] = col1vals.map(function(v) { return ax1._categories[v];});\n }\n\n if(ax2 && ax2.type === 'category') {\n trace['_' + var2Name + 'CategoryMap'] = col2vals.map(function(v) { return ax2._categories[v];});\n }\n\n trace._after2before = after2before;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nexports.version = require('./version').version;\n\n// inject promise polyfill\nrequire('es6-promise').polyfill();\n\n// inject plot css\nrequire('../build/plotcss');\n\n// inject default MathJax config\nrequire('./fonts/mathjax_config')();\n\n// include registry module and expose register method\nvar Registry = require('./registry');\nvar register = exports.register = Registry.register;\n\n// expose plot api methods\nvar plotApi = require('./plot_api');\nvar methodNames = Object.keys(plotApi);\nfor(var i = 0; i < methodNames.length; i++) {\n var name = methodNames[i];\n // _ -> private API methods, but still registered for internal use\n if(name.charAt(0) !== '_') exports[name] = plotApi[name];\n register({\n moduleType: 'apiMethod',\n name: name,\n fn: plotApi[name]\n });\n}\n\n// scatter is the only trace included by default\nregister(require('./traces/scatter'));\n\n// register all registrable components modules\nregister([\n require('./components/legend'),\n require('./components/fx'), // fx needs to come after legend\n require('./components/annotations'),\n require('./components/annotations3d'),\n require('./components/shapes'),\n require('./components/images'),\n require('./components/updatemenus'),\n require('./components/sliders'),\n require('./components/rangeslider'),\n require('./components/rangeselector'),\n require('./components/grid'),\n require('./components/errorbars'),\n require('./components/colorscale'),\n require('./components/colorbar')\n]);\n\n// locales en and en-US are required for default behavior\nregister([\n require('./locale-en'),\n require('./locale-en-us')\n]);\n\n// locales that are present in the window should be loaded\nif(window.PlotlyLocales && Array.isArray(window.PlotlyLocales)) {\n register(window.PlotlyLocales);\n delete window.PlotlyLocales;\n}\n\n// plot icons\nexports.Icons = require('./fonts/ploticon');\n\n// unofficial 'beta' plot methods, use at your own risk\nexports.Plots = require('./plots/plots');\nexports.Fx = require('./components/fx');\nexports.Snapshot = require('./snapshot');\nexports.PlotSchema = require('./plot_api/plot_schema');\nexports.Queue = require('./lib/queue');\n\n// export d3 used in the bundle\nexports.d3 = require('d3');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n FORMAT_LINK: 'https://github.com/d3/d3-3.x-api-reference/blob/master/Formatting.md#d3_format',\n DATE_FORMAT_LINK: 'https://github.com/d3/d3-3.x-api-reference/blob/master/Time-Formatting.md#format'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n\n// set cursors pointing toward the closest corner/side,\n// to indicate alignment\n// x and y are 0-1, fractions of the plot area\nvar cursorset = [\n ['sw-resize', 's-resize', 'se-resize'],\n ['w-resize', 'move', 'e-resize'],\n ['nw-resize', 'n-resize', 'ne-resize']\n];\n\nmodule.exports = function getCursor(x, y, xanchor, yanchor) {\n if(xanchor === 'left') x = 0;\n else if(xanchor === 'center') x = 1;\n else if(xanchor === 'right') x = 2;\n else x = Lib.constrain(Math.floor(x * 3), 0, 2);\n\n if(yanchor === 'bottom') y = 0;\n else if(yanchor === 'middle') y = 1;\n else if(yanchor === 'top') y = 2;\n else y = Lib.constrain(Math.floor(y * 3), 0, 2);\n\n return cursorset[y][x];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = {\n moduleType: 'component',\n name: 'legend',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw'),\n style: require('./style')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar dragElement = require('../dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar constants = require('./constants');\nvar helpers = require('./helpers');\n\n\n// Shapes are stored in gd.layout.shapes, an array of objects\n// index can point to one item in this array,\n// or non-numeric to simply add a new one\n// or -1 to modify all existing\n// opt can be the full options object, or one key (to be set to value)\n// or undefined to simply redraw\n// if opt is blank, val can be 'add' or a full options object to add a new\n// annotation at that point in the array, or 'remove' to delete this one\n\nmodule.exports = {\n draw: draw,\n drawOne: drawOne\n};\n\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n // Remove previous shapes before drawing new in shapes in fullLayout.shapes\n fullLayout._shapeUpperLayer.selectAll('path').remove();\n fullLayout._shapeLowerLayer.selectAll('path').remove();\n\n for(var k in fullLayout._plots) {\n var shapelayer = fullLayout._plots[k].shapelayer;\n if(shapelayer) shapelayer.selectAll('path').remove();\n }\n\n for(var i = 0; i < fullLayout.shapes.length; i++) {\n if(fullLayout.shapes[i].visible) {\n drawOne(gd, i);\n }\n }\n\n // may need to resurrect this if we put text (LaTeX) in shapes\n // return Plots.previousPromises(gd);\n}\n\nfunction drawOne(gd, index) {\n // remove the existing shape if there is one.\n // because indices can change, we need to look in all shape layers\n gd._fullLayout._paperdiv\n .selectAll('.shapelayer [data-index=\"' + index + '\"]')\n .remove();\n\n var options = gd._fullLayout.shapes[index] || {};\n\n // this shape is gone - quit now after deleting it\n // TODO: use d3 idioms instead of deleting and redrawing every time\n if(!options._input || options.visible === false) return;\n\n if(options.layer !== 'below') {\n drawShape(gd._fullLayout._shapeUpperLayer);\n } else if(options.xref === 'paper' || options.yref === 'paper') {\n drawShape(gd._fullLayout._shapeLowerLayer);\n } else {\n var plotinfo = gd._fullLayout._plots[options.xref + options.yref];\n if(plotinfo) {\n var mainPlot = plotinfo.mainplotinfo || plotinfo;\n drawShape(mainPlot.shapelayer);\n } else {\n // Fall back to _shapeLowerLayer in case the requested subplot doesn't exist.\n // This can happen if you reference the shape to an x / y axis combination\n // that doesn't have any data on it (and layer is below)\n drawShape(gd._fullLayout._shapeLowerLayer);\n }\n }\n\n function drawShape(shapeLayer) {\n var attrs = {\n 'data-index': index,\n 'fill-rule': 'evenodd',\n d: getPathString(gd, options)\n };\n var lineColor = options.line.width ? options.line.color : 'rgba(0,0,0,0)';\n\n var path = shapeLayer.append('path')\n .attr(attrs)\n .style('opacity', options.opacity)\n .call(Color.stroke, lineColor)\n .call(Color.fill, options.fillcolor)\n .call(Drawing.dashLine, options.line.dash, options.line.width);\n\n setClipPath(path, gd, options);\n\n if(gd._context.edits.shapePosition) setupDragElement(gd, path, options, index, shapeLayer);\n }\n}\n\nfunction setClipPath(shapePath, gd, shapeOptions) {\n // note that for layer=\"below\" the clipAxes can be different from the\n // subplot we're drawing this in. This could cause problems if the shape\n // spans two subplots. See https://github.com/plotly/plotly.js/issues/1452\n var clipAxes = (shapeOptions.xref + shapeOptions.yref).replace(/paper/g, '');\n\n Drawing.setClipUrl(\n shapePath,\n clipAxes ? 'clip' + gd._fullLayout._uid + clipAxes : null,\n gd\n );\n}\n\nfunction setupDragElement(gd, shapePath, shapeOptions, index, shapeLayer) {\n var MINWIDTH = 10;\n var MINHEIGHT = 10;\n\n var xPixelSized = shapeOptions.xsizemode === 'pixel';\n var yPixelSized = shapeOptions.ysizemode === 'pixel';\n var isLine = shapeOptions.type === 'line';\n var isPath = shapeOptions.type === 'path';\n\n var editHelpers = arrayEditor(gd.layout, 'shapes', shapeOptions);\n var modifyItem = editHelpers.modifyItem;\n\n var x0, y0, x1, y1, xAnchor, yAnchor;\n var n0, s0, w0, e0, optN, optS, optW, optE;\n var pathIn;\n\n // setup conversion functions\n var xa = Axes.getFromId(gd, shapeOptions.xref);\n var ya = Axes.getFromId(gd, shapeOptions.yref);\n var x2p = helpers.getDataToPixel(gd, xa);\n var y2p = helpers.getDataToPixel(gd, ya, true);\n var p2x = helpers.getPixelToData(gd, xa);\n var p2y = helpers.getPixelToData(gd, ya, true);\n\n var sensoryElement = obtainSensoryElement();\n var dragOptions = {\n element: sensoryElement.node(),\n gd: gd,\n prepFn: startDrag,\n doneFn: endDrag,\n clickFn: abortDrag\n };\n var dragMode;\n\n dragElement.init(dragOptions);\n\n sensoryElement.node().onmousemove = updateDragMode;\n\n function obtainSensoryElement() {\n return isLine ? createLineDragHandles() : shapePath;\n }\n\n function createLineDragHandles() {\n var minSensoryWidth = 10;\n var sensoryWidth = Math.max(shapeOptions.line.width, minSensoryWidth);\n\n // Helper shapes group\n // Note that by setting the `data-index` attr, it is ensured that\n // the helper group is purged in this modules `draw` function\n var g = shapeLayer.append('g')\n .attr('data-index', index);\n\n // Helper path for moving\n g.append('path')\n .attr('d', shapePath.attr('d'))\n .style({\n 'cursor': 'move',\n 'stroke-width': sensoryWidth,\n 'stroke-opacity': '0' // ensure not visible\n });\n\n // Helper circles for resizing\n var circleStyle = {\n 'fill-opacity': '0' // ensure not visible\n };\n var circleRadius = sensoryWidth / 2 > minSensoryWidth ? sensoryWidth / 2 : minSensoryWidth;\n\n g.append('circle')\n .attr({\n 'data-line-point': 'start-point',\n 'cx': xPixelSized ? x2p(shapeOptions.xanchor) + shapeOptions.x0 : x2p(shapeOptions.x0),\n 'cy': yPixelSized ? y2p(shapeOptions.yanchor) - shapeOptions.y0 : y2p(shapeOptions.y0),\n 'r': circleRadius\n })\n .style(circleStyle)\n .classed('cursor-grab', true);\n\n g.append('circle')\n .attr({\n 'data-line-point': 'end-point',\n 'cx': xPixelSized ? x2p(shapeOptions.xanchor) + shapeOptions.x1 : x2p(shapeOptions.x1),\n 'cy': yPixelSized ? y2p(shapeOptions.yanchor) - shapeOptions.y1 : y2p(shapeOptions.y1),\n 'r': circleRadius\n })\n .style(circleStyle)\n .classed('cursor-grab', true);\n\n return g;\n }\n\n function updateDragMode(evt) {\n if(isLine) {\n if(evt.target.tagName === 'path') {\n dragMode = 'move';\n } else {\n dragMode = evt.target.attributes['data-line-point'].value === 'start-point' ?\n 'resize-over-start-point' : 'resize-over-end-point';\n }\n } else {\n // element might not be on screen at time of setup,\n // so obtain bounding box here\n var dragBBox = dragOptions.element.getBoundingClientRect();\n\n // choose 'move' or 'resize'\n // based on initial position of cursor within the drag element\n var w = dragBBox.right - dragBBox.left;\n var h = dragBBox.bottom - dragBBox.top;\n var x = evt.clientX - dragBBox.left;\n var y = evt.clientY - dragBBox.top;\n var cursor = (!isPath && w > MINWIDTH && h > MINHEIGHT && !evt.shiftKey) ?\n dragElement.getCursor(x / w, 1 - y / h) :\n 'move';\n\n setCursor(shapePath, cursor);\n\n // possible values 'move', 'sw', 'w', 'se', 'e', 'ne', 'n', 'nw' and 'w'\n dragMode = cursor.split('-')[0];\n }\n }\n\n function startDrag(evt) {\n // setup update strings and initial values\n if(xPixelSized) {\n xAnchor = x2p(shapeOptions.xanchor);\n }\n if(yPixelSized) {\n yAnchor = y2p(shapeOptions.yanchor);\n }\n\n if(shapeOptions.type === 'path') {\n pathIn = shapeOptions.path;\n } else {\n x0 = xPixelSized ? shapeOptions.x0 : x2p(shapeOptions.x0);\n y0 = yPixelSized ? shapeOptions.y0 : y2p(shapeOptions.y0);\n x1 = xPixelSized ? shapeOptions.x1 : x2p(shapeOptions.x1);\n y1 = yPixelSized ? shapeOptions.y1 : y2p(shapeOptions.y1);\n }\n\n if(x0 < x1) {\n w0 = x0;\n optW = 'x0';\n e0 = x1;\n optE = 'x1';\n } else {\n w0 = x1;\n optW = 'x1';\n e0 = x0;\n optE = 'x0';\n }\n\n // For fixed size shapes take opposing direction of y-axis into account.\n // Hint: For data sized shapes this is done by the y2p function.\n if((!yPixelSized && y0 < y1) || (yPixelSized && y0 > y1)) {\n n0 = y0;\n optN = 'y0';\n s0 = y1;\n optS = 'y1';\n } else {\n n0 = y1;\n optN = 'y1';\n s0 = y0;\n optS = 'y0';\n }\n\n // setup dragMode and the corresponding handler\n updateDragMode(evt);\n renderVisualCues(shapeLayer, shapeOptions);\n deactivateClipPathTemporarily(shapePath, shapeOptions, gd);\n dragOptions.moveFn = (dragMode === 'move') ? moveShape : resizeShape;\n }\n\n function endDrag() {\n setCursor(shapePath);\n removeVisualCues(shapeLayer);\n\n // Don't rely on clipPath being activated during re-layout\n setClipPath(shapePath, gd, shapeOptions);\n Registry.call('_guiRelayout', gd, editHelpers.getUpdateObj());\n }\n\n function abortDrag() {\n removeVisualCues(shapeLayer);\n }\n\n function moveShape(dx, dy) {\n if(shapeOptions.type === 'path') {\n var noOp = function(coord) { return coord; };\n var moveX = noOp;\n var moveY = noOp;\n\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n moveX = function moveX(x) { return p2x(x2p(x) + dx); };\n if(xa && xa.type === 'date') moveX = helpers.encodeDate(moveX);\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n moveY = function moveY(y) { return p2y(y2p(y) + dy); };\n if(ya && ya.type === 'date') moveY = helpers.encodeDate(moveY);\n }\n\n modifyItem('path', shapeOptions.path = movePath(pathIn, moveX, moveY));\n } else {\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n modifyItem('x0', shapeOptions.x0 = p2x(x0 + dx));\n modifyItem('x1', shapeOptions.x1 = p2x(x1 + dx));\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n modifyItem('y0', shapeOptions.y0 = p2y(y0 + dy));\n modifyItem('y1', shapeOptions.y1 = p2y(y1 + dy));\n }\n }\n\n shapePath.attr('d', getPathString(gd, shapeOptions));\n renderVisualCues(shapeLayer, shapeOptions);\n }\n\n function resizeShape(dx, dy) {\n if(isPath) {\n // TODO: implement path resize, don't forget to update dragMode code\n var noOp = function(coord) { return coord; };\n var moveX = noOp;\n var moveY = noOp;\n\n if(xPixelSized) {\n modifyItem('xanchor', shapeOptions.xanchor = p2x(xAnchor + dx));\n } else {\n moveX = function moveX(x) { return p2x(x2p(x) + dx); };\n if(xa && xa.type === 'date') moveX = helpers.encodeDate(moveX);\n }\n\n if(yPixelSized) {\n modifyItem('yanchor', shapeOptions.yanchor = p2y(yAnchor + dy));\n } else {\n moveY = function moveY(y) { return p2y(y2p(y) + dy); };\n if(ya && ya.type === 'date') moveY = helpers.encodeDate(moveY);\n }\n\n modifyItem('path', shapeOptions.path = movePath(pathIn, moveX, moveY));\n } else if(isLine) {\n if(dragMode === 'resize-over-start-point') {\n var newX0 = x0 + dx;\n var newY0 = yPixelSized ? y0 - dy : y0 + dy;\n modifyItem('x0', shapeOptions.x0 = xPixelSized ? newX0 : p2x(newX0));\n modifyItem('y0', shapeOptions.y0 = yPixelSized ? newY0 : p2y(newY0));\n } else if(dragMode === 'resize-over-end-point') {\n var newX1 = x1 + dx;\n var newY1 = yPixelSized ? y1 - dy : y1 + dy;\n modifyItem('x1', shapeOptions.x1 = xPixelSized ? newX1 : p2x(newX1));\n modifyItem('y1', shapeOptions.y1 = yPixelSized ? newY1 : p2y(newY1));\n }\n } else {\n var newN = (~dragMode.indexOf('n')) ? n0 + dy : n0;\n var newS = (~dragMode.indexOf('s')) ? s0 + dy : s0;\n var newW = (~dragMode.indexOf('w')) ? w0 + dx : w0;\n var newE = (~dragMode.indexOf('e')) ? e0 + dx : e0;\n\n // Do things in opposing direction for y-axis.\n // Hint: for data-sized shapes the reversal of axis direction is done in p2y.\n if(~dragMode.indexOf('n') && yPixelSized) newN = n0 - dy;\n if(~dragMode.indexOf('s') && yPixelSized) newS = s0 - dy;\n\n // Update shape eventually. Again, be aware of the\n // opposing direction of the y-axis of fixed size shapes.\n if((!yPixelSized && newS - newN > MINHEIGHT) ||\n (yPixelSized && newN - newS > MINHEIGHT)) {\n modifyItem(optN, shapeOptions[optN] = yPixelSized ? newN : p2y(newN));\n modifyItem(optS, shapeOptions[optS] = yPixelSized ? newS : p2y(newS));\n }\n if(newE - newW > MINWIDTH) {\n modifyItem(optW, shapeOptions[optW] = xPixelSized ? newW : p2x(newW));\n modifyItem(optE, shapeOptions[optE] = xPixelSized ? newE : p2x(newE));\n }\n }\n\n shapePath.attr('d', getPathString(gd, shapeOptions));\n renderVisualCues(shapeLayer, shapeOptions);\n }\n\n function renderVisualCues(shapeLayer, shapeOptions) {\n if(xPixelSized || yPixelSized) {\n renderAnchor();\n }\n\n function renderAnchor() {\n var isNotPath = shapeOptions.type !== 'path';\n\n // d3 join with dummy data to satisfy d3 data-binding\n var visualCues = shapeLayer.selectAll('.visual-cue').data([0]);\n\n // Enter\n var strokeWidth = 1;\n visualCues.enter()\n .append('path')\n .attr({\n 'fill': '#fff',\n 'fill-rule': 'evenodd',\n 'stroke': '#000',\n 'stroke-width': strokeWidth\n })\n .classed('visual-cue', true);\n\n // Update\n var posX = x2p(\n xPixelSized ?\n shapeOptions.xanchor :\n Lib.midRange(\n isNotPath ?\n [shapeOptions.x0, shapeOptions.x1] :\n helpers.extractPathCoords(shapeOptions.path, constants.paramIsX))\n );\n var posY = y2p(\n yPixelSized ?\n shapeOptions.yanchor :\n Lib.midRange(\n isNotPath ?\n [shapeOptions.y0, shapeOptions.y1] :\n helpers.extractPathCoords(shapeOptions.path, constants.paramIsY))\n );\n\n posX = helpers.roundPositionForSharpStrokeRendering(posX, strokeWidth);\n posY = helpers.roundPositionForSharpStrokeRendering(posY, strokeWidth);\n\n if(xPixelSized && yPixelSized) {\n var crossPath = 'M' + (posX - 1 - strokeWidth) + ',' + (posY - 1 - strokeWidth) +\n 'h-8v2h8 v8h2v-8 h8v-2h-8 v-8h-2 Z';\n visualCues.attr('d', crossPath);\n } else if(xPixelSized) {\n var vBarPath = 'M' + (posX - 1 - strokeWidth) + ',' + (posY - 9 - strokeWidth) +\n 'v18 h2 v-18 Z';\n visualCues.attr('d', vBarPath);\n } else {\n var hBarPath = 'M' + (posX - 9 - strokeWidth) + ',' + (posY - 1 - strokeWidth) +\n 'h18 v2 h-18 Z';\n visualCues.attr('d', hBarPath);\n }\n }\n }\n\n function removeVisualCues(shapeLayer) {\n shapeLayer.selectAll('.visual-cue').remove();\n }\n\n function deactivateClipPathTemporarily(shapePath, shapeOptions, gd) {\n var xref = shapeOptions.xref;\n var yref = shapeOptions.yref;\n var xa = Axes.getFromId(gd, xref);\n var ya = Axes.getFromId(gd, yref);\n\n var clipAxes = '';\n if(xref !== 'paper' && !xa.autorange) clipAxes += xref;\n if(yref !== 'paper' && !ya.autorange) clipAxes += yref;\n\n Drawing.setClipUrl(\n shapePath,\n clipAxes ? 'clip' + gd._fullLayout._uid + clipAxes : null,\n gd\n );\n }\n}\n\nfunction getPathString(gd, options) {\n var type = options.type;\n var xa = Axes.getFromId(gd, options.xref);\n var ya = Axes.getFromId(gd, options.yref);\n var gs = gd._fullLayout._size;\n var x2r, x2p, y2r, y2p;\n var x0, x1, y0, y1;\n\n if(xa) {\n x2r = helpers.shapePositionToRange(xa);\n x2p = function(v) { return xa._offset + xa.r2p(x2r(v, true)); };\n } else {\n x2p = function(v) { return gs.l + gs.w * v; };\n }\n\n if(ya) {\n y2r = helpers.shapePositionToRange(ya);\n y2p = function(v) { return ya._offset + ya.r2p(y2r(v, true)); };\n } else {\n y2p = function(v) { return gs.t + gs.h * (1 - v); };\n }\n\n if(type === 'path') {\n if(xa && xa.type === 'date') x2p = helpers.decodeDate(x2p);\n if(ya && ya.type === 'date') y2p = helpers.decodeDate(y2p);\n return convertPath(options, x2p, y2p);\n }\n\n if(options.xsizemode === 'pixel') {\n var xAnchorPos = x2p(options.xanchor);\n x0 = xAnchorPos + options.x0;\n x1 = xAnchorPos + options.x1;\n } else {\n x0 = x2p(options.x0);\n x1 = x2p(options.x1);\n }\n\n if(options.ysizemode === 'pixel') {\n var yAnchorPos = y2p(options.yanchor);\n y0 = yAnchorPos - options.y0;\n y1 = yAnchorPos - options.y1;\n } else {\n y0 = y2p(options.y0);\n y1 = y2p(options.y1);\n }\n\n if(type === 'line') return 'M' + x0 + ',' + y0 + 'L' + x1 + ',' + y1;\n if(type === 'rect') return 'M' + x0 + ',' + y0 + 'H' + x1 + 'V' + y1 + 'H' + x0 + 'Z';\n\n // circle\n var cx = (x0 + x1) / 2;\n var cy = (y0 + y1) / 2;\n var rx = Math.abs(cx - x0);\n var ry = Math.abs(cy - y0);\n var rArc = 'A' + rx + ',' + ry;\n var rightPt = (cx + rx) + ',' + cy;\n var topPt = cx + ',' + (cy - ry);\n return 'M' + rightPt + rArc + ' 0 1,1 ' + topPt +\n rArc + ' 0 0,1 ' + rightPt + 'Z';\n}\n\n\nfunction convertPath(options, x2p, y2p) {\n var pathIn = options.path;\n var xSizemode = options.xsizemode;\n var ySizemode = options.ysizemode;\n var xAnchor = options.xanchor;\n var yAnchor = options.yanchor;\n\n return pathIn.replace(constants.segmentRE, function(segment) {\n var paramNumber = 0;\n var segmentType = segment.charAt(0);\n var xParams = constants.paramIsX[segmentType];\n var yParams = constants.paramIsY[segmentType];\n var nParams = constants.numParams[segmentType];\n\n var paramString = segment.substr(1).replace(constants.paramRE, function(param) {\n if(xParams[paramNumber]) {\n if(xSizemode === 'pixel') param = x2p(xAnchor) + Number(param);\n else param = x2p(param);\n } else if(yParams[paramNumber]) {\n if(ySizemode === 'pixel') param = y2p(yAnchor) - Number(param);\n else param = y2p(param);\n }\n paramNumber++;\n\n if(paramNumber > nParams) param = 'X';\n return param;\n });\n\n if(paramNumber > nParams) {\n paramString = paramString.replace(/[\\s,]*X.*/, '');\n Lib.log('Ignoring extra params in segment ' + segment);\n }\n\n return segmentType + paramString;\n });\n}\n\nfunction movePath(pathIn, moveX, moveY) {\n return pathIn.replace(constants.segmentRE, function(segment) {\n var paramNumber = 0;\n var segmentType = segment.charAt(0);\n var xParams = constants.paramIsX[segmentType];\n var yParams = constants.paramIsY[segmentType];\n var nParams = constants.numParams[segmentType];\n\n var paramString = segment.substr(1).replace(constants.paramRE, function(param) {\n if(paramNumber >= nParams) return param;\n\n if(xParams[paramNumber]) param = moveX(param);\n else if(yParams[paramNumber]) param = moveY(param);\n\n paramNumber++;\n\n return param;\n });\n\n return segmentType + paramString;\n });\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar axisIds = require('../../plots/cartesian/axis_ids');\nvar Lib = require('../../lib');\nvar Icons = require('../../fonts/ploticon');\n\nvar _ = Lib._;\n\nvar modeBarButtons = module.exports = {};\n\n/**\n * ModeBar buttons configuration\n *\n * @param {string} name\n * name / id of the buttons (for tracking)\n * @param {string} title\n * text that appears while hovering over the button,\n * enter null, false or '' for no hover text\n * @param {string} icon\n * svg icon object associated with the button\n * can be linked to Plotly.Icons to use the default plotly icons\n * @param {string} [gravity]\n * icon positioning\n * @param {function} click\n * click handler associated with the button, a function of\n * 'gd' (the main graph object) and\n * 'ev' (the event object)\n * @param {string} [attr]\n * attribute associated with button,\n * use this with 'val' to keep track of the state\n * @param {*} [val]\n * initial 'attr' value, can be a function of gd\n * @param {boolean} [toggle]\n * is the button a toggle button?\n */\nmodeBarButtons.toImage = {\n name: 'toImage',\n title: function(gd) {\n var opts = gd._context.toImageButtonOptions || {};\n var format = opts.format || 'png';\n return format === 'png' ?\n _(gd, 'Download plot as a png') : // legacy text\n _(gd, 'Download plot'); // generic non-PNG text\n },\n icon: Icons.camera,\n click: function(gd) {\n var toImageButtonOptions = gd._context.toImageButtonOptions;\n var opts = {format: toImageButtonOptions.format || 'png'};\n\n Lib.notifier(_(gd, 'Taking snapshot - this may take a few seconds'), 'long');\n\n if(opts.format !== 'svg' && Lib.isIE()) {\n Lib.notifier(_(gd, 'IE only supports svg. Changing format to svg.'), 'long');\n opts.format = 'svg';\n }\n\n ['filename', 'width', 'height', 'scale'].forEach(function(key) {\n if(key in toImageButtonOptions) {\n opts[key] = toImageButtonOptions[key];\n }\n });\n\n Registry.call('downloadImage', gd, opts)\n .then(function(filename) {\n Lib.notifier(_(gd, 'Snapshot succeeded') + ' - ' + filename, 'long');\n })\n .catch(function() {\n Lib.notifier(_(gd, 'Sorry, there was a problem downloading your snapshot!'), 'long');\n });\n }\n};\n\nmodeBarButtons.sendDataToCloud = {\n name: 'sendDataToCloud',\n title: function(gd) { return _(gd, 'Edit in Chart Studio'); },\n icon: Icons.disk,\n click: function(gd) {\n Plots.sendDataToCloud(gd);\n }\n};\n\nmodeBarButtons.editInChartStudio = {\n name: 'editInChartStudio',\n title: function(gd) { return _(gd, 'Edit in Chart Studio'); },\n icon: Icons.pencil,\n click: function(gd) {\n Plots.sendDataToCloud(gd);\n }\n};\n\nmodeBarButtons.zoom2d = {\n name: 'zoom2d',\n title: function(gd) { return _(gd, 'Zoom'); },\n attr: 'dragmode',\n val: 'zoom',\n icon: Icons.zoombox,\n click: handleCartesian\n};\n\nmodeBarButtons.pan2d = {\n name: 'pan2d',\n title: function(gd) { return _(gd, 'Pan'); },\n attr: 'dragmode',\n val: 'pan',\n icon: Icons.pan,\n click: handleCartesian\n};\n\nmodeBarButtons.select2d = {\n name: 'select2d',\n title: function(gd) { return _(gd, 'Box Select'); },\n attr: 'dragmode',\n val: 'select',\n icon: Icons.selectbox,\n click: handleCartesian\n};\n\nmodeBarButtons.lasso2d = {\n name: 'lasso2d',\n title: function(gd) { return _(gd, 'Lasso Select'); },\n attr: 'dragmode',\n val: 'lasso',\n icon: Icons.lasso,\n click: handleCartesian\n};\n\nmodeBarButtons.zoomIn2d = {\n name: 'zoomIn2d',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleCartesian\n};\n\nmodeBarButtons.zoomOut2d = {\n name: 'zoomOut2d',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleCartesian\n};\n\nmodeBarButtons.autoScale2d = {\n name: 'autoScale2d',\n title: function(gd) { return _(gd, 'Autoscale'); },\n attr: 'zoom',\n val: 'auto',\n icon: Icons.autoscale,\n click: handleCartesian\n};\n\nmodeBarButtons.resetScale2d = {\n name: 'resetScale2d',\n title: function(gd) { return _(gd, 'Reset axes'); },\n attr: 'zoom',\n val: 'reset',\n icon: Icons.home,\n click: handleCartesian\n};\n\nmodeBarButtons.hoverClosestCartesian = {\n name: 'hoverClosestCartesian',\n title: function(gd) { return _(gd, 'Show closest data on hover'); },\n attr: 'hovermode',\n val: 'closest',\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: handleCartesian\n};\n\nmodeBarButtons.hoverCompareCartesian = {\n name: 'hoverCompareCartesian',\n title: function(gd) { return _(gd, 'Compare data on hover'); },\n attr: 'hovermode',\n val: function(gd) {\n return gd._fullLayout._isHoriz ? 'y' : 'x';\n },\n icon: Icons.tooltip_compare,\n gravity: 'ne',\n click: handleCartesian\n};\n\nfunction handleCartesian(gd, ev) {\n var button = ev.currentTarget;\n var astr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var fullLayout = gd._fullLayout;\n var aobj = {};\n var axList = axisIds.list(gd, null, true);\n var allSpikesEnabled = fullLayout._cartesianSpikesEnabled;\n\n var ax, i;\n\n if(astr === 'zoom') {\n var mag = (val === 'in') ? 0.5 : 2;\n var r0 = (1 + mag) / 2;\n var r1 = (1 - mag) / 2;\n var axName;\n\n for(i = 0; i < axList.length; i++) {\n ax = axList[i];\n\n if(!ax.fixedrange) {\n axName = ax._name;\n if(val === 'auto') {\n aobj[axName + '.autorange'] = true;\n } else if(val === 'reset') {\n if(ax._rangeInitial === undefined) {\n aobj[axName + '.autorange'] = true;\n } else {\n var rangeInitial = ax._rangeInitial.slice();\n aobj[axName + '.range[0]'] = rangeInitial[0];\n aobj[axName + '.range[1]'] = rangeInitial[1];\n }\n\n // N.B. \"reset\" also resets showspikes\n if(ax._showSpikeInitial !== undefined) {\n aobj[axName + '.showspikes'] = ax._showSpikeInitial;\n if(allSpikesEnabled === 'on' && !ax._showSpikeInitial) {\n allSpikesEnabled = 'off';\n }\n }\n } else {\n var rangeNow = [\n ax.r2l(ax.range[0]),\n ax.r2l(ax.range[1]),\n ];\n\n var rangeNew = [\n r0 * rangeNow[0] + r1 * rangeNow[1],\n r0 * rangeNow[1] + r1 * rangeNow[0]\n ];\n\n aobj[axName + '.range[0]'] = ax.l2r(rangeNew[0]);\n aobj[axName + '.range[1]'] = ax.l2r(rangeNew[1]);\n }\n }\n }\n } else {\n // if ALL traces have orientation 'h', 'hovermode': 'x' otherwise: 'y'\n if(astr === 'hovermode' && (val === 'x' || val === 'y')) {\n val = fullLayout._isHoriz ? 'y' : 'x';\n button.setAttribute('data-val', val);\n }\n\n aobj[astr] = val;\n }\n\n fullLayout._cartesianSpikesEnabled = allSpikesEnabled;\n\n Registry.call('_guiRelayout', gd, aobj);\n}\n\nmodeBarButtons.zoom3d = {\n name: 'zoom3d',\n title: function(gd) { return _(gd, 'Zoom'); },\n attr: 'scene.dragmode',\n val: 'zoom',\n icon: Icons.zoombox,\n click: handleDrag3d\n};\n\nmodeBarButtons.pan3d = {\n name: 'pan3d',\n title: function(gd) { return _(gd, 'Pan'); },\n attr: 'scene.dragmode',\n val: 'pan',\n icon: Icons.pan,\n click: handleDrag3d\n};\n\nmodeBarButtons.orbitRotation = {\n name: 'orbitRotation',\n title: function(gd) { return _(gd, 'Orbital rotation'); },\n attr: 'scene.dragmode',\n val: 'orbit',\n icon: Icons['3d_rotate'],\n click: handleDrag3d\n};\n\nmodeBarButtons.tableRotation = {\n name: 'tableRotation',\n title: function(gd) { return _(gd, 'Turntable rotation'); },\n attr: 'scene.dragmode',\n val: 'turntable',\n icon: Icons['z-axis'],\n click: handleDrag3d\n};\n\nfunction handleDrag3d(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var sceneIds = gd._fullLayout._subplots.gl3d || [];\n var layoutUpdate = {};\n\n var parts = attr.split('.');\n\n for(var i = 0; i < sceneIds.length; i++) {\n layoutUpdate[sceneIds[i] + '.' + parts[1]] = val;\n }\n\n // for multi-type subplots\n var val2d = (val === 'pan') ? val : 'zoom';\n layoutUpdate.dragmode = val2d;\n\n Registry.call('_guiRelayout', gd, layoutUpdate);\n}\n\nmodeBarButtons.resetCameraDefault3d = {\n name: 'resetCameraDefault3d',\n title: function(gd) { return _(gd, 'Reset camera to default'); },\n attr: 'resetDefault',\n icon: Icons.home,\n click: handleCamera3d\n};\n\nmodeBarButtons.resetCameraLastSave3d = {\n name: 'resetCameraLastSave3d',\n title: function(gd) { return _(gd, 'Reset camera to last save'); },\n attr: 'resetLastSave',\n icon: Icons.movie,\n click: handleCamera3d\n};\n\nfunction handleCamera3d(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d || [];\n var aobj = {};\n\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneId = sceneIds[i];\n var camera = sceneId + '.camera';\n var aspectratio = sceneId + '.aspectratio';\n var aspectmode = sceneId + '.aspectmode';\n var scene = fullLayout[sceneId]._scene;\n var didUpdate;\n\n if(attr === 'resetLastSave') {\n aobj[camera + '.up'] = scene.viewInitial.up;\n aobj[camera + '.eye'] = scene.viewInitial.eye;\n aobj[camera + '.center'] = scene.viewInitial.center;\n didUpdate = true;\n } else if(attr === 'resetDefault') {\n aobj[camera + '.up'] = null;\n aobj[camera + '.eye'] = null;\n aobj[camera + '.center'] = null;\n didUpdate = true;\n }\n\n if(didUpdate) {\n aobj[aspectratio + '.x'] = scene.viewInitial.aspectratio.x;\n aobj[aspectratio + '.y'] = scene.viewInitial.aspectratio.y;\n aobj[aspectratio + '.z'] = scene.viewInitial.aspectratio.z;\n aobj[aspectmode] = scene.viewInitial.aspectmode;\n }\n }\n\n Registry.call('_guiRelayout', gd, aobj);\n}\n\nmodeBarButtons.hoverClosest3d = {\n name: 'hoverClosest3d',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: handleHover3d\n};\n\nfunction getNextHover3d(gd, ev) {\n var button = ev.currentTarget;\n var val = button._previousVal;\n var fullLayout = gd._fullLayout;\n var sceneIds = fullLayout._subplots.gl3d || [];\n\n var axes = ['xaxis', 'yaxis', 'zaxis'];\n\n // initialize 'current spike' object to be stored in the DOM\n var currentSpikes = {};\n var layoutUpdate = {};\n\n if(val) {\n layoutUpdate = val;\n button._previousVal = null;\n } else {\n for(var i = 0; i < sceneIds.length; i++) {\n var sceneId = sceneIds[i];\n var sceneLayout = fullLayout[sceneId];\n\n var hovermodeAStr = sceneId + '.hovermode';\n currentSpikes[hovermodeAStr] = sceneLayout.hovermode;\n layoutUpdate[hovermodeAStr] = false;\n\n // copy all the current spike attrs\n for(var j = 0; j < 3; j++) {\n var axis = axes[j];\n var spikeAStr = sceneId + '.' + axis + '.showspikes';\n layoutUpdate[spikeAStr] = false;\n currentSpikes[spikeAStr] = sceneLayout[axis].showspikes;\n }\n }\n\n button._previousVal = currentSpikes;\n }\n return layoutUpdate;\n}\n\nfunction handleHover3d(gd, ev) {\n var layoutUpdate = getNextHover3d(gd, ev);\n Registry.call('_guiRelayout', gd, layoutUpdate);\n}\n\nmodeBarButtons.zoomInGeo = {\n name: 'zoomInGeo',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleGeo\n};\n\nmodeBarButtons.zoomOutGeo = {\n name: 'zoomOutGeo',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleGeo\n};\n\nmodeBarButtons.resetGeo = {\n name: 'resetGeo',\n title: function(gd) { return _(gd, 'Reset'); },\n attr: 'reset',\n val: null,\n icon: Icons.autoscale,\n click: handleGeo\n};\n\nmodeBarButtons.hoverClosestGeo = {\n name: 'hoverClosestGeo',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nfunction handleGeo(gd, ev) {\n var button = ev.currentTarget;\n var attr = button.getAttribute('data-attr');\n var val = button.getAttribute('data-val') || true;\n var fullLayout = gd._fullLayout;\n var geoIds = fullLayout._subplots.geo || [];\n\n for(var i = 0; i < geoIds.length; i++) {\n var id = geoIds[i];\n var geoLayout = fullLayout[id];\n\n if(attr === 'zoom') {\n var scale = geoLayout.projection.scale;\n var newScale = (val === 'in') ? 2 * scale : 0.5 * scale;\n\n Registry.call('_guiRelayout', gd, id + '.projection.scale', newScale);\n }\n }\n\n if(attr === 'reset') {\n resetView(gd, 'geo');\n }\n}\n\nmodeBarButtons.hoverClosestGl2d = {\n name: 'hoverClosestGl2d',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nmodeBarButtons.hoverClosestPie = {\n name: 'hoverClosestPie',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: 'closest',\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: toggleHover\n};\n\nfunction getNextHover(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout.hovermode) return false;\n\n if(fullLayout._has('cartesian')) {\n return fullLayout._isHoriz ? 'y' : 'x';\n }\n return 'closest';\n}\n\nfunction toggleHover(gd) {\n var newHover = getNextHover(gd);\n Registry.call('_guiRelayout', gd, 'hovermode', newHover);\n}\n\nmodeBarButtons.resetViewSankey = {\n name: 'resetSankeyGroup',\n title: function(gd) { return _(gd, 'Reset view'); },\n icon: Icons.home,\n click: function(gd) {\n var aObj = {\n 'node.groups': [],\n 'node.x': [],\n 'node.y': []\n };\n for(var i = 0; i < gd._fullData.length; i++) {\n var viewInitial = gd._fullData[i]._viewInitial;\n aObj['node.groups'].push(viewInitial.node.groups.slice());\n aObj['node.x'].push(viewInitial.node.x.slice());\n aObj['node.y'].push(viewInitial.node.y.slice());\n }\n Registry.call('restyle', gd, aObj);\n }\n};\n\n// buttons when more then one plot types are present\n\nmodeBarButtons.toggleHover = {\n name: 'toggleHover',\n title: function(gd) { return _(gd, 'Toggle show closest data on hover'); },\n attr: 'hovermode',\n val: null,\n toggle: true,\n icon: Icons.tooltip_basic,\n gravity: 'ne',\n click: function(gd, ev) {\n var layoutUpdate = getNextHover3d(gd, ev);\n layoutUpdate.hovermode = getNextHover(gd);\n\n Registry.call('_guiRelayout', gd, layoutUpdate);\n }\n};\n\nmodeBarButtons.resetViews = {\n name: 'resetViews',\n title: function(gd) { return _(gd, 'Reset views'); },\n icon: Icons.home,\n click: function(gd, ev) {\n var button = ev.currentTarget;\n\n button.setAttribute('data-attr', 'zoom');\n button.setAttribute('data-val', 'reset');\n handleCartesian(gd, ev);\n\n button.setAttribute('data-attr', 'resetLastSave');\n handleCamera3d(gd, ev);\n\n resetView(gd, 'geo');\n resetView(gd, 'mapbox');\n }\n};\n\nmodeBarButtons.toggleSpikelines = {\n name: 'toggleSpikelines',\n title: function(gd) { return _(gd, 'Toggle Spike Lines'); },\n icon: Icons.spikeline,\n attr: '_cartesianSpikesEnabled',\n val: 'on',\n click: function(gd) {\n var fullLayout = gd._fullLayout;\n var allSpikesEnabled = fullLayout._cartesianSpikesEnabled;\n\n fullLayout._cartesianSpikesEnabled = allSpikesEnabled === 'on' ? 'off' : 'on';\n Registry.call('_guiRelayout', gd, setSpikelineVisibility(gd));\n }\n};\n\nfunction setSpikelineVisibility(gd) {\n var fullLayout = gd._fullLayout;\n var areSpikesOn = fullLayout._cartesianSpikesEnabled === 'on';\n var axList = axisIds.list(gd, null, true);\n var aobj = {};\n\n for(var i = 0; i < axList.length; i++) {\n var ax = axList[i];\n aobj[ax._name + '.showspikes'] = areSpikesOn ? true : ax._showSpikeInitial;\n }\n\n return aobj;\n}\n\nmodeBarButtons.resetViewMapbox = {\n name: 'resetViewMapbox',\n title: function(gd) { return _(gd, 'Reset view'); },\n attr: 'reset',\n icon: Icons.home,\n click: function(gd) {\n resetView(gd, 'mapbox');\n }\n};\n\nmodeBarButtons.zoomInMapbox = {\n name: 'zoomInMapbox',\n title: function(gd) { return _(gd, 'Zoom in'); },\n attr: 'zoom',\n val: 'in',\n icon: Icons.zoom_plus,\n click: handleMapboxZoom\n};\n\nmodeBarButtons.zoomOutMapbox = {\n name: 'zoomOutMapbox',\n title: function(gd) { return _(gd, 'Zoom out'); },\n attr: 'zoom',\n val: 'out',\n icon: Icons.zoom_minus,\n click: handleMapboxZoom\n};\n\nfunction handleMapboxZoom(gd, ev) {\n var button = ev.currentTarget;\n var val = button.getAttribute('data-val');\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots.mapbox || [];\n var scalar = 1.05;\n var aObj = {};\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var current = fullLayout[id].zoom;\n var next = (val === 'in') ? scalar * current : current / scalar;\n aObj[id + '.zoom'] = next;\n }\n\n Registry.call('_guiRelayout', gd, aObj);\n}\n\nfunction resetView(gd, subplotType) {\n var fullLayout = gd._fullLayout;\n var subplotIds = fullLayout._subplots[subplotType] || [];\n var aObj = {};\n\n for(var i = 0; i < subplotIds.length; i++) {\n var id = subplotIds[i];\n var subplotObj = fullLayout[id]._subplot;\n var viewInitial = subplotObj.viewInitial;\n var viewKeys = Object.keys(viewInitial);\n\n for(var j = 0; j < viewKeys.length; j++) {\n var key = viewKeys[j];\n aObj[id + '.' + key] = viewInitial[key];\n }\n }\n\n Registry.call('_guiRelayout', gd, aObj);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar calcColorscale = require('../../components/colorscale/calc');\n\nvar subTypes = require('./subtypes');\n\nmodule.exports = function calcMarkerColorscale(gd, trace) {\n if(subTypes.hasLines(trace) && hasColorscale(trace, 'line')) {\n calcColorscale(gd, trace, {\n vals: trace.line.color,\n containerStr: 'line',\n cLetter: 'c'\n });\n }\n\n if(subTypes.hasMarkers(trace)) {\n if(hasColorscale(trace, 'marker')) {\n calcColorscale(gd, trace, {\n vals: trace.marker.color,\n containerStr: 'marker',\n cLetter: 'c'\n });\n }\n if(hasColorscale(trace, 'marker.line')) {\n calcColorscale(gd, trace, {\n vals: trace.marker.line.color,\n containerStr: 'marker.line',\n cLetter: 'c'\n });\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar dash = require('../../components/drawing/attributes').dash;\n\nvar Drawing = require('../../components/drawing');\nvar constants = require('./constants');\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nmodule.exports = {\n x: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: 'Sets the x coordinates.'\n },\n x0: {\n valType: 'any',\n dflt: 0,\n role: 'info',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: [\n 'Alternate to `x`.',\n 'Builds a linear space of x coordinates.',\n 'Use with `dx`',\n 'where `x0` is the starting coordinate and `dx` the step.'\n ].join(' ')\n },\n dx: {\n valType: 'number',\n dflt: 1,\n role: 'info',\n editType: 'calc',\n anim: true,\n description: [\n 'Sets the x coordinate step.',\n 'See `x0` for more info.'\n ].join(' ')\n },\n y: {\n valType: 'data_array',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: 'Sets the y coordinates.'\n },\n y0: {\n valType: 'any',\n dflt: 0,\n role: 'info',\n editType: 'calc+clearAxisTypes',\n anim: true,\n description: [\n 'Alternate to `y`.',\n 'Builds a linear space of y coordinates.',\n 'Use with `dy`',\n 'where `y0` is the starting coordinate and `dy` the step.'\n ].join(' ')\n },\n dy: {\n valType: 'number',\n dflt: 1,\n role: 'info',\n editType: 'calc',\n anim: true,\n description: [\n 'Sets the y coordinate step.',\n 'See `y0` for more info.'\n ].join(' ')\n },\n\n stackgroup: {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several scatter traces (on the same subplot) to the same',\n 'stackgroup in order to add their y values (or their x values if',\n '`orientation` is *h*). If blank or omitted this trace will not be',\n 'stacked. Stacking also turns `fill` on by default, using *tonexty*',\n '(*tonextx*) if `orientation` is *h* (*v*) and sets the default',\n '`mode` to *lines* irrespective of point count.',\n 'You can only stack on a numeric (linear or log) axis.',\n 'Traces in a `stackgroup` will only fill to (or be filled to) other',\n 'traces in the same group. With multiple `stackgroup`s or some',\n 'traces stacked and some not, if fill-linked traces are not already',\n 'consecutive, the later ones will be pushed down in the drawing order.'\n ].join(' ')\n },\n orientation: {\n valType: 'enumerated',\n role: 'info',\n values: ['v', 'h'],\n editType: 'calc',\n description: [\n 'Only relevant when `stackgroup` is used, and only the first',\n '`orientation` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`. Sets the',\n 'stacking direction. With *v* (*h*), the y (x) values of subsequent',\n 'traces are added. Also affects the default value of `fill`.'\n ].join(' ')\n },\n groupnorm: {\n valType: 'enumerated',\n values: ['', 'fraction', 'percent'],\n dflt: '',\n role: 'info',\n editType: 'calc',\n description: [\n 'Only relevant when `stackgroup` is used, and only the first',\n '`groupnorm` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`.',\n 'Sets the normalization for the sum of this `stackgroup`.',\n 'With *fraction*, the value of each trace at each location is',\n 'divided by the sum of all trace values at that location.',\n '*percent* is the same but multiplied by 100 to show percentages.',\n 'If there are multiple subplots, or multiple `stackgroup`s on one',\n 'subplot, each will be normalized within its own set.'\n ].join(' ')\n },\n stackgaps: {\n valType: 'enumerated',\n values: ['infer zero', 'interpolate'],\n dflt: 'infer zero',\n role: 'info',\n editType: 'calc',\n description: [\n 'Only relevant when `stackgroup` is used, and only the first',\n '`stackgaps` found in the `stackgroup` will be used - including',\n 'if `visible` is *legendonly* but not if it is `false`.',\n 'Determines how we handle locations at which other traces in this',\n 'group have data but this one does not.',\n 'With *infer zero* we insert a zero at these locations.',\n 'With *interpolate* we linearly interpolate between existing',\n 'values, and extrapolate a constant beyond the existing values.'\n // TODO - implement interrupt mode\n // '*interrupt* omits this trace from the stack at this location by',\n // 'dropping abruptly, midway between the existing and missing locations.'\n ].join(' ')\n },\n\n text: {\n valType: 'string',\n role: 'info',\n dflt: '',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Sets text elements associated with each (x,y) pair.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.',\n 'If trace `hoverinfo` contains a *text* flag and *hovertext* is not set,',\n 'these elements will be seen in the hover labels.'\n ].join(' ')\n },\n\n texttemplate: texttemplateAttrs({}, {\n\n }),\n hovertext: {\n valType: 'string',\n role: 'info',\n dflt: '',\n arrayOk: true,\n editType: 'style',\n description: [\n 'Sets hover text elements associated with each (x,y) pair.',\n 'If a single string, the same string appears over',\n 'all the data points.',\n 'If an array of string, the items are mapped in order to the',\n 'this trace\\'s (x,y) coordinates.',\n 'To be seen, trace `hoverinfo` must contain a *text* flag.'\n ].join(' ')\n },\n mode: {\n valType: 'flaglist',\n flags: ['lines', 'markers', 'text'],\n extras: ['none'],\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines the drawing mode for this scatter trace.',\n 'If the provided `mode` includes *text* then the `text` elements',\n 'appear at the coordinates. Otherwise, the `text` elements',\n 'appear on hover.',\n 'If there are less than ' + constants.PTS_LINESONLY + ' points',\n 'and the trace is not stacked',\n 'then the default is *lines+markers*. Otherwise, *lines*.'\n ].join(' ')\n },\n hoveron: {\n valType: 'flaglist',\n flags: ['points', 'fills'],\n role: 'info',\n editType: 'style',\n description: [\n 'Do the hover effects highlight individual points (markers or',\n 'line points) or do they highlight filled regions?',\n 'If the fill is *toself* or *tonext* and there are no markers',\n 'or text, then the default is *fills*, otherwise it is *points*.'\n ].join(' ')\n },\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n line: {\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n anim: true,\n description: 'Sets the line color.'\n },\n width: {\n valType: 'number',\n min: 0,\n dflt: 2,\n role: 'style',\n editType: 'style',\n anim: true,\n description: 'Sets the line width (in px).'\n },\n shape: {\n valType: 'enumerated',\n values: ['linear', 'spline', 'hv', 'vh', 'hvh', 'vhv'],\n dflt: 'linear',\n role: 'style',\n editType: 'plot',\n description: [\n 'Determines the line shape.',\n 'With *spline* the lines are drawn using spline interpolation.',\n 'The other available values correspond to step-wise line shapes.'\n ].join(' ')\n },\n smoothing: {\n valType: 'number',\n min: 0,\n max: 1.3,\n dflt: 1,\n role: 'style',\n editType: 'plot',\n description: [\n 'Has an effect only if `shape` is set to *spline*',\n 'Sets the amount of smoothing.',\n '*0* corresponds to no smoothing (equivalent to a *linear* shape).'\n ].join(' ')\n },\n dash: extendFlat({}, dash, {editType: 'style'}),\n simplify: {\n valType: 'boolean',\n dflt: true,\n role: 'info',\n editType: 'plot',\n description: [\n 'Simplifies lines by removing nearly-collinear points. When transitioning',\n 'lines, it may be desirable to disable this so that the number of points',\n 'along the resulting SVG path is unaffected.'\n ].join(' ')\n },\n editType: 'plot'\n },\n\n connectgaps: {\n valType: 'boolean',\n dflt: false,\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not gaps',\n '(i.e. {nan} or missing values)',\n 'in the provided data arrays are connected.'\n ].join(' ')\n },\n cliponaxis: {\n valType: 'boolean',\n dflt: true,\n role: 'info',\n editType: 'plot',\n description: [\n 'Determines whether or not markers and text nodes',\n 'are clipped about the subplot axes.',\n 'To show markers and text nodes above axis lines and tick labels,',\n 'make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*.'\n ].join(' ')\n },\n\n fill: {\n valType: 'enumerated',\n values: ['none', 'tozeroy', 'tozerox', 'tonexty', 'tonextx', 'toself', 'tonext'],\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the area to fill with a solid color.',\n 'Defaults to *none* unless this trace is stacked, then it gets',\n '*tonexty* (*tonextx*) if `orientation` is *v* (*h*)',\n 'Use with `fillcolor` if not *none*.',\n '*tozerox* and *tozeroy* fill to x=0 and y=0 respectively.',\n '*tonextx* and *tonexty* fill between the endpoints of this',\n 'trace and the endpoints of the trace before it, connecting those',\n 'endpoints with straight lines (to make a stacked area graph);',\n 'if there is no trace before it, they behave like *tozerox* and',\n '*tozeroy*.',\n '*toself* connects the endpoints of the trace (or each segment',\n 'of the trace if it has gaps) into a closed shape.',\n '*tonext* fills the space between two traces if one completely',\n 'encloses the other (eg consecutive contour lines), and behaves like',\n '*toself* if there is no trace before it. *tonext* should not be',\n 'used if one trace does not enclose the other.',\n 'Traces in a `stackgroup` will only fill to (or be filled to) other',\n 'traces in the same group. With multiple `stackgroup`s or some',\n 'traces stacked and some not, if fill-linked traces are not already',\n 'consecutive, the later ones will be pushed down in the drawing order.'\n ].join(' ')\n },\n fillcolor: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n anim: true,\n description: [\n 'Sets the fill color.',\n 'Defaults to a half-transparent variant of the line color,',\n 'marker color, or marker line color, whichever is available.'\n ].join(' ')\n },\n marker: extendFlat({\n symbol: {\n valType: 'enumerated',\n values: Drawing.symbolList,\n dflt: 'circle',\n arrayOk: true,\n role: 'style',\n editType: 'style',\n description: [\n 'Sets the marker symbol type.',\n 'Adding 100 is equivalent to appending *-open* to a symbol name.',\n 'Adding 200 is equivalent to appending *-dot* to a symbol name.',\n 'Adding 300 is equivalent to appending *-open-dot*',\n 'or *dot-open* to a symbol name.'\n ].join(' ')\n },\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n arrayOk: true,\n role: 'style',\n editType: 'style',\n anim: true,\n description: 'Sets the marker opacity.'\n },\n size: {\n valType: 'number',\n min: 0,\n dflt: 6,\n arrayOk: true,\n role: 'style',\n editType: 'calc',\n anim: true,\n description: 'Sets the marker size (in px).'\n },\n maxdisplayed: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'plot',\n description: [\n 'Sets a maximum number of points to be drawn on the graph.',\n '*0* corresponds to no limit.'\n ].join(' ')\n },\n sizeref: {\n valType: 'number',\n dflt: 1,\n role: 'style',\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the scale factor used to determine the rendered size of',\n 'marker points. Use with `sizemin` and `sizemode`.'\n ].join(' ')\n },\n sizemin: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the minimum size (in px) of the rendered marker points.'\n ].join(' ')\n },\n sizemode: {\n valType: 'enumerated',\n values: ['diameter', 'area'],\n dflt: 'diameter',\n role: 'info',\n editType: 'calc',\n description: [\n 'Has an effect only if `marker.size` is set to a numerical array.',\n 'Sets the rule for which the data in `size` is converted',\n 'to pixels.'\n ].join(' ')\n },\n\n line: extendFlat({\n width: {\n valType: 'number',\n min: 0,\n arrayOk: true,\n role: 'style',\n editType: 'style',\n anim: true,\n description: 'Sets the width (in px) of the lines bounding the marker points.'\n },\n editType: 'calc'\n },\n colorScaleAttrs('marker.line', {anim: true})\n ),\n gradient: {\n type: {\n valType: 'enumerated',\n values: ['radial', 'horizontal', 'vertical', 'none'],\n arrayOk: true,\n dflt: 'none',\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the type of gradient used to fill the markers'\n ].join(' ')\n },\n color: {\n valType: 'color',\n arrayOk: true,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the final color of the gradient fill:',\n 'the center color for radial, the right for horizontal,',\n 'or the bottom for vertical.',\n ].join(' ')\n },\n editType: 'calc'\n },\n editType: 'calc'\n },\n colorScaleAttrs('marker', {anim: true})\n ),\n selected: {\n marker: {\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n role: 'style',\n editType: 'style',\n description: 'Sets the marker opacity of selected points.'\n },\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n description: 'Sets the marker color of selected points.'\n },\n size: {\n valType: 'number',\n min: 0,\n role: 'style',\n editType: 'style',\n description: 'Sets the marker size of selected points.'\n },\n editType: 'style'\n },\n textfont: {\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n description: 'Sets the text font color of selected points.'\n },\n editType: 'style'\n },\n editType: 'style'\n },\n unselected: {\n marker: {\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n role: 'style',\n editType: 'style',\n description: 'Sets the marker opacity of unselected points, applied only when a selection exists.'\n },\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n description: 'Sets the marker color of unselected points, applied only when a selection exists.'\n },\n size: {\n valType: 'number',\n min: 0,\n role: 'style',\n editType: 'style',\n description: 'Sets the marker size of unselected points, applied only when a selection exists.'\n },\n editType: 'style'\n },\n textfont: {\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n description: 'Sets the text font color of unselected points, applied only when a selection exists.'\n },\n editType: 'style'\n },\n editType: 'style'\n },\n\n textposition: {\n valType: 'enumerated',\n values: [\n 'top left', 'top center', 'top right',\n 'middle left', 'middle center', 'middle right',\n 'bottom left', 'bottom center', 'bottom right'\n ],\n dflt: 'middle center',\n arrayOk: true,\n role: 'style',\n editType: 'calc',\n description: [\n 'Sets the positions of the `text` elements',\n 'with respects to the (x,y) coordinates.'\n ].join(' ')\n },\n textfont: fontAttrs({\n editType: 'calc',\n colorEditType: 'style',\n arrayOk: true,\n description: 'Sets the text font.'\n }),\n\n r: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'r coordinates in scatter traces are deprecated!',\n 'Please switch to the *scatterpolar* trace type.',\n 'Sets the radial coordinates',\n 'for legacy polar chart only.'\n ].join('')\n },\n t: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 't coordinates in scatter traces are deprecated!',\n 'Please switch to the *scatterpolar* trace type.',\n 'Sets the angular coordinates',\n 'for legacy polar chart only.'\n ].join('')\n }\n};\n","module.exports = true;","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar polybool = require('polybooljs');\n\nvar Registry = require('../../registry');\nvar Color = require('../../components/color');\nvar Fx = require('../../components/fx');\n\nvar Lib = require('../../lib');\nvar polygon = require('../../lib/polygon');\nvar throttle = require('../../lib/throttle');\nvar makeEventData = require('../../components/fx/helpers').makeEventData;\nvar getFromId = require('./axis_ids').getFromId;\nvar clearGlCanvases = require('../../lib/clear_gl_canvases');\n\nvar redrawReglTraces = require('../../plot_api/subroutines').redrawReglTraces;\n\nvar constants = require('./constants');\nvar MINSELECT = constants.MINSELECT;\n\nvar filteredPolygon = polygon.filter;\nvar polygonTester = polygon.tester;\n\nfunction getAxId(ax) { return ax._id; }\n\nfunction prepSelect(e, startX, startY, dragOptions, mode) {\n var gd = dragOptions.gd;\n var fullLayout = gd._fullLayout;\n var zoomLayer = fullLayout._zoomlayer;\n var dragBBox = dragOptions.element.getBoundingClientRect();\n var plotinfo = dragOptions.plotinfo;\n var xs = plotinfo.xaxis._offset;\n var ys = plotinfo.yaxis._offset;\n var x0 = startX - dragBBox.left;\n var y0 = startY - dragBBox.top;\n var x1 = x0;\n var y1 = y0;\n var path0 = 'M' + x0 + ',' + y0;\n var pw = dragOptions.xaxes[0]._length;\n var ph = dragOptions.yaxes[0]._length;\n var allAxes = dragOptions.xaxes.concat(dragOptions.yaxes);\n var subtract = e.altKey;\n\n var filterPoly, selectionTester, mergedPolygons, currentPolygon;\n var i, searchInfo, eventData;\n\n coerceSelectionsCache(e, gd, dragOptions);\n\n if(mode === 'lasso') {\n filterPoly = filteredPolygon([[x0, y0]], constants.BENDPX);\n }\n\n var outlines = zoomLayer.selectAll('path.select-outline-' + plotinfo.id).data([1, 2]);\n\n outlines.enter()\n .append('path')\n .attr('class', function(d) { return 'select-outline select-outline-' + d + ' select-outline-' + plotinfo.id; })\n .attr('transform', 'translate(' + xs + ', ' + ys + ')')\n .attr('d', path0 + 'Z');\n\n var corners = zoomLayer.append('path')\n .attr('class', 'zoombox-corners')\n .style({\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': 1\n })\n .attr('transform', 'translate(' + xs + ', ' + ys + ')')\n .attr('d', 'M0,0Z');\n\n\n var throttleID = fullLayout._uid + constants.SELECTID;\n var selection = [];\n\n // find the traces to search for selection points\n var searchTraces = determineSearchTraces(gd, dragOptions.xaxes,\n dragOptions.yaxes, dragOptions.subplot);\n\n // in v2 (once log ranges are fixed),\n // we'll be able to p2r here for all axis types\n function p2r(ax, v) {\n return ax.type === 'log' ? ax.p2d(v) : ax.p2r(v);\n }\n\n function axValue(ax) {\n var index = (ax._id.charAt(0) === 'y') ? 1 : 0;\n return function(v) { return p2r(ax, v[index]); };\n }\n\n function ascending(a, b) { return a - b; }\n\n // allow subplots to override fillRangeItems routine\n var fillRangeItems;\n\n if(plotinfo.fillRangeItems) {\n fillRangeItems = plotinfo.fillRangeItems;\n } else {\n if(mode === 'select') {\n fillRangeItems = function(eventData, poly) {\n var ranges = eventData.range = {};\n\n for(i = 0; i < allAxes.length; i++) {\n var ax = allAxes[i];\n var axLetter = ax._id.charAt(0);\n\n ranges[ax._id] = [\n p2r(ax, poly[axLetter + 'min']),\n p2r(ax, poly[axLetter + 'max'])\n ].sort(ascending);\n }\n };\n } else {\n fillRangeItems = function(eventData, poly, filterPoly) {\n var dataPts = eventData.lassoPoints = {};\n\n for(i = 0; i < allAxes.length; i++) {\n var ax = allAxes[i];\n dataPts[ax._id] = filterPoly.filtered.map(axValue(ax));\n }\n };\n }\n }\n\n dragOptions.moveFn = function(dx0, dy0) {\n x1 = Math.max(0, Math.min(pw, dx0 + x0));\n y1 = Math.max(0, Math.min(ph, dy0 + y0));\n\n var dx = Math.abs(x1 - x0);\n var dy = Math.abs(y1 - y0);\n\n if(mode === 'select') {\n var direction = fullLayout.selectdirection;\n\n if(fullLayout.selectdirection === 'any') {\n if(dy < Math.min(dx * 0.6, MINSELECT)) direction = 'h';\n else if(dx < Math.min(dy * 0.6, MINSELECT)) direction = 'v';\n else direction = 'd';\n } else {\n direction = fullLayout.selectdirection;\n }\n\n if(direction === 'h') {\n // horizontal motion: make a vertical box\n currentPolygon = [[x0, 0], [x0, ph], [x1, ph], [x1, 0]];\n currentPolygon.xmin = Math.min(x0, x1);\n currentPolygon.xmax = Math.max(x0, x1);\n currentPolygon.ymin = Math.min(0, ph);\n currentPolygon.ymax = Math.max(0, ph);\n // extras to guide users in keeping a straight selection\n corners.attr('d', 'M' + currentPolygon.xmin + ',' + (y0 - MINSELECT) +\n 'h-4v' + (2 * MINSELECT) + 'h4Z' +\n 'M' + (currentPolygon.xmax - 1) + ',' + (y0 - MINSELECT) +\n 'h4v' + (2 * MINSELECT) + 'h-4Z');\n } else if(direction === 'v') {\n // vertical motion: make a horizontal box\n currentPolygon = [[0, y0], [0, y1], [pw, y1], [pw, y0]];\n currentPolygon.xmin = Math.min(0, pw);\n currentPolygon.xmax = Math.max(0, pw);\n currentPolygon.ymin = Math.min(y0, y1);\n currentPolygon.ymax = Math.max(y0, y1);\n corners.attr('d', 'M' + (x0 - MINSELECT) + ',' + currentPolygon.ymin +\n 'v-4h' + (2 * MINSELECT) + 'v4Z' +\n 'M' + (x0 - MINSELECT) + ',' + (currentPolygon.ymax - 1) +\n 'v4h' + (2 * MINSELECT) + 'v-4Z');\n } else if(direction === 'd') {\n // diagonal motion\n currentPolygon = [[x0, y0], [x0, y1], [x1, y1], [x1, y0]];\n currentPolygon.xmin = Math.min(x0, x1);\n currentPolygon.xmax = Math.max(x0, x1);\n currentPolygon.ymin = Math.min(y0, y1);\n currentPolygon.ymax = Math.max(y0, y1);\n corners.attr('d', 'M0,0Z');\n }\n } else if(mode === 'lasso') {\n filterPoly.addPt([x1, y1]);\n currentPolygon = filterPoly.filtered;\n }\n\n // create outline & tester\n if(dragOptions.selectionDefs && dragOptions.selectionDefs.length) {\n mergedPolygons = mergePolygons(dragOptions.mergedPolygons, currentPolygon, subtract);\n currentPolygon.subtract = subtract;\n selectionTester = multiTester(dragOptions.selectionDefs.concat([currentPolygon]));\n } else {\n mergedPolygons = [currentPolygon];\n selectionTester = polygonTester(currentPolygon);\n }\n\n // draw selection\n drawSelection(mergedPolygons, outlines);\n\n\n throttle.throttle(\n throttleID,\n constants.SELECTDELAY,\n function() {\n selection = [];\n\n var thisSelection;\n var traceSelections = [];\n var traceSelection;\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n\n traceSelection = searchInfo._module.selectPoints(searchInfo, selectionTester);\n traceSelections.push(traceSelection);\n\n thisSelection = fillSelectionItem(traceSelection, searchInfo);\n\n if(selection.length) {\n for(var j = 0; j < thisSelection.length; j++) {\n selection.push(thisSelection[j]);\n }\n } else selection = thisSelection;\n }\n\n eventData = {points: selection};\n updateSelectedState(gd, searchTraces, eventData);\n fillRangeItems(eventData, currentPolygon, filterPoly);\n dragOptions.gd.emit('plotly_selecting', eventData);\n }\n );\n };\n\n dragOptions.clickFn = function(numClicks, evt) {\n var clickmode = fullLayout.clickmode;\n\n corners.remove();\n\n throttle.done(throttleID).then(function() {\n throttle.clear(throttleID);\n if(numClicks === 2) {\n // clear selection on doubleclick\n outlines.remove();\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n searchInfo._module.selectPoints(searchInfo, false);\n }\n\n updateSelectedState(gd, searchTraces);\n\n clearSelectionsCache(dragOptions);\n\n gd.emit('plotly_deselect', null);\n } else {\n if(clickmode.indexOf('select') > -1) {\n selectOnClick(evt, gd, dragOptions.xaxes, dragOptions.yaxes,\n dragOptions.subplot, dragOptions, outlines);\n }\n\n if(clickmode === 'event') {\n // TODO: remove in v2 - this was probably never intended to work as it does,\n // but in case anyone depends on it we don't want to break it now.\n // Note that click-to-select introduced pre v2 also emitts proper\n // event data when clickmode is having 'select' in its flag list.\n gd.emit('plotly_selected', undefined);\n }\n }\n\n Fx.click(gd, evt);\n }).catch(Lib.error);\n };\n\n dragOptions.doneFn = function() {\n corners.remove();\n\n throttle.done(throttleID).then(function() {\n throttle.clear(throttleID);\n dragOptions.gd.emit('plotly_selected', eventData);\n\n if(currentPolygon && dragOptions.selectionDefs) {\n // save last polygons\n currentPolygon.subtract = subtract;\n dragOptions.selectionDefs.push(currentPolygon);\n\n // we have to keep reference to arrays container\n dragOptions.mergedPolygons.length = 0;\n [].push.apply(dragOptions.mergedPolygons, mergedPolygons);\n }\n\n if(dragOptions.doneFnCompleted) {\n dragOptions.doneFnCompleted(selection);\n }\n }).catch(Lib.error);\n };\n}\n\nfunction selectOnClick(evt, gd, xAxes, yAxes, subplot, dragOptions, polygonOutlines) {\n var hoverData = gd._hoverdata;\n var clickmode = gd._fullLayout.clickmode;\n var sendEvents = clickmode.indexOf('event') > -1;\n var selection = [];\n var searchTraces, searchInfo, currentSelectionDef, selectionTester, traceSelection;\n var thisTracesSelection, pointOrBinSelected, subtract, eventData, i;\n\n if(isHoverDataSet(hoverData)) {\n coerceSelectionsCache(evt, gd, dragOptions);\n searchTraces = determineSearchTraces(gd, xAxes, yAxes, subplot);\n var clickedPtInfo = extractClickedPtInfo(hoverData, searchTraces);\n var isBinnedTrace = clickedPtInfo.pointNumbers.length > 0;\n\n\n // Note: potentially costly operation isPointOrBinSelected is\n // called as late as possible through the use of an assignment\n // in an if condition.\n if(isBinnedTrace ?\n isOnlyThisBinSelected(searchTraces, clickedPtInfo) :\n isOnlyOnePointSelected(searchTraces) &&\n (pointOrBinSelected = isPointOrBinSelected(clickedPtInfo))) {\n if(polygonOutlines) polygonOutlines.remove();\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n searchInfo._module.selectPoints(searchInfo, false);\n }\n\n updateSelectedState(gd, searchTraces);\n\n clearSelectionsCache(dragOptions);\n\n if(sendEvents) {\n gd.emit('plotly_deselect', null);\n }\n } else {\n subtract = evt.shiftKey &&\n (pointOrBinSelected !== undefined ?\n pointOrBinSelected :\n isPointOrBinSelected(clickedPtInfo));\n currentSelectionDef = newPointSelectionDef(clickedPtInfo.pointNumber, clickedPtInfo.searchInfo, subtract);\n\n var allSelectionDefs = dragOptions.selectionDefs.concat([currentSelectionDef]);\n selectionTester = multiTester(allSelectionDefs);\n\n for(i = 0; i < searchTraces.length; i++) {\n traceSelection = searchTraces[i]._module.selectPoints(searchTraces[i], selectionTester);\n thisTracesSelection = fillSelectionItem(traceSelection, searchTraces[i]);\n\n if(selection.length) {\n for(var j = 0; j < thisTracesSelection.length; j++) {\n selection.push(thisTracesSelection[j]);\n }\n } else selection = thisTracesSelection;\n }\n\n eventData = {points: selection};\n updateSelectedState(gd, searchTraces, eventData);\n\n if(currentSelectionDef && dragOptions) {\n dragOptions.selectionDefs.push(currentSelectionDef);\n }\n\n if(polygonOutlines) drawSelection(dragOptions.mergedPolygons, polygonOutlines);\n\n if(sendEvents) {\n gd.emit('plotly_selected', eventData);\n }\n }\n }\n}\n\n/**\n * Constructs a new point selection definition object.\n */\nfunction newPointSelectionDef(pointNumber, searchInfo, subtract) {\n return {\n pointNumber: pointNumber,\n searchInfo: searchInfo,\n subtract: subtract\n };\n}\n\nfunction isPointSelectionDef(o) {\n return 'pointNumber' in o && 'searchInfo' in o;\n}\n\n/*\n * Constructs a new point number tester.\n */\nfunction newPointNumTester(pointSelectionDef) {\n return {\n xmin: 0,\n xmax: 0,\n ymin: 0,\n ymax: 0,\n pts: [],\n contains: function(pt, omitFirstEdge, pointNumber, searchInfo) {\n var idxWantedTrace = pointSelectionDef.searchInfo.cd[0].trace._expandedIndex;\n var idxActualTrace = searchInfo.cd[0].trace._expandedIndex;\n return idxActualTrace === idxWantedTrace &&\n pointNumber === pointSelectionDef.pointNumber;\n },\n isRect: false,\n degenerate: false,\n subtract: pointSelectionDef.subtract\n };\n}\n\n/**\n * Wraps multiple selection testers.\n *\n * @param {Array} list - An array of selection testers.\n *\n * @return a selection tester object with a contains function\n * that can be called to evaluate a point against all wrapped\n * selection testers that were passed in list.\n */\nfunction multiTester(list) {\n var testers = [];\n var xmin = isPointSelectionDef(list[0]) ? 0 : list[0][0][0];\n var xmax = xmin;\n var ymin = isPointSelectionDef(list[0]) ? 0 : list[0][0][1];\n var ymax = ymin;\n\n for(var i = 0; i < list.length; i++) {\n if(isPointSelectionDef(list[i])) {\n testers.push(newPointNumTester(list[i]));\n } else {\n var tester = polygon.tester(list[i]);\n tester.subtract = list[i].subtract;\n testers.push(tester);\n xmin = Math.min(xmin, tester.xmin);\n xmax = Math.max(xmax, tester.xmax);\n ymin = Math.min(ymin, tester.ymin);\n ymax = Math.max(ymax, tester.ymax);\n }\n }\n\n /**\n * Tests if the given point is within this tester.\n *\n * @param {Array} pt - [0] is the x coordinate, [1] is the y coordinate of the point.\n * @param {*} arg - An optional parameter to pass down to wrapped testers.\n * @param {number} pointNumber - The point number of the point within the underlying data array.\n * @param {number} searchInfo - An object identifying the trace the point is contained in.\n *\n * @return {boolean} true if point is considered to be selected, false otherwise.\n */\n function contains(pt, arg, pointNumber, searchInfo) {\n var contained = false;\n for(var i = 0; i < testers.length; i++) {\n if(testers[i].contains(pt, arg, pointNumber, searchInfo)) {\n // if contained by subtract tester - exclude the point\n contained = testers[i].subtract === false;\n }\n }\n\n return contained;\n }\n\n return {\n xmin: xmin,\n xmax: xmax,\n ymin: ymin,\n ymax: ymax,\n pts: [],\n contains: contains,\n isRect: false,\n degenerate: false\n };\n}\n\nfunction coerceSelectionsCache(evt, gd, dragOptions) {\n var fullLayout = gd._fullLayout;\n var plotinfo = dragOptions.plotinfo;\n\n var selectingOnSameSubplot = (\n fullLayout._lastSelectedSubplot &&\n fullLayout._lastSelectedSubplot === plotinfo.id\n );\n var hasModifierKey = evt.shiftKey || evt.altKey;\n\n if(selectingOnSameSubplot && hasModifierKey &&\n (plotinfo.selection && plotinfo.selection.selectionDefs) && !dragOptions.selectionDefs) {\n // take over selection definitions from prev mode, if any\n dragOptions.selectionDefs = plotinfo.selection.selectionDefs;\n dragOptions.mergedPolygons = plotinfo.selection.mergedPolygons;\n } else if(!hasModifierKey || !plotinfo.selection) {\n clearSelectionsCache(dragOptions);\n }\n\n // clear selection outline when selecting a different subplot\n if(!selectingOnSameSubplot) {\n clearSelect(gd);\n fullLayout._lastSelectedSubplot = plotinfo.id;\n }\n}\n\nfunction clearSelectionsCache(dragOptions) {\n var plotinfo = dragOptions.plotinfo;\n\n plotinfo.selection = {};\n plotinfo.selection.selectionDefs = dragOptions.selectionDefs = [];\n plotinfo.selection.mergedPolygons = dragOptions.mergedPolygons = [];\n}\n\nfunction determineSearchTraces(gd, xAxes, yAxes, subplot) {\n var searchTraces = [];\n var xAxisIds = xAxes.map(getAxId);\n var yAxisIds = yAxes.map(getAxId);\n var cd, trace, i;\n\n for(i = 0; i < gd.calcdata.length; i++) {\n cd = gd.calcdata[i];\n trace = cd[0].trace;\n\n if(trace.visible !== true || !trace._module || !trace._module.selectPoints) continue;\n\n if(subplot && (trace.subplot === subplot || trace.geo === subplot)) {\n searchTraces.push(createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]));\n } else if(\n trace.type === 'splom' &&\n // FIXME: make sure we don't have more than single axis for splom\n trace._xaxes[xAxisIds[0]] && trace._yaxes[yAxisIds[0]]\n ) {\n var info = createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]);\n info.scene = gd._fullLayout._splomScenes[trace.uid];\n searchTraces.push(info);\n } else if(\n trace.type === 'sankey'\n ) {\n var sankeyInfo = createSearchInfo(trace._module, cd, xAxes[0], yAxes[0]);\n searchTraces.push(sankeyInfo);\n } else {\n if(xAxisIds.indexOf(trace.xaxis) === -1) continue;\n if(yAxisIds.indexOf(trace.yaxis) === -1) continue;\n\n searchTraces.push(createSearchInfo(trace._module, cd,\n getFromId(gd, trace.xaxis), getFromId(gd, trace.yaxis)));\n }\n }\n\n return searchTraces;\n\n function createSearchInfo(module, calcData, xaxis, yaxis) {\n return {\n _module: module,\n cd: calcData,\n xaxis: xaxis,\n yaxis: yaxis\n };\n }\n}\n\nfunction drawSelection(polygons, outlines) {\n var paths = [];\n var i, d;\n\n for(i = 0; i < polygons.length; i++) {\n var ppts = polygons[i];\n paths.push(ppts.join('L') + 'L' + ppts[0]);\n }\n\n d = polygons.length > 0 ?\n 'M' + paths.join('M') + 'Z' :\n 'M0,0Z';\n outlines.attr('d', d);\n}\n\nfunction isHoverDataSet(hoverData) {\n return hoverData &&\n Array.isArray(hoverData) &&\n hoverData[0].hoverOnBox !== true;\n}\n\nfunction extractClickedPtInfo(hoverData, searchTraces) {\n var hoverDatum = hoverData[0];\n var pointNumber = -1;\n var pointNumbers = [];\n var searchInfo, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n if(hoverDatum.fullData._expandedIndex === searchInfo.cd[0].trace._expandedIndex) {\n // Special case for box (and violin)\n if(hoverDatum.hoverOnBox === true) {\n break;\n }\n\n // Hint: in some traces like histogram, one graphical element\n // doesn't correspond to one particular data point, but to\n // bins of data points. Thus, hoverDatum can have a binNumber\n // property instead of pointNumber.\n if(hoverDatum.pointNumber !== undefined) {\n pointNumber = hoverDatum.pointNumber;\n } else if(hoverDatum.binNumber !== undefined) {\n pointNumber = hoverDatum.binNumber;\n pointNumbers = hoverDatum.pointNumbers;\n }\n\n break;\n }\n }\n\n return {\n pointNumber: pointNumber,\n pointNumbers: pointNumbers,\n searchInfo: searchInfo\n };\n}\n\nfunction isPointOrBinSelected(clickedPtInfo) {\n var trace = clickedPtInfo.searchInfo.cd[0].trace;\n var ptNum = clickedPtInfo.pointNumber;\n var ptNums = clickedPtInfo.pointNumbers;\n var ptNumsSet = ptNums.length > 0;\n\n // When pointsNumbers is set (e.g. histogram's binning),\n // it is assumed that when the first point of\n // a bin is selected, all others are as well\n var ptNumToTest = ptNumsSet ? ptNums[0] : ptNum;\n\n // TODO potential performance improvement\n // Primarily we need this function to determine if a click adds\n // or subtracts from a selection.\n // In cases `trace.selectedpoints` is a huge array, indexOf\n // might be slow. One remedy would be to introduce a hash somewhere.\n return trace.selectedpoints ? trace.selectedpoints.indexOf(ptNumToTest) > -1 : false;\n}\n\nfunction isOnlyThisBinSelected(searchTraces, clickedPtInfo) {\n var tracesWithSelectedPts = [];\n var searchInfo, trace, isSameTrace, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n if(searchInfo.cd[0].trace.selectedpoints && searchInfo.cd[0].trace.selectedpoints.length > 0) {\n tracesWithSelectedPts.push(searchInfo);\n }\n }\n\n if(tracesWithSelectedPts.length === 1) {\n isSameTrace = tracesWithSelectedPts[0] === clickedPtInfo.searchInfo;\n if(isSameTrace) {\n trace = clickedPtInfo.searchInfo.cd[0].trace;\n if(trace.selectedpoints.length === clickedPtInfo.pointNumbers.length) {\n for(i = 0; i < clickedPtInfo.pointNumbers.length; i++) {\n if(trace.selectedpoints.indexOf(clickedPtInfo.pointNumbers[i]) < 0) {\n return false;\n }\n }\n return true;\n }\n }\n }\n\n return false;\n}\n\nfunction isOnlyOnePointSelected(searchTraces) {\n var len = 0;\n var searchInfo, trace, i;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n trace = searchInfo.cd[0].trace;\n if(trace.selectedpoints) {\n if(trace.selectedpoints.length > 1) return false;\n\n len += trace.selectedpoints.length;\n if(len > 1) return false;\n }\n }\n\n return len === 1;\n}\n\nfunction updateSelectedState(gd, searchTraces, eventData) {\n var i, searchInfo, cd, trace;\n\n // before anything else, update preGUI if necessary\n for(i = 0; i < searchTraces.length; i++) {\n var fullInputTrace = searchTraces[i].cd[0].trace._fullInput;\n var tracePreGUI = gd._fullLayout._tracePreGUI[fullInputTrace.uid] || {};\n if(tracePreGUI.selectedpoints === undefined) {\n tracePreGUI.selectedpoints = fullInputTrace._input.selectedpoints || null;\n }\n }\n\n if(eventData) {\n var pts = eventData.points || [];\n\n for(i = 0; i < searchTraces.length; i++) {\n trace = searchTraces[i].cd[0].trace;\n trace._input.selectedpoints = trace._fullInput.selectedpoints = [];\n if(trace._fullInput !== trace) trace.selectedpoints = [];\n }\n\n for(i = 0; i < pts.length; i++) {\n var pt = pts[i];\n var data = pt.data;\n var fullData = pt.fullData;\n\n if(pt.pointIndices) {\n [].push.apply(data.selectedpoints, pt.pointIndices);\n if(trace._fullInput !== trace) {\n [].push.apply(fullData.selectedpoints, pt.pointIndices);\n }\n } else {\n data.selectedpoints.push(pt.pointIndex);\n if(trace._fullInput !== trace) {\n fullData.selectedpoints.push(pt.pointIndex);\n }\n }\n }\n } else {\n for(i = 0; i < searchTraces.length; i++) {\n trace = searchTraces[i].cd[0].trace;\n delete trace.selectedpoints;\n delete trace._input.selectedpoints;\n if(trace._fullInput !== trace) {\n delete trace._fullInput.selectedpoints;\n }\n }\n }\n\n var hasRegl = false;\n\n for(i = 0; i < searchTraces.length; i++) {\n searchInfo = searchTraces[i];\n cd = searchInfo.cd;\n trace = cd[0].trace;\n\n if(Registry.traceIs(trace, 'regl')) {\n hasRegl = true;\n }\n\n var _module = searchInfo._module;\n var fn = _module.styleOnSelect || _module.style;\n if(fn) {\n fn(gd, cd, cd[0].node3);\n if(cd[0].nodeRangePlot3) fn(gd, cd, cd[0].nodeRangePlot3);\n }\n }\n\n if(hasRegl) {\n clearGlCanvases(gd);\n redrawReglTraces(gd);\n }\n}\n\nfunction mergePolygons(list, poly, subtract) {\n var res;\n\n if(subtract) {\n res = polybool.difference({\n regions: list,\n inverted: false\n }, {\n regions: [poly],\n inverted: false\n });\n\n return res.regions;\n }\n\n res = polybool.union({\n regions: list,\n inverted: false\n }, {\n regions: [poly],\n inverted: false\n });\n\n return res.regions;\n}\n\nfunction fillSelectionItem(selection, searchInfo) {\n if(Array.isArray(selection)) {\n var cd = searchInfo.cd;\n var trace = searchInfo.cd[0].trace;\n\n for(var i = 0; i < selection.length; i++) {\n selection[i] = makeEventData(selection[i], trace, cd);\n }\n }\n\n return selection;\n}\n\n// until we get around to persistent selections, remove the outline\n// here. The selection itself will be removed when the plot redraws\n// at the end.\nfunction clearSelect(gd) {\n var fullLayout = gd._fullLayout || {};\n var zoomlayer = fullLayout._zoomlayer;\n if(zoomlayer) {\n zoomlayer.selectAll('.select-outline').remove();\n }\n}\n\nmodule.exports = {\n prepSelect: prepSelect,\n clearSelect: clearSelect,\n selectOnClick: selectOnClick\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/**\n * Push array with unique items\n *\n * Ignores falsy items, except 0 so we can use it to construct arrays of indices.\n *\n * @param {array} array\n * array to be filled\n * @param {any} item\n * item to be or not to be inserted\n * @return {array}\n * ref to array (now possibly containing one more item)\n *\n */\nmodule.exports = function pushUnique(array, item) {\n if(item instanceof RegExp) {\n var itemStr = item.toString();\n for(var i = 0; i < array.length; i++) {\n if(array[i] instanceof RegExp && array[i].toString() === itemStr) {\n return array;\n }\n }\n array.push(item);\n } else if((item || item === 0) && array.indexOf(item) === -1) array.push(item);\n\n return array;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar Plots = require('../plots/plots');\nvar PlotSchema = require('./plot_schema');\nvar dfltConfig = require('./plot_config').dfltConfig;\n\nvar isPlainObject = Lib.isPlainObject;\nvar isArray = Array.isArray;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\n\n/**\n * Validate a data array and layout object.\n *\n * @param {array} data\n * @param {object} layout\n *\n * @return {array} array of error objects each containing:\n * - {string} code\n * error code ('object', 'array', 'schema', 'unused', 'invisible' or 'value')\n * - {string} container\n * container where the error occurs ('data' or 'layout')\n * - {number} trace\n * trace index of the 'data' container where the error occurs\n * - {array} path\n * nested path to the key that causes the error\n * - {string} astr\n * attribute string variant of 'path' compatible with Plotly.restyle and\n * Plotly.relayout.\n * - {string} msg\n * error message (shown in console in logger config argument is enable)\n */\nmodule.exports = function validate(data, layout) {\n var schema = PlotSchema.get();\n var errorList = [];\n var gd = {_context: Lib.extendFlat({}, dfltConfig)};\n\n var dataIn, layoutIn;\n\n if(isArray(data)) {\n gd.data = Lib.extendDeep([], data);\n dataIn = data;\n } else {\n gd.data = [];\n dataIn = [];\n errorList.push(format('array', 'data'));\n }\n\n if(isPlainObject(layout)) {\n gd.layout = Lib.extendDeep({}, layout);\n layoutIn = layout;\n } else {\n gd.layout = {};\n layoutIn = {};\n if(arguments.length > 1) {\n errorList.push(format('object', 'layout'));\n }\n }\n\n // N.B. dataIn and layoutIn are in general not the same as\n // gd.data and gd.layout after supplyDefaults as some attributes\n // in gd.data and gd.layout (still) get mutated during this step.\n\n Plots.supplyDefaults(gd);\n\n var dataOut = gd._fullData;\n var len = dataIn.length;\n\n for(var i = 0; i < len; i++) {\n var traceIn = dataIn[i];\n var base = ['data', i];\n\n if(!isPlainObject(traceIn)) {\n errorList.push(format('object', base));\n continue;\n }\n\n var traceOut = dataOut[i];\n var traceType = traceOut.type;\n var traceSchema = schema.traces[traceType].attributes;\n\n // PlotSchema does something fancy with trace 'type', reset it here\n // to make the trace schema compatible with Lib.validate.\n traceSchema.type = {\n valType: 'enumerated',\n values: [traceType]\n };\n\n if(traceOut.visible === false && traceIn.visible !== false) {\n errorList.push(format('invisible', base));\n }\n\n crawl(traceIn, traceOut, traceSchema, errorList, base);\n\n var transformsIn = traceIn.transforms;\n var transformsOut = traceOut.transforms;\n\n if(transformsIn) {\n if(!isArray(transformsIn)) {\n errorList.push(format('array', base, ['transforms']));\n }\n\n base.push('transforms');\n\n for(var j = 0; j < transformsIn.length; j++) {\n var path = ['transforms', j];\n var transformType = transformsIn[j].type;\n\n if(!isPlainObject(transformsIn[j])) {\n errorList.push(format('object', base, path));\n continue;\n }\n\n var transformSchema = schema.transforms[transformType] ?\n schema.transforms[transformType].attributes :\n {};\n\n // add 'type' to transform schema to validate the transform type\n transformSchema.type = {\n valType: 'enumerated',\n values: Object.keys(schema.transforms)\n };\n\n crawl(transformsIn[j], transformsOut[j], transformSchema, errorList, base, path);\n }\n }\n }\n\n var layoutOut = gd._fullLayout;\n var layoutSchema = fillLayoutSchema(schema, dataOut);\n\n crawl(layoutIn, layoutOut, layoutSchema, errorList, 'layout');\n\n // return undefined if no validation errors were found\n return (errorList.length === 0) ? void(0) : errorList;\n};\n\nfunction crawl(objIn, objOut, schema, list, base, path) {\n path = path || [];\n\n var keys = Object.keys(objIn);\n\n for(var i = 0; i < keys.length; i++) {\n var k = keys[i];\n\n // transforms are handled separately\n if(k === 'transforms') continue;\n\n var p = path.slice();\n p.push(k);\n\n var valIn = objIn[k];\n var valOut = objOut[k];\n\n var nestedSchema = getNestedSchema(schema, k);\n var nestedValType = (nestedSchema || {}).valType;\n var isInfoArray = nestedValType === 'info_array';\n var isColorscale = nestedValType === 'colorscale';\n var items = (nestedSchema || {}).items;\n\n if(!isInSchema(schema, k)) {\n list.push(format('schema', base, p));\n } else if(isPlainObject(valIn) && isPlainObject(valOut) && nestedValType !== 'any') {\n crawl(valIn, valOut, nestedSchema, list, base, p);\n } else if(isInfoArray && isArray(valIn)) {\n if(valIn.length > valOut.length) {\n list.push(format('unused', base, p.concat(valOut.length)));\n }\n var len = valOut.length;\n var arrayItems = Array.isArray(items);\n if(arrayItems) len = Math.min(len, items.length);\n var m, n, item, valInPart, valOutPart;\n if(nestedSchema.dimensions === 2) {\n for(n = 0; n < len; n++) {\n if(isArray(valIn[n])) {\n if(valIn[n].length > valOut[n].length) {\n list.push(format('unused', base, p.concat(n, valOut[n].length)));\n }\n var len2 = valOut[n].length;\n for(m = 0; m < (arrayItems ? Math.min(len2, items[n].length) : len2); m++) {\n item = arrayItems ? items[n][m] : items;\n valInPart = valIn[n][m];\n valOutPart = valOut[n][m];\n if(!Lib.validate(valInPart, item)) {\n list.push(format('value', base, p.concat(n, m), valInPart));\n } else if(valOutPart !== valInPart && valOutPart !== +valInPart) {\n list.push(format('dynamic', base, p.concat(n, m), valInPart, valOutPart));\n }\n }\n } else {\n list.push(format('array', base, p.concat(n), valIn[n]));\n }\n }\n } else {\n for(n = 0; n < len; n++) {\n item = arrayItems ? items[n] : items;\n valInPart = valIn[n];\n valOutPart = valOut[n];\n if(!Lib.validate(valInPart, item)) {\n list.push(format('value', base, p.concat(n), valInPart));\n } else if(valOutPart !== valInPart && valOutPart !== +valInPart) {\n list.push(format('dynamic', base, p.concat(n), valInPart, valOutPart));\n }\n }\n }\n } else if(nestedSchema.items && !isInfoArray && isArray(valIn)) {\n var _nestedSchema = items[Object.keys(items)[0]];\n var indexList = [];\n\n var j, _p;\n\n // loop over valOut items while keeping track of their\n // corresponding input container index (given by _index)\n for(j = 0; j < valOut.length; j++) {\n var _index = valOut[j]._index || j;\n\n _p = p.slice();\n _p.push(_index);\n\n if(isPlainObject(valIn[_index]) && isPlainObject(valOut[j])) {\n indexList.push(_index);\n var valInj = valIn[_index];\n var valOutj = valOut[j];\n if(isPlainObject(valInj) && valInj.visible !== false && valOutj.visible === false) {\n list.push(format('invisible', base, _p));\n } else crawl(valInj, valOutj, _nestedSchema, list, base, _p);\n }\n }\n\n // loop over valIn to determine where it went wrong for some items\n for(j = 0; j < valIn.length; j++) {\n _p = p.slice();\n _p.push(j);\n\n if(!isPlainObject(valIn[j])) {\n list.push(format('object', base, _p, valIn[j]));\n } else if(indexList.indexOf(j) === -1) {\n list.push(format('unused', base, _p));\n }\n }\n } else if(!isPlainObject(valIn) && isPlainObject(valOut)) {\n list.push(format('object', base, p, valIn));\n } else if(!isArrayOrTypedArray(valIn) && isArrayOrTypedArray(valOut) && !isInfoArray && !isColorscale) {\n list.push(format('array', base, p, valIn));\n } else if(!(k in objOut)) {\n list.push(format('unused', base, p, valIn));\n } else if(!Lib.validate(valIn, nestedSchema)) {\n list.push(format('value', base, p, valIn));\n } else if(nestedSchema.valType === 'enumerated' &&\n ((nestedSchema.coerceNumber && valIn !== +valOut) || valIn !== valOut)\n ) {\n list.push(format('dynamic', base, p, valIn, valOut));\n }\n }\n\n return list;\n}\n\n// the 'full' layout schema depends on the traces types presents\nfunction fillLayoutSchema(schema, dataOut) {\n var layoutSchema = schema.layout.layoutAttributes;\n\n for(var i = 0; i < dataOut.length; i++) {\n var traceOut = dataOut[i];\n var traceSchema = schema.traces[traceOut.type];\n var traceLayoutAttr = traceSchema.layoutAttributes;\n\n if(traceLayoutAttr) {\n if(traceOut.subplot) {\n Lib.extendFlat(layoutSchema[traceSchema.attributes.subplot.dflt], traceLayoutAttr);\n } else {\n Lib.extendFlat(layoutSchema, traceLayoutAttr);\n }\n }\n }\n\n return layoutSchema;\n}\n\n// validation error codes\nvar code2msgFunc = {\n object: function(base, astr) {\n var prefix;\n\n if(base === 'layout' && astr === '') prefix = 'The layout argument';\n else if(base[0] === 'data' && astr === '') {\n prefix = 'Trace ' + base[1] + ' in the data argument';\n } else prefix = inBase(base) + 'key ' + astr;\n\n return prefix + ' must be linked to an object container';\n },\n array: function(base, astr) {\n var prefix;\n\n if(base === 'data') prefix = 'The data argument';\n else prefix = inBase(base) + 'key ' + astr;\n\n return prefix + ' must be linked to an array container';\n },\n schema: function(base, astr) {\n return inBase(base) + 'key ' + astr + ' is not part of the schema';\n },\n unused: function(base, astr, valIn) {\n var target = isPlainObject(valIn) ? 'container' : 'key';\n\n return inBase(base) + target + ' ' + astr + ' did not get coerced';\n },\n dynamic: function(base, astr, valIn, valOut) {\n return [\n inBase(base) + 'key',\n astr,\n '(set to \\'' + valIn + '\\')',\n 'got reset to',\n '\\'' + valOut + '\\'',\n 'during defaults.'\n ].join(' ');\n },\n invisible: function(base, astr) {\n return (\n astr ? (inBase(base) + 'item ' + astr) : ('Trace ' + base[1])\n ) + ' got defaulted to be not visible';\n },\n value: function(base, astr, valIn) {\n return [\n inBase(base) + 'key ' + astr,\n 'is set to an invalid value (' + valIn + ')'\n ].join(' ');\n }\n};\n\nfunction inBase(base) {\n if(isArray(base)) return 'In data trace ' + base[1] + ', ';\n\n return 'In ' + base + ', ';\n}\n\nfunction format(code, base, path, valIn, valOut) {\n path = path || '';\n\n var container, trace;\n\n // container is either 'data' or 'layout\n // trace is the trace index if 'data', null otherwise\n\n if(isArray(base)) {\n container = base[0];\n trace = base[1];\n } else {\n container = base;\n trace = null;\n }\n\n var astr = convertPathToAttributeString(path);\n var msg = code2msgFunc[code](base, astr, valIn, valOut);\n\n // log to console if logger config option is enabled\n Lib.log(msg);\n\n return {\n code: code,\n container: container,\n trace: trace,\n path: path,\n astr: astr,\n msg: msg\n };\n}\n\nfunction isInSchema(schema, key) {\n var parts = splitKey(key);\n var keyMinusId = parts.keyMinusId;\n var id = parts.id;\n\n if((keyMinusId in schema) && schema[keyMinusId]._isSubplotObj && id) {\n return true;\n }\n\n return (key in schema);\n}\n\nfunction getNestedSchema(schema, key) {\n if(key in schema) return schema[key];\n\n var parts = splitKey(key);\n\n return schema[parts.keyMinusId];\n}\n\nvar idRegex = Lib.counterRegex('([a-z]+)');\n\nfunction splitKey(key) {\n var idMatch = key.match(idRegex);\n\n return {\n keyMinusId: idMatch && idMatch[1],\n id: idMatch && idMatch[2]\n };\n}\n\nfunction convertPathToAttributeString(path) {\n if(!isArray(path)) return String(path);\n\n var astr = '';\n\n for(var i = 0; i < path.length; i++) {\n var p = path[i];\n\n if(typeof p === 'number') {\n astr = astr.substr(0, astr.length - 1) + '[' + p + ']';\n } else {\n astr += p;\n }\n\n if(i < path.length - 1) astr += '.';\n }\n\n return astr;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n /**\n * Timing information for interactive elements\n */\n SHOW_PLACEHOLDER: 100,\n HIDE_PLACEHOLDER: 1000,\n\n // opacity dimming fraction for points that are not in selection\n DESELECTDIM: 0.2\n};\n","module.exports = fromQuat;\n\n/**\n * Creates a matrix from a quaternion rotation.\n *\n * @param {mat4} out mat4 receiving operation result\n * @param {quat4} q Rotation quaternion\n * @returns {mat4} out\n */\nfunction fromQuat(out, q) {\n var x = q[0], y = q[1], z = q[2], w = q[3],\n x2 = x + x,\n y2 = y + y,\n z2 = z + z,\n\n xx = x * x2,\n yx = y * x2,\n yy = y * y2,\n zx = z * x2,\n zy = z * y2,\n zz = z * z2,\n wx = w * x2,\n wy = w * y2,\n wz = w * z2;\n\n out[0] = 1 - yy - zz;\n out[1] = yx + wz;\n out[2] = zx - wy;\n out[3] = 0;\n\n out[4] = yx - wz;\n out[5] = 1 - xx - zz;\n out[6] = zy + wx;\n out[7] = 0;\n\n out[8] = zx + wy;\n out[9] = zy - wx;\n out[10] = 1 - xx - yy;\n out[11] = 0;\n\n out[12] = 0;\n out[13] = 0;\n out[14] = 0;\n out[15] = 1;\n\n return out;\n};","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\nvar attributes = require('./attributes');\n\nvar xyAttrs = {\n error_x: Lib.extendFlat({}, attributes),\n error_y: Lib.extendFlat({}, attributes)\n};\ndelete xyAttrs.error_x.copy_zstyle;\ndelete xyAttrs.error_y.copy_zstyle;\ndelete xyAttrs.error_y.copy_ystyle;\n\nvar xyzAttrs = {\n error_x: Lib.extendFlat({}, attributes),\n error_y: Lib.extendFlat({}, attributes),\n error_z: Lib.extendFlat({}, attributes)\n};\ndelete xyzAttrs.error_x.copy_ystyle;\ndelete xyzAttrs.error_y.copy_ystyle;\ndelete xyzAttrs.error_z.copy_ystyle;\ndelete xyzAttrs.error_z.copy_zstyle;\n\nmodule.exports = {\n moduleType: 'component',\n name: 'errorbars',\n\n schema: {\n traces: {\n scatter: xyAttrs,\n bar: xyAttrs,\n histogram: xyAttrs,\n scatter3d: overrideAll(xyzAttrs, 'calc', 'nested'),\n scattergl: overrideAll(xyAttrs, 'calc', 'nested')\n }\n },\n\n supplyDefaults: require('./defaults'),\n\n calc: require('./calc'),\n makeComputeError: require('./compute_error'),\n\n plot: require('./plot'),\n style: require('./style'),\n hoverInfo: hoverInfo\n};\n\nfunction hoverInfo(calcPoint, trace, hoverPoint) {\n if((trace.error_y || {}).visible) {\n hoverPoint.yerr = calcPoint.yh - calcPoint.y;\n if(!trace.error_y.symmetric) hoverPoint.yerrneg = calcPoint.y - calcPoint.ys;\n }\n if((trace.error_x || {}).visible) {\n hoverPoint.xerr = calcPoint.xh - calcPoint.x;\n if(!trace.error_x.symmetric) hoverPoint.xerrneg = calcPoint.x - calcPoint.xs;\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\n/*\n * Create or update an observer. This function is designed to be\n * idempotent so that it can be called over and over as the component\n * updates, and will attach and detach listeners as needed.\n *\n * @param {optional object} container\n * An object on which the observer is stored. This is the mechanism\n * by which it is idempotent. If it already exists, another won't be\n * added. Each time it's called, the value lookup table is updated.\n * @param {array} commandList\n * An array of commands, following either `buttons` of `updatemenus`\n * or `steps` of `sliders`.\n * @param {function} onchange\n * A listener called when the value is changed. Receives data object\n * with information about the new state.\n */\nexports.manageCommandObserver = function(gd, container, commandList, onchange) {\n var ret = {};\n var enabled = true;\n\n if(container && container._commandObserver) {\n ret = container._commandObserver;\n }\n\n if(!ret.cache) {\n ret.cache = {};\n }\n\n // Either create or just recompute this:\n ret.lookupTable = {};\n\n var binding = exports.hasSimpleAPICommandBindings(gd, commandList, ret.lookupTable);\n\n if(container && container._commandObserver) {\n if(!binding) {\n // If container exists and there are no longer any bindings,\n // remove existing:\n if(container._commandObserver.remove) {\n container._commandObserver.remove();\n container._commandObserver = null;\n return ret;\n }\n } else {\n // If container exists and there *are* bindings, then the lookup\n // table should have been updated and check is already attached,\n // so there's nothing to be done:\n return ret;\n }\n }\n\n // Determine whether there's anything to do for this binding:\n\n if(binding) {\n // Build the cache:\n bindingValueHasChanged(gd, binding, ret.cache);\n\n ret.check = function check() {\n if(!enabled) return;\n\n var update = bindingValueHasChanged(gd, binding, ret.cache);\n\n if(update.changed && onchange) {\n // Disable checks for the duration of this command in order to avoid\n // infinite loops:\n if(ret.lookupTable[update.value] !== undefined) {\n ret.disable();\n Promise.resolve(onchange({\n value: update.value,\n type: binding.type,\n prop: binding.prop,\n traces: binding.traces,\n index: ret.lookupTable[update.value]\n })).then(ret.enable, ret.enable);\n }\n }\n\n return update.changed;\n };\n\n var checkEvents = [\n 'plotly_relayout',\n 'plotly_redraw',\n 'plotly_restyle',\n 'plotly_update',\n 'plotly_animatingframe',\n 'plotly_afterplot'\n ];\n\n for(var i = 0; i < checkEvents.length; i++) {\n gd._internalOn(checkEvents[i], ret.check);\n }\n\n ret.remove = function() {\n for(var i = 0; i < checkEvents.length; i++) {\n gd._removeInternalListener(checkEvents[i], ret.check);\n }\n };\n } else {\n // TODO: It'd be really neat to actually give a *reason* for this, but at least a warning\n // is a start\n Lib.log('Unable to automatically bind plot updates to API command');\n\n ret.lookupTable = {};\n ret.remove = function() {};\n }\n\n ret.disable = function disable() {\n enabled = false;\n };\n\n ret.enable = function enable() {\n enabled = true;\n };\n\n if(container) {\n container._commandObserver = ret;\n }\n\n return ret;\n};\n\n/*\n * This function checks to see if an array of objects containing\n * method and args properties is compatible with automatic two-way\n * binding. The criteria right now are that\n *\n * 1. multiple traces may be affected\n * 2. only one property may be affected\n * 3. the same property must be affected by all commands\n */\nexports.hasSimpleAPICommandBindings = function(gd, commandList, bindingsByValue) {\n var i;\n var n = commandList.length;\n\n var refBinding;\n\n for(i = 0; i < n; i++) {\n var binding;\n var command = commandList[i];\n var method = command.method;\n var args = command.args;\n\n if(!Array.isArray(args)) args = [];\n\n // If any command has no method, refuse to bind:\n if(!method) {\n return false;\n }\n var bindings = exports.computeAPICommandBindings(gd, method, args);\n\n // Right now, handle one and *only* one property being set:\n if(bindings.length !== 1) {\n return false;\n }\n\n if(!refBinding) {\n refBinding = bindings[0];\n if(Array.isArray(refBinding.traces)) {\n refBinding.traces.sort();\n }\n } else {\n binding = bindings[0];\n if(binding.type !== refBinding.type) {\n return false;\n }\n if(binding.prop !== refBinding.prop) {\n return false;\n }\n if(Array.isArray(refBinding.traces)) {\n if(Array.isArray(binding.traces)) {\n binding.traces.sort();\n for(var j = 0; j < refBinding.traces.length; j++) {\n if(refBinding.traces[j] !== binding.traces[j]) {\n return false;\n }\n }\n } else {\n return false;\n }\n } else {\n if(binding.prop !== refBinding.prop) {\n return false;\n }\n }\n }\n\n binding = bindings[0];\n var value = binding.value;\n if(Array.isArray(value)) {\n if(value.length === 1) {\n value = value[0];\n } else {\n return false;\n }\n }\n if(bindingsByValue) {\n bindingsByValue[value] = i;\n }\n }\n\n return refBinding;\n};\n\nfunction bindingValueHasChanged(gd, binding, cache) {\n var container, value, obj;\n var changed = false;\n\n if(binding.type === 'data') {\n // If it's data, we need to get a trace. Based on the limited scope\n // of what we cover, we can just take the first trace from the list,\n // or otherwise just the first trace:\n container = gd._fullData[binding.traces !== null ? binding.traces[0] : 0];\n } else if(binding.type === 'layout') {\n container = gd._fullLayout;\n } else {\n return false;\n }\n\n value = Lib.nestedProperty(container, binding.prop).get();\n\n obj = cache[binding.type] = cache[binding.type] || {};\n\n if(obj.hasOwnProperty(binding.prop)) {\n if(obj[binding.prop] !== value) {\n changed = true;\n }\n }\n\n obj[binding.prop] = value;\n\n return {\n changed: changed,\n value: value\n };\n}\n\n/*\n * Execute an API command. There's really not much to this; it just provides\n * a common hook so that implementations don't need to be synchronized across\n * multiple components with the ability to invoke API commands.\n *\n * @param {string} method\n * The name of the plotly command to execute. Must be one of 'animate',\n * 'restyle', 'relayout', 'update'.\n * @param {array} args\n * A list of arguments passed to the API command\n */\nexports.executeAPICommand = function(gd, method, args) {\n if(method === 'skip') return Promise.resolve();\n\n var _method = Registry.apiMethodRegistry[method];\n var allArgs = [gd];\n if(!Array.isArray(args)) args = [];\n\n for(var i = 0; i < args.length; i++) {\n allArgs.push(args[i]);\n }\n\n return _method.apply(null, allArgs).catch(function(err) {\n Lib.warn('API call to Plotly.' + method + ' rejected.', err);\n return Promise.reject(err);\n });\n};\n\nexports.computeAPICommandBindings = function(gd, method, args) {\n var bindings;\n\n if(!Array.isArray(args)) args = [];\n\n switch(method) {\n case 'restyle':\n bindings = computeDataBindings(gd, args);\n break;\n case 'relayout':\n bindings = computeLayoutBindings(gd, args);\n break;\n case 'update':\n bindings = computeDataBindings(gd, [args[0], args[2]])\n .concat(computeLayoutBindings(gd, [args[1]]));\n break;\n case 'animate':\n bindings = computeAnimateBindings(gd, args);\n break;\n default:\n // This is the case where intelligent logic about what affects\n // this command is not implemented. It causes no ill effects.\n // For example, addFrames simply won't bind to a control component.\n bindings = [];\n }\n return bindings;\n};\n\nfunction computeAnimateBindings(gd, args) {\n // We'll assume that the only relevant modification an animation\n // makes that's meaningfully tracked is the frame:\n if(Array.isArray(args[0]) && args[0].length === 1 && ['string', 'number'].indexOf(typeof args[0][0]) !== -1) {\n return [{type: 'layout', prop: '_currentFrame', value: args[0][0].toString()}];\n } else {\n return [];\n }\n}\n\nfunction computeLayoutBindings(gd, args) {\n var bindings = [];\n\n var astr = args[0];\n var aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = args[1];\n } else if(Lib.isPlainObject(astr)) {\n aobj = astr;\n } else {\n return bindings;\n }\n\n crawl(aobj, function(path, attrName, attr) {\n bindings.push({type: 'layout', prop: path, value: attr});\n }, '', 0);\n\n return bindings;\n}\n\nfunction computeDataBindings(gd, args) {\n var traces, astr, val, aobj;\n var bindings = [];\n\n // Logic copied from Plotly.restyle:\n astr = args[0];\n val = args[1];\n traces = args[2];\n aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = val;\n } else if(Lib.isPlainObject(astr)) {\n // the 3-arg form\n aobj = astr;\n\n if(traces === undefined) {\n traces = val;\n }\n } else {\n return bindings;\n }\n\n if(traces === undefined) {\n // Explicitly assign this to null instead of undefined:\n traces = null;\n }\n\n crawl(aobj, function(path, attrName, _attr) {\n var thisTraces;\n var attr;\n\n if(Array.isArray(_attr)) {\n attr = _attr.slice();\n\n var nAttr = Math.min(attr.length, gd.data.length);\n if(traces) {\n nAttr = Math.min(nAttr, traces.length);\n }\n thisTraces = [];\n for(var j = 0; j < nAttr; j++) {\n thisTraces[j] = traces ? traces[j] : j;\n }\n } else {\n attr = _attr;\n thisTraces = traces ? traces.slice() : null;\n }\n\n // Convert [7] to just 7 when traces is null:\n if(thisTraces === null) {\n if(Array.isArray(attr)) {\n attr = attr[0];\n }\n } else if(Array.isArray(thisTraces)) {\n if(!Array.isArray(attr)) {\n var tmp = attr;\n attr = [];\n for(var i = 0; i < thisTraces.length; i++) {\n attr[i] = tmp;\n }\n }\n attr.length = Math.min(thisTraces.length, attr.length);\n }\n\n bindings.push({\n type: 'data',\n prop: path,\n traces: thisTraces,\n value: attr\n });\n }, '', 0);\n\n return bindings;\n}\n\nfunction crawl(attrs, callback, path, depth) {\n Object.keys(attrs).forEach(function(attrName) {\n var attr = attrs[attrName];\n\n if(attrName[0] === '_') return;\n\n var thisPath = path + (depth > 0 ? '.' : '') + attrName;\n\n if(Lib.isPlainObject(attr)) {\n crawl(attr, callback, thisPath, depth + 1);\n } else {\n // Only execute the callback on leaf nodes:\n callback(thisPath, attrName, attr);\n }\n });\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar subtypes = require('./subtypes');\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var selection = [];\n var trace = cd[0].trace;\n var i;\n var di;\n var x;\n var y;\n\n var hasOnlyLines = (!subtypes.hasMarkers(trace) && !subtypes.hasText(trace));\n if(hasOnlyLines) return [];\n\n if(selectionTester === false) { // clear selection\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n di = cd[i];\n x = xa.c2p(di.x);\n y = ya.c2p(di.y);\n\n if((di.i !== null) && selectionTester.contains([x, y], false, i, searchInfo)) {\n selection.push({\n pointNumber: di.i,\n x: xa.c2d(di.x),\n y: ya.c2d(di.y)\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Fx = require('../../components/fx');\nvar Registry = require('../../registry');\nvar Color = require('../../components/color');\n\nvar fillText = require('../../lib').fillText;\nvar getLineWidth = require('./helpers').getLineWidth;\nvar hoverLabelText = require('../../plots/cartesian/axes').hoverLabelText;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nfunction hoverPoints(pointData, xval, yval, hovermode) {\n var barPointData = hoverOnBars(pointData, xval, yval, hovermode);\n\n if(barPointData) {\n var cd = barPointData.cd;\n var trace = cd[0].trace;\n var di = cd[barPointData.index];\n\n barPointData.color = getTraceColor(trace, di);\n Registry.getComponentMethod('errorbars', 'hoverInfo')(di, trace, barPointData);\n\n return [barPointData];\n }\n}\n\nfunction hoverOnBars(pointData, xval, yval, hovermode) {\n var cd = pointData.cd;\n var trace = cd[0].trace;\n var t = cd[0].t;\n var isClosest = (hovermode === 'closest');\n var isWaterfall = (trace.type === 'waterfall');\n var maxHoverDistance = pointData.maxHoverDistance;\n\n var posVal, sizeVal, posLetter, sizeLetter, dx, dy, pRangeCalc;\n\n function thisBarMinPos(di) { return di[posLetter] - di.w / 2; }\n function thisBarMaxPos(di) { return di[posLetter] + di.w / 2; }\n\n var minPos = isClosest ?\n thisBarMinPos :\n function(di) {\n /*\n * In compare mode, accept a bar if you're on it *or* its group.\n * Nearly always it's the group that matters, but in case the bar\n * was explicitly set wider than its group we'd better accept the\n * whole bar.\n *\n * use `bardelta` instead of `bargroupwidth` so we accept hover\n * in the gap. That way hover doesn't flash on and off as you\n * mouse over the plot in compare modes.\n * In 'closest' mode though the flashing seems inevitable,\n * without far more complex logic\n */\n return Math.min(thisBarMinPos(di), di.p - t.bardelta / 2);\n };\n\n var maxPos = isClosest ?\n thisBarMaxPos :\n function(di) {\n return Math.max(thisBarMaxPos(di), di.p + t.bardelta / 2);\n };\n\n function _positionFn(_minPos, _maxPos) {\n // add a little to the pseudo-distance for wider bars, so that like scatter,\n // if you are over two overlapping bars, the narrower one wins.\n return Fx.inbox(_minPos - posVal, _maxPos - posVal,\n maxHoverDistance + Math.min(1, Math.abs(_maxPos - _minPos) / pRangeCalc) - 1);\n }\n\n function positionFn(di) {\n return _positionFn(minPos(di), maxPos(di));\n }\n\n function thisBarPositionFn(di) {\n return _positionFn(thisBarMinPos(di), thisBarMaxPos(di));\n }\n\n function sizeFn(di) {\n var v = sizeVal;\n var b = di.b;\n var s = di[sizeLetter];\n\n if(isWaterfall) {\n var rawS = Math.abs(di.rawS) || 0;\n if(v > 0) {\n s += rawS;\n } else if(v < 0) {\n s -= rawS;\n }\n }\n\n // add a gradient so hovering near the end of a\n // bar makes it a little closer match\n return Fx.inbox(b - v, s - v, maxHoverDistance + (s - v) / (s - b) - 1);\n }\n\n if(trace.orientation === 'h') {\n posVal = yval;\n sizeVal = xval;\n posLetter = 'y';\n sizeLetter = 'x';\n dx = sizeFn;\n dy = positionFn;\n } else {\n posVal = xval;\n sizeVal = yval;\n posLetter = 'x';\n sizeLetter = 'y';\n dy = sizeFn;\n dx = positionFn;\n }\n\n var pa = pointData[posLetter + 'a'];\n var sa = pointData[sizeLetter + 'a'];\n\n pRangeCalc = Math.abs(pa.r2c(pa.range[1]) - pa.r2c(pa.range[0]));\n\n function dxy(di) { return (dx(di) + dy(di)) / 2; }\n var distfn = Fx.getDistanceFunction(hovermode, dx, dy, dxy);\n Fx.getClosest(cd, distfn, pointData);\n\n // skip the rest (for this trace) if we didn't find a close point\n if(pointData.index === false) return;\n\n // skip points inside axis rangebreaks\n if(cd[pointData.index].p === BADNUM) return;\n\n // if we get here and we're not in 'closest' mode, push min/max pos back\n // onto the group - even though that means occasionally the mouse will be\n // over the hover label.\n if(!isClosest) {\n minPos = function(di) {\n return Math.min(thisBarMinPos(di), di.p - t.bargroupwidth / 2);\n };\n maxPos = function(di) {\n return Math.max(thisBarMaxPos(di), di.p + t.bargroupwidth / 2);\n };\n }\n\n // the closest data point\n var index = pointData.index;\n var di = cd[index];\n\n var size = (trace.base) ? di.b + di.s : di.s;\n pointData[sizeLetter + '0'] = pointData[sizeLetter + '1'] = sa.c2p(di[sizeLetter], true);\n pointData[sizeLetter + 'LabelVal'] = size;\n\n var extent = t.extents[t.extents.round(di.p)];\n pointData[posLetter + '0'] = pa.c2p(isClosest ? minPos(di) : extent[0], true);\n pointData[posLetter + '1'] = pa.c2p(isClosest ? maxPos(di) : extent[1], true);\n pointData[posLetter + 'LabelVal'] = di.p;\n\n pointData.labelLabel = hoverLabelText(pa, pointData[posLetter + 'LabelVal']);\n pointData.valueLabel = hoverLabelText(sa, pointData[sizeLetter + 'LabelVal']);\n\n // spikelines always want \"closest\" distance regardless of hovermode\n pointData.spikeDistance = (sizeFn(di) + thisBarPositionFn(di)) / 2 - maxHoverDistance;\n // they also want to point to the data value, regardless of where the label goes\n // in case of bars shifted within groups\n pointData[posLetter + 'Spike'] = pa.c2p(di.p, true);\n\n fillText(di, trace, pointData);\n pointData.hovertemplate = trace.hovertemplate;\n\n return pointData;\n}\n\nfunction getTraceColor(trace, di) {\n var mc = di.mcc || trace.marker.color;\n var mlc = di.mlcc || trace.marker.line.color;\n var mlw = getLineWidth(trace, di);\n\n if(Color.opacity(mc)) return mc;\n else if(Color.opacity(mlc) && mlw) return mlc;\n}\n\nmodule.exports = {\n hoverPoints: hoverPoints,\n hoverOnBars: hoverOnBars,\n getTraceColor: getTraceColor\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar mod = require('./mod').mod;\n\n/*\n * look for intersection of two line segments\n * (1->2 and 3->4) - returns array [x,y] if they do, null if not\n */\nexports.segmentsIntersect = segmentsIntersect;\nfunction segmentsIntersect(x1, y1, x2, y2, x3, y3, x4, y4) {\n var a = x2 - x1;\n var b = x3 - x1;\n var c = x4 - x3;\n var d = y2 - y1;\n var e = y3 - y1;\n var f = y4 - y3;\n var det = a * f - c * d;\n // parallel lines? intersection is undefined\n // ignore the case where they are colinear\n if(det === 0) return null;\n var t = (b * f - c * e) / det;\n var u = (b * d - a * e) / det;\n // segments do not intersect?\n if(u < 0 || u > 1 || t < 0 || t > 1) return null;\n\n return {x: x1 + a * t, y: y1 + d * t};\n}\n\n/*\n * find the minimum distance between two line segments (1->2 and 3->4)\n */\nexports.segmentDistance = function segmentDistance(x1, y1, x2, y2, x3, y3, x4, y4) {\n if(segmentsIntersect(x1, y1, x2, y2, x3, y3, x4, y4)) return 0;\n\n // the two segments and their lengths squared\n var x12 = x2 - x1;\n var y12 = y2 - y1;\n var x34 = x4 - x3;\n var y34 = y4 - y3;\n var ll12 = x12 * x12 + y12 * y12;\n var ll34 = x34 * x34 + y34 * y34;\n\n // calculate distance squared, then take the sqrt at the very end\n var dist2 = Math.min(\n perpDistance2(x12, y12, ll12, x3 - x1, y3 - y1),\n perpDistance2(x12, y12, ll12, x4 - x1, y4 - y1),\n perpDistance2(x34, y34, ll34, x1 - x3, y1 - y3),\n perpDistance2(x34, y34, ll34, x2 - x3, y2 - y3)\n );\n\n return Math.sqrt(dist2);\n};\n\n/*\n * distance squared from segment ab to point c\n * [xab, yab] is the vector b-a\n * [xac, yac] is the vector c-a\n * llab is the length squared of (b-a), just to simplify calculation\n */\nfunction perpDistance2(xab, yab, llab, xac, yac) {\n var fcAB = (xac * xab + yac * yab);\n if(fcAB < 0) {\n // point c is closer to point a\n return xac * xac + yac * yac;\n } else if(fcAB > llab) {\n // point c is closer to point b\n var xbc = xac - xab;\n var ybc = yac - yab;\n return xbc * xbc + ybc * ybc;\n } else {\n // perpendicular distance is the shortest\n var crossProduct = xac * yab - yac * xab;\n return crossProduct * crossProduct / llab;\n }\n}\n\n// a very short-term cache for getTextLocation, just because\n// we're often looping over the same locations multiple times\n// invalidated as soon as we look at a different path\nvar locationCache, workingPath, workingTextWidth;\n\n// turn a path and position along it into x, y, and angle for the given text\nexports.getTextLocation = function getTextLocation(path, totalPathLen, positionOnPath, textWidth) {\n if(path !== workingPath || textWidth !== workingTextWidth) {\n locationCache = {};\n workingPath = path;\n workingTextWidth = textWidth;\n }\n if(locationCache[positionOnPath]) {\n return locationCache[positionOnPath];\n }\n\n // for the angle, use points on the path separated by the text width\n // even though due to curvature, the text will cover a bit more than that\n var p0 = path.getPointAtLength(mod(positionOnPath - textWidth / 2, totalPathLen));\n var p1 = path.getPointAtLength(mod(positionOnPath + textWidth / 2, totalPathLen));\n // note: atan handles 1/0 nicely\n var theta = Math.atan((p1.y - p0.y) / (p1.x - p0.x));\n // center the text at 2/3 of the center position plus 1/3 the p0/p1 midpoint\n // that's the average position of this segment, assuming it's roughly quadratic\n var pCenter = path.getPointAtLength(mod(positionOnPath, totalPathLen));\n var x = (pCenter.x * 4 + p0.x + p1.x) / 6;\n var y = (pCenter.y * 4 + p0.y + p1.y) / 6;\n\n var out = {x: x, y: y, theta: theta};\n locationCache[positionOnPath] = out;\n return out;\n};\n\nexports.clearLocationCache = function() {\n workingPath = null;\n};\n\n/*\n * Find the segment of `path` that's within the visible area\n * given by `bounds` {left, right, top, bottom}, to within a\n * precision of `buffer` px\n *\n * returns: undefined if nothing is visible, else object:\n * {\n * min: position where the path first enters bounds, or 0 if it\n * starts within bounds\n * max: position where the path last exits bounds, or the path length\n * if it finishes within bounds\n * len: max - min, ie the length of visible path\n * total: the total path length - just included so the caller doesn't\n * need to call path.getTotalLength() again\n * isClosed: true iff the start and end points of the path are both visible\n * and are at the same point\n * }\n *\n * Works by starting from either end and repeatedly finding the distance from\n * that point to the plot area, and if it's outside the plot, moving along the\n * path by that distance (because the plot must be at least that far away on\n * the path). Note that if a path enters, exits, and re-enters the plot, we\n * will not capture this behavior.\n */\nexports.getVisibleSegment = function getVisibleSegment(path, bounds, buffer) {\n var left = bounds.left;\n var right = bounds.right;\n var top = bounds.top;\n var bottom = bounds.bottom;\n\n var pMin = 0;\n var pTotal = path.getTotalLength();\n var pMax = pTotal;\n\n var pt0, ptTotal;\n\n function getDistToPlot(len) {\n var pt = path.getPointAtLength(len);\n\n // hold on to the start and end points for `closed`\n if(len === 0) pt0 = pt;\n else if(len === pTotal) ptTotal = pt;\n\n var dx = (pt.x < left) ? left - pt.x : (pt.x > right ? pt.x - right : 0);\n var dy = (pt.y < top) ? top - pt.y : (pt.y > bottom ? pt.y - bottom : 0);\n return Math.sqrt(dx * dx + dy * dy);\n }\n\n var distToPlot = getDistToPlot(pMin);\n while(distToPlot) {\n pMin += distToPlot + buffer;\n if(pMin > pMax) return;\n distToPlot = getDistToPlot(pMin);\n }\n\n distToPlot = getDistToPlot(pMax);\n while(distToPlot) {\n pMax -= distToPlot + buffer;\n if(pMin > pMax) return;\n distToPlot = getDistToPlot(pMax);\n }\n\n return {\n min: pMin,\n max: pMax,\n len: pMax - pMin,\n total: pTotal,\n isClosed: pMin === 0 && pMax === pTotal &&\n Math.abs(pt0.x - ptTotal.x) < 0.1 &&\n Math.abs(pt0.y - ptTotal.y) < 0.1\n };\n};\n\n/**\n * Find point on SVG path corresponding to a given constraint coordinate\n *\n * @param {SVGPathElement} path\n * @param {Number} val : constraint coordinate value\n * @param {String} coord : 'x' or 'y' the constraint coordinate\n * @param {Object} opts :\n * - {Number} pathLength : supply total path length before hand\n * - {Number} tolerance\n * - {Number} iterationLimit\n * @return {SVGPoint}\n */\nexports.findPointOnPath = function findPointOnPath(path, val, coord, opts) {\n opts = opts || {};\n\n var pathLength = opts.pathLength || path.getTotalLength();\n var tolerance = opts.tolerance || 1e-3;\n var iterationLimit = opts.iterationLimit || 30;\n\n // if path starts at a val greater than the path tail (like on vertical violins),\n // we must flip the sign of the computed diff.\n var mul = path.getPointAtLength(0)[coord] > path.getPointAtLength(pathLength)[coord] ? -1 : 1;\n\n var i = 0;\n var b0 = 0;\n var b1 = pathLength;\n var mid;\n var pt;\n var diff;\n\n while(i < iterationLimit) {\n mid = (b0 + b1) / 2;\n pt = path.getPointAtLength(mid);\n diff = pt[coord] - val;\n\n if(Math.abs(diff) < tolerance) {\n return pt;\n } else {\n if(mul * diff > 0) {\n b1 = mid;\n } else {\n b0 = mid;\n }\n i++;\n }\n }\n return pt;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar attributes = require('./attributes');\n\n\nmodule.exports = function(traceIn, traceOut, defaultColor, opts) {\n var objName = 'error_' + opts.axis;\n var containerOut = Template.newContainer(traceOut, objName);\n var containerIn = traceIn[objName] || {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n var hasErrorBars = (\n containerIn.array !== undefined ||\n containerIn.value !== undefined ||\n containerIn.type === 'sqrt'\n );\n\n var visible = coerce('visible', hasErrorBars);\n\n if(visible === false) return;\n\n var type = coerce('type', 'array' in containerIn ? 'data' : 'percent');\n var symmetric = true;\n\n if(type !== 'sqrt') {\n symmetric = coerce('symmetric',\n !((type === 'data' ? 'arrayminus' : 'valueminus') in containerIn));\n }\n\n if(type === 'data') {\n coerce('array');\n coerce('traceref');\n if(!symmetric) {\n coerce('arrayminus');\n coerce('tracerefminus');\n }\n } else if(type === 'percent' || type === 'constant') {\n coerce('value');\n if(!symmetric) coerce('valueminus');\n }\n\n var copyAttr = 'copy_' + opts.inherit + 'style';\n if(opts.inherit) {\n var inheritObj = traceOut['error_' + opts.inherit];\n if((inheritObj || {}).visible) {\n coerce(copyAttr, !(containerIn.color ||\n isNumeric(containerIn.thickness) ||\n isNumeric(containerIn.width)));\n }\n }\n if(!opts.inherit || !containerOut[copyAttr]) {\n coerce('color', defaultColor);\n coerce('thickness');\n coerce('width', Registry.traceIs(traceOut, 'gl3d') ? 0 : 4);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Fx = require('../../components/fx');\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar extractOpts = require('../../components/colorscale').extractOpts;\n\nmodule.exports = function hoverPoints(pointData, xval, yval, hovermode, hoverLayer, contour) {\n var cd0 = pointData.cd[0];\n var trace = cd0.trace;\n var xa = pointData.xa;\n var ya = pointData.ya;\n var x = cd0.x;\n var y = cd0.y;\n var z = cd0.z;\n var xc = cd0.xCenter;\n var yc = cd0.yCenter;\n var zmask = cd0.zmask;\n var zhoverformat = trace.zhoverformat;\n var x2 = x;\n var y2 = y;\n\n var xl, yl, nx, ny;\n\n if(pointData.index !== false) {\n try {\n nx = Math.round(pointData.index[1]);\n ny = Math.round(pointData.index[0]);\n } catch(e) {\n Lib.error('Error hovering on heatmap, ' +\n 'pointNumber must be [row,col], found:', pointData.index);\n return;\n }\n if(nx < 0 || nx >= z[0].length || ny < 0 || ny > z.length) {\n return;\n }\n } else if(Fx.inbox(xval - x[0], xval - x[x.length - 1], 0) > 0 ||\n Fx.inbox(yval - y[0], yval - y[y.length - 1], 0) > 0) {\n return;\n } else {\n if(contour) {\n var i2;\n x2 = [2 * x[0] - x[1]];\n\n for(i2 = 1; i2 < x.length; i2++) {\n x2.push((x[i2] + x[i2 - 1]) / 2);\n }\n x2.push([2 * x[x.length - 1] - x[x.length - 2]]);\n\n y2 = [2 * y[0] - y[1]];\n for(i2 = 1; i2 < y.length; i2++) {\n y2.push((y[i2] + y[i2 - 1]) / 2);\n }\n y2.push([2 * y[y.length - 1] - y[y.length - 2]]);\n }\n nx = Math.max(0, Math.min(x2.length - 2, Lib.findBin(xval, x2)));\n ny = Math.max(0, Math.min(y2.length - 2, Lib.findBin(yval, y2)));\n }\n\n var x0 = xa.c2p(x[nx]);\n var x1 = xa.c2p(x[nx + 1]);\n var y0 = ya.c2p(y[ny]);\n var y1 = ya.c2p(y[ny + 1]);\n\n if(contour) {\n x1 = x0;\n xl = x[nx];\n y1 = y0;\n yl = y[ny];\n } else {\n xl = xc ? xc[nx] : ((x[nx] + x[nx + 1]) / 2);\n yl = yc ? yc[ny] : ((y[ny] + y[ny + 1]) / 2);\n\n if(xa && xa.type === 'category') xl = x[nx];\n if(ya && ya.type === 'category') yl = y[ny];\n\n if(trace.zsmooth) {\n x0 = x1 = xa.c2p(xl);\n y0 = y1 = ya.c2p(yl);\n }\n }\n\n var zVal = z[ny][nx];\n if(zmask && !zmask[ny][nx]) zVal = undefined;\n\n if(zVal === undefined && !trace.hoverongaps) return;\n\n var text;\n if(Array.isArray(cd0.hovertext) && Array.isArray(cd0.hovertext[ny])) {\n text = cd0.hovertext[ny][nx];\n } else if(Array.isArray(cd0.text) && Array.isArray(cd0.text[ny])) {\n text = cd0.text[ny][nx];\n }\n\n // dummy axis for formatting the z value\n var cOpts = extractOpts(trace);\n var dummyAx = {\n type: 'linear',\n range: [cOpts.min, cOpts.max],\n hoverformat: zhoverformat,\n _separators: xa._separators,\n _numFormat: xa._numFormat\n };\n var zLabel = Axes.tickText(dummyAx, zVal, 'hover').text;\n\n return [Lib.extendFlat(pointData, {\n index: trace._after2before ? trace._after2before[ny][nx] : [ny, nx],\n // never let a 2D override 1D type as closest point\n distance: pointData.maxHoverDistance,\n spikeDistance: pointData.maxSpikeDistance,\n x0: x0,\n x1: x1,\n y0: y0,\n y1: y1,\n xLabelVal: xl,\n yLabelVal: yl,\n zLabelVal: zVal,\n zLabel: zLabel,\n text: text\n })];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar attributes = require('./attributes');\nvar helpers = require('./helpers');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: 'shapes',\n handleItemDefaults: handleShapeDefaults\n });\n};\n\nfunction handleShapeDefaults(shapeIn, shapeOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(shapeIn, shapeOut, attributes, attr, dflt);\n }\n\n var visible = coerce('visible');\n\n if(!visible) return;\n\n coerce('layer');\n coerce('opacity');\n coerce('fillcolor');\n coerce('line.color');\n coerce('line.width');\n coerce('line.dash');\n\n var dfltType = shapeIn.path ? 'path' : 'rect';\n var shapeType = coerce('type', dfltType);\n var xSizeMode = coerce('xsizemode');\n var ySizeMode = coerce('ysizemode');\n\n // positioning\n var axLetters = ['x', 'y'];\n for(var i = 0; i < 2; i++) {\n var axLetter = axLetters[i];\n var attrAnchor = axLetter + 'anchor';\n var sizeMode = axLetter === 'x' ? xSizeMode : ySizeMode;\n var gdMock = {_fullLayout: fullLayout};\n var ax;\n var pos2r;\n var r2pos;\n\n // xref, yref\n var axRef = Axes.coerceRef(shapeIn, shapeOut, gdMock, axLetter, '', 'paper');\n\n if(axRef !== 'paper') {\n ax = Axes.getFromId(gdMock, axRef);\n ax._shapeIndices.push(shapeOut._index);\n r2pos = helpers.rangeToShapePosition(ax);\n pos2r = helpers.shapePositionToRange(ax);\n } else {\n pos2r = r2pos = Lib.identity;\n }\n\n // Coerce x0, x1, y0, y1\n if(shapeType !== 'path') {\n var dflt0 = 0.25;\n var dflt1 = 0.75;\n\n // hack until V2.0 when log has regular range behavior - make it look like other\n // ranges to send to coerce, then put it back after\n // this is all to give reasonable default position behavior on log axes, which is\n // a pretty unimportant edge case so we could just ignore this.\n var attr0 = axLetter + '0';\n var attr1 = axLetter + '1';\n var in0 = shapeIn[attr0];\n var in1 = shapeIn[attr1];\n shapeIn[attr0] = pos2r(shapeIn[attr0], true);\n shapeIn[attr1] = pos2r(shapeIn[attr1], true);\n\n if(sizeMode === 'pixel') {\n coerce(attr0, 0);\n coerce(attr1, 10);\n } else {\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attr0, dflt0);\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attr1, dflt1);\n }\n\n // hack part 2\n shapeOut[attr0] = r2pos(shapeOut[attr0]);\n shapeOut[attr1] = r2pos(shapeOut[attr1]);\n shapeIn[attr0] = in0;\n shapeIn[attr1] = in1;\n }\n\n // Coerce xanchor and yanchor\n if(sizeMode === 'pixel') {\n // Hack for log axis described above\n var inAnchor = shapeIn[attrAnchor];\n shapeIn[attrAnchor] = pos2r(shapeIn[attrAnchor], true);\n\n Axes.coercePosition(shapeOut, gdMock, coerce, axRef, attrAnchor, 0.25);\n\n // Hack part 2\n shapeOut[attrAnchor] = r2pos(shapeOut[attrAnchor]);\n shapeIn[attrAnchor] = inAnchor;\n }\n }\n\n if(shapeType === 'path') {\n coerce('path');\n } else {\n Lib.noneOrAll(shapeIn, shapeOut, ['x0', 'x1', 'y0', 'y1']);\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar counterRegex = require('../../lib/regex').counter;\n\nmodule.exports = {\n idRegex: {\n x: counterRegex('x'),\n y: counterRegex('y')\n },\n\n attrRegex: counterRegex('[xy]axis'),\n\n // axis match regular expression\n xAxisMatch: counterRegex('xaxis'),\n yAxisMatch: counterRegex('yaxis'),\n\n // pattern matching axis ids and names\n // note that this is more permissive than counterRegex, as\n // id2name, name2id, and cleanId accept \"x1\" etc\n AX_ID_PATTERN: /^[xyz][0-9]*$/,\n AX_NAME_PATTERN: /^[xyz]axis[0-9]*$/,\n\n // and for 2D subplots\n SUBPLOT_PATTERN: /^x([0-9]*)y([0-9]*)$/,\n\n HOUR_PATTERN: 'hour',\n WEEKDAY_PATTERN: 'day of week',\n\n // pixels to move mouse before you stop clamping to starting point\n MINDRAG: 8,\n\n // smallest dimension allowed for a select box\n MINSELECT: 12,\n\n // smallest dimension allowed for a zoombox\n MINZOOM: 20,\n\n // width of axis drag regions\n DRAGGERSIZE: 20,\n\n // max pixels off straight before a lasso select line counts as bent\n BENDPX: 1.5,\n\n // delay before a redraw (relayout) after smooth panning and zooming\n REDRAWDELAY: 50,\n\n // throttling limit (ms) for selectPoints calls\n SELECTDELAY: 100,\n\n // cache ID suffix for throttle\n SELECTID: '-select',\n\n // last resort axis ranges for x and y axes if we have no data\n DFLTRANGEX: [-1, 6],\n DFLTRANGEY: [-1, 4],\n\n // Layers to keep trace types in the right order\n // N.B. each 'unique' plot method must have its own layer\n traceLayerClasses: [\n 'imagelayer',\n 'heatmaplayer',\n 'contourcarpetlayer', 'contourlayer',\n 'funnellayer', 'waterfalllayer', 'barlayer',\n 'carpetlayer',\n 'violinlayer',\n 'boxlayer',\n 'ohlclayer',\n 'scattercarpetlayer', 'scatterlayer'\n ],\n\n clipOnAxisFalseQuery: [\n '.scatterlayer',\n '.barlayer',\n '.funnellayer',\n '.waterfalllayer'\n ],\n\n layerValue2layerClass: {\n 'above traces': 'above',\n 'below traces': 'below'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar resizeText = require('./uniform_text').resizeText;\nvar attributes = require('./attributes');\nvar attributeTextFont = attributes.textfont;\nvar attributeInsideTextFont = attributes.insidetextfont;\nvar attributeOutsideTextFont = attributes.outsidetextfont;\nvar helpers = require('./helpers');\n\nfunction style(gd) {\n var s = d3.select(gd).selectAll('g.barlayer').selectAll('g.trace');\n resizeText(gd, s, 'bar');\n\n var barcount = s.size();\n var fullLayout = gd._fullLayout;\n\n // trace styling\n s.style('opacity', function(d) { return d[0].trace.opacity; })\n\n // for gapless (either stacked or neighboring grouped) bars use\n // crispEdges to turn off antialiasing so an artificial gap\n // isn't introduced.\n .each(function(d) {\n if((fullLayout.barmode === 'stack' && barcount > 1) ||\n (fullLayout.bargap === 0 &&\n fullLayout.bargroupgap === 0 &&\n !d[0].trace.marker.line.width)) {\n d3.select(this).attr('shape-rendering', 'crispEdges');\n }\n });\n\n s.selectAll('g.points').each(function(d) {\n var sel = d3.select(this);\n var trace = d[0].trace;\n stylePoints(sel, trace, gd);\n });\n\n Registry.getComponentMethod('errorbars', 'style')(s);\n}\n\nfunction stylePoints(sel, trace, gd) {\n Drawing.pointStyle(sel.selectAll('path'), trace, gd);\n styleTextPoints(sel, trace, gd);\n}\n\nfunction styleTextPoints(sel, trace, gd) {\n sel.selectAll('text').each(function(d) {\n var tx = d3.select(this);\n var font = Lib.ensureUniformFontSize(gd, determineFont(tx, d, trace, gd));\n\n Drawing.font(tx, font);\n });\n}\n\nfunction styleOnSelect(gd, cd, sel) {\n var trace = cd[0].trace;\n\n if(trace.selectedpoints) {\n stylePointsInSelectionMode(sel, trace, gd);\n } else {\n stylePoints(sel, trace, gd);\n Registry.getComponentMethod('errorbars', 'style')(sel);\n }\n}\n\nfunction stylePointsInSelectionMode(s, trace, gd) {\n Drawing.selectedPointStyle(s.selectAll('path'), trace);\n styleTextInSelectionMode(s.selectAll('text'), trace, gd);\n}\n\nfunction styleTextInSelectionMode(txs, trace, gd) {\n txs.each(function(d) {\n var tx = d3.select(this);\n var font;\n\n if(d.selected) {\n font = Lib.ensureUniformFontSize(gd, determineFont(tx, d, trace, gd));\n\n var selectedFontColor = trace.selected.textfont && trace.selected.textfont.color;\n if(selectedFontColor) {\n font.color = selectedFontColor;\n }\n\n Drawing.font(tx, font);\n } else {\n Drawing.selectedTextStyle(tx, trace);\n }\n });\n}\n\nfunction determineFont(tx, d, trace, gd) {\n var layoutFont = gd._fullLayout.font;\n var textFont = trace.textfont;\n\n if(tx.classed('bartext-inside')) {\n var barColor = getBarColor(d, trace);\n textFont = getInsideTextFont(trace, d.i, layoutFont, barColor);\n } else if(tx.classed('bartext-outside')) {\n textFont = getOutsideTextFont(trace, d.i, layoutFont);\n }\n\n return textFont;\n}\n\nfunction getTextFont(trace, index, defaultValue) {\n return getFontValue(\n attributeTextFont, trace.textfont, index, defaultValue);\n}\n\nfunction getInsideTextFont(trace, index, layoutFont, barColor) {\n var defaultFont = getTextFont(trace, index, layoutFont);\n\n var wouldFallBackToLayoutFont =\n (trace._input.textfont === undefined || trace._input.textfont.color === undefined) ||\n (Array.isArray(trace.textfont.color) && trace.textfont.color[index] === undefined);\n if(wouldFallBackToLayoutFont) {\n defaultFont = {\n color: Color.contrast(barColor),\n family: defaultFont.family,\n size: defaultFont.size\n };\n }\n\n return getFontValue(\n attributeInsideTextFont, trace.insidetextfont, index, defaultFont);\n}\n\nfunction getOutsideTextFont(trace, index, layoutFont) {\n var defaultFont = getTextFont(trace, index, layoutFont);\n return getFontValue(\n attributeOutsideTextFont, trace.outsidetextfont, index, defaultFont);\n}\n\nfunction getFontValue(attributeDefinition, attributeValue, index, defaultValue) {\n attributeValue = attributeValue || {};\n\n var familyValue = helpers.getValue(attributeValue.family, index);\n var sizeValue = helpers.getValue(attributeValue.size, index);\n var colorValue = helpers.getValue(attributeValue.color, index);\n\n return {\n family: helpers.coerceString(\n attributeDefinition.family, familyValue, defaultValue.family),\n size: helpers.coerceNumber(\n attributeDefinition.size, sizeValue, defaultValue.size),\n color: helpers.coerceColor(\n attributeDefinition.color, colorValue, defaultValue.color)\n };\n}\n\nfunction getBarColor(cd, trace) {\n if(trace.type === 'waterfall') {\n return trace[cd.dir].marker.color;\n }\n return cd.mc || trace.marker.color;\n}\n\nmodule.exports = {\n style: style,\n styleTextPoints: styleTextPoints,\n styleOnSelect: styleOnSelect,\n getInsideTextFont: getInsideTextFont,\n getOutsideTextFont: getOutsideTextFont,\n getBarColor: getBarColor,\n resizeText: resizeText\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar tinycolor = require('tinycolor2');\n\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar dragElement = require('../dragelement');\nvar Lib = require('../../lib');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar setCursor = require('../../lib/setcursor');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar Titles = require('../titles');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar flipScale = require('../colorscale/helpers').flipScale;\n\nvar handleAxisDefaults = require('../../plots/cartesian/axis_defaults');\nvar handleAxisPositionDefaults = require('../../plots/cartesian/position_defaults');\nvar axisLayoutAttrs = require('../../plots/cartesian/layout_attributes');\n\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar cn = require('./constants').cn;\n\nfunction draw(gd) {\n var fullLayout = gd._fullLayout;\n\n var colorBars = fullLayout._infolayer\n .selectAll('g.' + cn.colorbar)\n .data(makeColorBarData(gd), function(opts) { return opts._id; });\n\n colorBars.enter().append('g')\n .attr('class', function(opts) { return opts._id; })\n .classed(cn.colorbar, true);\n\n colorBars.each(function(opts) {\n var g = d3.select(this);\n\n Lib.ensureSingle(g, 'rect', cn.cbbg);\n Lib.ensureSingle(g, 'g', cn.cbfills);\n Lib.ensureSingle(g, 'g', cn.cblines);\n Lib.ensureSingle(g, 'g', cn.cbaxis, function(s) { s.classed(cn.crisp, true); });\n Lib.ensureSingle(g, 'g', cn.cbtitleunshift, function(s) { s.append('g').classed(cn.cbtitle, true); });\n Lib.ensureSingle(g, 'rect', cn.cboutline);\n\n var done = drawColorBar(g, opts, gd);\n if(done && done.then) (gd._promises || []).push(done);\n\n if(gd._context.edits.colorbarPosition) {\n makeEditable(g, opts, gd);\n }\n });\n\n colorBars.exit()\n .each(function(opts) { Plots.autoMargin(gd, opts._id); })\n .remove();\n\n colorBars.order();\n}\n\nfunction makeColorBarData(gd) {\n var fullLayout = gd._fullLayout;\n var calcdata = gd.calcdata;\n var out = [];\n\n // single out item\n var opts;\n // colorbar attr parent container\n var cont;\n // trace attr container\n var trace;\n // colorbar options\n var cbOpt;\n\n function initOpts(opts) {\n return extendFlat(opts, {\n // fillcolor can be a d3 scale, domain is z values, range is colors\n // or leave it out for no fill,\n // or set to a string constant for single-color fill\n _fillcolor: null,\n // line.color has the same options as fillcolor\n _line: {color: null, width: null, dash: null},\n // levels of lines to draw.\n // note that this DOES NOT determine the extent of the bar\n // that's given by the domain of fillcolor\n // (or line.color if no fillcolor domain)\n _levels: {start: null, end: null, size: null},\n // separate fill levels (for example, heatmap coloring of a\n // contour map) if this is omitted, fillcolors will be\n // evaluated halfway between levels\n _filllevels: null,\n // for continuous colorscales: fill with a gradient instead of explicit levels\n // value should be the colorscale [[0, c0], [v1, c1], ..., [1, cEnd]]\n _fillgradient: null,\n // when using a gradient, we need the data range specified separately\n _zrange: null\n });\n }\n\n function calcOpts() {\n if(typeof cbOpt.calc === 'function') {\n cbOpt.calc(gd, trace, opts);\n } else {\n opts._fillgradient = cont.reversescale ?\n flipScale(cont.colorscale) :\n cont.colorscale;\n opts._zrange = [cont[cbOpt.min], cont[cbOpt.max]];\n }\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n trace = cd[0].trace;\n var moduleOpts = trace._module.colorbar;\n\n if(trace.visible === true && moduleOpts) {\n var allowsMultiplotCbs = Array.isArray(moduleOpts);\n var cbOpts = allowsMultiplotCbs ? moduleOpts : [moduleOpts];\n\n for(var j = 0; j < cbOpts.length; j++) {\n cbOpt = cbOpts[j];\n var contName = cbOpt.container;\n cont = contName ? trace[contName] : trace;\n\n if(cont && cont.showscale) {\n opts = initOpts(cont.colorbar);\n opts._id = 'cb' + trace.uid + (allowsMultiplotCbs && contName ? '-' + contName : '');\n opts._traceIndex = trace.index;\n opts._propPrefix = (contName ? contName + '.' : '') + 'colorbar.';\n opts._meta = trace._meta;\n calcOpts();\n out.push(opts);\n }\n }\n }\n }\n\n for(var k in fullLayout._colorAxes) {\n cont = fullLayout[k];\n\n if(cont.showscale) {\n var colorAxOpts = fullLayout._colorAxes[k];\n\n opts = initOpts(cont.colorbar);\n opts._id = 'cb' + k;\n opts._propPrefix = k + '.colorbar.';\n opts._meta = fullLayout._meta;\n\n cbOpt = {min: 'cmin', max: 'cmax'};\n if(colorAxOpts[0] !== 'heatmap') {\n trace = colorAxOpts[1];\n cbOpt.calc = trace._module.colorbar.calc;\n }\n\n calcOpts();\n out.push(opts);\n }\n }\n\n return out;\n}\n\nfunction drawColorBar(g, opts, gd) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n\n var fillColor = opts._fillcolor;\n var line = opts._line;\n var title = opts.title;\n var titleSide = title.side;\n\n var zrange = opts._zrange ||\n d3.extent((typeof fillColor === 'function' ? fillColor : line.color).domain());\n\n var lineColormap = typeof line.color === 'function' ?\n line.color :\n function() { return line.color; };\n var fillColormap = typeof fillColor === 'function' ?\n fillColor :\n function() { return fillColor; };\n\n var levelsIn = opts._levels;\n var levelsOut = calcLevels(gd, opts, zrange);\n var fillLevels = levelsOut.fill;\n var lineLevels = levelsOut.line;\n\n // we calculate pixel sizes based on the specified graph size,\n // not the actual (in case something pushed the margins around)\n // which is a little odd but avoids an odd iterative effect\n // when the colorbar itself is pushing the margins.\n // but then the fractional size is calculated based on the\n // actual graph size, so that the axes will size correctly.\n var thickPx = Math.round(opts.thickness * (opts.thicknessmode === 'fraction' ? gs.w : 1));\n var thickFrac = thickPx / gs.w;\n var lenPx = Math.round(opts.len * (opts.lenmode === 'fraction' ? gs.h : 1));\n var lenFrac = lenPx / gs.h;\n var xpadFrac = opts.xpad / gs.w;\n var yExtraPx = (opts.borderwidth + opts.outlinewidth) / 2;\n var ypadFrac = opts.ypad / gs.h;\n\n // x positioning: do it initially just for left anchor,\n // then fix at the end (since we don't know the width yet)\n var xLeft = Math.round(opts.x * gs.w + opts.xpad);\n // for dragging... this is getting a little muddled...\n var xLeftFrac = opts.x - thickFrac * ({middle: 0.5, right: 1}[opts.xanchor] || 0);\n\n // y positioning we can do correctly from the start\n var yBottomFrac = opts.y + lenFrac * (({top: -0.5, bottom: 0.5}[opts.yanchor] || 0) - 0.5);\n var yBottomPx = Math.round(gs.h * (1 - yBottomFrac));\n var yTopPx = yBottomPx - lenPx;\n\n // stash a few things for makeEditable\n opts._lenFrac = lenFrac;\n opts._thickFrac = thickFrac;\n opts._xLeftFrac = xLeftFrac;\n opts._yBottomFrac = yBottomFrac;\n\n // stash mocked axis for contour label formatting\n var ax = opts._axis = mockColorBarAxis(gd, opts, zrange);\n\n // position can't go in through supplyDefaults\n // because that restricts it to [0,1]\n ax.position = opts.x + xpadFrac + thickFrac;\n\n if(['top', 'bottom'].indexOf(titleSide) !== -1) {\n ax.title.side = titleSide;\n ax.titlex = opts.x + xpadFrac;\n ax.titley = yBottomFrac + (title.side === 'top' ? lenFrac - ypadFrac : ypadFrac);\n }\n\n if(line.color && opts.tickmode === 'auto') {\n ax.tickmode = 'linear';\n ax.tick0 = levelsIn.start;\n var dtick = levelsIn.size;\n // expand if too many contours, so we don't get too many ticks\n var autoNtick = Lib.constrain((yBottomPx - yTopPx) / 50, 4, 15) + 1;\n var dtFactor = (zrange[1] - zrange[0]) / ((opts.nticks || autoNtick) * dtick);\n if(dtFactor > 1) {\n var dtexp = Math.pow(10, Math.floor(Math.log(dtFactor) / Math.LN10));\n dtick *= dtexp * Lib.roundUp(dtFactor / dtexp, [2, 5, 10]);\n // if the contours are at round multiples, reset tick0\n // so they're still at round multiples. Otherwise,\n // keep the first label on the first contour level\n if((Math.abs(levelsIn.start) / levelsIn.size + 1e-6) % 1 < 2e-6) {\n ax.tick0 = 0;\n }\n }\n ax.dtick = dtick;\n }\n\n // set domain after init, because we may want to\n // allow it outside [0,1]\n ax.domain = [\n yBottomFrac + ypadFrac,\n yBottomFrac + lenFrac - ypadFrac\n ];\n\n ax.setScale();\n\n g.attr('transform', 'translate(' + Math.round(gs.l) + ',' + Math.round(gs.t) + ')');\n\n var titleCont = g.select('.' + cn.cbtitleunshift)\n .attr('transform', 'translate(-' + Math.round(gs.l) + ',-' + Math.round(gs.t) + ')');\n\n var axLayer = g.select('.' + cn.cbaxis);\n var titleEl;\n var titleHeight = 0;\n\n function drawTitle(titleClass, titleOpts) {\n var dfltTitleOpts = {\n propContainer: ax,\n propName: opts._propPrefix + 'title',\n traceIndex: opts._traceIndex,\n _meta: opts._meta,\n placeholder: fullLayout._dfltTitle.colorbar,\n containerGroup: g.select('.' + cn.cbtitle)\n };\n\n // this class-to-rotate thing with convertToTspans is\n // getting hackier and hackier... delete groups with the\n // wrong class (in case earlier the colorbar was drawn on\n // a different side, I think?)\n var otherClass = titleClass.charAt(0) === 'h' ?\n titleClass.substr(1) :\n 'h' + titleClass;\n g.selectAll('.' + otherClass + ',.' + otherClass + '-math-group').remove();\n\n Titles.draw(gd, titleClass, extendFlat(dfltTitleOpts, titleOpts || {}));\n }\n\n function drawDummyTitle() {\n if(['top', 'bottom'].indexOf(titleSide) !== -1) {\n // draw the title so we know how much room it needs\n // when we squish the axis. This one only applies to\n // top or bottom titles, not right side.\n var x = gs.l + (opts.x + xpadFrac) * gs.w;\n var fontSize = ax.title.font.size;\n var y;\n\n if(titleSide === 'top') {\n y = (1 - (yBottomFrac + lenFrac - ypadFrac)) * gs.h +\n gs.t + 3 + fontSize * 0.75;\n } else {\n y = (1 - (yBottomFrac + ypadFrac)) * gs.h +\n gs.t - 3 - fontSize * 0.25;\n }\n drawTitle(ax._id + 'title', {\n attributes: {x: x, y: y, 'text-anchor': 'start'}\n });\n }\n }\n\n function drawCbTitle() {\n if(['top', 'bottom'].indexOf(titleSide) === -1) {\n var fontSize = ax.title.font.size;\n var y = ax._offset + ax._length / 2;\n var x = gs.l + (ax.position || 0) * gs.w + ((ax.side === 'right') ?\n 10 + fontSize * ((ax.showticklabels ? 1 : 0.5)) :\n -10 - fontSize * ((ax.showticklabels ? 0.5 : 0)));\n\n // the 'h' + is a hack to get around the fact that\n // convertToTspans rotates any 'y...' class by 90 degrees.\n // TODO: find a better way to control this.\n drawTitle('h' + ax._id + 'title', {\n avoid: {\n selection: d3.select(gd).selectAll('g.' + ax._id + 'tick'),\n side: titleSide,\n offsetLeft: gs.l,\n offsetTop: 0,\n maxShift: fullLayout.width\n },\n attributes: {x: x, y: y, 'text-anchor': 'middle'},\n transform: {rotate: '-90', offset: 0}\n });\n }\n }\n\n function drawAxis() {\n if(['top', 'bottom'].indexOf(titleSide) !== -1) {\n // squish the axis top to make room for the title\n var titleGroup = g.select('.' + cn.cbtitle);\n var titleText = titleGroup.select('text');\n var titleTrans = [-opts.outlinewidth / 2, opts.outlinewidth / 2];\n var mathJaxNode = titleGroup\n .select('.h' + ax._id + 'title-math-group')\n .node();\n var lineSize = 15.6;\n if(titleText.node()) {\n lineSize = parseInt(titleText.node().style.fontSize, 10) * LINE_SPACING;\n }\n if(mathJaxNode) {\n titleHeight = Drawing.bBox(mathJaxNode).height;\n if(titleHeight > lineSize) {\n // not entirely sure how mathjax is doing\n // vertical alignment, but this seems to work.\n titleTrans[1] -= (titleHeight - lineSize) / 2;\n }\n } else if(titleText.node() && !titleText.classed(cn.jsPlaceholder)) {\n titleHeight = Drawing.bBox(titleText.node()).height;\n }\n if(titleHeight) {\n // buffer btwn colorbar and title\n // TODO: configurable\n titleHeight += 5;\n\n if(titleSide === 'top') {\n ax.domain[1] -= titleHeight / gs.h;\n titleTrans[1] *= -1;\n } else {\n ax.domain[0] += titleHeight / gs.h;\n var nlines = svgTextUtils.lineCount(titleText);\n titleTrans[1] += (1 - nlines) * lineSize;\n }\n\n titleGroup.attr('transform', 'translate(' + titleTrans + ')');\n ax.setScale();\n }\n }\n\n g.selectAll('.' + cn.cbfills + ',.' + cn.cblines)\n .attr('transform', 'translate(0,' + Math.round(gs.h * (1 - ax.domain[1])) + ')');\n\n axLayer.attr('transform', 'translate(0,' + Math.round(-gs.t) + ')');\n\n var fills = g.select('.' + cn.cbfills)\n .selectAll('rect.' + cn.cbfill)\n .data(fillLevels);\n fills.enter().append('rect')\n .classed(cn.cbfill, true)\n .style('stroke', 'none');\n fills.exit().remove();\n\n var zBounds = zrange\n .map(ax.c2p)\n .map(Math.round)\n .sort(function(a, b) { return a - b; });\n\n fills.each(function(d, i) {\n var z = [\n (i === 0) ? zrange[0] : (fillLevels[i] + fillLevels[i - 1]) / 2,\n (i === fillLevels.length - 1) ? zrange[1] : (fillLevels[i] + fillLevels[i + 1]) / 2\n ]\n .map(ax.c2p)\n .map(Math.round);\n\n // offset the side adjoining the next rectangle so they\n // overlap, to prevent antialiasing gaps\n z[1] = Lib.constrain(z[1] + (z[1] > z[0]) ? 1 : -1, zBounds[0], zBounds[1]);\n\n\n // Colorbar cannot currently support opacities so we\n // use an opaque fill even when alpha channels present\n var fillEl = d3.select(this).attr({\n x: xLeft,\n width: Math.max(thickPx, 2),\n y: d3.min(z),\n height: Math.max(d3.max(z) - d3.min(z), 2),\n });\n\n if(opts._fillgradient) {\n Drawing.gradient(fillEl, gd, opts._id, 'vertical', opts._fillgradient, 'fill');\n } else {\n // tinycolor can't handle exponents and\n // at this scale, removing it makes no difference.\n var colorString = fillColormap(d).replace('e-', '');\n fillEl.attr('fill', tinycolor(colorString).toHexString());\n }\n });\n\n var lines = g.select('.' + cn.cblines)\n .selectAll('path.' + cn.cbline)\n .data(line.color && line.width ? lineLevels : []);\n lines.enter().append('path')\n .classed(cn.cbline, true);\n lines.exit().remove();\n lines.each(function(d) {\n d3.select(this)\n .attr('d', 'M' + xLeft + ',' +\n (Math.round(ax.c2p(d)) + (line.width / 2) % 1) + 'h' + thickPx)\n .call(Drawing.lineGroupStyle, line.width, lineColormap(d), line.dash);\n });\n\n // force full redraw of labels and ticks\n axLayer.selectAll('g.' + ax._id + 'tick,path').remove();\n\n var shift = xLeft + thickPx +\n (opts.outlinewidth || 0) / 2 - (opts.ticks === 'outside' ? 1 : 0);\n\n var vals = Axes.calcTicks(ax);\n var transFn = Axes.makeTransFn(ax);\n var tickSign = Axes.getTickSigns(ax)[2];\n\n Axes.drawTicks(gd, ax, {\n vals: ax.ticks === 'inside' ? Axes.clipEnds(ax, vals) : vals,\n layer: axLayer,\n path: Axes.makeTickPath(ax, shift, tickSign),\n transFn: transFn\n });\n\n return Axes.drawLabels(gd, ax, {\n vals: vals,\n layer: axLayer,\n transFn: transFn,\n labelFns: Axes.makeLabelFns(ax, shift)\n });\n }\n\n // wait for the axis & title to finish rendering before\n // continuing positioning\n // TODO: why are we redrawing multiple times now with this?\n // I guess autoMargin doesn't like being post-promise?\n function positionCB() {\n var innerWidth = thickPx + opts.outlinewidth / 2 + Drawing.bBox(axLayer.node()).width;\n titleEl = titleCont.select('text');\n\n if(titleEl.node() && !titleEl.classed(cn.jsPlaceholder)) {\n var mathJaxNode = titleCont.select('.h' + ax._id + 'title-math-group').node();\n var titleWidth;\n if(mathJaxNode && ['top', 'bottom'].indexOf(titleSide) !== -1) {\n titleWidth = Drawing.bBox(mathJaxNode).width;\n } else {\n // note: the formula below works for all title sides,\n // (except for top/bottom mathjax, above)\n // but the weird gs.l is because the titleunshift\n // transform gets removed by Drawing.bBox\n titleWidth = Drawing.bBox(titleCont.node()).right - xLeft - gs.l;\n }\n innerWidth = Math.max(innerWidth, titleWidth);\n }\n\n var outerwidth = 2 * opts.xpad + innerWidth + opts.borderwidth + opts.outlinewidth / 2;\n var outerheight = yBottomPx - yTopPx;\n\n g.select('.' + cn.cbbg).attr({\n x: xLeft - opts.xpad - (opts.borderwidth + opts.outlinewidth) / 2,\n y: yTopPx - yExtraPx,\n width: Math.max(outerwidth, 2),\n height: Math.max(outerheight + 2 * yExtraPx, 2)\n })\n .call(Color.fill, opts.bgcolor)\n .call(Color.stroke, opts.bordercolor)\n .style('stroke-width', opts.borderwidth);\n\n g.selectAll('.' + cn.cboutline).attr({\n x: xLeft,\n y: yTopPx + opts.ypad + (titleSide === 'top' ? titleHeight : 0),\n width: Math.max(thickPx, 2),\n height: Math.max(outerheight - 2 * opts.ypad - titleHeight, 2)\n })\n .call(Color.stroke, opts.outlinecolor)\n .style({\n fill: 'none',\n 'stroke-width': opts.outlinewidth\n });\n\n // fix positioning for xanchor!='left'\n var xoffset = ({center: 0.5, right: 1}[opts.xanchor] || 0) * outerwidth;\n g.attr('transform', 'translate(' + (gs.l - xoffset) + ',' + gs.t + ')');\n\n // auto margin adjustment\n var marginOpts = {};\n var tFrac = FROM_TL[opts.yanchor];\n var bFrac = FROM_BR[opts.yanchor];\n if(opts.lenmode === 'pixels') {\n marginOpts.y = opts.y;\n marginOpts.t = outerheight * tFrac;\n marginOpts.b = outerheight * bFrac;\n } else {\n marginOpts.t = marginOpts.b = 0;\n marginOpts.yt = opts.y + opts.len * tFrac;\n marginOpts.yb = opts.y - opts.len * bFrac;\n }\n\n var lFrac = FROM_TL[opts.xanchor];\n var rFrac = FROM_BR[opts.xanchor];\n if(opts.thicknessmode === 'pixels') {\n marginOpts.x = opts.x;\n marginOpts.l = outerwidth * lFrac;\n marginOpts.r = outerwidth * rFrac;\n } else {\n var extraThickness = outerwidth - thickPx;\n marginOpts.l = extraThickness * lFrac;\n marginOpts.r = extraThickness * rFrac;\n marginOpts.xl = opts.x - opts.thickness * lFrac;\n marginOpts.xr = opts.x + opts.thickness * rFrac;\n }\n\n Plots.autoMargin(gd, opts._id, marginOpts);\n }\n\n return Lib.syncOrAsync([\n Plots.previousPromises,\n drawDummyTitle,\n drawAxis,\n drawCbTitle,\n Plots.previousPromises,\n positionCB\n ], gd);\n}\n\nfunction makeEditable(g, opts, gd) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n var t0, xf, yf;\n\n dragElement.init({\n element: g.node(),\n gd: gd,\n prepFn: function() {\n t0 = g.attr('transform');\n setCursor(g);\n },\n moveFn: function(dx, dy) {\n g.attr('transform', t0 + ' ' + 'translate(' + dx + ',' + dy + ')');\n\n xf = dragElement.align(opts._xLeftFrac + (dx / gs.w), opts._thickFrac,\n 0, 1, opts.xanchor);\n yf = dragElement.align(opts._yBottomFrac - (dy / gs.h), opts._lenFrac,\n 0, 1, opts.yanchor);\n\n var csr = dragElement.getCursor(xf, yf, opts.xanchor, opts.yanchor);\n setCursor(g, csr);\n },\n doneFn: function() {\n setCursor(g);\n\n if(xf !== undefined && yf !== undefined) {\n var update = {};\n update[opts._propPrefix + 'x'] = xf;\n update[opts._propPrefix + 'y'] = yf;\n if(opts._traceIndex !== undefined) {\n Registry.call('_guiRestyle', gd, update, opts._traceIndex);\n } else {\n Registry.call('_guiRelayout', gd, update);\n }\n }\n }\n });\n}\n\nfunction calcLevels(gd, opts, zrange) {\n var levelsIn = opts._levels;\n var lineLevels = [];\n var fillLevels = [];\n var l;\n var i;\n\n var l0 = levelsIn.end + levelsIn.size / 100;\n var ls = levelsIn.size;\n var zr0 = (1.001 * zrange[0] - 0.001 * zrange[1]);\n var zr1 = (1.001 * zrange[1] - 0.001 * zrange[0]);\n\n for(i = 0; i < 1e5; i++) {\n l = levelsIn.start + i * ls;\n if(ls > 0 ? (l >= l0) : (l <= l0)) break;\n if(l > zr0 && l < zr1) lineLevels.push(l);\n }\n\n if(opts._fillgradient) {\n fillLevels = [0];\n } else if(typeof opts._fillcolor === 'function') {\n var fillLevelsIn = opts._filllevels;\n\n if(fillLevelsIn) {\n l0 = fillLevelsIn.end + fillLevelsIn.size / 100;\n ls = fillLevelsIn.size;\n for(i = 0; i < 1e5; i++) {\n l = fillLevelsIn.start + i * ls;\n if(ls > 0 ? (l >= l0) : (l <= l0)) break;\n if(l > zrange[0] && l < zrange[1]) fillLevels.push(l);\n }\n } else {\n fillLevels = lineLevels.map(function(v) {\n return v - levelsIn.size / 2;\n });\n fillLevels.push(fillLevels[fillLevels.length - 1] + levelsIn.size);\n }\n } else if(opts._fillcolor && typeof opts._fillcolor === 'string') {\n // doesn't matter what this value is, with a single value\n // we'll make a single fill rect covering the whole bar\n fillLevels = [0];\n }\n\n if(levelsIn.size < 0) {\n lineLevels.reverse();\n fillLevels.reverse();\n }\n\n return {line: lineLevels, fill: fillLevels};\n}\n\nfunction mockColorBarAxis(gd, opts, zrange) {\n var fullLayout = gd._fullLayout;\n\n var cbAxisIn = {\n type: 'linear',\n range: zrange,\n tickmode: opts.tickmode,\n nticks: opts.nticks,\n tick0: opts.tick0,\n dtick: opts.dtick,\n tickvals: opts.tickvals,\n ticktext: opts.ticktext,\n ticks: opts.ticks,\n ticklen: opts.ticklen,\n tickwidth: opts.tickwidth,\n tickcolor: opts.tickcolor,\n showticklabels: opts.showticklabels,\n tickfont: opts.tickfont,\n tickangle: opts.tickangle,\n tickformat: opts.tickformat,\n exponentformat: opts.exponentformat,\n separatethousands: opts.separatethousands,\n showexponent: opts.showexponent,\n showtickprefix: opts.showtickprefix,\n tickprefix: opts.tickprefix,\n showticksuffix: opts.showticksuffix,\n ticksuffix: opts.ticksuffix,\n title: opts.title,\n showline: true,\n anchor: 'free',\n side: 'right',\n position: 1\n };\n\n var cbAxisOut = {\n type: 'linear',\n _id: 'y' + opts._id\n };\n\n var axisOptions = {\n letter: 'y',\n font: fullLayout.font,\n noHover: true,\n noTickson: true,\n calendar: fullLayout.calendar // not really necessary (yet?)\n };\n\n function coerce(attr, dflt) {\n return Lib.coerce(cbAxisIn, cbAxisOut, axisLayoutAttrs, attr, dflt);\n }\n\n handleAxisDefaults(cbAxisIn, cbAxisOut, coerce, axisOptions, fullLayout);\n handleAxisPositionDefaults(cbAxisIn, cbAxisOut, coerce, axisOptions);\n\n return cbAxisOut;\n}\n\nmodule.exports = {\n draw: draw\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar mouseOffset = require('mouse-event-offset');\nvar hasHover = require('has-hover');\nvar supportsPassive = require('has-passive-events');\n\nvar removeElement = require('../../lib').removeElement;\nvar constants = require('../../plots/cartesian/constants');\n\nvar dragElement = module.exports = {};\n\ndragElement.align = require('./align');\ndragElement.getCursor = require('./cursor');\n\nvar unhover = require('./unhover');\ndragElement.unhover = unhover.wrapped;\ndragElement.unhoverRaw = unhover.raw;\n\n/**\n * Abstracts click & drag interactions\n *\n * During the interaction, a \"coverSlip\" element - a transparent\n * div covering the whole page - is created, which has two key effects:\n * - Lets you drag beyond the boundaries of the plot itself without\n * dropping (but if you drag all the way out of the browser window the\n * interaction will end)\n * - Freezes the cursor: whatever mouse cursor the drag element had when the\n * interaction started gets copied to the coverSlip for use until mouseup\n *\n * If the user executes a drag bigger than MINDRAG, callbacks will fire as:\n * prepFn, moveFn (1 or more times), doneFn\n * If the user does not drag enough, prepFn and clickFn will fire.\n *\n * Note: If you cancel contextmenu, clickFn will fire even with a right click\n * (unlike native events) so you'll get a `plotly_click` event. Cancel context eg:\n * gd.addEventListener('contextmenu', function(e) { e.preventDefault(); });\n * TODO: we should probably turn this into a `config` parameter, so we can fix it\n * such that if you *don't* cancel contextmenu, we can prevent partial drags, which\n * put you in a weird state.\n *\n * If the user clicks multiple times quickly, clickFn will fire each time\n * but numClicks will increase to help you recognize doubleclicks.\n *\n * @param {object} options with keys:\n * element (required) the DOM element to drag\n * prepFn (optional) function(event, startX, startY)\n * executed on mousedown\n * startX and startY are the clientX and clientY pixel position\n * of the mousedown event\n * moveFn (optional) function(dx, dy)\n * executed on move, ONLY after we've exceeded MINDRAG\n * (we keep executing moveFn if you move back to where you started)\n * dx and dy are the net pixel offset of the drag,\n * dragged is true/false, has the mouse moved enough to\n * constitute a drag\n * doneFn (optional) function(e)\n * executed on mouseup, ONLY if we exceeded MINDRAG (so you can be\n * sure that moveFn has been called at least once)\n * numClicks is how many clicks we've registered within\n * a doubleclick time\n * e is the original mouseup event\n * clickFn (optional) function(numClicks, e)\n * executed on mouseup if we have NOT exceeded MINDRAG (ie moveFn\n * has not been called at all)\n * numClicks is how many clicks we've registered within\n * a doubleclick time\n * e is the original mousedown event\n * clampFn (optional, function(dx, dy) return [dx2, dy2])\n * Provide custom clamping function for small displacements.\n * By default, clamping is done using `minDrag` to x and y displacements\n * independently.\n */\ndragElement.init = function init(options) {\n var gd = options.gd;\n var numClicks = 1;\n var doubleClickDelay = gd._context.doubleClickDelay;\n var element = options.element;\n\n var startX,\n startY,\n newMouseDownTime,\n cursor,\n dragCover,\n initialEvent,\n initialTarget,\n rightClick;\n\n if(!gd._mouseDownTime) gd._mouseDownTime = 0;\n\n element.style.pointerEvents = 'all';\n\n element.onmousedown = onStart;\n\n if(!supportsPassive) {\n element.ontouchstart = onStart;\n } else {\n if(element._ontouchstart) {\n element.removeEventListener('touchstart', element._ontouchstart);\n }\n element._ontouchstart = onStart;\n element.addEventListener('touchstart', onStart, {passive: false});\n }\n\n function _clampFn(dx, dy, minDrag) {\n if(Math.abs(dx) < minDrag) dx = 0;\n if(Math.abs(dy) < minDrag) dy = 0;\n return [dx, dy];\n }\n\n var clampFn = options.clampFn || _clampFn;\n\n function onStart(e) {\n // make dragging and dragged into properties of gd\n // so that others can look at and modify them\n gd._dragged = false;\n gd._dragging = true;\n var offset = pointerOffset(e);\n startX = offset[0];\n startY = offset[1];\n initialTarget = e.target;\n initialEvent = e;\n rightClick = e.buttons === 2 || e.ctrlKey;\n\n // fix Fx.hover for touch events\n if(typeof e.clientX === 'undefined' && typeof e.clientY === 'undefined') {\n e.clientX = startX;\n e.clientY = startY;\n }\n\n newMouseDownTime = (new Date()).getTime();\n if(newMouseDownTime - gd._mouseDownTime < doubleClickDelay) {\n // in a click train\n numClicks += 1;\n } else {\n // new click train\n numClicks = 1;\n gd._mouseDownTime = newMouseDownTime;\n }\n\n if(options.prepFn) options.prepFn(e, startX, startY);\n\n if(hasHover && !rightClick) {\n dragCover = coverSlip();\n dragCover.style.cursor = window.getComputedStyle(element).cursor;\n } else if(!hasHover) {\n // document acts as a dragcover for mobile, bc we can't create dragcover dynamically\n dragCover = document;\n cursor = window.getComputedStyle(document.documentElement).cursor;\n document.documentElement.style.cursor = window.getComputedStyle(element).cursor;\n }\n\n document.addEventListener('mouseup', onDone);\n document.addEventListener('touchend', onDone);\n\n if(options.dragmode !== false) {\n e.preventDefault();\n document.addEventListener('mousemove', onMove);\n document.addEventListener('touchmove', onMove, {passive: false});\n }\n\n return;\n }\n\n function onMove(e) {\n e.preventDefault();\n\n var offset = pointerOffset(e);\n var minDrag = options.minDrag || constants.MINDRAG;\n var dxdy = clampFn(offset[0] - startX, offset[1] - startY, minDrag);\n var dx = dxdy[0];\n var dy = dxdy[1];\n\n if(dx || dy) {\n gd._dragged = true;\n dragElement.unhover(gd);\n }\n\n if(gd._dragged && options.moveFn && !rightClick) {\n gd._dragdata = {\n element: element,\n dx: dx,\n dy: dy\n };\n options.moveFn(dx, dy);\n }\n\n return;\n }\n\n function onDone(e) {\n delete gd._dragdata;\n\n if(options.dragmode !== false) {\n e.preventDefault();\n document.removeEventListener('mousemove', onMove);\n document.removeEventListener('touchmove', onMove);\n }\n\n document.removeEventListener('mouseup', onDone);\n document.removeEventListener('touchend', onDone);\n\n if(hasHover) {\n removeElement(dragCover);\n } else if(cursor) {\n dragCover.documentElement.style.cursor = cursor;\n cursor = null;\n }\n\n if(!gd._dragging) {\n gd._dragged = false;\n return;\n }\n gd._dragging = false;\n\n // don't count as a dblClick unless the mouseUp is also within\n // the dblclick delay\n if((new Date()).getTime() - gd._mouseDownTime > doubleClickDelay) {\n numClicks = Math.max(numClicks - 1, 1);\n }\n\n if(gd._dragged) {\n if(options.doneFn) options.doneFn();\n } else {\n if(options.clickFn) options.clickFn(numClicks, initialEvent);\n\n // If we haven't dragged, this should be a click. But because of the\n // coverSlip changing the element, the natural system might not generate one,\n // so we need to make our own. But right clicks don't normally generate\n // click events, only contextmenu events, which happen on mousedown.\n if(!rightClick) {\n var e2;\n\n try {\n e2 = new MouseEvent('click', e);\n } catch(err) {\n var offset = pointerOffset(e);\n e2 = document.createEvent('MouseEvents');\n e2.initMouseEvent('click',\n e.bubbles, e.cancelable,\n e.view, e.detail,\n e.screenX, e.screenY,\n offset[0], offset[1],\n e.ctrlKey, e.altKey, e.shiftKey, e.metaKey,\n e.button, e.relatedTarget);\n }\n\n initialTarget.dispatchEvent(e2);\n }\n }\n\n gd._dragging = false;\n gd._dragged = false;\n return;\n }\n};\n\nfunction coverSlip() {\n var cover = document.createElement('div');\n\n cover.className = 'dragcover';\n var cStyle = cover.style;\n cStyle.position = 'fixed';\n cStyle.left = 0;\n cStyle.right = 0;\n cStyle.top = 0;\n cStyle.bottom = 0;\n cStyle.zIndex = 999999999;\n cStyle.background = 'none';\n\n document.body.appendChild(cover);\n\n return cover;\n}\n\ndragElement.coverSlip = coverSlip;\n\nfunction pointerOffset(e) {\n return mouseOffset(\n e.changedTouches ? e.changedTouches[0] : e,\n document.body\n );\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nmodule.exports = {\n container: 'marker',\n min: 'cmin',\n max: 'cmax'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar loggers = require('./loggers');\nvar identity = require('./identity');\n\n// don't trust floating point equality - fraction of bin size to call\n// \"on the line\" and ensure that they go the right way specified by\n// linelow\nvar roundingError = 1e-9;\n\n\n/**\n * findBin - find the bin for val - note that it can return outside the\n * bin range any pos. or neg. integer for linear bins, or -1 or\n * bins.length-1 for explicit.\n * bins is either an object {start,size,end} or an array length #bins+1\n * bins can be either increasing or decreasing but must be monotonic\n * for linear bins, we can just calculate. For listed bins, run a binary\n * search linelow (truthy) says the bin boundary should be attributed to\n * the lower bin rather than the default upper bin\n */\nexports.findBin = function(val, bins, linelow) {\n if(isNumeric(bins.start)) {\n return linelow ?\n Math.ceil((val - bins.start) / bins.size - roundingError) - 1 :\n Math.floor((val - bins.start) / bins.size + roundingError);\n } else {\n var n1 = 0;\n var n2 = bins.length;\n var c = 0;\n var binSize = (n2 > 1) ? (bins[n2 - 1] - bins[0]) / (n2 - 1) : 1;\n var n, test;\n if(binSize >= 0) {\n test = linelow ? lessThan : lessOrEqual;\n } else {\n test = linelow ? greaterOrEqual : greaterThan;\n }\n val += binSize * roundingError * (linelow ? -1 : 1) * (binSize >= 0 ? 1 : -1);\n // c is just to avoid infinite loops if there's an error\n while(n1 < n2 && c++ < 100) {\n n = Math.floor((n1 + n2) / 2);\n if(test(bins[n], val)) n1 = n + 1;\n else n2 = n;\n }\n if(c > 90) loggers.log('Long binary search...');\n return n1 - 1;\n }\n};\n\nfunction lessThan(a, b) { return a < b; }\nfunction lessOrEqual(a, b) { return a <= b; }\nfunction greaterThan(a, b) { return a > b; }\nfunction greaterOrEqual(a, b) { return a >= b; }\n\nexports.sorterAsc = function(a, b) { return a - b; };\nexports.sorterDes = function(a, b) { return b - a; };\n\n/**\n * find distinct values in an array, lumping together ones that appear to\n * just be off by a rounding error\n * return the distinct values and the minimum difference between any two\n */\nexports.distinctVals = function(valsIn) {\n var vals = valsIn.slice(); // otherwise we sort the original array...\n vals.sort(exports.sorterAsc);\n\n var l = vals.length - 1;\n var minDiff = (vals[l] - vals[0]) || 1;\n var errDiff = minDiff / (l || 1) / 10000;\n var v2 = [vals[0]];\n\n for(var i = 0; i < l; i++) {\n // make sure values aren't just off by a rounding error\n if(vals[i + 1] > vals[i] + errDiff) {\n minDiff = Math.min(minDiff, vals[i + 1] - vals[i]);\n v2.push(vals[i + 1]);\n }\n }\n\n return {vals: v2, minDiff: minDiff};\n};\n\n/**\n * return the smallest element from (sorted) array arrayIn that's bigger than val,\n * or (reverse) the largest element smaller than val\n * used to find the best tick given the minimum (non-rounded) tick\n * particularly useful for date/time where things are not powers of 10\n * binary search is probably overkill here...\n */\nexports.roundUp = function(val, arrayIn, reverse) {\n var low = 0;\n var high = arrayIn.length - 1;\n var mid;\n var c = 0;\n var dlow = reverse ? 0 : 1;\n var dhigh = reverse ? 1 : 0;\n var rounded = reverse ? Math.ceil : Math.floor;\n // c is just to avoid infinite loops if there's an error\n while(low < high && c++ < 100) {\n mid = rounded((low + high) / 2);\n if(arrayIn[mid] <= val) low = mid + dlow;\n else high = mid - dhigh;\n }\n return arrayIn[low];\n};\n\n/**\n * Tweak to Array.sort(sortFn) that improves performance for pre-sorted arrays\n *\n * Note that newer browsers (such as Chrome v70+) are starting to pick up\n * on pre-sorted arrays which may render the following optimization unnecessary\n * in the future.\n *\n * Motivation: sometimes we need to sort arrays but the input is likely to\n * already be sorted. Browsers don't seem to pick up on pre-sorted arrays,\n * and in fact Chrome is actually *slower* sorting pre-sorted arrays than purely\n * random arrays. FF is at least faster if the array is pre-sorted, but still\n * not as fast as it could be.\n * Here's how this plays out sorting a length-1e6 array:\n *\n * Calls to Sort FN | Chrome bare | FF bare | Chrome tweak | FF tweak\n * | v68.0 Mac | v61.0 Mac| |\n * ------------------+---------------+-----------+----------------+------------\n * ordered | 30.4e6 | 10.1e6 | 1e6 | 1e6\n * reversed | 29.4e6 | 9.9e6 | 1e6 + reverse | 1e6 + reverse\n * random | ~21e6 | ~18.7e6 | ~21e6 | ~18.7e6\n *\n * So this is a substantial win for pre-sorted (ordered or exactly reversed)\n * arrays. Including this wrapper on an unsorted array adds a penalty that will\n * in general be only a few calls to the sort function. The only case this\n * penalty will be significant is if the array is mostly sorted but there are\n * a few unsorted items near the end, but the penalty is still at most N calls\n * out of (for N=1e6) ~20N total calls\n *\n * @param {Array} array: the array, to be sorted in place\n * @param {function} sortFn: As in Array.sort, function(a, b) that puts\n * item a before item b if the return is negative, a after b if positive,\n * and no change if zero.\n * @return {Array}: the original array, sorted in place.\n */\nexports.sort = function(array, sortFn) {\n var notOrdered = 0;\n var notReversed = 0;\n for(var i = 1; i < array.length; i++) {\n var pairOrder = sortFn(array[i], array[i - 1]);\n if(pairOrder < 0) notOrdered = 1;\n else if(pairOrder > 0) notReversed = 1;\n if(notOrdered && notReversed) return array.sort(sortFn);\n }\n return notReversed ? array : array.reverse();\n};\n\n/**\n * find index in array 'arr' that minimizes 'fn'\n *\n * @param {array} arr : array where to search\n * @param {fn (optional)} fn : function to minimize,\n * if not given, fn is the identity function\n * @return {integer}\n */\nexports.findIndexOfMin = function(arr, fn) {\n fn = fn || identity;\n\n var min = Infinity;\n var ind;\n\n for(var i = 0; i < arr.length; i++) {\n var v = fn(arr[i]);\n if(v < min) {\n min = v;\n ind = i;\n }\n }\n return ind;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nfunction xformMatrix(m, v) {\n var out = [0, 0, 0, 0];\n var i, j;\n\n for(i = 0; i < 4; ++i) {\n for(j = 0; j < 4; ++j) {\n out[j] += m[4 * i + j] * v[i];\n }\n }\n\n return out;\n}\n\nfunction project(camera, v) {\n var p = xformMatrix(camera.projection,\n xformMatrix(camera.view,\n xformMatrix(camera.model, [v[0], v[1], v[2], 1])));\n return p;\n}\n\nmodule.exports = project;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar extendFlat = Lib.extendFlat;\nvar extendDeep = Lib.extendDeep;\n\n// Put default plotTile layouts here\nfunction cloneLayoutOverride(tileClass) {\n var override;\n\n switch(tileClass) {\n case 'themes__thumb':\n override = {\n autosize: true,\n width: 150,\n height: 150,\n title: {text: ''},\n showlegend: false,\n margin: {l: 5, r: 5, t: 5, b: 5, pad: 0},\n annotations: []\n };\n break;\n\n case 'thumbnail':\n override = {\n title: {text: ''},\n hidesources: true,\n showlegend: false,\n borderwidth: 0,\n bordercolor: '',\n margin: {l: 1, r: 1, t: 1, b: 1, pad: 0},\n annotations: []\n };\n break;\n\n default:\n override = {};\n }\n\n\n return override;\n}\n\nfunction keyIsAxis(keyName) {\n var types = ['xaxis', 'yaxis', 'zaxis'];\n return (types.indexOf(keyName.slice(0, 5)) > -1);\n}\n\n\nmodule.exports = function clonePlot(graphObj, options) {\n // Polar plot compatibility\n if(graphObj.framework && graphObj.framework.isPolar) {\n graphObj = graphObj.framework.getConfig();\n }\n\n var i;\n var oldData = graphObj.data;\n var oldLayout = graphObj.layout;\n var newData = extendDeep([], oldData);\n var newLayout = extendDeep({}, oldLayout, cloneLayoutOverride(options.tileClass));\n var context = graphObj._context || {};\n\n if(options.width) newLayout.width = options.width;\n if(options.height) newLayout.height = options.height;\n\n if(options.tileClass === 'thumbnail' || options.tileClass === 'themes__thumb') {\n // kill annotations\n newLayout.annotations = [];\n var keys = Object.keys(newLayout);\n\n for(i = 0; i < keys.length; i++) {\n if(keyIsAxis(keys[i])) {\n newLayout[keys[i]].title = {text: ''};\n }\n }\n\n // kill colorbar and pie labels\n for(i = 0; i < newData.length; i++) {\n var trace = newData[i];\n trace.showscale = false;\n if(trace.marker) trace.marker.showscale = false;\n if(Registry.traceIs(trace, 'pie-like')) trace.textposition = 'none';\n }\n }\n\n if(Array.isArray(options.annotations)) {\n for(i = 0; i < options.annotations.length; i++) {\n newLayout.annotations.push(options.annotations[i]);\n }\n }\n\n // TODO: does this scene modification really belong here?\n // If we still need it, can it move into the gl3d module?\n var sceneIds = Object.keys(newLayout).filter(function(key) {\n return key.match(/^scene\\d*$/);\n });\n if(sceneIds.length) {\n var axesImageOverride = {};\n if(options.tileClass === 'thumbnail') {\n axesImageOverride = {\n title: {text: ''},\n showaxeslabels: false,\n showticklabels: false,\n linetickenable: false\n };\n }\n for(i = 0; i < sceneIds.length; i++) {\n var scene = newLayout[sceneIds[i]];\n\n if(!scene.xaxis) {\n scene.xaxis = {};\n }\n\n if(!scene.yaxis) {\n scene.yaxis = {};\n }\n\n if(!scene.zaxis) {\n scene.zaxis = {};\n }\n\n extendFlat(scene.xaxis, axesImageOverride);\n extendFlat(scene.yaxis, axesImageOverride);\n extendFlat(scene.zaxis, axesImageOverride);\n\n // TODO what does this do?\n scene._scene = null;\n }\n }\n\n var gd = document.createElement('div');\n if(options.tileClass) gd.className = options.tileClass;\n\n var plotTile = {\n gd: gd,\n td: gd, // for external (image server) compatibility\n layout: newLayout,\n data: newData,\n config: {\n staticPlot: (options.staticPlot === undefined) ?\n true :\n options.staticPlot,\n plotGlPixelRatio: (options.plotGlPixelRatio === undefined) ?\n 2 :\n options.plotGlPixelRatio,\n displaylogo: options.displaylogo || false,\n showLink: options.showLink || false,\n showTips: options.showTips || false,\n mapboxAccessToken: context.mapboxAccessToken\n }\n };\n\n if(options.setBackground !== 'transparent') {\n plotTile.config.setBackground = options.setBackground || 'opaque';\n }\n\n // attaching the default Layout the gd, so you can grab it later\n plotTile.gd.defaultLayout = cloneLayoutOverride(options.tileClass);\n\n return plotTile;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = require('../src/core');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../lib');\nvar isPlainObject = Lib.isPlainObject;\nvar PlotSchema = require('./plot_schema');\nvar Plots = require('../plots/plots');\nvar plotAttributes = require('../plots/attributes');\nvar Template = require('./plot_template');\nvar dfltConfig = require('./plot_config').dfltConfig;\n\n/**\n * Plotly.makeTemplate: create a template off an existing figure to reuse\n * style attributes on other figures.\n *\n * Note: separated from the rest of templates because otherwise we get circular\n * references due to PlotSchema.\n *\n * @param {object|DOM element|string} figure: The figure to base the template on\n * should contain a trace array `figure.data`\n * and a layout object `figure.layout`\n * @returns {object} template: the extracted template - can then be used as\n * `layout.template` in another figure.\n */\nexports.makeTemplate = function(figure) {\n figure = Lib.isPlainObject(figure) ? figure : Lib.getGraphDiv(figure);\n figure = Lib.extendDeep({_context: dfltConfig}, {data: figure.data, layout: figure.layout});\n Plots.supplyDefaults(figure);\n var data = figure.data || [];\n var layout = figure.layout || {};\n // copy over a few items to help follow the schema\n layout._basePlotModules = figure._fullLayout._basePlotModules;\n layout._modules = figure._fullLayout._modules;\n\n var template = {\n data: {},\n layout: {}\n };\n\n /*\n * Note: we do NOT validate template values, we just take what's in the\n * user inputs data and layout, not the validated values in fullData and\n * fullLayout. Even if we were to validate here, there's no guarantee that\n * these values would still be valid when applied to a new figure, which\n * may contain different trace modes, different axes, etc. So it's\n * important that when applying a template we still validate the template\n * values, rather than just using them as defaults.\n */\n\n data.forEach(function(trace) {\n // TODO: What if no style info is extracted for this trace. We may\n // not want an empty object as the null value.\n // TODO: allow transforms to contribute to templates?\n // as it stands they are ignored, which may be for the best...\n\n var traceTemplate = {};\n walkStyleKeys(trace, traceTemplate, getTraceInfo.bind(null, trace));\n\n var traceType = Lib.coerce(trace, {}, plotAttributes, 'type');\n var typeTemplates = template.data[traceType];\n if(!typeTemplates) typeTemplates = template.data[traceType] = [];\n typeTemplates.push(traceTemplate);\n });\n\n walkStyleKeys(layout, template.layout, getLayoutInfo.bind(null, layout));\n\n /*\n * Compose the new template with an existing one to the same effect\n *\n * NOTE: there's a possibility of slightly different behavior: if the plot\n * has an invalid value and the old template has a valid value for the same\n * attribute, the plot will use the old template value but this routine\n * will pull the invalid value (resulting in the original default).\n * In the general case it's not possible to solve this with a single value,\n * since valid options can be context-dependent. It could be solved with\n * a *list* of values, but that would be huge complexity for little gain.\n */\n delete template.layout.template;\n var oldTemplate = layout.template;\n if(isPlainObject(oldTemplate)) {\n var oldLayoutTemplate = oldTemplate.layout;\n\n var i, traceType, oldTypeTemplates, oldTypeLen, typeTemplates, typeLen;\n\n if(isPlainObject(oldLayoutTemplate)) {\n mergeTemplates(oldLayoutTemplate, template.layout);\n }\n var oldDataTemplate = oldTemplate.data;\n if(isPlainObject(oldDataTemplate)) {\n for(traceType in template.data) {\n oldTypeTemplates = oldDataTemplate[traceType];\n if(Array.isArray(oldTypeTemplates)) {\n typeTemplates = template.data[traceType];\n typeLen = typeTemplates.length;\n oldTypeLen = oldTypeTemplates.length;\n for(i = 0; i < typeLen; i++) {\n mergeTemplates(oldTypeTemplates[i % oldTypeLen], typeTemplates[i]);\n }\n for(i = typeLen; i < oldTypeLen; i++) {\n typeTemplates.push(Lib.extendDeep({}, oldTypeTemplates[i]));\n }\n }\n }\n for(traceType in oldDataTemplate) {\n if(!(traceType in template.data)) {\n template.data[traceType] = Lib.extendDeep([], oldDataTemplate[traceType]);\n }\n }\n }\n }\n\n return template;\n};\n\nfunction mergeTemplates(oldTemplate, newTemplate) {\n // we don't care about speed here, just make sure we have a totally\n // distinct object from the previous template\n oldTemplate = Lib.extendDeep({}, oldTemplate);\n\n // sort keys so we always get annotationdefaults before annotations etc\n // so arrayTemplater will work right\n var oldKeys = Object.keys(oldTemplate).sort();\n var i, j;\n\n function mergeOne(oldVal, newVal, key) {\n if(isPlainObject(newVal) && isPlainObject(oldVal)) {\n mergeTemplates(oldVal, newVal);\n } else if(Array.isArray(newVal) && Array.isArray(oldVal)) {\n // Note: omitted `inclusionAttr` from arrayTemplater here,\n // it's irrelevant as we only want the resulting `_template`.\n var templater = Template.arrayTemplater({_template: oldTemplate}, key);\n for(j = 0; j < newVal.length; j++) {\n var item = newVal[j];\n var oldItem = templater.newItem(item)._template;\n if(oldItem) mergeTemplates(oldItem, item);\n }\n var defaultItems = templater.defaultItems();\n for(j = 0; j < defaultItems.length; j++) newVal.push(defaultItems[j]._template);\n\n // templateitemname only applies to receiving plots\n for(j = 0; j < newVal.length; j++) delete newVal[j].templateitemname;\n }\n }\n\n for(i = 0; i < oldKeys.length; i++) {\n var key = oldKeys[i];\n var oldVal = oldTemplate[key];\n if(key in newTemplate) {\n mergeOne(oldVal, newTemplate[key], key);\n } else newTemplate[key] = oldVal;\n\n // if this is a base key from the old template (eg xaxis), look for\n // extended keys (eg xaxis2) in the new template to merge into\n if(getBaseKey(key) === key) {\n for(var key2 in newTemplate) {\n var baseKey2 = getBaseKey(key2);\n if(key2 !== baseKey2 && baseKey2 === key && !(key2 in oldTemplate)) {\n mergeOne(oldVal, newTemplate[key2], key);\n }\n }\n }\n }\n}\n\nfunction getBaseKey(key) {\n return key.replace(/[0-9]+$/, '');\n}\n\nfunction walkStyleKeys(parent, templateOut, getAttributeInfo, path, basePath) {\n var pathAttr = basePath && getAttributeInfo(basePath);\n for(var key in parent) {\n var child = parent[key];\n var nextPath = getNextPath(parent, key, path);\n var nextBasePath = getNextPath(parent, key, basePath);\n var attr = getAttributeInfo(nextBasePath);\n if(!attr) {\n var baseKey = getBaseKey(key);\n if(baseKey !== key) {\n nextBasePath = getNextPath(parent, baseKey, basePath);\n attr = getAttributeInfo(nextBasePath);\n }\n }\n\n // we'll get an attr if path starts with a valid part, then has an\n // invalid ending. Make sure we got all the way to the end.\n if(pathAttr && (pathAttr === attr)) continue;\n\n if(!attr || attr._noTemplating ||\n attr.valType === 'data_array' ||\n (attr.arrayOk && Array.isArray(child))\n ) {\n continue;\n }\n\n if(!attr.valType && isPlainObject(child)) {\n walkStyleKeys(child, templateOut, getAttributeInfo, nextPath, nextBasePath);\n } else if(attr._isLinkedToArray && Array.isArray(child)) {\n var dfltDone = false;\n var namedIndex = 0;\n var usedNames = {};\n for(var i = 0; i < child.length; i++) {\n var item = child[i];\n if(isPlainObject(item)) {\n var name = item.name;\n if(name) {\n if(!usedNames[name]) {\n // named array items: allow all attributes except data arrays\n walkStyleKeys(item, templateOut, getAttributeInfo,\n getNextPath(child, namedIndex, nextPath),\n getNextPath(child, namedIndex, nextBasePath));\n namedIndex++;\n usedNames[name] = 1;\n }\n } else if(!dfltDone) {\n var dfltKey = Template.arrayDefaultKey(key);\n var dfltPath = getNextPath(parent, dfltKey, path);\n\n // getAttributeInfo will fail if we try to use dfltKey directly.\n // Instead put this item into the next array element, then\n // pull it out and move it to dfltKey.\n var pathInArray = getNextPath(child, namedIndex, nextPath);\n walkStyleKeys(item, templateOut, getAttributeInfo, pathInArray,\n getNextPath(child, namedIndex, nextBasePath));\n var itemPropInArray = Lib.nestedProperty(templateOut, pathInArray);\n var dfltProp = Lib.nestedProperty(templateOut, dfltPath);\n dfltProp.set(itemPropInArray.get());\n itemPropInArray.set(null);\n\n dfltDone = true;\n }\n }\n }\n } else {\n var templateProp = Lib.nestedProperty(templateOut, nextPath);\n templateProp.set(child);\n }\n }\n}\n\nfunction getLayoutInfo(layout, path) {\n return PlotSchema.getLayoutValObject(\n layout, Lib.nestedProperty({}, path).parts\n );\n}\n\nfunction getTraceInfo(trace, path) {\n return PlotSchema.getTraceValObject(\n trace, Lib.nestedProperty({}, path).parts\n );\n}\n\nfunction getNextPath(parent, key, path) {\n var nextPath;\n if(!path) nextPath = key;\n else if(Array.isArray(parent)) nextPath = path + '[' + key + ']';\n else nextPath = path + '.' + key;\n\n return nextPath;\n}\n\n/**\n * validateTemplate: Test for consistency between the given figure and\n * a template, either already included in the figure or given separately.\n * Note that not every issue we identify here is necessarily a problem,\n * it depends on what you're using the template for.\n *\n * @param {object|DOM element} figure: the plot, with {data, layout} members,\n * to test the template against\n * @param {Optional(object)} template: the template, with its own {data, layout},\n * to test. If omitted, we will look for a template already attached as the\n * plot's `layout.template` attribute.\n *\n * @returns {array} array of error objects each containing:\n * - {string} code\n * error code ('missing', 'unused', 'reused', 'noLayout', 'noData')\n * - {string} msg\n * a full readable description of the issue.\n */\nexports.validateTemplate = function(figureIn, template) {\n var figure = Lib.extendDeep({}, {\n _context: dfltConfig,\n data: figureIn.data,\n layout: figureIn.layout\n });\n var layout = figure.layout || {};\n if(!isPlainObject(template)) template = layout.template || {};\n var layoutTemplate = template.layout;\n var dataTemplate = template.data;\n var errorList = [];\n\n figure.layout = layout;\n figure.layout.template = template;\n Plots.supplyDefaults(figure);\n\n var fullLayout = figure._fullLayout;\n var fullData = figure._fullData;\n\n var layoutPaths = {};\n function crawlLayoutForContainers(obj, paths) {\n for(var key in obj) {\n if(key.charAt(0) !== '_' && isPlainObject(obj[key])) {\n var baseKey = getBaseKey(key);\n var nextPaths = [];\n var i;\n for(i = 0; i < paths.length; i++) {\n nextPaths.push(getNextPath(obj, key, paths[i]));\n if(baseKey !== key) nextPaths.push(getNextPath(obj, baseKey, paths[i]));\n }\n for(i = 0; i < nextPaths.length; i++) {\n layoutPaths[nextPaths[i]] = 1;\n }\n crawlLayoutForContainers(obj[key], nextPaths);\n }\n }\n }\n\n function crawlLayoutTemplateForContainers(obj, path) {\n for(var key in obj) {\n if(key.indexOf('defaults') === -1 && isPlainObject(obj[key])) {\n var nextPath = getNextPath(obj, key, path);\n if(layoutPaths[nextPath]) {\n crawlLayoutTemplateForContainers(obj[key], nextPath);\n } else {\n errorList.push({code: 'unused', path: nextPath});\n }\n }\n }\n }\n\n if(!isPlainObject(layoutTemplate)) {\n errorList.push({code: 'layout'});\n } else {\n crawlLayoutForContainers(fullLayout, ['layout']);\n crawlLayoutTemplateForContainers(layoutTemplate, 'layout');\n }\n\n if(!isPlainObject(dataTemplate)) {\n errorList.push({code: 'data'});\n } else {\n var typeCount = {};\n var traceType;\n for(var i = 0; i < fullData.length; i++) {\n var fullTrace = fullData[i];\n traceType = fullTrace.type;\n typeCount[traceType] = (typeCount[traceType] || 0) + 1;\n if(!fullTrace._fullInput._template) {\n // this takes care of the case of traceType in the data but not\n // the template\n errorList.push({\n code: 'missing',\n index: fullTrace._fullInput.index,\n traceType: traceType\n });\n }\n }\n for(traceType in dataTemplate) {\n var templateCount = dataTemplate[traceType].length;\n var dataCount = typeCount[traceType] || 0;\n if(templateCount > dataCount) {\n errorList.push({\n code: 'unused',\n traceType: traceType,\n templateCount: templateCount,\n dataCount: dataCount\n });\n } else if(dataCount > templateCount) {\n errorList.push({\n code: 'reused',\n traceType: traceType,\n templateCount: templateCount,\n dataCount: dataCount\n });\n }\n }\n }\n\n // _template: false is when someone tried to modify an array item\n // but there was no template with matching name\n function crawlForMissingTemplates(obj, path) {\n for(var key in obj) {\n if(key.charAt(0) === '_') continue;\n var val = obj[key];\n var nextPath = getNextPath(obj, key, path);\n if(isPlainObject(val)) {\n if(Array.isArray(obj) && val._template === false && val.templateitemname) {\n errorList.push({\n code: 'missing',\n path: nextPath,\n templateitemname: val.templateitemname\n });\n }\n crawlForMissingTemplates(val, nextPath);\n } else if(Array.isArray(val) && hasPlainObject(val)) {\n crawlForMissingTemplates(val, nextPath);\n }\n }\n }\n crawlForMissingTemplates({data: fullData, layout: fullLayout}, '');\n\n if(errorList.length) return errorList.map(format);\n};\n\nfunction hasPlainObject(arr) {\n for(var i = 0; i < arr.length; i++) {\n if(isPlainObject(arr[i])) return true;\n }\n}\n\nfunction format(opts) {\n var msg;\n switch(opts.code) {\n case 'data':\n msg = 'The template has no key data.';\n break;\n case 'layout':\n msg = 'The template has no key layout.';\n break;\n case 'missing':\n if(opts.path) {\n msg = 'There are no templates for item ' + opts.path +\n ' with name ' + opts.templateitemname;\n } else {\n msg = 'There are no templates for trace ' + opts.index +\n ', of type ' + opts.traceType + '.';\n }\n break;\n case 'unused':\n if(opts.path) {\n msg = 'The template item at ' + opts.path +\n ' was not used in constructing the plot.';\n } else if(opts.dataCount) {\n msg = 'Some of the templates of type ' + opts.traceType +\n ' were not used. The template has ' + opts.templateCount +\n ' traces, the data only has ' + opts.dataCount +\n ' of this type.';\n } else {\n msg = 'The template has ' + opts.templateCount +\n ' traces of type ' + opts.traceType +\n ' but there are none in the data.';\n }\n break;\n case 'reused':\n msg = 'Some of the templates of type ' + opts.traceType +\n ' were used more than once. The template has ' +\n opts.templateCount + ' traces, the data has ' +\n opts.dataCount + ' of this type.';\n break;\n }\n opts.msg = msg;\n\n return opts;\n}\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// this is the core work-horse\n//\n\nvar LinkedList = require('./linked-list');\n\nfunction Intersecter(selfIntersection, eps, buildLog){\n\t// selfIntersection is true/false depending on the phase of the overall algorithm\n\n\t//\n\t// segment creation\n\t//\n\n\tfunction segmentNew(start, end){\n\t\treturn {\n\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\tstart: start,\n\t\t\tend: end,\n\t\t\tmyFill: {\n\t\t\t\tabove: null, // is there fill above us?\n\t\t\t\tbelow: null // is there fill below us?\n\t\t\t},\n\t\t\totherFill: null\n\t\t};\n\t}\n\n\tfunction segmentCopy(start, end, seg){\n\t\treturn {\n\t\t\tid: buildLog ? buildLog.segmentId() : -1,\n\t\t\tstart: start,\n\t\t\tend: end,\n\t\t\tmyFill: {\n\t\t\t\tabove: seg.myFill.above,\n\t\t\t\tbelow: seg.myFill.below\n\t\t\t},\n\t\t\totherFill: null\n\t\t};\n\t}\n\n\t//\n\t// event logic\n\t//\n\n\tvar event_root = LinkedList.create();\n\n\tfunction eventCompare(p1_isStart, p1_1, p1_2, p2_isStart, p2_1, p2_2){\n\t\t// compare the selected points first\n\t\tvar comp = eps.pointsCompare(p1_1, p2_1);\n\t\tif (comp !== 0)\n\t\t\treturn comp;\n\t\t// the selected points are the same\n\n\t\tif (eps.pointsSame(p1_2, p2_2)) // if the non-selected points are the same too...\n\t\t\treturn 0; // then the segments are equal\n\n\t\tif (p1_isStart !== p2_isStart) // if one is a start and the other isn't...\n\t\t\treturn p1_isStart ? 1 : -1; // favor the one that isn't the start\n\n\t\t// otherwise, we'll have to calculate which one is below the other manually\n\t\treturn eps.pointAboveOrOnLine(p1_2,\n\t\t\tp2_isStart ? p2_1 : p2_2, // order matters\n\t\t\tp2_isStart ? p2_2 : p2_1\n\t\t) ? 1 : -1;\n\t}\n\n\tfunction eventAdd(ev, other_pt){\n\t\tevent_root.insertBefore(ev, function(here){\n\t\t\t// should ev be inserted before here?\n\t\t\tvar comp = eventCompare(\n\t\t\t\tev .isStart, ev .pt, other_pt,\n\t\t\t\there.isStart, here.pt, here.other.pt\n\t\t\t);\n\t\t\treturn comp < 0;\n\t\t});\n\t}\n\n\tfunction eventAddSegmentStart(seg, primary){\n\t\tvar ev_start = LinkedList.node({\n\t\t\tisStart: true,\n\t\t\tpt: seg.start,\n\t\t\tseg: seg,\n\t\t\tprimary: primary,\n\t\t\tother: null,\n\t\t\tstatus: null\n\t\t});\n\t\teventAdd(ev_start, seg.end);\n\t\treturn ev_start;\n\t}\n\n\tfunction eventAddSegmentEnd(ev_start, seg, primary){\n\t\tvar ev_end = LinkedList.node({\n\t\t\tisStart: false,\n\t\t\tpt: seg.end,\n\t\t\tseg: seg,\n\t\t\tprimary: primary,\n\t\t\tother: ev_start,\n\t\t\tstatus: null\n\t\t});\n\t\tev_start.other = ev_end;\n\t\teventAdd(ev_end, ev_start.pt);\n\t}\n\n\tfunction eventAddSegment(seg, primary){\n\t\tvar ev_start = eventAddSegmentStart(seg, primary);\n\t\teventAddSegmentEnd(ev_start, seg, primary);\n\t\treturn ev_start;\n\t}\n\n\tfunction eventUpdateEnd(ev, end){\n\t\t// slides an end backwards\n\t\t// (start)------------(end) to:\n\t\t// (start)---(end)\n\n\t\tif (buildLog)\n\t\t\tbuildLog.segmentChop(ev.seg, end);\n\n\t\tev.other.remove();\n\t\tev.seg.end = end;\n\t\tev.other.pt = end;\n\t\teventAdd(ev.other, ev.pt);\n\t}\n\n\tfunction eventDivide(ev, pt){\n\t\tvar ns = segmentCopy(pt, ev.seg.end, ev.seg);\n\t\teventUpdateEnd(ev, pt);\n\t\treturn eventAddSegment(ns, ev.primary);\n\t}\n\n\tfunction calculate(primaryPolyInverted, secondaryPolyInverted){\n\t\t// if selfIntersection is true then there is no secondary polygon, so that isn't used\n\n\t\t//\n\t\t// status logic\n\t\t//\n\n\t\tvar status_root = LinkedList.create();\n\n\t\tfunction statusCompare(ev1, ev2){\n\t\t\tvar a1 = ev1.seg.start;\n\t\t\tvar a2 = ev1.seg.end;\n\t\t\tvar b1 = ev2.seg.start;\n\t\t\tvar b2 = ev2.seg.end;\n\n\t\t\tif (eps.pointsCollinear(a1, b1, b2)){\n\t\t\t\tif (eps.pointsCollinear(a2, b1, b2))\n\t\t\t\t\treturn 1;//eventCompare(true, a1, a2, true, b1, b2);\n\t\t\t\treturn eps.pointAboveOrOnLine(a2, b1, b2) ? 1 : -1;\n\t\t\t}\n\t\t\treturn eps.pointAboveOrOnLine(a1, b1, b2) ? 1 : -1;\n\t\t}\n\n\t\tfunction statusFindSurrounding(ev){\n\t\t\treturn status_root.findTransition(function(here){\n\t\t\t\tvar comp = statusCompare(ev, here.ev);\n\t\t\t\treturn comp > 0;\n\t\t\t});\n\t\t}\n\n\t\tfunction checkIntersection(ev1, ev2){\n\t\t\t// returns the segment equal to ev1, or false if nothing equal\n\n\t\t\tvar seg1 = ev1.seg;\n\t\t\tvar seg2 = ev2.seg;\n\t\t\tvar a1 = seg1.start;\n\t\t\tvar a2 = seg1.end;\n\t\t\tvar b1 = seg2.start;\n\t\t\tvar b2 = seg2.end;\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.checkIntersection(seg1, seg2);\n\n\t\t\tvar i = eps.linesIntersect(a1, a2, b1, b2);\n\n\t\t\tif (i === false){\n\t\t\t\t// segments are parallel or coincident\n\n\t\t\t\t// if points aren't collinear, then the segments are parallel, so no intersections\n\t\t\t\tif (!eps.pointsCollinear(a1, a2, b1))\n\t\t\t\t\treturn false;\n\t\t\t\t// otherwise, segments are on top of each other somehow (aka coincident)\n\n\t\t\t\tif (eps.pointsSame(a1, b2) || eps.pointsSame(a2, b1))\n\t\t\t\t\treturn false; // segments touch at endpoints... no intersection\n\n\t\t\t\tvar a1_equ_b1 = eps.pointsSame(a1, b1);\n\t\t\t\tvar a2_equ_b2 = eps.pointsSame(a2, b2);\n\n\t\t\t\tif (a1_equ_b1 && a2_equ_b2)\n\t\t\t\t\treturn ev2; // segments are exactly equal\n\n\t\t\t\tvar a1_between = !a1_equ_b1 && eps.pointBetween(a1, b1, b2);\n\t\t\t\tvar a2_between = !a2_equ_b2 && eps.pointBetween(a2, b1, b2);\n\n\t\t\t\t// handy for debugging:\n\t\t\t\t// buildLog.log({\n\t\t\t\t//\ta1_equ_b1: a1_equ_b1,\n\t\t\t\t//\ta2_equ_b2: a2_equ_b2,\n\t\t\t\t//\ta1_between: a1_between,\n\t\t\t\t//\ta2_between: a2_between\n\t\t\t\t// });\n\n\t\t\t\tif (a1_equ_b1){\n\t\t\t\t\tif (a2_between){\n\t\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// (a1)----------(a2)\n\t\t\t\t\t\t// (b1)---(b2)\n\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t\t}\n\t\t\t\t\treturn ev2;\n\t\t\t\t}\n\t\t\t\telse if (a1_between){\n\t\t\t\t\tif (!a2_equ_b2){\n\t\t\t\t\t\t// make a2 equal to b2\n\t\t\t\t\t\tif (a2_between){\n\t\t\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t\t\t// (b1)-----------------(b2)\n\t\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse{\n\t\t\t\t\t\t\t// (a1)----------(a2)\n\t\t\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// (a1)---(a2)\n\t\t\t\t\t// (b1)----------(b2)\n\t\t\t\t\teventDivide(ev2, a1);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse{\n\t\t\t\t// otherwise, lines intersect at i.pt, which may or may not be between the endpoints\n\n\t\t\t\t// is A divided between its endpoints? (exclusive)\n\t\t\t\tif (i.alongA === 0){\n\t\t\t\t\tif (i.alongB === -1) // yes, at exactly b1\n\t\t\t\t\t\teventDivide(ev1, b1);\n\t\t\t\t\telse if (i.alongB === 0) // yes, somewhere between B's endpoints\n\t\t\t\t\t\teventDivide(ev1, i.pt);\n\t\t\t\t\telse if (i.alongB === 1) // yes, at exactly b2\n\t\t\t\t\t\teventDivide(ev1, b2);\n\t\t\t\t}\n\n\t\t\t\t// is B divided between its endpoints? (exclusive)\n\t\t\t\tif (i.alongB === 0){\n\t\t\t\t\tif (i.alongA === -1) // yes, at exactly a1\n\t\t\t\t\t\teventDivide(ev2, a1);\n\t\t\t\t\telse if (i.alongA === 0) // yes, somewhere between A's endpoints (exclusive)\n\t\t\t\t\t\teventDivide(ev2, i.pt);\n\t\t\t\t\telse if (i.alongA === 1) // yes, at exactly a2\n\t\t\t\t\t\teventDivide(ev2, a2);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t}\n\n\t\t//\n\t\t// main event loop\n\t\t//\n\t\tvar segments = [];\n\t\twhile (!event_root.isEmpty()){\n\t\t\tvar ev = event_root.getHead();\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.vert(ev.pt[0]);\n\n\t\t\tif (ev.isStart){\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.segmentNew(ev.seg, ev.primary);\n\n\t\t\t\tvar surrounding = statusFindSurrounding(ev);\n\t\t\t\tvar above = surrounding.before ? surrounding.before.ev : null;\n\t\t\t\tvar below = surrounding.after ? surrounding.after.ev : null;\n\n\t\t\t\tif (buildLog){\n\t\t\t\t\tbuildLog.tempStatus(\n\t\t\t\t\t\tev.seg,\n\t\t\t\t\t\tabove ? above.seg : false,\n\t\t\t\t\t\tbelow ? below.seg : false\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tfunction checkBothIntersections(){\n\t\t\t\t\tif (above){\n\t\t\t\t\t\tvar eve = checkIntersection(ev, above);\n\t\t\t\t\t\tif (eve)\n\t\t\t\t\t\t\treturn eve;\n\t\t\t\t\t}\n\t\t\t\t\tif (below)\n\t\t\t\t\t\treturn checkIntersection(ev, below);\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\tvar eve = checkBothIntersections();\n\t\t\t\tif (eve){\n\t\t\t\t\t// ev and eve are equal\n\t\t\t\t\t// we'll keep eve and throw away ev\n\n\t\t\t\t\t// merge ev.seg's fill information into eve.seg\n\n\t\t\t\t\tif (selfIntersection){\n\t\t\t\t\t\tvar toggle; // are we a toggling edge?\n\t\t\t\t\t\tif (ev.seg.myFill.below === null)\n\t\t\t\t\t\t\ttoggle = true;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\ttoggle = ev.seg.myFill.above !== ev.seg.myFill.below;\n\n\t\t\t\t\t\t// merge two segments that belong to the same polygon\n\t\t\t\t\t\t// think of this as sandwiching two segments together, where `eve.seg` is\n\t\t\t\t\t\t// the bottom -- this will cause the above fill flag to toggle\n\t\t\t\t\t\tif (toggle)\n\t\t\t\t\t\t\teve.seg.myFill.above = !eve.seg.myFill.above;\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// merge two segments that belong to different polygons\n\t\t\t\t\t\t// each segment has distinct knowledge, so no special logic is needed\n\t\t\t\t\t\t// note that this can only happen once per segment in this phase, because we\n\t\t\t\t\t\t// are guaranteed that all self-intersections are gone\n\t\t\t\t\t\teve.seg.otherFill = ev.seg.myFill;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.segmentUpdate(eve.seg);\n\n\t\t\t\t\tev.other.remove();\n\t\t\t\t\tev.remove();\n\t\t\t\t}\n\n\t\t\t\tif (event_root.getHead() !== ev){\n\t\t\t\t\t// something was inserted before us in the event queue, so loop back around and\n\t\t\t\t\t// process it before continuing\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.rewind(ev.seg);\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t//\n\t\t\t\t// calculate fill flags\n\t\t\t\t//\n\t\t\t\tif (selfIntersection){\n\t\t\t\t\tvar toggle; // are we a toggling edge?\n\t\t\t\t\tif (ev.seg.myFill.below === null) // if we are a new segment...\n\t\t\t\t\t\ttoggle = true; // then we toggle\n\t\t\t\t\telse // we are a segment that has previous knowledge from a division\n\t\t\t\t\t\ttoggle = ev.seg.myFill.above !== ev.seg.myFill.below; // calculate toggle\n\n\t\t\t\t\t// next, calculate whether we are filled below us\n\t\t\t\t\tif (!below){ // if nothing is below us...\n\t\t\t\t\t\t// we are filled below us if the polygon is inverted\n\t\t\t\t\t\tev.seg.myFill.below = primaryPolyInverted;\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\t// otherwise, we know the answer -- it's the same if whatever is below\n\t\t\t\t\t\t// us is filled above it\n\t\t\t\t\t\tev.seg.myFill.below = below.seg.myFill.above;\n\t\t\t\t\t}\n\n\t\t\t\t\t// since now we know if we're filled below us, we can calculate whether\n\t\t\t\t\t// we're filled above us by applying toggle to whatever is below us\n\t\t\t\t\tif (toggle)\n\t\t\t\t\t\tev.seg.myFill.above = !ev.seg.myFill.below;\n\t\t\t\t\telse\n\t\t\t\t\t\tev.seg.myFill.above = ev.seg.myFill.below;\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// now we fill in any missing transition information, since we are all-knowing\n\t\t\t\t\t// at this point\n\n\t\t\t\t\tif (ev.seg.otherFill === null){\n\t\t\t\t\t\t// if we don't have other information, then we need to figure out if we're\n\t\t\t\t\t\t// inside the other polygon\n\t\t\t\t\t\tvar inside;\n\t\t\t\t\t\tif (!below){\n\t\t\t\t\t\t\t// if nothing is below us, then we're inside if the other polygon is\n\t\t\t\t\t\t\t// inverted\n\t\t\t\t\t\t\tinside =\n\t\t\t\t\t\t\t\tev.primary ? secondaryPolyInverted : primaryPolyInverted;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse{ // otherwise, something is below us\n\t\t\t\t\t\t\t// so copy the below segment's other polygon's above\n\t\t\t\t\t\t\tif (ev.primary === below.primary)\n\t\t\t\t\t\t\t\tinside = below.seg.otherFill.above;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tinside = below.seg.myFill.above;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tev.seg.otherFill = {\n\t\t\t\t\t\t\tabove: inside,\n\t\t\t\t\t\t\tbelow: inside\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (buildLog){\n\t\t\t\t\tbuildLog.status(\n\t\t\t\t\t\tev.seg,\n\t\t\t\t\t\tabove ? above.seg : false,\n\t\t\t\t\t\tbelow ? below.seg : false\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\t// insert the status and remember it for later removal\n\t\t\t\tev.other.status = surrounding.insert(LinkedList.node({ ev: ev }));\n\t\t\t}\n\t\t\telse{\n\t\t\t\tvar st = ev.status;\n\n\t\t\t\tif (st === null){\n\t\t\t\t\tthrow new Error('PolyBool: Zero-length segment detected; your epsilon is ' +\n\t\t\t\t\t\t'probably too small or too large');\n\t\t\t\t}\n\n\t\t\t\t// removing the status will create two new adjacent edges, so we'll need to check\n\t\t\t\t// for those\n\t\t\t\tif (status_root.exists(st.prev) && status_root.exists(st.next))\n\t\t\t\t\tcheckIntersection(st.prev.ev, st.next.ev);\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.statusRemove(st.ev.seg);\n\n\t\t\t\t// remove the status\n\t\t\t\tst.remove();\n\n\t\t\t\t// if we've reached this point, we've calculated everything there is to know, so\n\t\t\t\t// save the segment for reporting\n\t\t\t\tif (!ev.primary){\n\t\t\t\t\t// make sure `seg.myFill` actually points to the primary polygon though\n\t\t\t\t\tvar s = ev.seg.myFill;\n\t\t\t\t\tev.seg.myFill = ev.seg.otherFill;\n\t\t\t\t\tev.seg.otherFill = s;\n\t\t\t\t}\n\t\t\t\tsegments.push(ev.seg);\n\t\t\t}\n\n\t\t\t// remove the event and continue\n\t\t\tevent_root.getHead().remove();\n\t\t}\n\n\t\tif (buildLog)\n\t\t\tbuildLog.done();\n\n\t\treturn segments;\n\t}\n\n\t// return the appropriate API depending on what we're doing\n\tif (!selfIntersection){\n\t\t// performing combination of polygons, so only deal with already-processed segments\n\t\treturn {\n\t\t\tcalculate: function(segments1, inverted1, segments2, inverted2){\n\t\t\t\t// segmentsX come from the self-intersection API, or this API\n\t\t\t\t// invertedX is whether we treat that list of segments as an inverted polygon or not\n\t\t\t\t// returns segments that can be used for further operations\n\t\t\t\tsegments1.forEach(function(seg){\n\t\t\t\t\teventAddSegment(segmentCopy(seg.start, seg.end, seg), true);\n\t\t\t\t});\n\t\t\t\tsegments2.forEach(function(seg){\n\t\t\t\t\teventAddSegment(segmentCopy(seg.start, seg.end, seg), false);\n\t\t\t\t});\n\t\t\t\treturn calculate(inverted1, inverted2);\n\t\t\t}\n\t\t};\n\t}\n\n\t// otherwise, performing self-intersection, so deal with regions\n\treturn {\n\t\taddRegion: function(region){\n\t\t\t// regions are a list of points:\n\t\t\t// [ [0, 0], [100, 0], [50, 100] ]\n\t\t\t// you can add multiple regions before running calculate\n\t\t\tvar pt1;\n\t\t\tvar pt2 = region[region.length - 1];\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tpt1 = pt2;\n\t\t\t\tpt2 = region[i];\n\n\t\t\t\tvar forward = eps.pointsCompare(pt1, pt2);\n\t\t\t\tif (forward === 0) // points are equal, so we have a zero-length segment\n\t\t\t\t\tcontinue; // just skip it\n\n\t\t\t\teventAddSegment(\n\t\t\t\t\tsegmentNew(\n\t\t\t\t\t\tforward < 0 ? pt1 : pt2,\n\t\t\t\t\t\tforward < 0 ? pt2 : pt1\n\t\t\t\t\t),\n\t\t\t\t\ttrue\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t\tcalculate: function(inverted){\n\t\t\t// is the polygon inverted?\n\t\t\t// returns segments\n\t\t\treturn calculate(inverted, false);\n\t\t}\n\t};\n}\n\nmodule.exports = Intersecter;\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// used strictly for logging the processing of the algorithm... only useful if you intend on\n// looking under the covers (for pretty UI's or debugging)\n//\n\nfunction BuildLog(){\n\tvar my;\n\tvar nextSegmentId = 0;\n\tvar curVert = false;\n\n\tfunction push(type, data){\n\t\tmy.list.push({\n\t\t\ttype: type,\n\t\t\tdata: data ? JSON.parse(JSON.stringify(data)) : void 0\n\t\t});\n\t\treturn my;\n\t}\n\n\tmy = {\n\t\tlist: [],\n\t\tsegmentId: function(){\n\t\t\treturn nextSegmentId++;\n\t\t},\n\t\tcheckIntersection: function(seg1, seg2){\n\t\t\treturn push('check', { seg1: seg1, seg2: seg2 });\n\t\t},\n\t\tsegmentChop: function(seg, end){\n\t\t\tpush('div_seg', { seg: seg, pt: end });\n\t\t\treturn push('chop', { seg: seg, pt: end });\n\t\t},\n\t\tstatusRemove: function(seg){\n\t\t\treturn push('pop_seg', { seg: seg });\n\t\t},\n\t\tsegmentUpdate: function(seg){\n\t\t\treturn push('seg_update', { seg: seg });\n\t\t},\n\t\tsegmentNew: function(seg, primary){\n\t\t\treturn push('new_seg', { seg: seg, primary: primary });\n\t\t},\n\t\tsegmentRemove: function(seg){\n\t\t\treturn push('rem_seg', { seg: seg });\n\t\t},\n\t\ttempStatus: function(seg, above, below){\n\t\t\treturn push('temp_status', { seg: seg, above: above, below: below });\n\t\t},\n\t\trewind: function(seg){\n\t\t\treturn push('rewind', { seg: seg });\n\t\t},\n\t\tstatus: function(seg, above, below){\n\t\t\treturn push('status', { seg: seg, above: above, below: below });\n\t\t},\n\t\tvert: function(x){\n\t\t\tif (x === curVert)\n\t\t\t\treturn my;\n\t\t\tcurVert = x;\n\t\t\treturn push('vert', { x: x });\n\t\t},\n\t\tlog: function(data){\n\t\t\tif (typeof data !== 'string')\n\t\t\t\tdata = JSON.stringify(data, false, ' ');\n\t\t\treturn push('log', { txt: data });\n\t\t},\n\t\treset: function(){\n\t\t\treturn push('reset');\n\t\t},\n\t\tselected: function(segs){\n\t\t\treturn push('selected', { segs: segs });\n\t\t},\n\t\tchainStart: function(seg){\n\t\t\treturn push('chain_start', { seg: seg });\n\t\t},\n\t\tchainRemoveHead: function(index, pt){\n\t\t\treturn push('chain_rem_head', { index: index, pt: pt });\n\t\t},\n\t\tchainRemoveTail: function(index, pt){\n\t\t\treturn push('chain_rem_tail', { index: index, pt: pt });\n\t\t},\n\t\tchainNew: function(pt1, pt2){\n\t\t\treturn push('chain_new', { pt1: pt1, pt2: pt2 });\n\t\t},\n\t\tchainMatch: function(index){\n\t\t\treturn push('chain_match', { index: index });\n\t\t},\n\t\tchainClose: function(index){\n\t\t\treturn push('chain_close', { index: index });\n\t\t},\n\t\tchainAddHead: function(index, pt){\n\t\t\treturn push('chain_add_head', { index: index, pt: pt });\n\t\t},\n\t\tchainAddTail: function(index, pt){\n\t\t\treturn push('chain_add_tail', { index: index, pt: pt, });\n\t\t},\n\t\tchainConnect: function(index1, index2){\n\t\t\treturn push('chain_con', { index1: index1, index2: index2 });\n\t\t},\n\t\tchainReverse: function(index){\n\t\t\treturn push('chain_rev', { index: index });\n\t\t},\n\t\tchainJoin: function(index1, index2){\n\t\t\treturn push('chain_join', { index1: index1, index2: index2 });\n\t\t},\n\t\tdone: function(){\n\t\t\treturn push('done');\n\t\t}\n\t};\n\treturn my;\n}\n\nmodule.exports = BuildLog;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = ScrollBox;\n\nvar d3 = require('d3');\n\nvar Color = require('../color');\nvar Drawing = require('../drawing');\n\nvar Lib = require('../../lib');\n\n/**\n * Helper class to setup a scroll box\n *\n * @class\n * @param gd Plotly's graph div\n * @param container Container to be scroll-boxed (as a D3 selection)\n * @param {string} id Id for the clip path to implement the scroll box\n */\nfunction ScrollBox(gd, container, id) {\n this.gd = gd;\n this.container = container;\n this.id = id;\n\n // See ScrollBox.prototype.enable for further definition\n this.position = null; // scrollbox position\n this.translateX = null; // scrollbox horizontal translation\n this.translateY = null; // scrollbox vertical translation\n this.hbar = null; // horizontal scrollbar D3 selection\n this.vbar = null; // vertical scrollbar D3 selection\n\n // element to capture pointer events\n this.bg = this.container.selectAll('rect.scrollbox-bg').data([0]);\n\n this.bg.exit()\n .on('.drag', null)\n .on('wheel', null)\n .remove();\n\n this.bg.enter().append('rect')\n .classed('scrollbox-bg', true)\n .style('pointer-events', 'all')\n .attr({\n opacity: 0,\n x: 0,\n y: 0,\n width: 0,\n height: 0\n });\n}\n\n// scroll bar dimensions\nScrollBox.barWidth = 2;\nScrollBox.barLength = 20;\nScrollBox.barRadius = 2;\nScrollBox.barPad = 1;\nScrollBox.barColor = '#808BA4';\n\n/**\n * If needed, setup a clip path and scrollbars\n *\n * @method\n * @param {Object} position\n * @param {number} position.l Left side position (in pixels)\n * @param {number} position.t Top side (in pixels)\n * @param {number} position.w Width (in pixels)\n * @param {number} position.h Height (in pixels)\n * @param {string} [position.direction='down']\n * Either 'down', 'left', 'right' or 'up'\n * @param {number} [translateX=0] Horizontal offset (in pixels)\n * @param {number} [translateY=0] Vertical offset (in pixels)\n */\nScrollBox.prototype.enable = function enable(position, translateX, translateY) {\n var fullLayout = this.gd._fullLayout;\n var fullWidth = fullLayout.width;\n var fullHeight = fullLayout.height;\n\n // compute position of scrollbox\n this.position = position;\n\n var l = this.position.l;\n var w = this.position.w;\n var t = this.position.t;\n var h = this.position.h;\n var direction = this.position.direction;\n var isDown = (direction === 'down');\n var isLeft = (direction === 'left');\n var isRight = (direction === 'right');\n var isUp = (direction === 'up');\n var boxW = w;\n var boxH = h;\n var boxL, boxR;\n var boxT, boxB;\n\n if(!isDown && !isLeft && !isRight && !isUp) {\n this.position.direction = 'down';\n isDown = true;\n }\n\n var isVertical = isDown || isUp;\n if(isVertical) {\n boxL = l;\n boxR = boxL + boxW;\n\n if(isDown) {\n // anchor to top side\n boxT = t;\n boxB = Math.min(boxT + boxH, fullHeight);\n boxH = boxB - boxT;\n } else {\n // anchor to bottom side\n boxB = t + boxH;\n boxT = Math.max(boxB - boxH, 0);\n boxH = boxB - boxT;\n }\n } else {\n boxT = t;\n boxB = boxT + boxH;\n\n if(isLeft) {\n // anchor to right side\n boxR = l + boxW;\n boxL = Math.max(boxR - boxW, 0);\n boxW = boxR - boxL;\n } else {\n // anchor to left side\n boxL = l;\n boxR = Math.min(boxL + boxW, fullWidth);\n boxW = boxR - boxL;\n }\n }\n\n this._box = {\n l: boxL,\n t: boxT,\n w: boxW,\n h: boxH\n };\n\n // compute position of horizontal scroll bar\n var needsHorizontalScrollBar = (w > boxW);\n var hbarW = ScrollBox.barLength + 2 * ScrollBox.barPad;\n var hbarH = ScrollBox.barWidth + 2 * ScrollBox.barPad;\n // draw horizontal scrollbar on the bottom side\n var hbarL = l;\n var hbarT = t + h;\n\n if(hbarT + hbarH > fullHeight) hbarT = fullHeight - hbarH;\n\n var hbar = this.container.selectAll('rect.scrollbar-horizontal').data(\n (needsHorizontalScrollBar) ? [0] : []);\n\n hbar.exit()\n .on('.drag', null)\n .remove();\n\n hbar.enter().append('rect')\n .classed('scrollbar-horizontal', true)\n .call(Color.fill, ScrollBox.barColor);\n\n if(needsHorizontalScrollBar) {\n this.hbar = hbar.attr({\n 'rx': ScrollBox.barRadius,\n 'ry': ScrollBox.barRadius,\n 'x': hbarL,\n 'y': hbarT,\n 'width': hbarW,\n 'height': hbarH\n });\n\n // hbar center moves between hbarXMin and hbarXMin + hbarTranslateMax\n this._hbarXMin = hbarL + hbarW / 2;\n this._hbarTranslateMax = boxW - hbarW;\n } else {\n delete this.hbar;\n delete this._hbarXMin;\n delete this._hbarTranslateMax;\n }\n\n // compute position of vertical scroll bar\n var needsVerticalScrollBar = (h > boxH);\n var vbarW = ScrollBox.barWidth + 2 * ScrollBox.barPad;\n var vbarH = ScrollBox.barLength + 2 * ScrollBox.barPad;\n // draw vertical scrollbar on the right side\n var vbarL = l + w;\n var vbarT = t;\n\n if(vbarL + vbarW > fullWidth) vbarL = fullWidth - vbarW;\n\n var vbar = this.container.selectAll('rect.scrollbar-vertical').data(\n (needsVerticalScrollBar) ? [0] : []);\n\n vbar.exit()\n .on('.drag', null)\n .remove();\n\n vbar.enter().append('rect')\n .classed('scrollbar-vertical', true)\n .call(Color.fill, ScrollBox.barColor);\n\n if(needsVerticalScrollBar) {\n this.vbar = vbar.attr({\n 'rx': ScrollBox.barRadius,\n 'ry': ScrollBox.barRadius,\n 'x': vbarL,\n 'y': vbarT,\n 'width': vbarW,\n 'height': vbarH\n });\n\n // vbar center moves between vbarYMin and vbarYMin + vbarTranslateMax\n this._vbarYMin = vbarT + vbarH / 2;\n this._vbarTranslateMax = boxH - vbarH;\n } else {\n delete this.vbar;\n delete this._vbarYMin;\n delete this._vbarTranslateMax;\n }\n\n // setup a clip path (if scroll bars are needed)\n var clipId = this.id;\n var clipL = boxL - 0.5;\n var clipR = (needsVerticalScrollBar) ? boxR + vbarW + 0.5 : boxR + 0.5;\n var clipT = boxT - 0.5;\n var clipB = (needsHorizontalScrollBar) ? boxB + hbarH + 0.5 : boxB + 0.5;\n\n var clipPath = fullLayout._topdefs.selectAll('#' + clipId)\n .data((needsHorizontalScrollBar || needsVerticalScrollBar) ? [0] : []);\n\n clipPath.exit().remove();\n\n clipPath.enter()\n .append('clipPath').attr('id', clipId)\n .append('rect');\n\n if(needsHorizontalScrollBar || needsVerticalScrollBar) {\n this._clipRect = clipPath.select('rect').attr({\n x: Math.floor(clipL),\n y: Math.floor(clipT),\n width: Math.ceil(clipR) - Math.floor(clipL),\n height: Math.ceil(clipB) - Math.floor(clipT)\n });\n\n this.container.call(Drawing.setClipUrl, clipId, this.gd);\n\n this.bg.attr({\n x: l,\n y: t,\n width: w,\n height: h\n });\n } else {\n this.bg.attr({\n width: 0,\n height: 0\n });\n this.container\n .on('wheel', null)\n .on('.drag', null)\n .call(Drawing.setClipUrl, null);\n delete this._clipRect;\n }\n\n // set up drag listeners (if scroll bars are needed)\n if(needsHorizontalScrollBar || needsVerticalScrollBar) {\n var onBoxDrag = d3.behavior.drag()\n .on('dragstart', function() {\n d3.event.sourceEvent.preventDefault();\n })\n .on('drag', this._onBoxDrag.bind(this));\n\n this.container\n .on('wheel', null)\n .on('wheel', this._onBoxWheel.bind(this))\n .on('.drag', null)\n .call(onBoxDrag);\n\n var onBarDrag = d3.behavior.drag()\n .on('dragstart', function() {\n d3.event.sourceEvent.preventDefault();\n d3.event.sourceEvent.stopPropagation();\n })\n .on('drag', this._onBarDrag.bind(this));\n\n if(needsHorizontalScrollBar) {\n this.hbar\n .on('.drag', null)\n .call(onBarDrag);\n }\n\n if(needsVerticalScrollBar) {\n this.vbar\n .on('.drag', null)\n .call(onBarDrag);\n }\n }\n\n // set scrollbox translation\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * If present, remove clip-path and scrollbars\n *\n * @method\n */\nScrollBox.prototype.disable = function disable() {\n if(this.hbar || this.vbar) {\n this.bg.attr({\n width: 0,\n height: 0\n });\n this.container\n .on('wheel', null)\n .on('.drag', null)\n .call(Drawing.setClipUrl, null);\n delete this._clipRect;\n }\n\n if(this.hbar) {\n this.hbar.on('.drag', null);\n this.hbar.remove();\n delete this.hbar;\n delete this._hbarXMin;\n delete this._hbarTranslateMax;\n }\n\n if(this.vbar) {\n this.vbar.on('.drag', null);\n this.vbar.remove();\n delete this.vbar;\n delete this._vbarYMin;\n delete this._vbarTranslateMax;\n }\n};\n\n/**\n * Handles scroll box drag events\n *\n * @method\n */\nScrollBox.prototype._onBoxDrag = function _onBoxDrag() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n translateX -= d3.event.dx;\n }\n\n if(this.vbar) {\n translateY -= d3.event.dy;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Handles scroll box wheel events\n *\n * @method\n */\nScrollBox.prototype._onBoxWheel = function _onBoxWheel() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n translateX += d3.event.deltaY;\n }\n\n if(this.vbar) {\n translateY += d3.event.deltaY;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Handles scroll bar drag events\n *\n * @method\n */\nScrollBox.prototype._onBarDrag = function _onBarDrag() {\n var translateX = this.translateX;\n var translateY = this.translateY;\n\n if(this.hbar) {\n var xMin = translateX + this._hbarXMin;\n var xMax = xMin + this._hbarTranslateMax;\n var x = Lib.constrain(d3.event.x, xMin, xMax);\n var xf = (x - xMin) / (xMax - xMin);\n\n var translateXMax = this.position.w - this._box.w;\n\n translateX = xf * translateXMax;\n }\n\n if(this.vbar) {\n var yMin = translateY + this._vbarYMin;\n var yMax = yMin + this._vbarTranslateMax;\n var y = Lib.constrain(d3.event.y, yMin, yMax);\n var yf = (y - yMin) / (yMax - yMin);\n\n var translateYMax = this.position.h - this._box.h;\n\n translateY = yf * translateYMax;\n }\n\n this.setTranslate(translateX, translateY);\n};\n\n/**\n * Set clip path and scroll bar translate transform\n *\n * @method\n * @param {number} [translateX=0] Horizontal offset (in pixels)\n * @param {number} [translateY=0] Vertical offset (in pixels)\n */\nScrollBox.prototype.setTranslate = function setTranslate(translateX, translateY) {\n // store translateX and translateY (needed by mouse event handlers)\n var translateXMax = this.position.w - this._box.w;\n var translateYMax = this.position.h - this._box.h;\n\n translateX = Lib.constrain(translateX || 0, 0, translateXMax);\n translateY = Lib.constrain(translateY || 0, 0, translateYMax);\n\n this.translateX = translateX;\n this.translateY = translateY;\n\n this.container.call(Drawing.setTranslate,\n this._box.l - this.position.l - translateX,\n this._box.t - this.position.t - translateY);\n\n if(this._clipRect) {\n this._clipRect.attr({\n x: Math.floor(this.position.l + translateX - 0.5),\n y: Math.floor(this.position.t + translateY - 0.5)\n });\n }\n\n if(this.hbar) {\n var xf = translateX / translateXMax;\n\n this.hbar.call(Drawing.setTranslate,\n translateX + xf * this._hbarTranslateMax,\n translateY);\n }\n\n if(this.vbar) {\n var yf = translateY / translateYMax;\n\n this.vbar.call(Drawing.setTranslate,\n translateX,\n translateY + yf * this._vbarTranslateMax);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar Drawing = require('../drawing');\nvar Axes = require('../../plots/cartesian/axes');\nvar xmlnsNamespaces = require('../../constants/xmlns_namespaces');\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n var imageDataAbove = [];\n var imageDataSubplot = {};\n var imageDataBelow = [];\n var subplot;\n var i;\n\n // Sort into top, subplot, and bottom layers\n for(i = 0; i < fullLayout.images.length; i++) {\n var img = fullLayout.images[i];\n\n if(img.visible) {\n if(img.layer === 'below' && img.xref !== 'paper' && img.yref !== 'paper') {\n subplot = img.xref + img.yref;\n\n var plotinfo = fullLayout._plots[subplot];\n\n if(!plotinfo) {\n // Fall back to _imageLowerLayer in case the requested subplot doesn't exist.\n // This can happen if you reference the image to an x / y axis combination\n // that doesn't have any data on it (and layer is below)\n imageDataBelow.push(img);\n continue;\n }\n\n if(plotinfo.mainplot) {\n subplot = plotinfo.mainplot.id;\n }\n\n if(!imageDataSubplot[subplot]) {\n imageDataSubplot[subplot] = [];\n }\n imageDataSubplot[subplot].push(img);\n } else if(img.layer === 'above') {\n imageDataAbove.push(img);\n } else {\n imageDataBelow.push(img);\n }\n }\n }\n\n\n var anchors = {\n x: {\n left: { sizing: 'xMin', offset: 0 },\n center: { sizing: 'xMid', offset: -1 / 2 },\n right: { sizing: 'xMax', offset: -1 }\n },\n y: {\n top: { sizing: 'YMin', offset: 0 },\n middle: { sizing: 'YMid', offset: -1 / 2 },\n bottom: { sizing: 'YMax', offset: -1 }\n }\n };\n\n\n // Images must be converted to dataURL's for exporting.\n function setImage(d) {\n var thisImage = d3.select(this);\n\n if(this._imgSrc === d.source) {\n return;\n }\n\n thisImage.attr('xmlns', xmlnsNamespaces.svg);\n\n if(d.source && d.source.slice(0, 5) === 'data:') {\n thisImage.attr('xlink:href', d.source);\n this._imgSrc = d.source;\n } else {\n var imagePromise = new Promise(function(resolve) {\n var img = new Image();\n this.img = img;\n\n // If not set, a `tainted canvas` error is thrown\n img.setAttribute('crossOrigin', 'anonymous');\n img.onerror = errorHandler;\n img.onload = function() {\n var canvas = document.createElement('canvas');\n canvas.width = this.width;\n canvas.height = this.height;\n\n var ctx = canvas.getContext('2d');\n ctx.drawImage(this, 0, 0);\n\n var dataURL = canvas.toDataURL('image/png');\n\n thisImage.attr('xlink:href', dataURL);\n\n // resolve promise in onload handler instead of on 'load' to support IE11\n // see https://github.com/plotly/plotly.js/issues/1685\n // for more details\n resolve();\n };\n\n thisImage.on('error', errorHandler);\n\n img.src = d.source;\n this._imgSrc = d.source;\n\n function errorHandler() {\n thisImage.remove();\n resolve();\n }\n }.bind(this));\n\n gd._promises.push(imagePromise);\n }\n }\n\n function applyAttributes(d) {\n var thisImage = d3.select(this);\n\n // Axes if specified\n var xa = Axes.getFromId(gd, d.xref);\n var ya = Axes.getFromId(gd, d.yref);\n\n var size = fullLayout._size;\n var width = xa ? Math.abs(xa.l2p(d.sizex) - xa.l2p(0)) : d.sizex * size.w;\n var height = ya ? Math.abs(ya.l2p(d.sizey) - ya.l2p(0)) : d.sizey * size.h;\n\n // Offsets for anchor positioning\n var xOffset = width * anchors.x[d.xanchor].offset;\n var yOffset = height * anchors.y[d.yanchor].offset;\n\n var sizing = anchors.x[d.xanchor].sizing + anchors.y[d.yanchor].sizing;\n\n // Final positions\n var xPos = (xa ? xa.r2p(d.x) + xa._offset : d.x * size.w + size.l) + xOffset;\n var yPos = (ya ? ya.r2p(d.y) + ya._offset : size.h - d.y * size.h + size.t) + yOffset;\n\n // Construct the proper aspectRatio attribute\n switch(d.sizing) {\n case 'fill':\n sizing += ' slice';\n break;\n\n case 'stretch':\n sizing = 'none';\n break;\n }\n\n thisImage.attr({\n x: xPos,\n y: yPos,\n width: width,\n height: height,\n preserveAspectRatio: sizing,\n opacity: d.opacity\n });\n\n\n // Set proper clipping on images\n var xId = xa ? xa._id : '';\n var yId = ya ? ya._id : '';\n var clipAxes = xId + yId;\n\n Drawing.setClipUrl(\n thisImage,\n clipAxes ? ('clip' + fullLayout._uid + clipAxes) : null,\n gd\n );\n }\n\n var imagesBelow = fullLayout._imageLowerLayer.selectAll('image')\n .data(imageDataBelow);\n var imagesAbove = fullLayout._imageUpperLayer.selectAll('image')\n .data(imageDataAbove);\n\n imagesBelow.enter().append('image');\n imagesAbove.enter().append('image');\n\n imagesBelow.exit().remove();\n imagesAbove.exit().remove();\n\n imagesBelow.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n imagesAbove.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n\n var allSubplots = Object.keys(fullLayout._plots);\n for(i = 0; i < allSubplots.length; i++) {\n subplot = allSubplots[i];\n var subplotObj = fullLayout._plots[subplot];\n\n // filter out overlaid plots (which havd their images on the main plot)\n // and gl2d plots (which don't support below images, at least not yet)\n if(!subplotObj.imagelayer) continue;\n\n var imagesOnSubplot = subplotObj.imagelayer.selectAll('image')\n // even if there are no images on this subplot, we need to run\n // enter and exit in case there were previously\n .data(imageDataSubplot[subplot] || []);\n\n imagesOnSubplot.enter().append('image');\n imagesOnSubplot.exit().remove();\n\n imagesOnSubplot.each(function(d) {\n setImage.bind(this)(d);\n applyAttributes.bind(this)(d);\n });\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\n\nvar Lib = require('../../lib');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar Titles = require('../titles');\n\nvar Cartesian = require('../../plots/cartesian');\nvar axisIDs = require('../../plots/cartesian/axis_ids');\n\nvar dragElement = require('../dragelement');\nvar setCursor = require('../../lib/setcursor');\n\nvar constants = require('./constants');\n\nmodule.exports = function(gd) {\n var fullLayout = gd._fullLayout;\n var rangeSliderData = fullLayout._rangeSliderData;\n for(var i = 0; i < rangeSliderData.length; i++) {\n var opts = rangeSliderData[i][constants.name];\n // fullLayout._uid may not exist when we call makeData\n opts._clipId = opts._id + '-' + fullLayout._uid;\n }\n\n /*\n * \n * \n * < .... range plot />\n * \n * \n * \n * \n * \n * \n * \n * \n * \n *\n * ...\n */\n\n function keyFunction(axisOpts) {\n return axisOpts._name;\n }\n\n var rangeSliders = fullLayout._infolayer\n .selectAll('g.' + constants.containerClassName)\n .data(rangeSliderData, keyFunction);\n\n // remove exiting sliders and their corresponding clip paths\n rangeSliders.exit().each(function(axisOpts) {\n var opts = axisOpts[constants.name];\n fullLayout._topdefs.select('#' + opts._clipId).remove();\n }).remove();\n\n // return early if no range slider is visible\n if(rangeSliderData.length === 0) return;\n\n rangeSliders.enter().append('g')\n .classed(constants.containerClassName, true)\n .attr('pointer-events', 'all');\n\n // for all present range sliders\n rangeSliders.each(function(axisOpts) {\n var rangeSlider = d3.select(this);\n var opts = axisOpts[constants.name];\n var oppAxisOpts = fullLayout[axisIDs.id2name(axisOpts.anchor)];\n var oppAxisRangeOpts = opts[axisIDs.id2name(axisOpts.anchor)];\n\n // update range\n // Expand slider range to the axis range\n if(opts.range) {\n var rng = Lib.simpleMap(opts.range, axisOpts.r2l);\n var axRng = Lib.simpleMap(axisOpts.range, axisOpts.r2l);\n var newRng;\n\n if(axRng[0] < axRng[1]) {\n newRng = [\n Math.min(rng[0], axRng[0]),\n Math.max(rng[1], axRng[1])\n ];\n } else {\n newRng = [\n Math.max(rng[0], axRng[0]),\n Math.min(rng[1], axRng[1])\n ];\n }\n\n opts.range = opts._input.range = Lib.simpleMap(newRng, axisOpts.l2r);\n }\n\n axisOpts.cleanRange('rangeslider.range');\n\n // update range slider dimensions\n\n var gs = fullLayout._size;\n var domain = axisOpts.domain;\n\n opts._width = gs.w * (domain[1] - domain[0]);\n\n var x = Math.round(gs.l + (gs.w * domain[0]));\n\n var y = Math.round(\n gs.t + gs.h * (1 - axisOpts._counterDomainMin) +\n (axisOpts.side === 'bottom' ? axisOpts._depth : 0) +\n opts._offsetShift + constants.extraPad\n );\n\n rangeSlider.attr('transform', 'translate(' + x + ',' + y + ')');\n\n // update data <--> pixel coordinate conversion methods\n\n opts._rl = Lib.simpleMap(opts.range, axisOpts.r2l);\n var rl0 = opts._rl[0];\n var rl1 = opts._rl[1];\n var drl = rl1 - rl0;\n\n opts.p2d = function(v) {\n return (v / opts._width) * drl + rl0;\n };\n\n opts.d2p = function(v) {\n return (v - rl0) / drl * opts._width;\n };\n\n if(axisOpts.rangebreaks) {\n var rsBreaks = axisOpts.locateBreaks(rl0, rl1);\n\n if(rsBreaks.length) {\n var j, brk;\n\n var lBreaks = 0;\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n lBreaks += (brk.max - brk.min);\n }\n\n // TODO fix for reversed-range axes !!!\n\n // compute slope and piecewise offsets\n var m2 = opts._width / (rl1 - rl0 - lBreaks);\n var _B = [-m2 * rl0];\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n _B.push(_B[_B.length - 1] - m2 * (brk.max - brk.min));\n }\n\n opts.d2p = function(v) {\n var b = _B[0];\n for(var j = 0; j < rsBreaks.length; j++) {\n var brk = rsBreaks[j];\n if(v >= brk.max) b = _B[j + 1];\n else if(v < brk.min) break;\n }\n return b + m2 * v;\n };\n\n // fill pixel (i.e. 'p') min/max here,\n // to not have to loop through the _rangebreaks twice during `p2d`\n for(j = 0; j < rsBreaks.length; j++) {\n brk = rsBreaks[j];\n brk.pmin = opts.d2p(brk.min);\n brk.pmax = opts.d2p(brk.max);\n }\n\n opts.p2d = function(v) {\n var b = _B[0];\n for(var j = 0; j < rsBreaks.length; j++) {\n var brk = rsBreaks[j];\n if(v >= brk.pmax) b = _B[j + 1];\n else if(v < brk.pmin) break;\n }\n return (v - b) / m2;\n };\n }\n }\n\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var range0OppAxis = oppAxisOpts.r2l(oppAxisRangeOpts.range[0]);\n var range1OppAxis = oppAxisOpts.r2l(oppAxisRangeOpts.range[1]);\n var distOppAxis = range1OppAxis - range0OppAxis;\n\n opts.d2pOppAxis = function(v) {\n return (v - range0OppAxis) / distOppAxis * opts._height;\n };\n }\n\n // update inner nodes\n\n rangeSlider\n .call(drawBg, gd, axisOpts, opts)\n .call(addClipPath, gd, axisOpts, opts)\n .call(drawRangePlot, gd, axisOpts, opts)\n .call(drawMasks, gd, axisOpts, opts, oppAxisRangeOpts)\n .call(drawSlideBox, gd, axisOpts, opts)\n .call(drawGrabbers, gd, axisOpts, opts);\n\n // setup drag element\n setupDragElement(rangeSlider, gd, axisOpts, opts);\n\n // update current range\n setPixelRange(rangeSlider, gd, axisOpts, opts, oppAxisOpts, oppAxisRangeOpts);\n\n // title goes next to range slider instead of tick labels, so\n // just take it over and draw it from here\n if(axisOpts.side === 'bottom') {\n Titles.draw(gd, axisOpts._id + 'title', {\n propContainer: axisOpts,\n propName: axisOpts._name + '.title',\n placeholder: fullLayout._dfltTitle.x,\n attributes: {\n x: axisOpts._offset + axisOpts._length / 2,\n y: y + opts._height + opts._offsetShift + 10 + 1.5 * axisOpts.title.font.size,\n 'text-anchor': 'middle'\n }\n });\n }\n });\n};\n\nfunction setupDragElement(rangeSlider, gd, axisOpts, opts) {\n var slideBox = rangeSlider.select('rect.' + constants.slideBoxClassName).node();\n var grabAreaMin = rangeSlider.select('rect.' + constants.grabAreaMinClassName).node();\n var grabAreaMax = rangeSlider.select('rect.' + constants.grabAreaMaxClassName).node();\n\n rangeSlider.on('mousedown', function() {\n var event = d3.event;\n var target = event.target;\n var startX = event.clientX;\n var offsetX = startX - rangeSlider.node().getBoundingClientRect().left;\n var minVal = opts.d2p(axisOpts._rl[0]);\n var maxVal = opts.d2p(axisOpts._rl[1]);\n\n var dragCover = dragElement.coverSlip();\n\n dragCover.addEventListener('mousemove', mouseMove);\n dragCover.addEventListener('mouseup', mouseUp);\n\n function mouseMove(e) {\n var delta = +e.clientX - startX;\n var pixelMin, pixelMax, cursor;\n\n switch(target) {\n case slideBox:\n cursor = 'ew-resize';\n pixelMin = minVal + delta;\n pixelMax = maxVal + delta;\n break;\n\n case grabAreaMin:\n cursor = 'col-resize';\n pixelMin = minVal + delta;\n pixelMax = maxVal;\n break;\n\n case grabAreaMax:\n cursor = 'col-resize';\n pixelMin = minVal;\n pixelMax = maxVal + delta;\n break;\n\n default:\n cursor = 'ew-resize';\n pixelMin = offsetX;\n pixelMax = offsetX + delta;\n break;\n }\n\n if(pixelMax < pixelMin) {\n var tmp = pixelMax;\n pixelMax = pixelMin;\n pixelMin = tmp;\n }\n\n opts._pixelMin = pixelMin;\n opts._pixelMax = pixelMax;\n\n setCursor(d3.select(dragCover), cursor);\n setDataRange(rangeSlider, gd, axisOpts, opts);\n }\n\n function mouseUp() {\n dragCover.removeEventListener('mousemove', mouseMove);\n dragCover.removeEventListener('mouseup', mouseUp);\n Lib.removeElement(dragCover);\n }\n });\n}\n\nfunction setDataRange(rangeSlider, gd, axisOpts, opts) {\n function clamp(v) {\n return axisOpts.l2r(Lib.constrain(v, opts._rl[0], opts._rl[1]));\n }\n\n var dataMin = clamp(opts.p2d(opts._pixelMin));\n var dataMax = clamp(opts.p2d(opts._pixelMax));\n\n window.requestAnimationFrame(function() {\n Registry.call('_guiRelayout', gd, axisOpts._name + '.range', [dataMin, dataMax]);\n });\n}\n\nfunction setPixelRange(rangeSlider, gd, axisOpts, opts, oppAxisOpts, oppAxisRangeOpts) {\n var hw2 = constants.handleWidth / 2;\n\n function clamp(v) {\n return Lib.constrain(v, 0, opts._width);\n }\n\n function clampOppAxis(v) {\n return Lib.constrain(v, 0, opts._height);\n }\n\n function clampHandle(v) {\n return Lib.constrain(v, -hw2, opts._width + hw2);\n }\n\n var pixelMin = clamp(opts.d2p(axisOpts._rl[0]));\n var pixelMax = clamp(opts.d2p(axisOpts._rl[1]));\n\n rangeSlider.select('rect.' + constants.slideBoxClassName)\n .attr('x', pixelMin)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMinClassName)\n .attr('width', pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMaxClassName)\n .attr('x', pixelMax)\n .attr('width', opts._width - pixelMax);\n\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var pixelMinOppAxis = opts._height - clampOppAxis(opts.d2pOppAxis(oppAxisOpts._rl[1]));\n var pixelMaxOppAxis = opts._height - clampOppAxis(opts.d2pOppAxis(oppAxisOpts._rl[0]));\n\n rangeSlider.select('rect.' + constants.maskMinOppAxisClassName)\n .attr('x', pixelMin)\n .attr('height', pixelMinOppAxis)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.maskMaxOppAxisClassName)\n .attr('x', pixelMin)\n .attr('y', pixelMaxOppAxis)\n .attr('height', opts._height - pixelMaxOppAxis)\n .attr('width', pixelMax - pixelMin);\n\n rangeSlider.select('rect.' + constants.slideBoxClassName)\n .attr('y', pixelMinOppAxis)\n .attr('height', pixelMaxOppAxis - pixelMinOppAxis);\n }\n\n // add offset for crispier corners\n // https://github.com/plotly/plotly.js/pull/1409\n var offset = 0.5;\n\n var xMin = Math.round(clampHandle(pixelMin - hw2)) - offset;\n var xMax = Math.round(clampHandle(pixelMax - hw2)) + offset;\n\n rangeSlider.select('g.' + constants.grabberMinClassName)\n .attr('transform', 'translate(' + xMin + ',' + offset + ')');\n\n rangeSlider.select('g.' + constants.grabberMaxClassName)\n .attr('transform', 'translate(' + xMax + ',' + offset + ')');\n}\n\nfunction drawBg(rangeSlider, gd, axisOpts, opts) {\n var bg = Lib.ensureSingle(rangeSlider, 'rect', constants.bgClassName, function(s) {\n s.attr({\n x: 0,\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n var borderCorrect = (opts.borderwidth % 2) === 0 ?\n opts.borderwidth :\n opts.borderwidth - 1;\n\n var offsetShift = -opts._offsetShift;\n var lw = Drawing.crispRound(gd, opts.borderwidth);\n\n bg.attr({\n width: opts._width + borderCorrect,\n height: opts._height + borderCorrect,\n transform: 'translate(' + offsetShift + ',' + offsetShift + ')',\n fill: opts.bgcolor,\n stroke: opts.bordercolor,\n 'stroke-width': lw\n });\n}\n\nfunction addClipPath(rangeSlider, gd, axisOpts, opts) {\n var fullLayout = gd._fullLayout;\n\n var clipPath = Lib.ensureSingleById(fullLayout._topdefs, 'clipPath', opts._clipId, function(s) {\n s.append('rect').attr({ x: 0, y: 0 });\n });\n\n clipPath.select('rect').attr({\n width: opts._width,\n height: opts._height\n });\n}\n\nfunction drawRangePlot(rangeSlider, gd, axisOpts, opts) {\n var calcData = gd.calcdata;\n\n var rangePlots = rangeSlider.selectAll('g.' + constants.rangePlotClassName)\n .data(axisOpts._subplotsWith, Lib.identity);\n\n rangePlots.enter().append('g')\n .attr('class', function(id) { return constants.rangePlotClassName + ' ' + id; })\n .call(Drawing.setClipUrl, opts._clipId, gd);\n\n rangePlots.order();\n\n rangePlots.exit().remove();\n\n var mainplotinfo;\n\n rangePlots.each(function(id, i) {\n var plotgroup = d3.select(this);\n var isMainPlot = (i === 0);\n\n var oppAxisOpts = axisIDs.getFromId(gd, id, 'y');\n var oppAxisName = oppAxisOpts._name;\n var oppAxisRangeOpts = opts[oppAxisName];\n\n var mockFigure = {\n data: [],\n layout: {\n xaxis: {\n type: axisOpts.type,\n domain: [0, 1],\n range: opts.range.slice(),\n calendar: axisOpts.calendar\n },\n width: opts._width,\n height: opts._height,\n margin: { t: 0, b: 0, l: 0, r: 0 }\n },\n _context: gd._context\n };\n\n if(axisOpts.rangebreaks) {\n mockFigure.layout.xaxis.rangebreaks = axisOpts.rangebreaks;\n }\n\n mockFigure.layout[oppAxisName] = {\n type: oppAxisOpts.type,\n domain: [0, 1],\n range: oppAxisRangeOpts.rangemode !== 'match' ? oppAxisRangeOpts.range.slice() : oppAxisOpts.range.slice(),\n calendar: oppAxisOpts.calendar\n };\n\n if(oppAxisOpts.rangebreaks) {\n mockFigure.layout[oppAxisName].rangebreaks = oppAxisOpts.rangebreaks;\n }\n\n Plots.supplyDefaults(mockFigure);\n\n var xa = mockFigure._fullLayout.xaxis;\n var ya = mockFigure._fullLayout[oppAxisName];\n\n xa.clearCalc();\n xa.setScale();\n ya.clearCalc();\n ya.setScale();\n\n var plotinfo = {\n id: id,\n plotgroup: plotgroup,\n xaxis: xa,\n yaxis: ya,\n isRangePlot: true\n };\n\n if(isMainPlot) mainplotinfo = plotinfo;\n else {\n plotinfo.mainplot = 'xy';\n plotinfo.mainplotinfo = mainplotinfo;\n }\n\n Cartesian.rangePlot(gd, plotinfo, filterRangePlotCalcData(calcData, id));\n });\n}\n\nfunction filterRangePlotCalcData(calcData, subplotId) {\n var out = [];\n\n for(var i = 0; i < calcData.length; i++) {\n var calcTrace = calcData[i];\n var trace = calcTrace[0].trace;\n\n if(trace.xaxis + trace.yaxis === subplotId) {\n out.push(calcTrace);\n }\n }\n\n return out;\n}\n\nfunction drawMasks(rangeSlider, gd, axisOpts, opts, oppAxisRangeOpts) {\n var maskMin = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMinClassName, function(s) {\n s.attr({\n x: 0,\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMin\n .attr('height', opts._height)\n .call(Color.fill, constants.maskColor);\n\n var maskMax = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMaxClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMax\n .attr('height', opts._height)\n .call(Color.fill, constants.maskColor);\n\n // masks used for oppAxis zoom\n if(oppAxisRangeOpts.rangemode !== 'match') {\n var maskMinOppAxis = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMinOppAxisClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMinOppAxis\n .attr('width', opts._width)\n .call(Color.fill, constants.maskOppAxisColor);\n\n var maskMaxOppAxis = Lib.ensureSingle(rangeSlider, 'rect', constants.maskMaxOppAxisClassName, function(s) {\n s.attr({\n y: 0,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n maskMaxOppAxis\n .attr('width', opts._width)\n .style('border-top', constants.maskOppBorder)\n .call(Color.fill, constants.maskOppAxisColor);\n }\n}\n\nfunction drawSlideBox(rangeSlider, gd, axisOpts, opts) {\n if(gd._context.staticPlot) return;\n\n var slideBox = Lib.ensureSingle(rangeSlider, 'rect', constants.slideBoxClassName, function(s) {\n s.attr({\n y: 0,\n cursor: constants.slideBoxCursor,\n 'shape-rendering': 'crispEdges'\n });\n });\n\n slideBox.attr({\n height: opts._height,\n fill: constants.slideBoxFill\n });\n}\n\nfunction drawGrabbers(rangeSlider, gd, axisOpts, opts) {\n // \n var grabberMin = Lib.ensureSingle(rangeSlider, 'g', constants.grabberMinClassName);\n var grabberMax = Lib.ensureSingle(rangeSlider, 'g', constants.grabberMaxClassName);\n\n // \n var handleFixAttrs = {\n x: 0,\n width: constants.handleWidth,\n rx: constants.handleRadius,\n fill: Color.background,\n stroke: Color.defaultLine,\n 'stroke-width': constants.handleStrokeWidth,\n 'shape-rendering': 'crispEdges'\n };\n var handleDynamicAttrs = {\n y: Math.round(opts._height / 4),\n height: Math.round(opts._height / 2),\n };\n var handleMin = Lib.ensureSingle(grabberMin, 'rect', constants.handleMinClassName, function(s) {\n s.attr(handleFixAttrs);\n });\n handleMin.attr(handleDynamicAttrs);\n\n var handleMax = Lib.ensureSingle(grabberMax, 'rect', constants.handleMaxClassName, function(s) {\n s.attr(handleFixAttrs);\n });\n handleMax.attr(handleDynamicAttrs);\n\n // \n if(gd._context.staticPlot) return;\n\n var grabAreaFixAttrs = {\n width: constants.grabAreaWidth,\n x: 0,\n y: 0,\n fill: constants.grabAreaFill,\n cursor: constants.grabAreaCursor\n };\n\n var grabAreaMin = Lib.ensureSingle(grabberMin, 'rect', constants.grabAreaMinClassName, function(s) {\n s.attr(grabAreaFixAttrs);\n });\n grabAreaMin.attr('height', opts._height);\n\n var grabAreaMax = Lib.ensureSingle(grabberMax, 'rect', constants.grabAreaMaxClassName, function(s) {\n s.attr(grabAreaFixAttrs);\n });\n grabAreaMax.attr('height', opts._height);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nexports.isGrouped = function isGrouped(legendLayout) {\n return (legendLayout.traceorder || '').indexOf('grouped') !== -1;\n};\n\nexports.isVertical = function isVertical(legendLayout) {\n return legendLayout.orientation !== 'h';\n};\n\nexports.isReversed = function isReversed(legendLayout) {\n return (legendLayout.traceorder || '').indexOf('reversed') !== -1;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar numConstants = require('../../constants/numerical');\nvar BADNUM = numConstants.BADNUM;\nvar LOG_CLIP = numConstants.LOG_CLIP;\nvar LOG_CLIP_PLUS = LOG_CLIP + 0.5;\nvar LOG_CLIP_MINUS = LOG_CLIP - 0.5;\nvar Lib = require('../../lib');\nvar segmentsIntersect = Lib.segmentsIntersect;\nvar constrain = Lib.constrain;\nvar constants = require('./constants');\n\n\nmodule.exports = function linePoints(d, opts) {\n var xa = opts.xaxis;\n var ya = opts.yaxis;\n var xLog = xa.type === 'log';\n var yLog = ya.type === 'log';\n var xLen = xa._length;\n var yLen = ya._length;\n var connectGaps = opts.connectGaps;\n var baseTolerance = opts.baseTolerance;\n var shape = opts.shape;\n var linear = shape === 'linear';\n var fill = opts.fill && opts.fill !== 'none';\n var segments = [];\n var minTolerance = constants.minTolerance;\n var len = d.length;\n var pts = new Array(len);\n var pti = 0;\n\n var i;\n\n // pt variables are pixel coordinates [x,y] of one point\n // these four are the outputs of clustering on a line\n var clusterStartPt, clusterEndPt, clusterHighPt, clusterLowPt;\n\n // \"this\" is the next point we're considering adding to the cluster\n var thisPt;\n\n // did we encounter the high point first, then a low point, or vice versa?\n var clusterHighFirst;\n\n // the first two points in the cluster determine its unit vector\n // so the second is always in the \"High\" direction\n var clusterUnitVector;\n\n // the pixel delta from clusterStartPt\n var thisVector;\n\n // val variables are (signed) pixel distances along the cluster vector\n var clusterRefDist, clusterHighVal, clusterLowVal, thisVal;\n\n // deviation variables are (signed) pixel distances normal to the cluster vector\n var clusterMinDeviation, clusterMaxDeviation, thisDeviation;\n\n // turn one calcdata point into pixel coordinates\n function getPt(index) {\n var di = d[index];\n if(!di) return false;\n var x = opts.linearized ? xa.l2p(di.x) : xa.c2p(di.x);\n var y = opts.linearized ? ya.l2p(di.y) : ya.c2p(di.y);\n\n // if non-positive log values, set them VERY far off-screen\n // so the line looks essentially straight from the previous point.\n if(x === BADNUM) {\n if(xLog) x = xa.c2p(di.x, true);\n if(x === BADNUM) return false;\n // If BOTH were bad log values, make the line follow a constant\n // exponent rather than a constant slope\n if(yLog && y === BADNUM) {\n x *= Math.abs(xa._m * yLen * (xa._m > 0 ? LOG_CLIP_PLUS : LOG_CLIP_MINUS) /\n (ya._m * xLen * (ya._m > 0 ? LOG_CLIP_PLUS : LOG_CLIP_MINUS)));\n }\n x *= 1000;\n }\n if(y === BADNUM) {\n if(yLog) y = ya.c2p(di.y, true);\n if(y === BADNUM) return false;\n y *= 1000;\n }\n return [x, y];\n }\n\n function crossesViewport(xFrac0, yFrac0, xFrac1, yFrac1) {\n var dx = xFrac1 - xFrac0;\n var dy = yFrac1 - yFrac0;\n var dx0 = 0.5 - xFrac0;\n var dy0 = 0.5 - yFrac0;\n var norm2 = dx * dx + dy * dy;\n var dot = dx * dx0 + dy * dy0;\n if(dot > 0 && dot < norm2) {\n var cross = dx0 * dy - dy0 * dx;\n if(cross * cross < norm2) return true;\n }\n }\n\n var latestXFrac, latestYFrac;\n // if we're off-screen, increase tolerance over baseTolerance\n function getTolerance(pt, nextPt) {\n var xFrac = pt[0] / xLen;\n var yFrac = pt[1] / yLen;\n var offScreenFraction = Math.max(0, -xFrac, xFrac - 1, -yFrac, yFrac - 1);\n if(offScreenFraction && (latestXFrac !== undefined) &&\n crossesViewport(xFrac, yFrac, latestXFrac, latestYFrac)\n ) {\n offScreenFraction = 0;\n }\n if(offScreenFraction && nextPt &&\n crossesViewport(xFrac, yFrac, nextPt[0] / xLen, nextPt[1] / yLen)\n ) {\n offScreenFraction = 0;\n }\n\n return (1 + constants.toleranceGrowth * offScreenFraction) * baseTolerance;\n }\n\n function ptDist(pt1, pt2) {\n var dx = pt1[0] - pt2[0];\n var dy = pt1[1] - pt2[1];\n return Math.sqrt(dx * dx + dy * dy);\n }\n\n // last bit of filtering: clip paths that are VERY far off-screen\n // so we don't get near the browser's hard limit (+/- 2^29 px in Chrome and FF)\n\n var maxScreensAway = constants.maxScreensAway;\n\n // find the intersections between the segment from pt1 to pt2\n // and the large rectangle maxScreensAway around the viewport\n // if one of pt1 and pt2 is inside and the other outside, there\n // will be only one intersection.\n // if both are outside there will be 0 or 2 intersections\n // (or 1 if it's right at a corner - we'll treat that like 0)\n // returns an array of intersection pts\n var xEdge0 = -xLen * maxScreensAway;\n var xEdge1 = xLen * (1 + maxScreensAway);\n var yEdge0 = -yLen * maxScreensAway;\n var yEdge1 = yLen * (1 + maxScreensAway);\n var edges = [\n [xEdge0, yEdge0, xEdge1, yEdge0],\n [xEdge1, yEdge0, xEdge1, yEdge1],\n [xEdge1, yEdge1, xEdge0, yEdge1],\n [xEdge0, yEdge1, xEdge0, yEdge0]\n ];\n var xEdge, yEdge, lastXEdge, lastYEdge, lastFarPt, edgePt;\n\n // for linear line shape, edge intersections should be linearly interpolated\n // spline uses this too, which isn't precisely correct but is actually pretty\n // good, because Catmull-Rom weights far-away points less in creating the curvature\n function getLinearEdgeIntersections(pt1, pt2) {\n var out = [];\n var ptCount = 0;\n for(var i = 0; i < 4; i++) {\n var edge = edges[i];\n var ptInt = segmentsIntersect(\n pt1[0], pt1[1], pt2[0], pt2[1],\n edge[0], edge[1], edge[2], edge[3]\n );\n if(ptInt && (!ptCount ||\n Math.abs(ptInt.x - out[0][0]) > 1 ||\n Math.abs(ptInt.y - out[0][1]) > 1\n )) {\n ptInt = [ptInt.x, ptInt.y];\n // if we have 2 intersections, make sure the closest one to pt1 comes first\n if(ptCount && ptDist(ptInt, pt1) < ptDist(out[0], pt1)) out.unshift(ptInt);\n else out.push(ptInt);\n ptCount++;\n }\n }\n return out;\n }\n\n function onlyConstrainedPoint(pt) {\n if(pt[0] < xEdge0 || pt[0] > xEdge1 || pt[1] < yEdge0 || pt[1] > yEdge1) {\n return [constrain(pt[0], xEdge0, xEdge1), constrain(pt[1], yEdge0, yEdge1)];\n }\n }\n\n function sameEdge(pt1, pt2) {\n if(pt1[0] === pt2[0] && (pt1[0] === xEdge0 || pt1[0] === xEdge1)) return true;\n if(pt1[1] === pt2[1] && (pt1[1] === yEdge0 || pt1[1] === yEdge1)) return true;\n }\n\n // for line shapes hv and vh, movement in the two dimensions is decoupled,\n // so all we need to do is constrain each dimension independently\n function getHVEdgeIntersections(pt1, pt2) {\n var out = [];\n var ptInt1 = onlyConstrainedPoint(pt1);\n var ptInt2 = onlyConstrainedPoint(pt2);\n if(ptInt1 && ptInt2 && sameEdge(ptInt1, ptInt2)) return out;\n\n if(ptInt1) out.push(ptInt1);\n if(ptInt2) out.push(ptInt2);\n return out;\n }\n\n // hvh and vhv we sometimes have to move one of the intersection points\n // out BEYOND the clipping rect, by a maximum of a factor of 2, so that\n // the midpoint line is drawn in the right place\n function getABAEdgeIntersections(dim, limit0, limit1) {\n return function(pt1, pt2) {\n var ptInt1 = onlyConstrainedPoint(pt1);\n var ptInt2 = onlyConstrainedPoint(pt2);\n\n var out = [];\n if(ptInt1 && ptInt2 && sameEdge(ptInt1, ptInt2)) return out;\n\n if(ptInt1) out.push(ptInt1);\n if(ptInt2) out.push(ptInt2);\n\n var midShift = 2 * Lib.constrain((pt1[dim] + pt2[dim]) / 2, limit0, limit1) -\n ((ptInt1 || pt1)[dim] + (ptInt2 || pt2)[dim]);\n if(midShift) {\n var ptToAlter;\n if(ptInt1 && ptInt2) {\n ptToAlter = (midShift > 0 === ptInt1[dim] > ptInt2[dim]) ? ptInt1 : ptInt2;\n } else ptToAlter = ptInt1 || ptInt2;\n\n ptToAlter[dim] += midShift;\n }\n\n return out;\n };\n }\n\n var getEdgeIntersections;\n if(shape === 'linear' || shape === 'spline') {\n getEdgeIntersections = getLinearEdgeIntersections;\n } else if(shape === 'hv' || shape === 'vh') {\n getEdgeIntersections = getHVEdgeIntersections;\n } else if(shape === 'hvh') getEdgeIntersections = getABAEdgeIntersections(0, xEdge0, xEdge1);\n else if(shape === 'vhv') getEdgeIntersections = getABAEdgeIntersections(1, yEdge0, yEdge1);\n\n // a segment pt1->pt2 entirely outside the nearby region:\n // find the corner it gets closest to touching\n function getClosestCorner(pt1, pt2) {\n var dx = pt2[0] - pt1[0];\n var m = (pt2[1] - pt1[1]) / dx;\n var b = (pt1[1] * pt2[0] - pt2[1] * pt1[0]) / dx;\n\n if(b > 0) return [m > 0 ? xEdge0 : xEdge1, yEdge1];\n else return [m > 0 ? xEdge1 : xEdge0, yEdge0];\n }\n\n function updateEdge(pt) {\n var x = pt[0];\n var y = pt[1];\n var xSame = x === pts[pti - 1][0];\n var ySame = y === pts[pti - 1][1];\n // duplicate point?\n if(xSame && ySame) return;\n if(pti > 1) {\n // backtracking along an edge?\n var xSame2 = x === pts[pti - 2][0];\n var ySame2 = y === pts[pti - 2][1];\n if(xSame && (x === xEdge0 || x === xEdge1) && xSame2) {\n if(ySame2) pti--; // backtracking exactly - drop prev pt and don't add\n else pts[pti - 1] = pt; // not exact: replace the prev pt\n } else if(ySame && (y === yEdge0 || y === yEdge1) && ySame2) {\n if(xSame2) pti--;\n else pts[pti - 1] = pt;\n } else pts[pti++] = pt;\n } else pts[pti++] = pt;\n }\n\n function updateEdgesForReentry(pt) {\n // if we're outside the nearby region and going back in,\n // we may need to loop around a corner point\n if(pts[pti - 1][0] !== pt[0] && pts[pti - 1][1] !== pt[1]) {\n updateEdge([lastXEdge, lastYEdge]);\n }\n updateEdge(pt);\n lastFarPt = null;\n lastXEdge = lastYEdge = 0;\n }\n\n function addPt(pt) {\n latestXFrac = pt[0] / xLen;\n latestYFrac = pt[1] / yLen;\n // Are we more than maxScreensAway off-screen any direction?\n // if so, clip to this box, but in such a way that on-screen\n // drawing is unchanged\n xEdge = (pt[0] < xEdge0) ? xEdge0 : (pt[0] > xEdge1) ? xEdge1 : 0;\n yEdge = (pt[1] < yEdge0) ? yEdge0 : (pt[1] > yEdge1) ? yEdge1 : 0;\n if(xEdge || yEdge) {\n if(!pti) {\n // to get fills right - if first point is far, push it toward the\n // screen in whichever direction(s) are far\n\n pts[pti++] = [xEdge || pt[0], yEdge || pt[1]];\n } else if(lastFarPt) {\n // both this point and the last are outside the nearby region\n // check if we're crossing the nearby region\n var intersections = getEdgeIntersections(lastFarPt, pt);\n if(intersections.length > 1) {\n updateEdgesForReentry(intersections[0]);\n pts[pti++] = intersections[1];\n }\n } else {\n // we're leaving the nearby region - add the point where we left it\n\n edgePt = getEdgeIntersections(pts[pti - 1], pt)[0];\n pts[pti++] = edgePt;\n }\n\n var lastPt = pts[pti - 1];\n if(xEdge && yEdge && (lastPt[0] !== xEdge || lastPt[1] !== yEdge)) {\n // we've gone out beyond a new corner: add the corner too\n // so that the next point will take the right winding\n if(lastFarPt) {\n if(lastXEdge !== xEdge && lastYEdge !== yEdge) {\n if(lastXEdge && lastYEdge) {\n // we've gone around to an opposite corner - we\n // need to add the correct extra corner\n // in order to get the right winding\n updateEdge(getClosestCorner(lastFarPt, pt));\n } else {\n // we're coming from a far edge - the extra corner\n // we need is determined uniquely by the sectors\n updateEdge([lastXEdge || xEdge, lastYEdge || yEdge]);\n }\n } else if(lastXEdge && lastYEdge) {\n updateEdge([lastXEdge, lastYEdge]);\n }\n }\n updateEdge([xEdge, yEdge]);\n } else if((lastXEdge - xEdge) && (lastYEdge - yEdge)) {\n // we're coming from an edge or far corner to an edge - again the\n // extra corner we need is uniquely determined by the sectors\n updateEdge([xEdge || lastXEdge, yEdge || lastYEdge]);\n }\n lastFarPt = pt;\n lastXEdge = xEdge;\n lastYEdge = yEdge;\n } else {\n if(lastFarPt) {\n // this point is in range but the previous wasn't: add its entry pt first\n updateEdgesForReentry(getEdgeIntersections(lastFarPt, pt)[0]);\n }\n\n pts[pti++] = pt;\n }\n }\n\n // loop over ALL points in this trace\n for(i = 0; i < len; i++) {\n clusterStartPt = getPt(i);\n if(!clusterStartPt) continue;\n\n pti = 0;\n lastFarPt = null;\n addPt(clusterStartPt);\n\n // loop over one segment of the trace\n for(i++; i < len; i++) {\n clusterHighPt = getPt(i);\n if(!clusterHighPt) {\n if(connectGaps) continue;\n else break;\n }\n\n // can't decimate if nonlinear line shape\n // TODO: we *could* decimate [hv]{2,3} shapes if we restricted clusters to horz or vert again\n // but spline would be verrry awkward to decimate\n if(!linear || !opts.simplify) {\n addPt(clusterHighPt);\n continue;\n }\n\n var nextPt = getPt(i + 1);\n\n clusterRefDist = ptDist(clusterHighPt, clusterStartPt);\n\n // #3147 - always include the very first and last points for fills\n if(!(fill && (pti === 0 || pti === len - 1)) &&\n clusterRefDist < getTolerance(clusterHighPt, nextPt) * minTolerance) continue;\n\n clusterUnitVector = [\n (clusterHighPt[0] - clusterStartPt[0]) / clusterRefDist,\n (clusterHighPt[1] - clusterStartPt[1]) / clusterRefDist\n ];\n\n clusterLowPt = clusterStartPt;\n clusterHighVal = clusterRefDist;\n clusterLowVal = clusterMinDeviation = clusterMaxDeviation = 0;\n clusterHighFirst = false;\n clusterEndPt = clusterHighPt;\n\n // loop over one cluster of points that collapse onto one line\n for(i++; i < d.length; i++) {\n thisPt = nextPt;\n nextPt = getPt(i + 1);\n if(!thisPt) {\n if(connectGaps) continue;\n else break;\n }\n thisVector = [\n thisPt[0] - clusterStartPt[0],\n thisPt[1] - clusterStartPt[1]\n ];\n // cross product (or dot with normal to the cluster vector)\n thisDeviation = thisVector[0] * clusterUnitVector[1] - thisVector[1] * clusterUnitVector[0];\n clusterMinDeviation = Math.min(clusterMinDeviation, thisDeviation);\n clusterMaxDeviation = Math.max(clusterMaxDeviation, thisDeviation);\n\n if(clusterMaxDeviation - clusterMinDeviation > getTolerance(thisPt, nextPt)) break;\n\n clusterEndPt = thisPt;\n thisVal = thisVector[0] * clusterUnitVector[0] + thisVector[1] * clusterUnitVector[1];\n\n if(thisVal > clusterHighVal) {\n clusterHighVal = thisVal;\n clusterHighPt = thisPt;\n clusterHighFirst = false;\n } else if(thisVal < clusterLowVal) {\n clusterLowVal = thisVal;\n clusterLowPt = thisPt;\n clusterHighFirst = true;\n }\n }\n\n // insert this cluster into pts\n // we've already inserted the start pt, now check if we have high and low pts\n if(clusterHighFirst) {\n addPt(clusterHighPt);\n if(clusterEndPt !== clusterLowPt) addPt(clusterLowPt);\n } else {\n if(clusterLowPt !== clusterStartPt) addPt(clusterLowPt);\n if(clusterEndPt !== clusterHighPt) addPt(clusterHighPt);\n }\n // and finally insert the end pt\n addPt(clusterEndPt);\n\n // have we reached the end of this segment?\n if(i >= d.length || !thisPt) break;\n\n // otherwise we have an out-of-cluster point to insert as next clusterStartPt\n addPt(thisPt);\n clusterStartPt = thisPt;\n }\n\n // to get fills right - repeat what we did at the start\n if(lastFarPt) updateEdge([lastXEdge || lastFarPt[0], lastYEdge || lastFarPt[1]]);\n\n segments.push(pts.slice(0, pti));\n }\n\n return segments;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar attributes = require('./attributes');\nvar handleDomainDefaults = require('../../plots/domain').defaults;\nvar handleText = require('../bar/defaults').handleText;\n\nfunction handleLabelsAndValues(labels, values) {\n var hasLabels = Array.isArray(labels);\n var hasValues = Lib.isArrayOrTypedArray(values);\n var len = Math.min(\n hasLabels ? labels.length : Infinity,\n hasValues ? values.length : Infinity\n );\n\n if(!isFinite(len)) len = 0;\n\n if(len && hasValues) {\n var hasPositive;\n for(var i = 0; i < len; i++) {\n var v = values[i];\n if(isNumeric(v) && v > 0) {\n hasPositive = true;\n break;\n }\n }\n if(!hasPositive) len = 0;\n }\n\n return {\n hasLabels: hasLabels,\n hasValues: hasValues,\n len: len\n };\n}\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var labels = coerce('labels');\n var values = coerce('values');\n\n var res = handleLabelsAndValues(labels, values);\n var len = res.len;\n traceOut._hasLabels = res.hasLabels;\n traceOut._hasValues = res.hasValues;\n\n if(!traceOut._hasLabels &&\n traceOut._hasValues\n ) {\n coerce('label0');\n coerce('dlabel');\n }\n\n if(!len) {\n traceOut.visible = false;\n return;\n }\n traceOut._length = len;\n\n var lineWidth = coerce('marker.line.width');\n if(lineWidth) coerce('marker.line.color');\n\n coerce('marker.colors');\n\n coerce('scalegroup');\n // TODO: hole needs to be coerced to the same value within a scaleegroup\n\n var textData = coerce('text');\n var textTemplate = coerce('texttemplate');\n var textInfo;\n if(!textTemplate) textInfo = coerce('textinfo', Array.isArray(textData) ? 'text+percent' : 'percent');\n\n coerce('hovertext');\n coerce('hovertemplate');\n\n if(textTemplate || (textInfo && textInfo !== 'none')) {\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: false,\n moduleHasUnselected: false,\n moduleHasConstrain: false,\n moduleHasCliponaxis: false,\n moduleHasTextangle: false,\n moduleHasInsideanchor: false\n });\n\n var hasBoth = Array.isArray(textposition) || textposition === 'auto';\n var hasOutside = hasBoth || textposition === 'outside';\n if(hasOutside) {\n coerce('automargin');\n }\n\n if(textposition === 'inside' || textposition === 'auto' || Array.isArray(textposition)) {\n coerce('insidetextorientation');\n }\n }\n\n handleDomainDefaults(traceOut, layout, coerce);\n\n var hole = coerce('hole');\n var title = coerce('title.text');\n if(title) {\n var titlePosition = coerce('title.position', hole ? 'middle center' : 'top center');\n if(!hole && titlePosition === 'middle center') traceOut.title.position = 'top center';\n Lib.coerceFont(coerce, 'title.font', layout.font);\n }\n\n coerce('sort');\n coerce('direction');\n coerce('rotation');\n coerce('pull');\n}\n\nmodule.exports = {\n handleLabelsAndValues: handleLabelsAndValues,\n supplyDefaults: supplyDefaults\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nmodule.exports = function makeBoundArray(trace, arrayIn, v0In, dvIn, numbricks, ax) {\n var arrayOut = [];\n var isContour = Registry.traceIs(trace, 'contour');\n var isHist = Registry.traceIs(trace, 'histogram');\n var isGL2D = Registry.traceIs(trace, 'gl2d');\n var v0;\n var dv;\n var i;\n\n var isArrayOfTwoItemsOrMore = isArrayOrTypedArray(arrayIn) && arrayIn.length > 1;\n\n if(isArrayOfTwoItemsOrMore && !isHist && (ax.type !== 'category')) {\n var len = arrayIn.length;\n\n // given vals are brick centers\n // hopefully length === numbricks, but use this method even if too few are supplied\n // and extend it linearly based on the last two points\n if(len <= numbricks) {\n // contour plots only want the centers\n if(isContour || isGL2D) arrayOut = arrayIn.slice(0, numbricks);\n else if(numbricks === 1) {\n arrayOut = [arrayIn[0] - 0.5, arrayIn[0] + 0.5];\n } else {\n arrayOut = [1.5 * arrayIn[0] - 0.5 * arrayIn[1]];\n\n for(i = 1; i < len; i++) {\n arrayOut.push((arrayIn[i - 1] + arrayIn[i]) * 0.5);\n }\n\n arrayOut.push(1.5 * arrayIn[len - 1] - 0.5 * arrayIn[len - 2]);\n }\n\n if(len < numbricks) {\n var lastPt = arrayOut[arrayOut.length - 1];\n var delta = lastPt - arrayOut[arrayOut.length - 2];\n\n for(i = len; i < numbricks; i++) {\n lastPt += delta;\n arrayOut.push(lastPt);\n }\n }\n } else {\n // hopefully length === numbricks+1, but do something regardless:\n // given vals are brick boundaries\n return isContour ?\n arrayIn.slice(0, numbricks) : // we must be strict for contours\n arrayIn.slice(0, numbricks + 1);\n }\n } else {\n var calendar = trace[ax._id.charAt(0) + 'calendar'];\n\n if(isHist) {\n v0 = ax.r2c(v0In, 0, calendar);\n } else {\n if(isArrayOrTypedArray(arrayIn) && arrayIn.length === 1) {\n v0 = arrayIn[0];\n } else if(v0In === undefined) {\n v0 = 0;\n } else {\n var fn = ax.type === 'log' ? ax.d2c : ax.r2c;\n v0 = fn(v0In, 0, calendar);\n }\n }\n\n dv = dvIn || 1;\n\n for(i = (isContour || isGL2D) ? 0 : -0.5; i < numbricks; i++) {\n arrayOut.push(v0 + dv * i);\n }\n }\n\n return arrayOut;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = {\n\n // layout attribute name\n name: 'updatemenus',\n\n // class names\n containerClassName: 'updatemenu-container',\n headerGroupClassName: 'updatemenu-header-group',\n headerClassName: 'updatemenu-header',\n headerArrowClassName: 'updatemenu-header-arrow',\n dropdownButtonGroupClassName: 'updatemenu-dropdown-button-group',\n dropdownButtonClassName: 'updatemenu-dropdown-button',\n buttonClassName: 'updatemenu-button',\n itemRectClassName: 'updatemenu-item-rect',\n itemTextClassName: 'updatemenu-item-text',\n\n // DOM attribute name in button group keeping track\n // of active update menu\n menuIndexAttrName: 'updatemenu-active-index',\n\n // id root pass to Plots.autoMargin\n autoMarginIdRoot: 'updatemenu-',\n\n // options when 'active: -1'\n blankHeaderOpts: { label: ' ' },\n\n // min item width / height\n minWidth: 30,\n minHeight: 30,\n\n // padding around item text\n textPadX: 24,\n arrowPadX: 16,\n\n // item rect radii\n rx: 2,\n ry: 2,\n\n // item text x offset off left edge\n textOffsetX: 12,\n\n // item text y offset (w.r.t. middle)\n textOffsetY: 3,\n\n // arrow offset off right edge\n arrowOffsetX: 4,\n\n // gap between header and buttons\n gapButtonHeader: 5,\n\n // gap between between buttons\n gapButton: 2,\n\n // color given to active buttons\n activeColor: '#F4FAFF',\n\n // color given to hovered buttons\n hoverColor: '#F4FAFF',\n\n // symbol for menu open arrow\n arrowSymbol: {\n left: '◄',\n right: '►',\n up: '▲',\n down: '▼'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nvar attributes = require('./attributes');\nvar constants = require('./constants');\nvar subTypes = require('./subtypes');\nvar handleXYDefaults = require('./xy_defaults');\nvar handleStackDefaults = require('./stack_defaults');\nvar handleMarkerDefaults = require('./marker_defaults');\nvar handleLineDefaults = require('./line_defaults');\nvar handleLineShapeDefaults = require('./line_shape_defaults');\nvar handleTextDefaults = require('./text_defaults');\nvar handleFillColorDefaults = require('./fillcolor_defaults');\n\nmodule.exports = function supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) traceOut.visible = false;\n\n if(!traceOut.visible) return;\n\n var stackGroupOpts = handleStackDefaults(traceIn, traceOut, layout, coerce);\n\n var defaultMode = !stackGroupOpts && (len < constants.PTS_LINESONLY) ?\n 'lines+markers' : 'lines';\n coerce('text');\n coerce('hovertext');\n coerce('mode', defaultMode);\n\n if(subTypes.hasLines(traceOut)) {\n handleLineDefaults(traceIn, traceOut, defaultColor, layout, coerce);\n handleLineShapeDefaults(traceIn, traceOut, coerce);\n coerce('connectgaps');\n coerce('line.simplify');\n }\n\n if(subTypes.hasMarkers(traceOut)) {\n handleMarkerDefaults(traceIn, traceOut, defaultColor, layout, coerce, {gradient: true});\n }\n\n if(subTypes.hasText(traceOut)) {\n coerce('texttemplate');\n handleTextDefaults(traceIn, traceOut, layout, coerce);\n }\n\n var dfltHoverOn = [];\n\n if(subTypes.hasMarkers(traceOut) || subTypes.hasText(traceOut)) {\n coerce('cliponaxis');\n coerce('marker.maxdisplayed');\n dfltHoverOn.push('points');\n }\n\n // It's possible for this default to be changed by a later trace.\n // We handle that case in some hacky code inside handleStackDefaults.\n coerce('fill', stackGroupOpts ? stackGroupOpts.fillDflt : 'none');\n if(traceOut.fill !== 'none') {\n handleFillColorDefaults(traceIn, traceOut, defaultColor, coerce);\n if(!subTypes.hasLines(traceOut)) handleLineShapeDefaults(traceIn, traceOut, coerce);\n }\n\n var lineColor = (traceOut.line || {}).color;\n var markerColor = (traceOut.marker || {}).color;\n\n if(traceOut.fill === 'tonext' || traceOut.fill === 'toself') {\n dfltHoverOn.push('fills');\n }\n coerce('hoveron', dfltHoverOn.join('+') || 'points');\n if(traceOut.hoveron !== 'fills') coerce('hovertemplate');\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || markerColor || defaultColor, {axis: 'x', inherit: 'y'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar cartesianConstants = require('../../plots/cartesian/constants');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\n\nmodule.exports = templatedArray('image', {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'arraydraw',\n description: [\n 'Determines whether or not this image is visible.'\n ].join(' ')\n },\n\n source: {\n valType: 'string',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Specifies the URL of the image to be used.',\n 'The URL must be accessible from the domain where the',\n 'plot code is run, and can be either relative or absolute.'\n\n ].join(' ')\n },\n\n layer: {\n valType: 'enumerated',\n values: ['below', 'above'],\n dflt: 'above',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Specifies whether images are drawn below or above traces.',\n 'When `xref` and `yref` are both set to `paper`,',\n 'image is drawn below the entire plot area.'\n ].join(' ')\n },\n\n sizex: {\n valType: 'number',\n role: 'info',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image container size horizontally.',\n 'The image will be sized based on the `position` value.',\n 'When `xref` is set to `paper`, units are sized relative',\n 'to the plot width.'\n ].join(' ')\n },\n\n sizey: {\n valType: 'number',\n role: 'info',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image container size vertically.',\n 'The image will be sized based on the `position` value.',\n 'When `yref` is set to `paper`, units are sized relative',\n 'to the plot height.'\n ].join(' ')\n },\n\n sizing: {\n valType: 'enumerated',\n values: ['fill', 'contain', 'stretch'],\n dflt: 'contain',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Specifies which dimension of the image to constrain.'\n ].join(' ')\n },\n\n opacity: {\n valType: 'number',\n role: 'info',\n min: 0,\n max: 1,\n dflt: 1,\n editType: 'arraydraw',\n description: 'Sets the opacity of the image.'\n },\n\n x: {\n valType: 'any',\n role: 'info',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image\\'s x position.',\n 'When `xref` is set to `paper`, units are sized relative',\n 'to the plot height.',\n 'See `xref` for more info'\n ].join(' ')\n },\n\n y: {\n valType: 'any',\n role: 'info',\n dflt: 0,\n editType: 'arraydraw',\n description: [\n 'Sets the image\\'s y position.',\n 'When `yref` is set to `paper`, units are sized relative',\n 'to the plot height.',\n 'See `yref` for more info'\n ].join(' ')\n },\n\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'left',\n role: 'info',\n editType: 'arraydraw',\n description: 'Sets the anchor for the x position'\n },\n\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'top',\n role: 'info',\n editType: 'arraydraw',\n description: 'Sets the anchor for the y position.'\n },\n\n xref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.x.toString()\n ],\n dflt: 'paper',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Sets the images\\'s x coordinate axis.',\n 'If set to a x axis id (e.g. *x* or *x2*), the `x` position',\n 'refers to an x data coordinate',\n 'If set to *paper*, the `x` position refers to the distance from',\n 'the left of plot in normalized coordinates',\n 'where *0* (*1*) corresponds to the left (right).'\n ].join(' ')\n },\n\n yref: {\n valType: 'enumerated',\n values: [\n 'paper',\n cartesianConstants.idRegex.y.toString()\n ],\n dflt: 'paper',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Sets the images\\'s y coordinate axis.',\n 'If set to a y axis id (e.g. *y* or *y2*), the `y` position',\n 'refers to a y data coordinate.',\n 'If set to *paper*, the `y` position refers to the distance from',\n 'the bottom of the plot in normalized coordinates',\n 'where *0* (*1*) corresponds to the bottom (top).'\n ].join(' ')\n },\n editType: 'arraydraw'\n});\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar toLogRange = require('../../lib/to_log_range');\n\n/*\n * convertCoords: when converting an axis between log and linear\n * you need to alter any annotations on that axis to keep them\n * pointing at the same data point.\n * In v2.0 this will become obsolete\n *\n * gd: the plot div\n * ax: the axis being changed\n * newType: the type it's getting\n * doExtra: function(attr, val) from inside relayout that sets the attribute.\n * Use this to make the changes as it's aware if any other changes in the\n * same relayout call should override this conversion.\n */\nmodule.exports = function convertCoords(gd, ax, newType, doExtra) {\n ax = ax || {};\n\n var toLog = (newType === 'log') && (ax.type === 'linear');\n var fromLog = (newType === 'linear') && (ax.type === 'log');\n\n if(!(toLog || fromLog)) return;\n\n var annotations = gd._fullLayout.annotations;\n var axLetter = ax._id.charAt(0);\n var ann;\n var attrPrefix;\n\n function convert(attr) {\n var currentVal = ann[attr];\n var newVal = null;\n\n if(toLog) newVal = toLogRange(currentVal, ax.range);\n else newVal = Math.pow(10, currentVal);\n\n // if conversion failed, delete the value so it gets a default value\n if(!isNumeric(newVal)) newVal = null;\n\n doExtra(attrPrefix + attr, newVal);\n }\n\n for(var i = 0; i < annotations.length; i++) {\n ann = annotations[i];\n attrPrefix = 'annotations[' + i + '].';\n\n if(ann[axLetter + 'ref'] === ax._id) convert(axLetter);\n if(ann['a' + axLetter + 'ref'] === ax._id) convert('a' + axLetter);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nmodule.exports = function lineDefaults(traceIn, traceOut, defaultColor, layout, coerce, opts) {\n var markerColor = (traceIn.marker || {}).color;\n\n coerce('line.color', defaultColor);\n\n if(hasColorscale(traceIn, 'line')) {\n colorscaleDefaults(traceIn, traceOut, layout, coerce, {prefix: 'line.', cLetter: 'c'});\n } else {\n var lineColorDflt = (isArrayOrTypedArray(markerColor) ? false : markerColor) || defaultColor;\n coerce('line.color', lineColorDflt);\n }\n\n coerce('line.width');\n if(!(opts || {}).noDash) coerce('line.dash');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nmodule.exports = {\n hasClickToShow: hasClickToShow,\n onClick: onClick\n};\n\n/*\n * hasClickToShow: does the given hoverData have ANY annotations which will\n * turn ON if we click here? (used by hover events to set cursor)\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: boolean\n */\nfunction hasClickToShow(gd, hoverData) {\n var sets = getToggleSets(gd, hoverData);\n return sets.on.length > 0 || sets.explicitOff.length > 0;\n}\n\n/*\n * onClick: perform the toggling (via Plotly.update) implied by clicking\n * at this hoverData\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: Promise that the update is complete\n */\nfunction onClick(gd, hoverData) {\n var toggleSets = getToggleSets(gd, hoverData);\n var onSet = toggleSets.on;\n var offSet = toggleSets.off.concat(toggleSets.explicitOff);\n var update = {};\n var annotationsOut = gd._fullLayout.annotations;\n var i, editHelpers;\n\n if(!(onSet.length || offSet.length)) return;\n\n for(i = 0; i < onSet.length; i++) {\n editHelpers = arrayEditor(gd.layout, 'annotations', annotationsOut[onSet[i]]);\n editHelpers.modifyItem('visible', true);\n Lib.extendFlat(update, editHelpers.getUpdateObj());\n }\n\n for(i = 0; i < offSet.length; i++) {\n editHelpers = arrayEditor(gd.layout, 'annotations', annotationsOut[offSet[i]]);\n editHelpers.modifyItem('visible', false);\n Lib.extendFlat(update, editHelpers.getUpdateObj());\n }\n\n return Registry.call('update', gd, {}, update);\n}\n\n/*\n * getToggleSets: find the annotations which will turn on or off at this\n * hoverData\n *\n * gd: graphDiv\n * hoverData: a hoverData array, as included with the *plotly_hover* or\n * *plotly_click* events in the `points` attribute\n *\n * returns: {\n * on: Array (indices of annotations to turn on),\n * off: Array (indices to turn off because you're not hovering on them),\n * explicitOff: Array (indices to turn off because you *are* hovering on them)\n * }\n */\nfunction getToggleSets(gd, hoverData) {\n var annotations = gd._fullLayout.annotations;\n var onSet = [];\n var offSet = [];\n var explicitOffSet = [];\n var hoverLen = (hoverData || []).length;\n\n var i, j, anni, showMode, pointj, xa, ya, toggleType;\n\n for(i = 0; i < annotations.length; i++) {\n anni = annotations[i];\n showMode = anni.clicktoshow;\n\n if(showMode) {\n for(j = 0; j < hoverLen; j++) {\n pointj = hoverData[j];\n xa = pointj.xaxis;\n ya = pointj.yaxis;\n\n if(xa._id === anni.xref &&\n ya._id === anni.yref &&\n xa.d2r(pointj.x) === clickData2r(anni._xclick, xa) &&\n ya.d2r(pointj.y) === clickData2r(anni._yclick, ya)\n ) {\n // match! toggle this annotation\n // regardless of its clicktoshow mode\n // but if it's onout mode, off is implicit\n if(anni.visible) {\n if(showMode === 'onout') toggleType = offSet;\n else toggleType = explicitOffSet;\n } else {\n toggleType = onSet;\n }\n toggleType.push(i);\n break;\n }\n }\n\n if(j === hoverLen) {\n // no match - only turn this annotation OFF, and only if\n // showmode is 'onout'\n if(anni.visible && showMode === 'onout') offSet.push(i);\n }\n }\n }\n\n return {on: onSet, off: offSet, explicitOff: explicitOffSet};\n}\n\n// to handle log axes until v2\nfunction clickData2r(d, ax) {\n return ax.type === 'log' ? ax.l2r(d) : ax.d2r(d);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar drawModule = require('./draw');\nvar clickModule = require('./click');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'annotations',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('annotations'),\n\n calcAutorange: require('./calc_autorange'),\n draw: drawModule.draw,\n drawOne: drawModule.drawOne,\n drawRaw: drawModule.drawRaw,\n\n hasClickToShow: clickModule.hasClickToShow,\n onClick: clickModule.onClick,\n\n convertCoords: require('./convert_coords')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar Lib = require('../../lib');\n\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function(layoutIn, layoutOut, fullData) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n var hasBars = false;\n var shouldBeGapless = false;\n var gappedAnyway = false;\n var usedSubplots = {};\n\n var mode = coerce('barmode');\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(Registry.traceIs(trace, 'bar') && trace.visible) hasBars = true;\n else continue;\n\n // if we have at least 2 grouped bar traces on the same subplot,\n // we should default to a gap anyway, even if the data is histograms\n if(mode === 'group') {\n var subploti = trace.xaxis + trace.yaxis;\n if(usedSubplots[subploti]) gappedAnyway = true;\n usedSubplots[subploti] = true;\n }\n\n if(trace.visible && trace.type === 'histogram') {\n var pa = Axes.getFromId({_fullLayout: layoutOut},\n trace[trace.orientation === 'v' ? 'xaxis' : 'yaxis']);\n if(pa.type !== 'category') shouldBeGapless = true;\n }\n }\n\n if(!hasBars) {\n delete layoutOut.barmode;\n return;\n }\n\n if(mode !== 'overlay') coerce('barnorm');\n\n coerce('bargap', (shouldBeGapless && !gappedAnyway) ? 0 : 0.2);\n coerce('bargroupgap');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n// more info: http://stackoverflow.com/questions/18531624/isplainobject-thing\nmodule.exports = function isPlainObject(obj) {\n // We need to be a little less strict in the `imagetest` container because\n // of how async image requests are handled.\n //\n // N.B. isPlainObject(new Constructor()) will return true in `imagetest`\n if(window && window.process && window.process.versions) {\n return Object.prototype.toString.call(obj) === '[object Object]';\n }\n\n return (\n Object.prototype.toString.call(obj) === '[object Object]' &&\n Object.getPrototypeOf(obj) === Object.prototype\n );\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nvar INTERPTHRESHOLD = 1e-2;\nvar NEIGHBORSHIFTS = [[-1, 0], [1, 0], [0, -1], [0, 1]];\n\nfunction correctionOvershoot(maxFractionalChange) {\n // start with less overshoot, until we know it's converging,\n // then ramp up the overshoot for faster convergence\n return 0.5 - 0.25 * Math.min(1, maxFractionalChange * 0.5);\n}\n\n/*\n * interp2d: Fill in missing data from a 2D array using an iterative\n * poisson equation solver with zero-derivative BC at edges.\n * Amazingly, this just amounts to repeatedly averaging all the existing\n * nearest neighbors, at least if we don't take x/y scaling into account,\n * which is the right approach here where x and y may not even have the\n * same units.\n *\n * @param {array of arrays} z\n * The 2D array to fill in. Will be mutated here. Assumed to already be\n * cleaned, so all entries are numbers except gaps, which are `undefined`.\n * @param {array of arrays} emptyPoints\n * Each entry [i, j, neighborCount] for empty points z[i][j] and the number\n * of neighbors that are *not* missing. Assumed to be sorted from most to\n * least neighbors, as produced by heatmap/find_empties.\n */\nmodule.exports = function interp2d(z, emptyPoints) {\n var maxFractionalChange = 1;\n var i;\n\n // one pass to fill in a starting value for all the empties\n iterateInterp2d(z, emptyPoints);\n\n // we're don't need to iterate lone empties - remove them\n for(i = 0; i < emptyPoints.length; i++) {\n if(emptyPoints[i][2] < 4) break;\n }\n // but don't remove these points from the original array,\n // we'll use them for masking, so make a copy.\n emptyPoints = emptyPoints.slice(i);\n\n for(i = 0; i < 100 && maxFractionalChange > INTERPTHRESHOLD; i++) {\n maxFractionalChange = iterateInterp2d(z, emptyPoints,\n correctionOvershoot(maxFractionalChange));\n }\n if(maxFractionalChange > INTERPTHRESHOLD) {\n Lib.log('interp2d didn\\'t converge quickly', maxFractionalChange);\n }\n\n return z;\n};\n\nfunction iterateInterp2d(z, emptyPoints, overshoot) {\n var maxFractionalChange = 0;\n var thisPt;\n var i;\n var j;\n var p;\n var q;\n var neighborShift;\n var neighborRow;\n var neighborVal;\n var neighborCount;\n var neighborSum;\n var initialVal;\n var minNeighbor;\n var maxNeighbor;\n\n for(p = 0; p < emptyPoints.length; p++) {\n thisPt = emptyPoints[p];\n i = thisPt[0];\n j = thisPt[1];\n initialVal = z[i][j];\n neighborSum = 0;\n neighborCount = 0;\n\n for(q = 0; q < 4; q++) {\n neighborShift = NEIGHBORSHIFTS[q];\n neighborRow = z[i + neighborShift[0]];\n if(!neighborRow) continue;\n neighborVal = neighborRow[j + neighborShift[1]];\n if(neighborVal !== undefined) {\n if(neighborSum === 0) {\n minNeighbor = maxNeighbor = neighborVal;\n } else {\n minNeighbor = Math.min(minNeighbor, neighborVal);\n maxNeighbor = Math.max(maxNeighbor, neighborVal);\n }\n neighborCount++;\n neighborSum += neighborVal;\n }\n }\n\n if(neighborCount === 0) {\n throw 'iterateInterp2d order is wrong: no defined neighbors';\n }\n\n // this is the laplace equation interpolation:\n // each point is just the average of its neighbors\n // note that this ignores differential x/y scaling\n // which I think is the right approach, since we\n // don't know what that scaling means\n z[i][j] = neighborSum / neighborCount;\n\n if(initialVal === undefined) {\n if(neighborCount < 4) maxFractionalChange = 1;\n } else {\n // we can make large empty regions converge faster\n // if we overshoot the change vs the previous value\n z[i][j] = (1 + overshoot) * z[i][j] - overshoot * initialVal;\n\n if(maxNeighbor > minNeighbor) {\n maxFractionalChange = Math.max(maxFractionalChange,\n Math.abs(z[i][j] - initialVal) / (maxNeighbor - minNeighbor));\n }\n }\n }\n\n return maxFractionalChange;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar padAttrs = require('../../plots/pad_attributes');\nvar extendDeepAll = require('../../lib/extend').extendDeepAll;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar animationAttrs = require('../../plots/animation_attributes');\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\nvar constants = require('./constants');\n\nvar stepsAttrs = templatedArray('step', {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n description: [\n 'Determines whether or not this step is included in the slider.'\n ].join(' ')\n },\n method: {\n valType: 'enumerated',\n values: ['restyle', 'relayout', 'animate', 'update', 'skip'],\n dflt: 'restyle',\n role: 'info',\n description: [\n 'Sets the Plotly method to be called when the slider value is changed.',\n 'If the `skip` method is used, the API slider will function as normal',\n 'but will perform no API calls and will not bind automatically to state',\n 'updates. This may be used to create a component interface and attach to',\n 'slider events manually via JavaScript.'\n ].join(' ')\n },\n args: {\n valType: 'info_array',\n role: 'info',\n freeLength: true,\n items: [\n { valType: 'any' },\n { valType: 'any' },\n { valType: 'any' }\n ],\n description: [\n 'Sets the arguments values to be passed to the Plotly',\n 'method set in `method` on slide.'\n ].join(' ')\n },\n label: {\n valType: 'string',\n role: 'info',\n description: 'Sets the text label to appear on the slider'\n },\n value: {\n valType: 'string',\n role: 'info',\n description: [\n 'Sets the value of the slider step, used to refer to the step programatically.',\n 'Defaults to the slider label if not provided.'\n ].join(' ')\n },\n execute: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n description: [\n 'When true, the API method is executed. When false, all other behaviors are the same',\n 'and command execution is skipped. This may be useful when hooking into, for example,',\n 'the `plotly_sliderchange` method and executing the API command manually without losing',\n 'the benefit of the slider automatically binding to the state of the plot through the',\n 'specification of `method` and `args`.'\n ].join(' ')\n }\n});\n\nmodule.exports = overrideAll(templatedArray('slider', {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n description: [\n 'Determines whether or not the slider is visible.'\n ].join(' ')\n },\n\n active: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 0,\n description: [\n 'Determines which button (by index starting from 0) is',\n 'considered active.'\n ].join(' ')\n },\n\n steps: stepsAttrs,\n\n lenmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n role: 'info',\n dflt: 'fraction',\n description: [\n 'Determines whether this slider length',\n 'is set in units of plot *fraction* or in *pixels.',\n 'Use `len` to set the value.'\n ].join(' ')\n },\n len: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n description: [\n 'Sets the length of the slider',\n 'This measure excludes the padding of both ends.',\n 'That is, the slider\\'s length is this length minus the',\n 'padding on both ends.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: 0,\n role: 'style',\n description: 'Sets the x position (in normalized coordinates) of the slider.'\n },\n pad: extendDeepAll(padAttrs({editType: 'arraydraw'}), {\n description: 'Set the padding of the slider component along each side.'\n }, {t: {dflt: 20}}),\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'left',\n role: 'info',\n description: [\n 'Sets the slider\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the range selector.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: -2,\n max: 3,\n dflt: 0,\n role: 'style',\n description: 'Sets the y position (in normalized coordinates) of the slider.'\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n dflt: 'top',\n role: 'info',\n description: [\n 'Sets the slider\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the range selector.'\n ].join(' ')\n },\n\n transition: {\n duration: {\n valType: 'number',\n role: 'info',\n min: 0,\n dflt: 150,\n description: 'Sets the duration of the slider transition'\n },\n easing: {\n valType: 'enumerated',\n values: animationAttrs.transition.easing.values,\n role: 'info',\n dflt: 'cubic-in-out',\n description: 'Sets the easing function of the slider transition'\n }\n },\n\n currentvalue: {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n description: [\n 'Shows the currently-selected value above the slider.'\n ].join(' ')\n },\n\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'left',\n role: 'info',\n description: [\n 'The alignment of the value readout relative to the length of the slider.'\n ].join(' ')\n },\n\n offset: {\n valType: 'number',\n dflt: 10,\n role: 'info',\n description: [\n 'The amount of space, in pixels, between the current value label',\n 'and the slider.'\n ].join(' ')\n },\n\n prefix: {\n valType: 'string',\n role: 'info',\n description: 'When currentvalue.visible is true, this sets the prefix of the label.'\n },\n\n suffix: {\n valType: 'string',\n role: 'info',\n description: 'When currentvalue.visible is true, this sets the suffix of the label.'\n },\n\n font: fontAttrs({\n description: 'Sets the font of the current value label text.'\n })\n },\n\n font: fontAttrs({\n description: 'Sets the font of the slider step labels.'\n }),\n\n activebgcolor: {\n valType: 'color',\n role: 'style',\n dflt: constants.gripBgActiveColor,\n description: [\n 'Sets the background color of the slider grip',\n 'while dragging.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n role: 'style',\n dflt: constants.railBgColor,\n description: 'Sets the background color of the slider.'\n },\n bordercolor: {\n valType: 'color',\n dflt: constants.railBorderColor,\n role: 'style',\n description: 'Sets the color of the border enclosing the slider.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: constants.railBorderWidth,\n role: 'style',\n description: 'Sets the width (in px) of the border enclosing the slider.'\n },\n ticklen: {\n valType: 'number',\n min: 0,\n dflt: constants.tickLength,\n role: 'style',\n description: 'Sets the length in pixels of step tick marks'\n },\n tickcolor: {\n valType: 'color',\n dflt: constants.tickColor,\n role: 'style',\n description: 'Sets the color of the border enclosing the slider.'\n },\n tickwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n description: 'Sets the tick width (in px).'\n },\n minorticklen: {\n valType: 'number',\n min: 0,\n dflt: constants.minorTickLength,\n role: 'style',\n description: 'Sets the length in pixels of minor step tick marks'\n }\n}), 'arraydraw', 'from-root');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = require('../src/traces/scatter');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\n\nvar handleAnnotationCommonDefaults = require('./common_defaults');\nvar attributes = require('./attributes');\n\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut) {\n handleArrayContainerDefaults(layoutIn, layoutOut, {\n name: 'annotations',\n handleItemDefaults: handleAnnotationDefaults\n });\n};\n\nfunction handleAnnotationDefaults(annIn, annOut, fullLayout) {\n function coerce(attr, dflt) {\n return Lib.coerce(annIn, annOut, attributes, attr, dflt);\n }\n\n var visible = coerce('visible');\n var clickToShow = coerce('clicktoshow');\n\n if(!(visible || clickToShow)) return;\n\n handleAnnotationCommonDefaults(annIn, annOut, fullLayout, coerce);\n\n var showArrow = annOut.showarrow;\n\n // positioning\n var axLetters = ['x', 'y'];\n var arrowPosDflt = [-10, -30];\n var gdMock = {_fullLayout: fullLayout};\n\n for(var i = 0; i < 2; i++) {\n var axLetter = axLetters[i];\n\n // xref, yref\n var axRef = Axes.coerceRef(annIn, annOut, gdMock, axLetter, '', 'paper');\n\n if(axRef !== 'paper') {\n var ax = Axes.getFromId(gdMock, axRef);\n ax._annIndices.push(annOut._index);\n }\n\n // x, y\n Axes.coercePosition(annOut, gdMock, coerce, axRef, axLetter, 0.5);\n\n if(showArrow) {\n var arrowPosAttr = 'a' + axLetter;\n // axref, ayref\n var aaxRef = Axes.coerceRef(annIn, annOut, gdMock, arrowPosAttr, 'pixel');\n\n // for now the arrow can only be on the same axis or specified as pixels\n // TODO: sometime it might be interesting to allow it to be on *any* axis\n // but that would require updates to drawing & autorange code and maybe more\n if(aaxRef !== 'pixel' && aaxRef !== axRef) {\n aaxRef = annOut[arrowPosAttr] = 'pixel';\n }\n\n // ax, ay\n var aDflt = (aaxRef === 'pixel') ? arrowPosDflt[i] : 0.4;\n Axes.coercePosition(annOut, gdMock, coerce, aaxRef, arrowPosAttr, aDflt);\n }\n\n // xanchor, yanchor\n coerce(axLetter + 'anchor');\n\n // xshift, yshift\n coerce(axLetter + 'shift');\n }\n\n // if you have one coordinate you should have both\n Lib.noneOrAll(annIn, annOut, ['x', 'y']);\n\n // if you have one part of arrow length you should have both\n if(showArrow) {\n Lib.noneOrAll(annIn, annOut, ['ax', 'ay']);\n }\n\n if(clickToShow) {\n var xClick = coerce('xclick');\n var yClick = coerce('yclick');\n\n // put the actual click data to bind to into private attributes\n // so we don't have to do this little bit of logic on every hover event\n annOut._xclick = (xClick === undefined) ?\n annOut.x :\n Axes.cleanPosition(xClick, gdMock, annOut.xref);\n annOut._yclick = (yClick === undefined) ?\n annOut.y :\n Axes.cleanPosition(yClick, gdMock, annOut.yref);\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\n\nexports.formatPiePercent = function formatPiePercent(v, separators) {\n var vRounded = (v * 100).toPrecision(3);\n if(vRounded.lastIndexOf('.') !== -1) {\n vRounded = vRounded.replace(/[.]?0+$/, '');\n }\n return Lib.numSeparate(vRounded, separators) + '%';\n};\n\nexports.formatPieValue = function formatPieValue(v, separators) {\n var vRounded = v.toPrecision(10);\n if(vRounded.lastIndexOf('.') !== -1) {\n vRounded = vRounded.replace(/[.]?0+$/, '');\n }\n return Lib.numSeparate(vRounded, separators);\n};\n\nexports.getFirstFilled = function getFirstFilled(array, indices) {\n if(!Array.isArray(array)) return;\n for(var i = 0; i < indices.length; i++) {\n var v = array[indices[i]];\n if(v || v === 0 || v === '') return v;\n }\n};\n\nexports.castOption = function castOption(item, indices) {\n if(Array.isArray(item)) return exports.getFirstFilled(item, indices);\n else if(item) return item;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar subtypes = require('./subtypes');\n\nmodule.exports = {\n hasLines: subtypes.hasLines,\n hasMarkers: subtypes.hasMarkers,\n hasText: subtypes.hasText,\n isBubble: subtypes.isBubble,\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n crossTraceDefaults: require('./cross_trace_defaults'),\n calc: require('./calc').calc,\n crossTraceCalc: require('./cross_trace_calc'),\n arraysToCalcdata: require('./arrays_to_calcdata'),\n plot: require('./plot'),\n colorbar: require('./marker_colorbar'),\n formatLabels: require('./format_labels'),\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover'),\n selectPoints: require('./select'),\n animatable: true,\n\n moduleType: 'trace',\n name: 'scatter',\n basePlotModule: require('../../plots/cartesian'),\n categories: [\n 'cartesian', 'svg', 'symbols', 'errorBarsOK', 'showLegend', 'scatter-like',\n 'zoomScale'\n ],\n meta: {\n description: [\n 'The scatter trace type encompasses line charts, scatter charts, text charts, and bubble charts.',\n 'The data visualized as scatter point or lines is set in `x` and `y`.',\n 'Text (appearing either on the chart or on hover only) is via `text`.',\n 'Bubble charts are achieved by setting `marker.size` and/or `marker.color`',\n 'to numerical arrays.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\nvar handleArrayContainerDefaults = require('../../plots/array_container_defaults');\nvar handleAnnotationCommonDefaults = require('../annotations/common_defaults');\nvar attributes = require('./attributes');\n\nmodule.exports = function handleDefaults(sceneLayoutIn, sceneLayoutOut, opts) {\n handleArrayContainerDefaults(sceneLayoutIn, sceneLayoutOut, {\n name: 'annotations',\n handleItemDefaults: handleAnnotationDefaults,\n fullLayout: opts.fullLayout\n });\n};\n\nfunction handleAnnotationDefaults(annIn, annOut, sceneLayout, opts) {\n function coerce(attr, dflt) {\n return Lib.coerce(annIn, annOut, attributes, attr, dflt);\n }\n\n function coercePosition(axLetter) {\n var axName = axLetter + 'axis';\n\n // mock in such way that getFromId grabs correct 3D axis\n var gdMock = { _fullLayout: {} };\n gdMock._fullLayout[axName] = sceneLayout[axName];\n\n return Axes.coercePosition(annOut, gdMock, coerce, axLetter, axLetter, 0.5);\n }\n\n\n var visible = coerce('visible');\n if(!visible) return;\n\n handleAnnotationCommonDefaults(annIn, annOut, opts.fullLayout, coerce);\n\n coercePosition('x');\n coercePosition('y');\n coercePosition('z');\n\n // if you have one coordinate you should all three\n Lib.noneOrAll(annIn, annOut, ['x', 'y', 'z']);\n\n // hard-set here for completeness\n annOut.xref = 'x';\n annOut.yref = 'y';\n annOut.zref = 'z';\n\n coerce('xanchor');\n coerce('yanchor');\n coerce('xshift');\n coerce('yshift');\n\n if(annOut.showarrow) {\n annOut.axref = 'pixel';\n annOut.ayref = 'pixel';\n\n // TODO maybe default values should be bigger than the 2D case?\n coerce('ax', -10);\n coerce('ay', -30);\n\n // if you have one part of arrow length you should have both\n Lib.noneOrAll(annIn, annOut, ['ax', 'ay']);\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n// package version injected by `npm run preprocess`\nexports.version = '1.53.0';\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar BADNUM = require('../constants/numerical').BADNUM;\n\n// precompile for speed\nvar JUNK = /^['\"%,$#\\s']+|[, ]|['\"%,$#\\s']+$/g;\n\n/**\n * cleanNumber: remove common leading and trailing cruft\n * Always returns either a number or BADNUM.\n */\nmodule.exports = function cleanNumber(v) {\n if(typeof v === 'string') {\n v = v.replace(JUNK, '');\n }\n\n if(isNumeric(v)) return Number(v);\n\n return BADNUM;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../registry');\nvar Lib = require('../lib');\n\nvar baseAttributes = require('../plots/attributes');\nvar baseLayoutAttributes = require('../plots/layout_attributes');\nvar frameAttributes = require('../plots/frame_attributes');\nvar animationAttributes = require('../plots/animation_attributes');\nvar configAttributes = require('./plot_config').configAttributes;\n\n// polar attributes are not part of the Registry yet\nvar polarAreaAttrs = require('../plots/polar/legacy/area_attributes');\nvar polarAxisAttrs = require('../plots/polar/legacy/axis_attributes');\n\nvar editTypes = require('./edit_types');\n\nvar extendFlat = Lib.extendFlat;\nvar extendDeepAll = Lib.extendDeepAll;\nvar isPlainObject = Lib.isPlainObject;\nvar isArrayOrTypedArray = Lib.isArrayOrTypedArray;\nvar nestedProperty = Lib.nestedProperty;\nvar valObjectMeta = Lib.valObjectMeta;\n\nvar IS_SUBPLOT_OBJ = '_isSubplotObj';\nvar IS_LINKED_TO_ARRAY = '_isLinkedToArray';\nvar ARRAY_ATTR_REGEXPS = '_arrayAttrRegexps';\nvar DEPRECATED = '_deprecated';\nvar UNDERSCORE_ATTRS = [IS_SUBPLOT_OBJ, IS_LINKED_TO_ARRAY, ARRAY_ATTR_REGEXPS, DEPRECATED];\n\nexports.IS_SUBPLOT_OBJ = IS_SUBPLOT_OBJ;\nexports.IS_LINKED_TO_ARRAY = IS_LINKED_TO_ARRAY;\nexports.DEPRECATED = DEPRECATED;\nexports.UNDERSCORE_ATTRS = UNDERSCORE_ATTRS;\n\n/** Outputs the full plotly.js plot schema\n *\n * @return {object}\n * - defs\n * - traces\n * - layout\n * - transforms\n * - frames\n * - animations\n * - config\n */\nexports.get = function() {\n var traces = {};\n\n Registry.allTypes.concat('area').forEach(function(type) {\n traces[type] = getTraceAttributes(type);\n });\n\n var transforms = {};\n\n Object.keys(Registry.transformsRegistry).forEach(function(type) {\n transforms[type] = getTransformAttributes(type);\n });\n\n return {\n defs: {\n valObjects: valObjectMeta,\n metaKeys: UNDERSCORE_ATTRS.concat(['description', 'role', 'editType', 'impliedEdits']),\n editType: {\n traces: editTypes.traces,\n layout: editTypes.layout\n },\n impliedEdits: {\n description: [\n 'Sometimes when an attribute is changed, other attributes',\n 'must be altered as well in order to achieve the intended',\n 'result. For example, when `range` is specified, it is',\n 'important to set `autorange` to `false` or the new `range`',\n 'value would be lost in the redraw. `impliedEdits` is the',\n 'mechanism to do this: `impliedEdits: {autorange: false}`.',\n 'Each key is a relative paths to the attribute string to',\n 'change, using *^* to ascend into the parent container,',\n 'for example `range[0]` has `impliedEdits: {*^autorange*: false}`.',\n 'A value of `undefined` means that the attribute will not be',\n 'changed, but its previous value should be recorded in case',\n 'we want to reverse this change later. For example, `autorange`',\n 'has `impliedEdits: {*range[0]*: undefined, *range[1]*:undefined}',\n 'because the range will likely be changed by redraw.'\n ].join(' ')\n }\n },\n\n traces: traces,\n layout: getLayoutAttributes(),\n\n transforms: transforms,\n\n frames: getFramesAttributes(),\n animation: formatAttributes(animationAttributes),\n\n config: formatAttributes(configAttributes)\n };\n};\n\n/**\n * Crawl the attribute tree, recursively calling a callback function\n *\n * @param {object} attrs\n * The node of the attribute tree (e.g. the root) from which recursion originates\n * @param {Function} callback\n * A callback function with the signature:\n * @callback callback\n * @param {object} attr an attribute\n * @param {String} attrName name string\n * @param {object[]} attrs all the attributes\n * @param {Number} level the recursion level, 0 at the root\n * @param {String} fullAttrString full attribute name (ie 'marker.line')\n * @param {Number} [specifiedLevel]\n * The level in the tree, in order to let the callback function detect descend or backtrack,\n * typically unsupplied (implied 0), just used by the self-recursive call.\n * The necessity arises because the tree traversal is not controlled by callback return values.\n * The decision to not use callback return values for controlling tree pruning arose from\n * the goal of keeping the crawler backwards compatible. Observe that one of the pruning conditions\n * precedes the callback call.\n * @param {string} [attrString]\n * the path to the current attribute, as an attribute string (ie 'marker.line')\n * typically unsupplied, but you may supply it if you want to disambiguate which attrs tree you\n * are starting from\n *\n * @return {object} transformOut\n * copy of transformIn that contains attribute defaults\n */\nexports.crawl = function(attrs, callback, specifiedLevel, attrString) {\n var level = specifiedLevel || 0;\n attrString = attrString || '';\n\n Object.keys(attrs).forEach(function(attrName) {\n var attr = attrs[attrName];\n\n if(UNDERSCORE_ATTRS.indexOf(attrName) !== -1) return;\n\n var fullAttrString = (attrString ? attrString + '.' : '') + attrName;\n callback(attr, attrName, attrs, level, fullAttrString);\n\n if(exports.isValObject(attr)) return;\n\n if(isPlainObject(attr) && attrName !== 'impliedEdits') {\n exports.crawl(attr, callback, level + 1, fullAttrString);\n }\n });\n};\n\n/** Is object a value object (or a container object)?\n *\n * @param {object} obj\n * @return {boolean}\n * returns true for a valid value object and\n * false for tree nodes in the attribute hierarchy\n */\nexports.isValObject = function(obj) {\n return obj && obj.valType !== undefined;\n};\n\n/**\n * Find all data array attributes in a given trace object - including\n * `arrayOk` attributes.\n *\n * @param {object} trace\n * full trace object that contains a reference to `_module.attributes`\n *\n * @return {array} arrayAttributes\n * list of array attributes for the given trace\n */\nexports.findArrayAttributes = function(trace) {\n var arrayAttributes = [];\n var stack = [];\n var isArrayStack = [];\n var baseContainer, baseAttrName;\n\n function callback(attr, attrName, attrs, level) {\n stack = stack.slice(0, level).concat([attrName]);\n isArrayStack = isArrayStack.slice(0, level).concat([attr && attr._isLinkedToArray]);\n\n var splittableAttr = (\n attr &&\n (attr.valType === 'data_array' || attr.arrayOk === true) &&\n !(stack[level - 1] === 'colorbar' && (attrName === 'ticktext' || attrName === 'tickvals'))\n );\n\n // Manually exclude 'colorbar.tickvals' and 'colorbar.ticktext' for now\n // which are declared as `valType: 'data_array'` but scale independently of\n // the coordinate arrays.\n //\n // Down the road, we might want to add a schema field (e.g `uncorrelatedArray: true`)\n // to distinguish attributes of the likes.\n\n if(!splittableAttr) return;\n\n crawlIntoTrace(baseContainer, 0, '');\n }\n\n function crawlIntoTrace(container, i, astrPartial) {\n var item = container[stack[i]];\n var newAstrPartial = astrPartial + stack[i];\n if(i === stack.length - 1) {\n if(isArrayOrTypedArray(item)) {\n arrayAttributes.push(baseAttrName + newAstrPartial);\n }\n } else {\n if(isArrayStack[i]) {\n if(Array.isArray(item)) {\n for(var j = 0; j < item.length; j++) {\n if(isPlainObject(item[j])) {\n crawlIntoTrace(item[j], i + 1, newAstrPartial + '[' + j + '].');\n }\n }\n }\n } else if(isPlainObject(item)) {\n crawlIntoTrace(item, i + 1, newAstrPartial + '.');\n }\n }\n }\n\n baseContainer = trace;\n baseAttrName = '';\n exports.crawl(baseAttributes, callback);\n if(trace._module && trace._module.attributes) {\n exports.crawl(trace._module.attributes, callback);\n }\n\n var transforms = trace.transforms;\n if(transforms) {\n for(var i = 0; i < transforms.length; i++) {\n var transform = transforms[i];\n var module = transform._module;\n\n if(module) {\n baseAttrName = 'transforms[' + i + '].';\n baseContainer = transform;\n\n exports.crawl(module.attributes, callback);\n }\n }\n }\n\n return arrayAttributes;\n};\n\n/*\n * Find the valObject for one attribute in an existing trace\n *\n * @param {object} trace\n * full trace object that contains a reference to `_module.attributes`\n * @param {object} parts\n * an array of parts, like ['transforms', 1, 'value']\n * typically from nestedProperty(...).parts\n *\n * @return {object|false}\n * the valObject for this attribute, or the last found parent\n * in some cases the innermost valObject will not exist, for example\n * `valType: 'any'` attributes where we might set a part of the attribute.\n * In that case, stop at the deepest valObject we *do* find.\n */\nexports.getTraceValObject = function(trace, parts) {\n var head = parts[0];\n var i = 1; // index to start recursing from\n var moduleAttrs, valObject;\n\n if(head === 'transforms') {\n if(parts.length === 1) {\n return baseAttributes.transforms;\n }\n var transforms = trace.transforms;\n if(!Array.isArray(transforms) || !transforms.length) return false;\n var tNum = parts[1];\n if(!isIndex(tNum) || tNum >= transforms.length) {\n return false;\n }\n moduleAttrs = (Registry.transformsRegistry[transforms[tNum].type] || {}).attributes;\n valObject = moduleAttrs && moduleAttrs[parts[2]];\n i = 3; // start recursing only inside the transform\n } else if(trace.type === 'area') {\n valObject = polarAreaAttrs[head];\n } else {\n // first look in the module for this trace\n // components have already merged their trace attributes in here\n var _module = trace._module;\n if(!_module) _module = (Registry.modules[trace.type || baseAttributes.type.dflt] || {})._module;\n if(!_module) return false;\n\n moduleAttrs = _module.attributes;\n valObject = moduleAttrs && moduleAttrs[head];\n\n // then look in the subplot attributes\n if(!valObject) {\n var subplotModule = _module.basePlotModule;\n if(subplotModule && subplotModule.attributes) {\n valObject = subplotModule.attributes[head];\n }\n }\n\n // finally look in the global attributes\n if(!valObject) valObject = baseAttributes[head];\n }\n\n return recurseIntoValObject(valObject, parts, i);\n};\n\n/*\n * Find the valObject for one layout attribute\n *\n * @param {array} parts\n * an array of parts, like ['annotations', 1, 'x']\n * typically from nestedProperty(...).parts\n *\n * @return {object|false}\n * the valObject for this attribute, or the last found parent\n * in some cases the innermost valObject will not exist, for example\n * `valType: 'any'` attributes where we might set a part of the attribute.\n * In that case, stop at the deepest valObject we *do* find.\n */\nexports.getLayoutValObject = function(fullLayout, parts) {\n var valObject = layoutHeadAttr(fullLayout, parts[0]);\n\n return recurseIntoValObject(valObject, parts, 1);\n};\n\nfunction layoutHeadAttr(fullLayout, head) {\n var i, key, _module, attributes;\n\n // look for attributes of the subplot types used on the plot\n var basePlotModules = fullLayout._basePlotModules;\n if(basePlotModules) {\n var out;\n for(i = 0; i < basePlotModules.length; i++) {\n _module = basePlotModules[i];\n if(_module.attrRegex && _module.attrRegex.test(head)) {\n // if a module defines overrides, these take precedence\n // initially this is to allow gl2d different editTypes from svg cartesian\n if(_module.layoutAttrOverrides) return _module.layoutAttrOverrides;\n\n // otherwise take the first attributes we find\n if(!out && _module.layoutAttributes) out = _module.layoutAttributes;\n }\n\n // a module can also override the behavior of base (and component) module layout attrs\n // again see gl2d for initial use case\n var baseOverrides = _module.baseLayoutAttrOverrides;\n if(baseOverrides && head in baseOverrides) return baseOverrides[head];\n }\n if(out) return out;\n }\n\n // look for layout attributes contributed by traces on the plot\n var modules = fullLayout._modules;\n if(modules) {\n for(i = 0; i < modules.length; i++) {\n attributes = modules[i].layoutAttributes;\n if(attributes && head in attributes) {\n return attributes[head];\n }\n }\n }\n\n /*\n * Next look in components.\n * Components that define a schema have already merged this into\n * base and subplot attribute defs, so ignore these.\n * Others (older style) all put all their attributes\n * inside a container matching the module `name`\n * eg `attributes` (array) or `legend` (object)\n */\n for(key in Registry.componentsRegistry) {\n _module = Registry.componentsRegistry[key];\n if(_module.name === 'colorscale' && head.indexOf('coloraxis') === 0) {\n return _module.layoutAttributes[head];\n } else if(!_module.schema && (head === _module.name)) {\n return _module.layoutAttributes;\n }\n }\n\n if(head in baseLayoutAttributes) return baseLayoutAttributes[head];\n\n // Polar doesn't populate _modules or _basePlotModules\n // just fall back on these when the others fail\n if(head === 'radialaxis' || head === 'angularaxis') {\n return polarAxisAttrs[head];\n }\n return polarAxisAttrs.layout[head] || false;\n}\n\nfunction recurseIntoValObject(valObject, parts, i) {\n if(!valObject) return false;\n\n if(valObject._isLinkedToArray) {\n // skip array index, abort if we try to dive into an array without an index\n if(isIndex(parts[i])) i++;\n else if(i < parts.length) return false;\n }\n\n // now recurse as far as we can. Occasionally we have an attribute\n // setting an internal part below what's in the schema; just return\n // the innermost schema item we find.\n for(; i < parts.length; i++) {\n var newValObject = valObject[parts[i]];\n if(isPlainObject(newValObject)) valObject = newValObject;\n else break;\n\n if(i === parts.length - 1) break;\n\n if(valObject._isLinkedToArray) {\n i++;\n if(!isIndex(parts[i])) return false;\n } else if(valObject.valType === 'info_array') {\n i++;\n var index = parts[i];\n if(!isIndex(index)) return false;\n\n var items = valObject.items;\n if(Array.isArray(items)) {\n if(index >= items.length) return false;\n if(valObject.dimensions === 2) {\n i++;\n if(parts.length === i) return valObject;\n var index2 = parts[i];\n if(!isIndex(index2)) return false;\n valObject = items[index][index2];\n } else valObject = items[index];\n } else {\n valObject = items;\n }\n }\n }\n\n return valObject;\n}\n\n// note: this is different from Lib.isIndex, this one doesn't accept numeric\n// strings, only actual numbers.\nfunction isIndex(val) {\n return val === Math.round(val) && val >= 0;\n}\n\nfunction getTraceAttributes(type) {\n var _module, basePlotModule;\n\n if(type === 'area') {\n _module = { attributes: polarAreaAttrs };\n basePlotModule = {};\n } else {\n _module = Registry.modules[type]._module,\n basePlotModule = _module.basePlotModule;\n }\n\n var attributes = {};\n\n // make 'type' the first attribute in the object\n attributes.type = null;\n\n var copyBaseAttributes = extendDeepAll({}, baseAttributes);\n var copyModuleAttributes = extendDeepAll({}, _module.attributes);\n\n // prune global-level trace attributes that are already defined in a trace\n exports.crawl(copyModuleAttributes, function(attr, attrName, attrs, level, fullAttrString) {\n nestedProperty(copyBaseAttributes, fullAttrString).set(undefined);\n // Prune undefined attributes\n if(attr === undefined) nestedProperty(copyModuleAttributes, fullAttrString).set(undefined);\n });\n\n // base attributes (same for all trace types)\n extendDeepAll(attributes, copyBaseAttributes);\n\n // prune-out base attributes based on trace module categories\n if(Registry.traceIs(type, 'noOpacity')) {\n delete attributes.opacity;\n }\n if(!Registry.traceIs(type, 'showLegend')) {\n delete attributes.showlegend;\n delete attributes.legendgroup;\n }\n if(Registry.traceIs(type, 'noHover')) {\n delete attributes.hoverinfo;\n delete attributes.hoverlabel;\n }\n if(!_module.selectPoints) {\n delete attributes.selectedpoints;\n }\n\n // module attributes\n extendDeepAll(attributes, copyModuleAttributes);\n\n // subplot attributes\n if(basePlotModule.attributes) {\n extendDeepAll(attributes, basePlotModule.attributes);\n }\n\n // 'type' gets overwritten by baseAttributes; reset it here\n attributes.type = type;\n\n var out = {\n meta: _module.meta || {},\n categories: _module.categories || {},\n animatable: Boolean(_module.animatable),\n type: type,\n attributes: formatAttributes(attributes),\n };\n\n // trace-specific layout attributes\n if(_module.layoutAttributes) {\n var layoutAttributes = {};\n\n extendDeepAll(layoutAttributes, _module.layoutAttributes);\n out.layoutAttributes = formatAttributes(layoutAttributes);\n }\n\n // drop anim:true in non-animatable modules\n if(!_module.animatable) {\n exports.crawl(out, function(attr) {\n if(exports.isValObject(attr) && 'anim' in attr) {\n delete attr.anim;\n }\n });\n }\n\n return out;\n}\n\nfunction getLayoutAttributes() {\n var layoutAttributes = {};\n var key, _module;\n\n // global layout attributes\n extendDeepAll(layoutAttributes, baseLayoutAttributes);\n\n // add base plot module layout attributes\n for(key in Registry.subplotsRegistry) {\n _module = Registry.subplotsRegistry[key];\n\n if(!_module.layoutAttributes) continue;\n\n if(Array.isArray(_module.attr)) {\n for(var i = 0; i < _module.attr.length; i++) {\n handleBasePlotModule(layoutAttributes, _module, _module.attr[i]);\n }\n } else {\n var astr = _module.attr === 'subplot' ? _module.name : _module.attr;\n handleBasePlotModule(layoutAttributes, _module, astr);\n }\n }\n\n // polar layout attributes\n layoutAttributes = assignPolarLayoutAttrs(layoutAttributes);\n\n // add registered components layout attributes\n for(key in Registry.componentsRegistry) {\n _module = Registry.componentsRegistry[key];\n var schema = _module.schema;\n\n if(schema && (schema.subplots || schema.layout)) {\n /*\n * Components with defined schema have already been merged in at register time\n * but a few components define attributes that apply only to xaxis\n * not yaxis (rangeselector, rangeslider) - delete from y schema.\n * Note that the input attributes for xaxis/yaxis are the same object\n * so it's not possible to only add them to xaxis from the start.\n * If we ever have such asymmetry the other way, or anywhere else,\n * we will need to extend both this code and mergeComponentAttrsToSubplot\n * (which will not find yaxis only for example)\n */\n var subplots = schema.subplots;\n if(subplots && subplots.xaxis && !subplots.yaxis) {\n for(var xkey in subplots.xaxis) {\n delete layoutAttributes.yaxis[xkey];\n }\n }\n } else if(_module.name === 'colorscale') {\n extendDeepAll(layoutAttributes, _module.layoutAttributes);\n } else if(_module.layoutAttributes) {\n // older style without schema need to be explicitly merged in now\n insertAttrs(layoutAttributes, _module.layoutAttributes, _module.name);\n }\n }\n\n return {\n layoutAttributes: formatAttributes(layoutAttributes)\n };\n}\n\nfunction getTransformAttributes(type) {\n var _module = Registry.transformsRegistry[type];\n var attributes = extendDeepAll({}, _module.attributes);\n\n // add registered components transform attributes\n Object.keys(Registry.componentsRegistry).forEach(function(k) {\n var _module = Registry.componentsRegistry[k];\n\n if(_module.schema && _module.schema.transforms && _module.schema.transforms[type]) {\n Object.keys(_module.schema.transforms[type]).forEach(function(v) {\n insertAttrs(attributes, _module.schema.transforms[type][v], v);\n });\n }\n });\n\n return {\n attributes: formatAttributes(attributes)\n };\n}\n\nfunction getFramesAttributes() {\n var attrs = {\n frames: extendDeepAll({}, frameAttributes)\n };\n\n formatAttributes(attrs);\n\n return attrs.frames;\n}\n\nfunction formatAttributes(attrs) {\n mergeValTypeAndRole(attrs);\n formatArrayContainers(attrs);\n stringify(attrs);\n\n return attrs;\n}\n\nfunction mergeValTypeAndRole(attrs) {\n function makeSrcAttr(attrName) {\n return {\n valType: 'string',\n role: 'info',\n description: [\n 'Sets the source reference on Chart Studio Cloud for ',\n attrName, '.'\n ].join(' '),\n editType: 'none'\n };\n }\n\n function callback(attr, attrName, attrs) {\n if(exports.isValObject(attr)) {\n if(attr.valType === 'data_array') {\n // all 'data_array' attrs have role 'data'\n attr.role = 'data';\n // all 'data_array' attrs have a corresponding 'src' attr\n attrs[attrName + 'src'] = makeSrcAttr(attrName);\n } else if(attr.arrayOk === true) {\n // all 'arrayOk' attrs have a corresponding 'src' attr\n attrs[attrName + 'src'] = makeSrcAttr(attrName);\n }\n } else if(isPlainObject(attr)) {\n // all attrs container objects get role 'object'\n attr.role = 'object';\n }\n }\n\n exports.crawl(attrs, callback);\n}\n\nfunction formatArrayContainers(attrs) {\n function callback(attr, attrName, attrs) {\n if(!attr) return;\n\n var itemName = attr[IS_LINKED_TO_ARRAY];\n\n if(!itemName) return;\n\n delete attr[IS_LINKED_TO_ARRAY];\n\n attrs[attrName] = { items: {} };\n attrs[attrName].items[itemName] = attr;\n attrs[attrName].role = 'object';\n }\n\n exports.crawl(attrs, callback);\n}\n\n// this can take around 10ms and should only be run from PlotSchema.get(),\n// to ensure JSON.stringify(PlotSchema.get()) gives the intended result.\nfunction stringify(attrs) {\n function walk(attr) {\n for(var k in attr) {\n if(isPlainObject(attr[k])) {\n walk(attr[k]);\n } else if(Array.isArray(attr[k])) {\n for(var i = 0; i < attr[k].length; i++) {\n walk(attr[k][i]);\n }\n } else {\n // as JSON.stringify(/test/) // => {}\n if(attr[k] instanceof RegExp) {\n attr[k] = attr[k].toString();\n }\n }\n }\n }\n\n walk(attrs);\n}\n\nfunction assignPolarLayoutAttrs(layoutAttributes) {\n extendFlat(layoutAttributes, {\n radialaxis: polarAxisAttrs.radialaxis,\n angularaxis: polarAxisAttrs.angularaxis\n });\n\n extendFlat(layoutAttributes, polarAxisAttrs.layout);\n\n return layoutAttributes;\n}\n\nfunction handleBasePlotModule(layoutAttributes, _module, astr) {\n var np = nestedProperty(layoutAttributes, astr);\n var attrs = extendDeepAll({}, _module.layoutAttributes);\n\n attrs[IS_SUBPLOT_OBJ] = true;\n np.set(attrs);\n}\n\nfunction insertAttrs(baseAttrs, newAttrs, astr) {\n var np = nestedProperty(baseAttrs, astr);\n\n np.set(extendDeepAll(np.get() || {}, newAttrs));\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar tinycolor = require('tinycolor2');\n\nvar baseTraceAttrs = require('../plots/attributes');\nvar colorscales = require('../components/colorscale/scales');\nvar DESELECTDIM = require('../constants/interactions').DESELECTDIM;\n\nvar nestedProperty = require('./nested_property');\nvar counterRegex = require('./regex').counter;\nvar modHalf = require('./mod').modHalf;\nvar isArrayOrTypedArray = require('./array').isArrayOrTypedArray;\n\nexports.valObjectMeta = {\n data_array: {\n // You can use *dflt=[] to force said array to exist though.\n description: [\n 'An {array} of data.',\n 'The value MUST be an {array}, or we ignore it.',\n 'Note that typed arrays (e.g. Float32Array) are supported.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n // TODO maybe `v: {type: 'float32', vals: [/* ... */]}` also\n if(isArrayOrTypedArray(v)) propOut.set(v);\n else if(dflt !== undefined) propOut.set(dflt);\n }\n },\n enumerated: {\n description: [\n 'Enumerated value type. The available values are listed',\n 'in `values`.'\n ].join(' '),\n requiredOpts: ['values'],\n otherOpts: ['dflt', 'coerceNumber', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(opts.coerceNumber) v = +v;\n if(opts.values.indexOf(v) === -1) propOut.set(dflt);\n else propOut.set(v);\n },\n validateFunction: function(v, opts) {\n if(opts.coerceNumber) v = +v;\n\n var values = opts.values;\n for(var i = 0; i < values.length; i++) {\n var k = String(values[i]);\n\n if((k.charAt(0) === '/' && k.charAt(k.length - 1) === '/')) {\n var regex = new RegExp(k.substr(1, k.length - 2));\n if(regex.test(v)) return true;\n } else if(v === values[i]) return true;\n }\n return false;\n }\n },\n 'boolean': {\n description: 'A boolean (true/false) value.',\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n if(v === true || v === false) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n number: {\n description: [\n 'A number or a numeric value',\n '(e.g. a number inside a string).',\n 'When applicable, values greater (less) than `max` (`min`)',\n 'are coerced to the `dflt`.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'min', 'max', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(!isNumeric(v) ||\n (opts.min !== undefined && v < opts.min) ||\n (opts.max !== undefined && v > opts.max)) {\n propOut.set(dflt);\n } else propOut.set(+v);\n }\n },\n integer: {\n description: [\n 'An integer or an integer inside a string.',\n 'When applicable, values greater (less) than `max` (`min`)',\n 'are coerced to the `dflt`.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'min', 'max', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(v % 1 || !isNumeric(v) ||\n (opts.min !== undefined && v < opts.min) ||\n (opts.max !== undefined && v > opts.max)) {\n propOut.set(dflt);\n } else propOut.set(+v);\n }\n },\n string: {\n description: [\n 'A string value.',\n 'Numbers are converted to strings except for attributes with',\n '`strict` set to true.'\n ].join(' '),\n requiredOpts: [],\n // TODO 'values shouldn't be in there (edge case: 'dash' in Scatter)\n otherOpts: ['dflt', 'noBlank', 'strict', 'arrayOk', 'values'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(typeof v !== 'string') {\n var okToCoerce = (typeof v === 'number');\n\n if(opts.strict === true || !okToCoerce) propOut.set(dflt);\n else propOut.set(String(v));\n } else if(opts.noBlank && !v) propOut.set(dflt);\n else propOut.set(v);\n }\n },\n color: {\n description: [\n 'A string describing color.',\n 'Supported formats:',\n '- hex (e.g. \\'#d3d3d3\\')',\n '- rgb (e.g. \\'rgb(255, 0, 0)\\')',\n '- rgba (e.g. \\'rgb(255, 0, 0, 0.5)\\')',\n '- hsl (e.g. \\'hsl(0, 100%, 50%)\\')',\n '- hsv (e.g. \\'hsv(0, 100%, 100%)\\')',\n '- named colors (full list: http://www.w3.org/TR/css3-color/#svg-color)'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt) {\n if(tinycolor(v).isValid()) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n colorlist: {\n description: [\n 'A list of colors.',\n 'Must be an {array} containing valid colors.',\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n function isColor(color) {\n return tinycolor(color).isValid();\n }\n if(!Array.isArray(v) || !v.length) propOut.set(dflt);\n else if(v.every(isColor)) propOut.set(v);\n else propOut.set(dflt);\n }\n },\n colorscale: {\n description: [\n 'A Plotly colorscale either picked by a name:',\n '(any of', Object.keys(colorscales.scales).join(', '), ')',\n 'customized as an {array} of 2-element {arrays} where',\n 'the first element is the normalized color level value',\n '(starting at *0* and ending at *1*),',\n 'and the second item is a valid color string.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n propOut.set(colorscales.get(v, dflt));\n }\n },\n angle: {\n description: [\n 'A number (in degree) between -180 and 180.'\n ].join(' '),\n requiredOpts: [],\n otherOpts: ['dflt'],\n coerceFunction: function(v, propOut, dflt) {\n if(v === 'auto') propOut.set('auto');\n else if(!isNumeric(v)) propOut.set(dflt);\n else propOut.set(modHalf(+v, 360));\n }\n },\n subplotid: {\n description: [\n 'An id string of a subplot type (given by dflt), optionally',\n 'followed by an integer >1. e.g. if dflt=\\'geo\\', we can have',\n '\\'geo\\', \\'geo2\\', \\'geo3\\', ...'\n ].join(' '),\n requiredOpts: ['dflt'],\n otherOpts: ['regex'],\n coerceFunction: function(v, propOut, dflt, opts) {\n var regex = opts.regex || counterRegex(dflt);\n if(typeof v === 'string' && regex.test(v)) {\n propOut.set(v);\n return;\n }\n propOut.set(dflt);\n },\n validateFunction: function(v, opts) {\n var dflt = opts.dflt;\n\n if(v === dflt) return true;\n if(typeof v !== 'string') return false;\n if(counterRegex(dflt).test(v)) return true;\n\n return false;\n }\n },\n flaglist: {\n description: [\n 'A string representing a combination of flags',\n '(order does not matter here).',\n 'Combine any of the available `flags` with *+*.',\n '(e.g. (\\'lines+markers\\')).',\n 'Values in `extras` cannot be combined.'\n ].join(' '),\n requiredOpts: ['flags'],\n otherOpts: ['dflt', 'extras', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt, opts) {\n if(typeof v !== 'string') {\n propOut.set(dflt);\n return;\n }\n if((opts.extras || []).indexOf(v) !== -1) {\n propOut.set(v);\n return;\n }\n var vParts = v.split('+');\n var i = 0;\n while(i < vParts.length) {\n var vi = vParts[i];\n if(opts.flags.indexOf(vi) === -1 || vParts.indexOf(vi) < i) {\n vParts.splice(i, 1);\n } else i++;\n }\n if(!vParts.length) propOut.set(dflt);\n else propOut.set(vParts.join('+'));\n }\n },\n any: {\n description: 'Any type.',\n requiredOpts: [],\n otherOpts: ['dflt', 'values', 'arrayOk'],\n coerceFunction: function(v, propOut, dflt) {\n if(v === undefined) propOut.set(dflt);\n else propOut.set(v);\n }\n },\n info_array: {\n description: [\n 'An {array} of plot information.'\n ].join(' '),\n requiredOpts: ['items'],\n // set `dimensions=2` for a 2D array or '1-2' for either\n // `items` may be a single object instead of an array, in which case\n // `freeLength` must be true.\n // if `dimensions='1-2'` and items is a 1D array, then the value can\n // either be a matching 1D array or an array of such matching 1D arrays\n otherOpts: ['dflt', 'freeLength', 'dimensions'],\n coerceFunction: function(v, propOut, dflt, opts) {\n // simplified coerce function just for array items\n function coercePart(v, opts, dflt) {\n var out;\n var propPart = {set: function(v) { out = v; }};\n\n if(dflt === undefined) dflt = opts.dflt;\n\n exports.valObjectMeta[opts.valType].coerceFunction(v, propPart, dflt, opts);\n\n return out;\n }\n\n var twoD = opts.dimensions === 2 || (opts.dimensions === '1-2' && Array.isArray(v) && Array.isArray(v[0]));\n\n if(!Array.isArray(v)) {\n propOut.set(dflt);\n return;\n }\n\n var items = opts.items;\n var vOut = [];\n var arrayItems = Array.isArray(items);\n var arrayItems2D = arrayItems && twoD && Array.isArray(items[0]);\n var innerItemsOnly = twoD && arrayItems && !arrayItems2D;\n var len = (arrayItems && !innerItemsOnly) ? items.length : v.length;\n\n var i, j, row, item, len2, vNew;\n\n dflt = Array.isArray(dflt) ? dflt : [];\n\n if(twoD) {\n for(i = 0; i < len; i++) {\n vOut[i] = [];\n row = Array.isArray(v[i]) ? v[i] : [];\n if(innerItemsOnly) len2 = items.length;\n else if(arrayItems) len2 = items[i].length;\n else len2 = row.length;\n\n for(j = 0; j < len2; j++) {\n if(innerItemsOnly) item = items[j];\n else if(arrayItems) item = items[i][j];\n else item = items;\n\n vNew = coercePart(row[j], item, (dflt[i] || [])[j]);\n if(vNew !== undefined) vOut[i][j] = vNew;\n }\n }\n } else {\n for(i = 0; i < len; i++) {\n vNew = coercePart(v[i], arrayItems ? items[i] : items, dflt[i]);\n if(vNew !== undefined) vOut[i] = vNew;\n }\n }\n\n propOut.set(vOut);\n },\n validateFunction: function(v, opts) {\n if(!Array.isArray(v)) return false;\n\n var items = opts.items;\n var arrayItems = Array.isArray(items);\n var twoD = opts.dimensions === 2;\n\n // when free length is off, input and declared lengths must match\n if(!opts.freeLength && v.length !== items.length) return false;\n\n // valid when all input items are valid\n for(var i = 0; i < v.length; i++) {\n if(twoD) {\n if(!Array.isArray(v[i]) || (!opts.freeLength && v[i].length !== items[i].length)) {\n return false;\n }\n for(var j = 0; j < v[i].length; j++) {\n if(!validate(v[i][j], arrayItems ? items[i][j] : items)) {\n return false;\n }\n }\n } else if(!validate(v[i], arrayItems ? items[i] : items)) return false;\n }\n\n return true;\n }\n }\n};\n\n/**\n * Ensures that container[attribute] has a valid value.\n *\n * attributes[attribute] is an object with possible keys:\n * - valType: data_array, enumerated, boolean, ... as in valObjectMeta\n * - values: (enumerated only) array of allowed vals\n * - min, max: (number, integer only) inclusive bounds on allowed vals\n * either or both may be omitted\n * - dflt: if attribute is invalid or missing, use this default\n * if dflt is provided as an argument to lib.coerce it takes precedence\n * as a convenience, returns the value it finally set\n */\nexports.coerce = function(containerIn, containerOut, attributes, attribute, dflt) {\n var opts = nestedProperty(attributes, attribute).get();\n var propIn = nestedProperty(containerIn, attribute);\n var propOut = nestedProperty(containerOut, attribute);\n var v = propIn.get();\n\n var template = containerOut._template;\n if(v === undefined && template) {\n v = nestedProperty(template, attribute).get();\n // already used the template value, so short-circuit the second check\n template = 0;\n }\n\n if(dflt === undefined) dflt = opts.dflt;\n\n /**\n * arrayOk: value MAY be an array, then we do no value checking\n * at this point, because it can be more complicated than the\n * individual form (eg. some array vals can be numbers, even if the\n * single values must be color strings)\n */\n if(opts.arrayOk && isArrayOrTypedArray(v)) {\n propOut.set(v);\n return v;\n }\n\n var coerceFunction = exports.valObjectMeta[opts.valType].coerceFunction;\n coerceFunction(v, propOut, dflt, opts);\n\n var out = propOut.get();\n // in case v was provided but invalid, try the template again so it still\n // overrides the regular default\n if(template && out === dflt && !validate(v, opts)) {\n v = nestedProperty(template, attribute).get();\n coerceFunction(v, propOut, dflt, opts);\n out = propOut.get();\n }\n return out;\n};\n\n/**\n * Variation on coerce\n *\n * Uses coerce to get attribute value if user input is valid,\n * returns attribute default if user input it not valid or\n * returns false if there is no user input.\n */\nexports.coerce2 = function(containerIn, containerOut, attributes, attribute, dflt) {\n var propIn = nestedProperty(containerIn, attribute);\n var propOut = exports.coerce(containerIn, containerOut, attributes, attribute, dflt);\n var valIn = propIn.get();\n\n return (valIn !== undefined && valIn !== null) ? propOut : false;\n};\n\n/*\n * Shortcut to coerce the three font attributes\n *\n * 'coerce' is a lib.coerce wrapper with implied first three arguments\n */\nexports.coerceFont = function(coerce, attr, dfltObj) {\n var out = {};\n\n dfltObj = dfltObj || {};\n\n out.family = coerce(attr + '.family', dfltObj.family);\n out.size = coerce(attr + '.size', dfltObj.size);\n out.color = coerce(attr + '.color', dfltObj.color);\n\n return out;\n};\n\n/** Coerce shortcut for 'hoverinfo'\n * handling 1-vs-multi-trace dflt logic\n *\n * @param {object} traceIn : user trace object\n * @param {object} traceOut : full trace object (requires _module ref)\n * @param {object} layoutOut : full layout object (require _dataLength ref)\n * @return {any} : the coerced value\n */\nexports.coerceHoverinfo = function(traceIn, traceOut, layoutOut) {\n var moduleAttrs = traceOut._module.attributes;\n var attrs = moduleAttrs.hoverinfo ? moduleAttrs : baseTraceAttrs;\n\n var valObj = attrs.hoverinfo;\n var dflt;\n\n if(layoutOut._dataLength === 1) {\n var flags = valObj.dflt === 'all' ?\n valObj.flags.slice() :\n valObj.dflt.split('+');\n\n flags.splice(flags.indexOf('name'), 1);\n dflt = flags.join('+');\n }\n\n return exports.coerce(traceIn, traceOut, attrs, 'hoverinfo', dflt);\n};\n\n/** Coerce shortcut for [un]selected.marker.opacity,\n * which has special default logic, to ensure that it corresponds to the\n * default selection behavior while allowing to be overtaken by any other\n * [un]selected attribute.\n *\n * N.B. This must be called *after* coercing all the other [un]selected attrs,\n * to give the intended result.\n *\n * @param {object} traceOut : fullData item\n * @param {function} coerce : lib.coerce wrapper with implied first three arguments\n */\nexports.coerceSelectionMarkerOpacity = function(traceOut, coerce) {\n if(!traceOut.marker) return;\n\n var mo = traceOut.marker.opacity;\n // you can still have a `marker` container with no markers if there's text\n if(mo === undefined) return;\n\n var smoDflt;\n var usmoDflt;\n\n // Don't give [un]selected.marker.opacity a default value if\n // marker.opacity is an array: handle this during style step.\n //\n // Only give [un]selected.marker.opacity a default value if you don't\n // set any other [un]selected attributes.\n if(!isArrayOrTypedArray(mo) && !traceOut.selected && !traceOut.unselected) {\n smoDflt = mo;\n usmoDflt = DESELECTDIM * mo;\n }\n\n coerce('selected.marker.opacity', smoDflt);\n coerce('unselected.marker.opacity', usmoDflt);\n};\n\nfunction validate(value, opts) {\n var valObjectDef = exports.valObjectMeta[opts.valType];\n\n if(opts.arrayOk && isArrayOrTypedArray(value)) return true;\n\n if(valObjectDef.validateFunction) {\n return valObjectDef.validateFunction(value, opts);\n }\n\n var failed = {};\n var out = failed;\n var propMock = { set: function(v) { out = v; } };\n\n // 'failed' just something mutable that won't be === anything else\n\n valObjectDef.coerceFunction(value, propMock, failed, opts);\n return out !== failed;\n}\nexports.validate = validate;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar axisIds = require('../../plots/cartesian/axis_ids');\n\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nvar constants = require('./constants');\nvar getUpdateObject = require('./get_update_object');\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n\n var selectors = fullLayout._infolayer.selectAll('.rangeselector')\n .data(makeSelectorData(gd), selectorKeyFunc);\n\n selectors.enter().append('g')\n .classed('rangeselector', true);\n\n selectors.exit().remove();\n\n selectors.style({\n cursor: 'pointer',\n 'pointer-events': 'all'\n });\n\n selectors.each(function(d) {\n var selector = d3.select(this);\n var axisLayout = d;\n var selectorLayout = axisLayout.rangeselector;\n\n var buttons = selector.selectAll('g.button')\n .data(Lib.filterVisible(selectorLayout.buttons));\n\n buttons.enter().append('g')\n .classed('button', true);\n\n buttons.exit().remove();\n\n buttons.each(function(d) {\n var button = d3.select(this);\n var update = getUpdateObject(axisLayout, d);\n\n d._isActive = isActive(axisLayout, d, update);\n\n button.call(drawButtonRect, selectorLayout, d);\n button.call(drawButtonText, selectorLayout, d, gd);\n\n button.on('click', function() {\n if(gd._dragged) return;\n\n Registry.call('_guiRelayout', gd, update);\n });\n\n button.on('mouseover', function() {\n d._isHovered = true;\n button.call(drawButtonRect, selectorLayout, d);\n });\n\n button.on('mouseout', function() {\n d._isHovered = false;\n button.call(drawButtonRect, selectorLayout, d);\n });\n });\n\n reposition(gd, buttons, selectorLayout, axisLayout._name, selector);\n });\n};\n\nfunction makeSelectorData(gd) {\n var axes = axisIds.list(gd, 'x', true);\n var data = [];\n\n for(var i = 0; i < axes.length; i++) {\n var axis = axes[i];\n\n if(axis.rangeselector && axis.rangeselector.visible) {\n data.push(axis);\n }\n }\n\n return data;\n}\n\nfunction selectorKeyFunc(d) {\n return d._id;\n}\n\nfunction isActive(axisLayout, opts, update) {\n if(opts.step === 'all') {\n return axisLayout.autorange === true;\n } else {\n var keys = Object.keys(update);\n\n return (\n axisLayout.range[0] === update[keys[0]] &&\n axisLayout.range[1] === update[keys[1]]\n );\n }\n}\n\nfunction drawButtonRect(button, selectorLayout, d) {\n var rect = Lib.ensureSingle(button, 'rect', 'selector-rect', function(s) {\n s.attr('shape-rendering', 'crispEdges');\n });\n\n rect.attr({\n 'rx': constants.rx,\n 'ry': constants.ry\n });\n\n rect.call(Color.stroke, selectorLayout.bordercolor)\n .call(Color.fill, getFillColor(selectorLayout, d))\n .style('stroke-width', selectorLayout.borderwidth + 'px');\n}\n\nfunction getFillColor(selectorLayout, d) {\n return (d._isActive || d._isHovered) ?\n selectorLayout.activecolor :\n selectorLayout.bgcolor;\n}\n\nfunction drawButtonText(button, selectorLayout, d, gd) {\n function textLayout(s) {\n svgTextUtils.convertToTspans(s, gd);\n }\n\n var text = Lib.ensureSingle(button, 'text', 'selector-text', function(s) {\n s.classed('user-select-none', true)\n .attr('text-anchor', 'middle');\n });\n\n text.call(Drawing.font, selectorLayout.font)\n .text(getLabel(d, gd._fullLayout._meta))\n .call(textLayout);\n}\n\nfunction getLabel(opts, _meta) {\n if(opts.label) {\n return _meta ?\n Lib.templateString(opts.label, _meta) :\n opts.label;\n }\n\n if(opts.step === 'all') return 'all';\n\n return opts.count + opts.step.charAt(0);\n}\n\nfunction reposition(gd, buttons, opts, axName, selector) {\n var width = 0;\n var height = 0;\n\n var borderWidth = opts.borderwidth;\n\n buttons.each(function() {\n var button = d3.select(this);\n var text = button.select('.selector-text');\n\n var tHeight = opts.font.size * LINE_SPACING;\n var hEff = Math.max(tHeight * svgTextUtils.lineCount(text), 16) + 3;\n\n height = Math.max(height, hEff);\n });\n\n buttons.each(function() {\n var button = d3.select(this);\n var rect = button.select('.selector-rect');\n var text = button.select('.selector-text');\n\n var tWidth = text.node() && Drawing.bBox(text.node()).width;\n var tHeight = opts.font.size * LINE_SPACING;\n var tLines = svgTextUtils.lineCount(text);\n\n var wEff = Math.max(tWidth + 10, constants.minButtonWidth);\n\n // TODO add MathJax support\n\n // TODO add buttongap attribute\n\n button.attr('transform', 'translate(' +\n (borderWidth + width) + ',' + borderWidth +\n ')');\n\n rect.attr({\n x: 0,\n y: 0,\n width: wEff,\n height: height\n });\n\n svgTextUtils.positionText(text, wEff / 2,\n height / 2 - ((tLines - 1) * tHeight / 2) + 3);\n\n width += wEff + 5;\n });\n\n var graphSize = gd._fullLayout._size;\n var lx = graphSize.l + graphSize.w * opts.x;\n var ly = graphSize.t + graphSize.h * (1 - opts.y);\n\n var xanchor = 'left';\n if(Lib.isRightAnchor(opts)) {\n lx -= width;\n xanchor = 'right';\n }\n if(Lib.isCenterAnchor(opts)) {\n lx -= width / 2;\n xanchor = 'center';\n }\n\n var yanchor = 'top';\n if(Lib.isBottomAnchor(opts)) {\n ly -= height;\n yanchor = 'bottom';\n }\n if(Lib.isMiddleAnchor(opts)) {\n ly -= height / 2;\n yanchor = 'middle';\n }\n\n width = Math.ceil(width);\n height = Math.ceil(height);\n lx = Math.round(lx);\n ly = Math.round(ly);\n\n Plots.autoMargin(gd, axName + '-range-selector', {\n x: opts.x,\n y: opts.y,\n l: width * FROM_TL[xanchor],\n r: width * FROM_BR[xanchor],\n b: height * FROM_BR[yanchor],\n t: height * FROM_TL[yanchor]\n });\n\n selector.attr('transform', 'translate(' + lx + ',' + ly + ')');\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n\n // attribute container name\n name: 'rangeslider',\n\n // class names\n\n containerClassName: 'rangeslider-container',\n bgClassName: 'rangeslider-bg',\n rangePlotClassName: 'rangeslider-rangeplot',\n\n maskMinClassName: 'rangeslider-mask-min',\n maskMaxClassName: 'rangeslider-mask-max',\n slideBoxClassName: 'rangeslider-slidebox',\n\n grabberMinClassName: 'rangeslider-grabber-min',\n grabAreaMinClassName: 'rangeslider-grabarea-min',\n handleMinClassName: 'rangeslider-handle-min',\n\n grabberMaxClassName: 'rangeslider-grabber-max',\n grabAreaMaxClassName: 'rangeslider-grabarea-max',\n handleMaxClassName: 'rangeslider-handle-max',\n\n maskMinOppAxisClassName: 'rangeslider-mask-min-opp-axis',\n maskMaxOppAxisClassName: 'rangeslider-mask-max-opp-axis',\n\n // style constants\n\n maskColor: 'rgba(0,0,0,0.4)',\n maskOppAxisColor: 'rgba(0,0,0,0.2)',\n\n slideBoxFill: 'transparent',\n slideBoxCursor: 'ew-resize',\n\n grabAreaFill: 'transparent',\n grabAreaCursor: 'col-resize',\n grabAreaWidth: 10,\n\n handleWidth: 4,\n handleRadius: 1,\n handleStrokeWidth: 1,\n\n extraPad: 15\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar colorMix = require('tinycolor2').mix;\nvar lightFraction = require('../../components/color/attributes').lightFraction;\nvar Lib = require('../../lib');\n\n/**\n * @param {object} opts :\n * - dfltColor {string} : default axis color\n * - bgColor {string} : combined subplot bg color\n * - blend {number, optional} : blend percentage (to compute dflt grid color)\n * - showLine {boolean} : show line by default\n * - showGrid {boolean} : show grid by default\n * - noZeroLine {boolean} : don't coerce zeroline* attributes\n * - attributes {object} : attribute object associated with input containers\n */\nmodule.exports = function handleLineGridDefaults(containerIn, containerOut, coerce, opts) {\n opts = opts || {};\n\n var dfltColor = opts.dfltColor;\n\n function coerce2(attr, dflt) {\n return Lib.coerce2(containerIn, containerOut, opts.attributes, attr, dflt);\n }\n\n var lineColor = coerce2('linecolor', dfltColor);\n var lineWidth = coerce2('linewidth');\n var showLine = coerce('showline', opts.showLine || !!lineColor || !!lineWidth);\n\n if(!showLine) {\n delete containerOut.linecolor;\n delete containerOut.linewidth;\n }\n\n var gridColorDflt = colorMix(dfltColor, opts.bgColor, opts.blend || lightFraction).toRgbString();\n var gridColor = coerce2('gridcolor', gridColorDflt);\n var gridWidth = coerce2('gridwidth');\n var showGridLines = coerce('showgrid', opts.showGrid || !!gridColor || !!gridWidth);\n\n if(!showGridLines) {\n delete containerOut.gridcolor;\n delete containerOut.gridwidth;\n }\n\n if(!opts.noZeroLine) {\n var zeroLineColor = coerce2('zerolinecolor', dfltColor);\n var zeroLineWidth = coerce2('zerolinewidth');\n var showZeroLine = coerce('zeroline', opts.showGrid || !!zeroLineColor || !!zeroLineWidth);\n\n if(!showZeroLine) {\n delete containerOut.zerolinecolor;\n delete containerOut.zerolinewidth;\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n// for automatic alignment on dragging, <1/3 means left align,\n// >2/3 means right, and between is center. Pick the right fraction\n// based on where you are, and return the fraction corresponding to\n// that position on the object\nmodule.exports = function align(v, dv, v0, v1, anchor) {\n var vmin = (v - v0) / (v1 - v0);\n var vmax = vmin + dv / (v1 - v0);\n var vc = (vmin + vmax) / 2;\n\n // explicitly specified anchor\n if(anchor === 'left' || anchor === 'bottom') return vmin;\n if(anchor === 'center' || anchor === 'middle') return vc;\n if(anchor === 'right' || anchor === 'top') return vmax;\n\n // automatic based on position\n if(vmin < (2 / 3) - vc) return vmin;\n if(vmax > (4 / 3) - vc) return vmax;\n return vc;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n crossTraceDefaults: require('./defaults').crossTraceDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n calc: require('./calc'),\n crossTraceCalc: require('./cross_trace_calc').crossTraceCalc,\n colorbar: require('../scatter/marker_colorbar'),\n arraysToCalcdata: require('./arrays_to_calcdata'),\n plot: require('./plot').plot,\n style: require('./style').style,\n styleOnSelect: require('./style').styleOnSelect,\n hoverPoints: require('./hover').hoverPoints,\n eventData: require('./event_data'),\n selectPoints: require('./select'),\n\n moduleType: 'trace',\n name: 'bar',\n basePlotModule: require('../../plots/cartesian'),\n categories: ['bar-like', 'cartesian', 'svg', 'bar', 'oriented', 'errorBarsOK', 'showLegend', 'zoomScale'],\n animatable: true,\n meta: {\n description: [\n 'The data visualized by the span of the bars is set in `y`',\n 'if `orientation` is set th *v* (the default)',\n 'and the labels are set in `x`.',\n 'By setting `orientation` to *h*, the roles are interchanged.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar dot = require('./matrix').dot;\nvar BADNUM = require('../constants/numerical').BADNUM;\n\nvar polygon = module.exports = {};\n\n/**\n * Turn an array of [x, y] pairs into a polygon object\n * that can test if points are inside it\n *\n * @param ptsIn Array of [x, y] pairs\n *\n * @returns polygon Object {xmin, xmax, ymin, ymax, pts, contains}\n * (x|y)(min|max) are the bounding rect of the polygon\n * pts is the original array, with the first pair repeated at the end\n * contains is a function: (pt, omitFirstEdge)\n * pt is the [x, y] pair to test\n * omitFirstEdge truthy means points exactly on the first edge don't\n * count. This is for use adding one polygon to another so we\n * don't double-count the edge where they meet.\n * returns boolean: is pt inside the polygon (including on its edges)\n */\npolygon.tester = function tester(ptsIn) {\n var pts = ptsIn.slice();\n var xmin = pts[0][0];\n var xmax = xmin;\n var ymin = pts[0][1];\n var ymax = ymin;\n var i;\n\n pts.push(pts[0]);\n for(i = 1; i < pts.length; i++) {\n xmin = Math.min(xmin, pts[i][0]);\n xmax = Math.max(xmax, pts[i][0]);\n ymin = Math.min(ymin, pts[i][1]);\n ymax = Math.max(ymax, pts[i][1]);\n }\n\n // do we have a rectangle? Handle this here, so we can use the same\n // tester for the rectangular case without sacrificing speed\n\n var isRect = false;\n var rectFirstEdgeTest;\n\n if(pts.length === 5) {\n if(pts[0][0] === pts[1][0]) { // vert, horz, vert, horz\n if(pts[2][0] === pts[3][0] &&\n pts[0][1] === pts[3][1] &&\n pts[1][1] === pts[2][1]) {\n isRect = true;\n rectFirstEdgeTest = function(pt) { return pt[0] === pts[0][0]; };\n }\n } else if(pts[0][1] === pts[1][1]) { // horz, vert, horz, vert\n if(pts[2][1] === pts[3][1] &&\n pts[0][0] === pts[3][0] &&\n pts[1][0] === pts[2][0]) {\n isRect = true;\n rectFirstEdgeTest = function(pt) { return pt[1] === pts[0][1]; };\n }\n }\n }\n\n function rectContains(pt, omitFirstEdge) {\n var x = pt[0];\n var y = pt[1];\n\n if(x === BADNUM || x < xmin || x > xmax || y === BADNUM || y < ymin || y > ymax) {\n // pt is outside the bounding box of polygon\n return false;\n }\n if(omitFirstEdge && rectFirstEdgeTest(pt)) return false;\n\n return true;\n }\n\n function contains(pt, omitFirstEdge) {\n var x = pt[0];\n var y = pt[1];\n\n if(x === BADNUM || x < xmin || x > xmax || y === BADNUM || y < ymin || y > ymax) {\n // pt is outside the bounding box of polygon\n return false;\n }\n\n var imax = pts.length;\n var x1 = pts[0][0];\n var y1 = pts[0][1];\n var crossings = 0;\n var i;\n var x0;\n var y0;\n var xmini;\n var ycross;\n\n for(i = 1; i < imax; i++) {\n // find all crossings of a vertical line upward from pt with\n // polygon segments\n // crossings exactly at xmax don't count, unless the point is\n // exactly on the segment, then it counts as inside.\n x0 = x1;\n y0 = y1;\n x1 = pts[i][0];\n y1 = pts[i][1];\n xmini = Math.min(x0, x1);\n\n if(x < xmini || x > Math.max(x0, x1) || y > Math.max(y0, y1)) {\n // outside the bounding box of this segment, it's only a crossing\n // if it's below the box.\n\n continue;\n } else if(y < Math.min(y0, y1)) {\n // don't count the left-most point of the segment as a crossing\n // because we don't want to double-count adjacent crossings\n // UNLESS the polygon turns past vertical at exactly this x\n // Note that this is repeated below, but we can't factor it out\n // because\n if(x !== xmini) crossings++;\n } else {\n // inside the bounding box, check the actual line intercept\n\n // vertical segment - we know already that the point is exactly\n // on the segment, so mark the crossing as exactly at the point.\n if(x1 === x0) ycross = y;\n // any other angle\n else ycross = y0 + (x - x0) * (y1 - y0) / (x1 - x0);\n\n // exactly on the edge: counts as inside the polygon, unless it's the\n // first edge and we're omitting it.\n if(y === ycross) {\n if(i === 1 && omitFirstEdge) return false;\n return true;\n }\n\n if(y <= ycross && x !== xmini) crossings++;\n }\n }\n\n // if we've gotten this far, odd crossings means inside, even is outside\n return crossings % 2 === 1;\n }\n\n // detect if poly is degenerate\n var degenerate = true;\n var lastPt = pts[0];\n for(i = 1; i < pts.length; i++) {\n if(lastPt[0] !== pts[i][0] || lastPt[1] !== pts[i][1]) {\n degenerate = false;\n break;\n }\n }\n\n return {\n xmin: xmin,\n xmax: xmax,\n ymin: ymin,\n ymax: ymax,\n pts: pts,\n contains: isRect ? rectContains : contains,\n isRect: isRect,\n degenerate: degenerate\n };\n};\n\n/**\n * Test if a segment of a points array is bent or straight\n *\n * @param pts Array of [x, y] pairs\n * @param start the index of the proposed start of the straight section\n * @param end the index of the proposed end point\n * @param tolerance the max distance off the line connecting start and end\n * before the line counts as bent\n * @returns boolean: true means this segment is bent, false means straight\n */\npolygon.isSegmentBent = function isSegmentBent(pts, start, end, tolerance) {\n var startPt = pts[start];\n var segment = [pts[end][0] - startPt[0], pts[end][1] - startPt[1]];\n var segmentSquared = dot(segment, segment);\n var segmentLen = Math.sqrt(segmentSquared);\n var unitPerp = [-segment[1] / segmentLen, segment[0] / segmentLen];\n var i;\n var part;\n var partParallel;\n\n for(i = start + 1; i < end; i++) {\n part = [pts[i][0] - startPt[0], pts[i][1] - startPt[1]];\n partParallel = dot(part, segment);\n\n if(partParallel < 0 || partParallel > segmentSquared ||\n Math.abs(dot(part, unitPerp)) > tolerance) return true;\n }\n return false;\n};\n\n/**\n * Make a filtering polygon, to minimize the number of segments\n *\n * @param pts Array of [x, y] pairs (must start with at least 1 pair)\n * @param tolerance the maximum deviation from straight allowed for\n * removing points to simplify the polygon\n *\n * @returns Object {addPt, raw, filtered}\n * addPt is a function(pt: [x, y] pair) to add a raw point and\n * continue filtering\n * raw is all the input points\n * filtered is the resulting filtered Array of [x, y] pairs\n */\npolygon.filter = function filter(pts, tolerance) {\n var ptsFiltered = [pts[0]];\n var doneRawIndex = 0;\n var doneFilteredIndex = 0;\n\n function addPt(pt) {\n pts.push(pt);\n var prevFilterLen = ptsFiltered.length;\n var iLast = doneRawIndex;\n ptsFiltered.splice(doneFilteredIndex + 1);\n\n for(var i = iLast + 1; i < pts.length; i++) {\n if(i === pts.length - 1 || polygon.isSegmentBent(pts, iLast, i + 1, tolerance)) {\n ptsFiltered.push(pts[i]);\n if(ptsFiltered.length < prevFilterLen - 2) {\n doneRawIndex = i;\n doneFilteredIndex = ptsFiltered.length - 1;\n }\n iLast = i;\n }\n }\n }\n\n if(pts.length > 1) {\n var lastPt = pts.pop();\n addPt(lastPt);\n }\n\n return {\n addPt: addPt,\n raw: pts,\n filtered: ptsFiltered\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = function eventData(out, pt, trace) {\n // standard cartesian event data\n out.x = 'xVal' in pt ? pt.xVal : pt.x;\n out.y = 'yVal' in pt ? pt.yVal : pt.y;\n if(pt.xa) out.xaxis = pt.xa;\n if(pt.ya) out.yaxis = pt.ya;\n\n if(trace.orientation === 'h') {\n out.label = out.y;\n out.value = out.x;\n } else {\n out.label = out.x;\n out.value = out.y;\n }\n\n return out;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'rangeselector',\n\n schema: {\n subplots: {\n xaxis: {rangeselector: require('./attributes')}\n }\n },\n\n layoutAttributes: require('./attributes'),\n handleDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar FROM_BL = require('../../constants/alignment').FROM_BL;\n\nmodule.exports = function scaleZoom(ax, factor, centerFraction) {\n if(centerFraction === undefined) {\n centerFraction = FROM_BL[ax.constraintoward || 'center'];\n }\n\n var rangeLinear = [ax.r2l(ax.range[0]), ax.r2l(ax.range[1])];\n var center = rangeLinear[0] + (rangeLinear[1] - rangeLinear[0]) * centerFraction;\n\n ax.range = ax._input.range = [\n ax.l2r(center + (rangeLinear[0] - center) * factor),\n ax.l2r(center + (rangeLinear[1] - center) * factor)\n ];\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nmodule.exports = function getUpdateObject(axisLayout, buttonLayout) {\n var axName = axisLayout._name;\n var update = {};\n\n if(buttonLayout.step === 'all') {\n update[axName + '.autorange'] = true;\n } else {\n var xrange = getXRange(axisLayout, buttonLayout);\n\n update[axName + '.range[0]'] = xrange[0];\n update[axName + '.range[1]'] = xrange[1];\n }\n\n return update;\n};\n\nfunction getXRange(axisLayout, buttonLayout) {\n var currentRange = axisLayout.range;\n var base = new Date(axisLayout.r2l(currentRange[1]));\n var step = buttonLayout.step;\n var count = buttonLayout.count;\n var range0;\n\n switch(buttonLayout.stepmode) {\n case 'backward':\n range0 = axisLayout.l2r(+d3.time[step].utc.offset(base, -count));\n break;\n\n case 'todate':\n var base2 = d3.time[step].utc.offset(base, -count);\n\n range0 = axisLayout.l2r(+d3.time[step].utc.ceil(base2));\n break;\n }\n\n var range1 = currentRange[1];\n\n return [range0, range1];\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults').supplyDefaults,\n supplyLayoutDefaults: require('./layout_defaults'),\n layoutAttributes: require('./layout_attributes'),\n\n calc: require('./calc').calc,\n crossTraceCalc: require('./calc').crossTraceCalc,\n\n plot: require('./plot').plot,\n style: require('./style'),\n styleOne: require('./style_one'),\n\n moduleType: 'trace',\n name: 'pie',\n basePlotModule: require('./base_plot'),\n categories: ['pie-like', 'pie', 'showLegend'],\n meta: {\n description: [\n 'A data visualized by the sectors of the pie is set in `values`.',\n 'The sector labels are set in `labels`.',\n 'The sector colors are set in `marker.colors`'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar listAxes = require('../../plots/cartesian/axis_ids').list;\nvar getAutoRange = require('../../plots/cartesian/autorange').getAutoRange;\nvar constants = require('./constants');\n\nmodule.exports = function calcAutorange(gd) {\n var axes = listAxes(gd, 'x', true);\n\n // Compute new slider range using axis autorange if necessary.\n //\n // Copy back range to input range slider container to skip\n // this step in subsequent draw calls.\n\n for(var i = 0; i < axes.length; i++) {\n var ax = axes[i];\n var opts = ax[constants.name];\n\n if(opts && opts.visible && opts.autorange) {\n opts._input.autorange = true;\n opts._input.range = opts.range = getAutoRange(gd, ax);\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Plots = require('../../plots/plots');\nvar Fx = require('../../components/fx');\nvar Color = require('../../components/color');\nvar Drawing = require('../../components/drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar uniformText = require('../bar/uniform_text');\nvar recordMinTextSize = uniformText.recordMinTextSize;\nvar clearMinTextSize = uniformText.clearMinTextSize;\nvar TEXTPAD = require('../bar/constants').TEXTPAD;\n\nvar helpers = require('./helpers');\nvar eventData = require('./event_data');\nvar isValidTextValue = require('../../lib').isValidTextValue;\n\nfunction plot(gd, cdModule) {\n var fullLayout = gd._fullLayout;\n var gs = fullLayout._size;\n\n clearMinTextSize('pie', fullLayout);\n\n prerenderTitles(cdModule, gd);\n layoutAreas(cdModule, gs);\n\n var plotGroups = Lib.makeTraceGroups(fullLayout._pielayer, cdModule, 'trace').each(function(cd) {\n var plotGroup = d3.select(this);\n var cd0 = cd[0];\n var trace = cd0.trace;\n\n setCoords(cd);\n\n // TODO: miter might look better but can sometimes cause problems\n // maybe miter with a small-ish stroke-miterlimit?\n plotGroup.attr('stroke-linejoin', 'round');\n\n plotGroup.each(function() {\n var slices = d3.select(this).selectAll('g.slice').data(cd);\n\n slices.enter().append('g')\n .classed('slice', true);\n slices.exit().remove();\n\n var quadrants = [\n [[], []], // y<0: x<0, x>=0\n [[], []] // y>=0: x<0, x>=0\n ];\n var hasOutsideText = false;\n\n slices.each(function(pt, i) {\n if(pt.hidden) {\n d3.select(this).selectAll('path,g').remove();\n return;\n }\n\n // to have consistent event data compared to other traces\n pt.pointNumber = pt.i;\n pt.curveNumber = trace.index;\n\n quadrants[pt.pxmid[1] < 0 ? 0 : 1][pt.pxmid[0] < 0 ? 0 : 1].push(pt);\n\n var cx = cd0.cx;\n var cy = cd0.cy;\n var sliceTop = d3.select(this);\n var slicePath = sliceTop.selectAll('path.surface').data([pt]);\n\n slicePath.enter().append('path')\n .classed('surface', true)\n .style({'pointer-events': 'all'});\n\n sliceTop.call(attachFxHandlers, gd, cd);\n\n if(trace.pull) {\n var pull = +helpers.castOption(trace.pull, pt.pts) || 0;\n if(pull > 0) {\n cx += pull * pt.pxmid[0];\n cy += pull * pt.pxmid[1];\n }\n }\n\n pt.cxFinal = cx;\n pt.cyFinal = cy;\n\n function arc(start, finish, cw, scale) {\n var dx = scale * (finish[0] - start[0]);\n var dy = scale * (finish[1] - start[1]);\n\n return 'a' +\n (scale * cd0.r) + ',' + (scale * cd0.r) + ' 0 ' +\n pt.largeArc + (cw ? ' 1 ' : ' 0 ') + dx + ',' + dy;\n }\n\n var hole = trace.hole;\n if(pt.v === cd0.vTotal) { // 100% fails bcs arc start and end are identical\n var outerCircle = 'M' + (cx + pt.px0[0]) + ',' + (cy + pt.px0[1]) +\n arc(pt.px0, pt.pxmid, true, 1) +\n arc(pt.pxmid, pt.px0, true, 1) + 'Z';\n if(hole) {\n slicePath.attr('d',\n 'M' + (cx + hole * pt.px0[0]) + ',' + (cy + hole * pt.px0[1]) +\n arc(pt.px0, pt.pxmid, false, hole) +\n arc(pt.pxmid, pt.px0, false, hole) +\n 'Z' + outerCircle);\n } else slicePath.attr('d', outerCircle);\n } else {\n var outerArc = arc(pt.px0, pt.px1, true, 1);\n\n if(hole) {\n var rim = 1 - hole;\n slicePath.attr('d',\n 'M' + (cx + hole * pt.px1[0]) + ',' + (cy + hole * pt.px1[1]) +\n arc(pt.px1, pt.px0, false, hole) +\n 'l' + (rim * pt.px0[0]) + ',' + (rim * pt.px0[1]) +\n outerArc +\n 'Z');\n } else {\n slicePath.attr('d',\n 'M' + cx + ',' + cy +\n 'l' + pt.px0[0] + ',' + pt.px0[1] +\n outerArc +\n 'Z');\n }\n }\n\n // add text\n formatSliceLabel(gd, pt, cd0);\n var textPosition = helpers.castOption(trace.textposition, pt.pts);\n var sliceTextGroup = sliceTop.selectAll('g.slicetext')\n .data(pt.text && (textPosition !== 'none') ? [0] : []);\n\n sliceTextGroup.enter().append('g')\n .classed('slicetext', true);\n sliceTextGroup.exit().remove();\n\n sliceTextGroup.each(function() {\n var sliceText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation until we can handle\n // tex and regular text together\n s.attr('data-notex', 1);\n });\n\n var font = Lib.ensureUniformFontSize(gd, textPosition === 'outside' ?\n determineOutsideTextFont(trace, pt, fullLayout.font) :\n determineInsideTextFont(trace, pt, fullLayout.font)\n );\n\n sliceText.text(pt.text)\n .attr({\n 'class': 'slicetext',\n transform: '',\n 'text-anchor': 'middle'\n })\n .call(Drawing.font, font)\n .call(svgTextUtils.convertToTspans, gd);\n\n // position the text relative to the slice\n var textBB = Drawing.bBox(sliceText.node());\n var transform;\n\n if(textPosition === 'outside') {\n transform = transformOutsideText(textBB, pt);\n } else {\n transform = transformInsideText(textBB, pt, cd0);\n if(textPosition === 'auto' && transform.scale < 1) {\n var newFont = Lib.ensureUniformFontSize(gd, trace.outsidetextfont);\n\n sliceText.call(Drawing.font, newFont);\n textBB = Drawing.bBox(sliceText.node());\n\n transform = transformOutsideText(textBB, pt);\n }\n }\n\n var textPosAngle = transform.textPosAngle;\n var textXY = textPosAngle === undefined ? pt.pxmid : getCoords(cd0.r, textPosAngle);\n transform.targetX = cx + textXY[0] * transform.rCenter + (transform.x || 0);\n transform.targetY = cy + textXY[1] * transform.rCenter + (transform.y || 0);\n computeTransform(transform, textBB);\n\n // save some stuff to use later ensure no labels overlap\n if(transform.outside) {\n var targetY = transform.targetY;\n pt.yLabelMin = targetY - textBB.height / 2;\n pt.yLabelMid = targetY;\n pt.yLabelMax = targetY + textBB.height / 2;\n pt.labelExtraX = 0;\n pt.labelExtraY = 0;\n hasOutsideText = true;\n }\n\n transform.fontSize = font.size;\n recordMinTextSize(trace.type, transform, fullLayout);\n cd[i].transform = transform;\n\n sliceText.attr('transform', Lib.getTextTransform(transform));\n });\n });\n\n // add the title\n var titleTextGroup = d3.select(this).selectAll('g.titletext')\n .data(trace.title.text ? [0] : []);\n\n titleTextGroup.enter().append('g')\n .classed('titletext', true);\n titleTextGroup.exit().remove();\n\n titleTextGroup.each(function() {\n var titleText = Lib.ensureSingle(d3.select(this), 'text', '', function(s) {\n // prohibit tex interpretation as above\n s.attr('data-notex', 1);\n });\n\n var txt = trace.title.text;\n if(trace._meta) {\n txt = Lib.templateString(txt, trace._meta);\n }\n\n titleText.text(txt)\n .attr({\n 'class': 'titletext',\n transform: '',\n 'text-anchor': 'middle',\n })\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n\n var transform;\n\n if(trace.title.position === 'middle center') {\n transform = positionTitleInside(cd0);\n } else {\n transform = positionTitleOutside(cd0, gs);\n }\n\n titleText.attr('transform',\n 'translate(' + transform.x + ',' + transform.y + ')' +\n (transform.scale < 1 ? ('scale(' + transform.scale + ')') : '') +\n 'translate(' + transform.tx + ',' + transform.ty + ')');\n });\n\n // now make sure no labels overlap (at least within one pie)\n if(hasOutsideText) scootLabels(quadrants, trace);\n\n plotTextLines(slices, trace);\n\n if(hasOutsideText && trace.automargin) {\n // TODO if we ever want to improve perf,\n // we could reuse the textBB computed above together\n // with the sliceText transform info\n var traceBbox = Drawing.bBox(plotGroup.node());\n\n var domain = trace.domain;\n var vpw = gs.w * (domain.x[1] - domain.x[0]);\n var vph = gs.h * (domain.y[1] - domain.y[0]);\n var xgap = (0.5 * vpw - cd0.r) / gs.w;\n var ygap = (0.5 * vph - cd0.r) / gs.h;\n\n Plots.autoMargin(gd, 'pie.' + trace.uid + '.automargin', {\n xl: domain.x[0] - xgap,\n xr: domain.x[1] + xgap,\n yb: domain.y[0] - ygap,\n yt: domain.y[1] + ygap,\n l: Math.max(cd0.cx - cd0.r - traceBbox.left, 0),\n r: Math.max(traceBbox.right - (cd0.cx + cd0.r), 0),\n b: Math.max(traceBbox.bottom - (cd0.cy + cd0.r), 0),\n t: Math.max(cd0.cy - cd0.r - traceBbox.top, 0),\n pad: 5\n });\n }\n });\n });\n\n // This is for a bug in Chrome (as of 2015-07-22, and does not affect FF)\n // if insidetextfont and outsidetextfont are different sizes, sometimes the size\n // of an \"em\" gets taken from the wrong element at first so lines are\n // spaced wrong. You just have to tell it to try again later and it gets fixed.\n // I have no idea why we haven't seen this in other contexts. Also, sometimes\n // it gets the initial draw correct but on redraw it gets confused.\n setTimeout(function() {\n plotGroups.selectAll('tspan').each(function() {\n var s = d3.select(this);\n if(s.attr('dy')) s.attr('dy', s.attr('dy'));\n });\n }, 0);\n}\n\n// TODO add support for transition\nfunction plotTextLines(slices, trace) {\n slices.each(function(pt) {\n var sliceTop = d3.select(this);\n\n if(!pt.labelExtraX && !pt.labelExtraY) {\n sliceTop.select('path.textline').remove();\n return;\n }\n\n // first move the text to its new location\n var sliceText = sliceTop.select('g.slicetext text');\n\n pt.transform.targetX += pt.labelExtraX;\n pt.transform.targetY += pt.labelExtraY;\n\n sliceText.attr('transform', Lib.getTextTransform(pt.transform));\n\n // then add a line to the new location\n var lineStartX = pt.cxFinal + pt.pxmid[0];\n var lineStartY = pt.cyFinal + pt.pxmid[1];\n var textLinePath = 'M' + lineStartX + ',' + lineStartY;\n var finalX = (pt.yLabelMax - pt.yLabelMin) * (pt.pxmid[0] < 0 ? -1 : 1) / 4;\n\n if(pt.labelExtraX) {\n var yFromX = pt.labelExtraX * pt.pxmid[1] / pt.pxmid[0];\n var yNet = pt.yLabelMid + pt.labelExtraY - (pt.cyFinal + pt.pxmid[1]);\n\n if(Math.abs(yFromX) > Math.abs(yNet)) {\n textLinePath +=\n 'l' + (yNet * pt.pxmid[0] / pt.pxmid[1]) + ',' + yNet +\n 'H' + (lineStartX + pt.labelExtraX + finalX);\n } else {\n textLinePath += 'l' + pt.labelExtraX + ',' + yFromX +\n 'v' + (yNet - yFromX) +\n 'h' + finalX;\n }\n } else {\n textLinePath +=\n 'V' + (pt.yLabelMid + pt.labelExtraY) +\n 'h' + finalX;\n }\n\n Lib.ensureSingle(sliceTop, 'path', 'textline')\n .call(Color.stroke, trace.outsidetextfont.color)\n .attr({\n 'stroke-width': Math.min(2, trace.outsidetextfont.size / 8),\n d: textLinePath,\n fill: 'none'\n });\n });\n}\n\nfunction attachFxHandlers(sliceTop, gd, cd) {\n var cd0 = cd[0];\n var trace = cd0.trace;\n var cx = cd0.cx;\n var cy = cd0.cy;\n\n // hover state vars\n // have we drawn a hover label, so it should be cleared later\n if(!('_hasHoverLabel' in trace)) trace._hasHoverLabel = false;\n // have we emitted a hover event, so later an unhover event should be emitted\n // note that click events do not depend on this - you can still get them\n // with hovermode: false or if you were earlier dragging, then clicked\n // in the same slice that you moused up in\n if(!('_hasHoverEvent' in trace)) trace._hasHoverEvent = false;\n\n sliceTop.on('mouseover', function(pt) {\n // in case fullLayout or fullData has changed without a replot\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n\n if(gd._dragging || fullLayout2.hovermode === false) return;\n\n var hoverinfo = trace2.hoverinfo;\n if(Array.isArray(hoverinfo)) {\n // super hacky: we need to pull out the *first* hoverinfo from\n // pt.pts, then put it back into an array in a dummy trace\n // and call castHoverinfo on that.\n // TODO: do we want to have Fx.castHoverinfo somehow handle this?\n // it already takes an array for index, for 2D, so this seems tricky.\n hoverinfo = Fx.castHoverinfo({\n hoverinfo: [helpers.castOption(hoverinfo, pt.pts)],\n _module: trace._module\n }, fullLayout2, 0);\n }\n\n if(hoverinfo === 'all') hoverinfo = 'label+text+value+percent+name';\n\n // in case we dragged over the pie from another subplot,\n // or if hover is turned off\n if(trace2.hovertemplate || (hoverinfo !== 'none' && hoverinfo !== 'skip' && hoverinfo)) {\n var rInscribed = pt.rInscribed || 0;\n var hoverCenterX = cx + pt.pxmid[0] * (1 - rInscribed);\n var hoverCenterY = cy + pt.pxmid[1] * (1 - rInscribed);\n var separators = fullLayout2.separators;\n var text = [];\n\n if(hoverinfo && hoverinfo.indexOf('label') !== -1) text.push(pt.label);\n pt.text = helpers.castOption(trace2.hovertext || trace2.text, pt.pts);\n if(hoverinfo && hoverinfo.indexOf('text') !== -1) {\n var tx = pt.text;\n if(Lib.isValidTextValue(tx)) text.push(tx);\n }\n pt.value = pt.v;\n pt.valueLabel = helpers.formatPieValue(pt.v, separators);\n if(hoverinfo && hoverinfo.indexOf('value') !== -1) text.push(pt.valueLabel);\n pt.percent = pt.v / cd0.vTotal;\n pt.percentLabel = helpers.formatPiePercent(pt.percent, separators);\n if(hoverinfo && hoverinfo.indexOf('percent') !== -1) text.push(pt.percentLabel);\n\n var hoverLabel = trace2.hoverlabel;\n var hoverFont = hoverLabel.font;\n\n Fx.loneHover({\n trace: trace,\n x0: hoverCenterX - rInscribed * cd0.r,\n x1: hoverCenterX + rInscribed * cd0.r,\n y: hoverCenterY,\n text: text.join('
'),\n name: (trace2.hovertemplate || hoverinfo.indexOf('name') !== -1) ? trace2.name : undefined,\n idealAlign: pt.pxmid[0] < 0 ? 'left' : 'right',\n color: helpers.castOption(hoverLabel.bgcolor, pt.pts) || pt.color,\n borderColor: helpers.castOption(hoverLabel.bordercolor, pt.pts),\n fontFamily: helpers.castOption(hoverFont.family, pt.pts),\n fontSize: helpers.castOption(hoverFont.size, pt.pts),\n fontColor: helpers.castOption(hoverFont.color, pt.pts),\n nameLength: helpers.castOption(hoverLabel.namelength, pt.pts),\n textAlign: helpers.castOption(hoverLabel.align, pt.pts),\n hovertemplate: helpers.castOption(trace2.hovertemplate, pt.pts),\n hovertemplateLabels: pt,\n eventData: [eventData(pt, trace2)]\n }, {\n container: fullLayout2._hoverlayer.node(),\n outerContainer: fullLayout2._paper.node(),\n gd: gd\n });\n\n trace._hasHoverLabel = true;\n }\n\n trace._hasHoverEvent = true;\n gd.emit('plotly_hover', {\n points: [eventData(pt, trace2)],\n event: d3.event\n });\n });\n\n sliceTop.on('mouseout', function(evt) {\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n var pt = d3.select(this).datum();\n\n if(trace._hasHoverEvent) {\n evt.originalEvent = d3.event;\n gd.emit('plotly_unhover', {\n points: [eventData(pt, trace2)],\n event: d3.event\n });\n trace._hasHoverEvent = false;\n }\n\n if(trace._hasHoverLabel) {\n Fx.loneUnhover(fullLayout2._hoverlayer.node());\n trace._hasHoverLabel = false;\n }\n });\n\n sliceTop.on('click', function(pt) {\n // TODO: this does not support right-click. If we want to support it, we\n // would likely need to change pie to use dragElement instead of straight\n // mapbox event binding. Or perhaps better, make a simple wrapper with the\n // right mousedown, mousemove, and mouseup handlers just for a left/right click\n // mapbox would use this too.\n var fullLayout2 = gd._fullLayout;\n var trace2 = gd._fullData[trace.index];\n\n if(gd._dragging || fullLayout2.hovermode === false) return;\n\n gd._hoverdata = [eventData(pt, trace2)];\n Fx.click(gd, d3.event);\n });\n}\n\nfunction determineOutsideTextFont(trace, pt, layoutFont) {\n var color =\n helpers.castOption(trace.outsidetextfont.color, pt.pts) ||\n helpers.castOption(trace.textfont.color, pt.pts) ||\n layoutFont.color;\n\n var family =\n helpers.castOption(trace.outsidetextfont.family, pt.pts) ||\n helpers.castOption(trace.textfont.family, pt.pts) ||\n layoutFont.family;\n\n var size =\n helpers.castOption(trace.outsidetextfont.size, pt.pts) ||\n helpers.castOption(trace.textfont.size, pt.pts) ||\n layoutFont.size;\n\n return {\n color: color,\n family: family,\n size: size\n };\n}\n\nfunction determineInsideTextFont(trace, pt, layoutFont) {\n var customColor = helpers.castOption(trace.insidetextfont.color, pt.pts);\n if(!customColor && trace._input.textfont) {\n // Why not simply using trace.textfont? Because if not set, it\n // defaults to layout.font which has a default color. But if\n // textfont.color and insidetextfont.color don't supply a value,\n // a contrasting color shall be used.\n customColor = helpers.castOption(trace._input.textfont.color, pt.pts);\n }\n\n var family =\n helpers.castOption(trace.insidetextfont.family, pt.pts) ||\n helpers.castOption(trace.textfont.family, pt.pts) ||\n layoutFont.family;\n\n var size =\n helpers.castOption(trace.insidetextfont.size, pt.pts) ||\n helpers.castOption(trace.textfont.size, pt.pts) ||\n layoutFont.size;\n\n return {\n color: customColor || Color.contrast(pt.color),\n family: family,\n size: size\n };\n}\n\nfunction prerenderTitles(cdModule, gd) {\n var cd0, trace;\n\n // Determine the width and height of the title for each pie.\n for(var i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n\n if(trace.title.text) {\n var txt = trace.title.text;\n if(trace._meta) {\n txt = Lib.templateString(txt, trace._meta);\n }\n\n var dummyTitle = Drawing.tester.append('text')\n .attr('data-notex', 1)\n .text(txt)\n .call(Drawing.font, trace.title.font)\n .call(svgTextUtils.convertToTspans, gd);\n var bBox = Drawing.bBox(dummyTitle.node(), true);\n cd0.titleBox = {\n width: bBox.width,\n height: bBox.height,\n };\n dummyTitle.remove();\n }\n }\n}\n\nfunction transformInsideText(textBB, pt, cd0) {\n var r = cd0.r || pt.rpx1;\n var rInscribed = pt.rInscribed;\n\n var isEmpty = pt.startangle === pt.stopangle;\n if(isEmpty) {\n return {\n rCenter: 1 - rInscribed,\n scale: 0,\n rotate: 0,\n textPosAngle: 0\n };\n }\n\n var ring = pt.ring;\n var isCircle = (ring === 1) && (Math.abs(pt.startangle - pt.stopangle) === Math.PI * 2);\n\n var halfAngle = pt.halfangle;\n var midAngle = pt.midangle;\n\n var orientation = cd0.trace.insidetextorientation;\n var isHorizontal = orientation === 'horizontal';\n var isTangential = orientation === 'tangential';\n var isRadial = orientation === 'radial';\n var isAuto = orientation === 'auto';\n\n var allTransforms = [];\n var newT;\n\n if(!isAuto) {\n // max size if text is placed (horizontally) at the top or bottom of the arc\n\n var considerCrossing = function(angle, key) {\n if(isCrossing(pt, angle)) {\n var dStart = Math.abs(angle - pt.startangle);\n var dStop = Math.abs(angle - pt.stopangle);\n\n var closestEdge = dStart < dStop ? dStart : dStop;\n\n if(key === 'tan') {\n newT = calcTanTransform(textBB, r, ring, closestEdge, 0);\n } else { // case of 'rad'\n newT = calcRadTransform(textBB, r, ring, closestEdge, Math.PI / 2);\n }\n newT.textPosAngle = angle;\n\n allTransforms.push(newT);\n }\n };\n\n // to cover all cases with trace.rotation added\n var i;\n if(isHorizontal || isTangential) {\n // top\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * i, 'tan');\n // bottom\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 1), 'tan');\n }\n if(isHorizontal || isRadial) {\n // left\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 1.5), 'rad');\n // right\n for(i = 4; i >= -4; i -= 2) considerCrossing(Math.PI * (i + 0.5), 'rad');\n }\n }\n\n if(isCircle || isAuto || isHorizontal) {\n // max size text can be inserted inside without rotating it\n // this inscribes the text rectangle in a circle, which is then inscribed\n // in the slice, so it will be an underestimate, which some day we may want\n // to improve so this case can get more use\n var textDiameter = Math.sqrt(textBB.width * textBB.width + textBB.height * textBB.height);\n\n newT = {\n scale: rInscribed * r * 2 / textDiameter,\n\n // and the center position and rotation in this case\n rCenter: 1 - rInscribed,\n rotate: 0\n };\n\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n if(newT.scale >= 1) return newT;\n\n allTransforms.push(newT);\n }\n\n if(isAuto || isRadial) {\n newT = calcRadTransform(textBB, r, ring, halfAngle, midAngle);\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n allTransforms.push(newT);\n }\n\n if(isAuto || isTangential) {\n newT = calcTanTransform(textBB, r, ring, halfAngle, midAngle);\n newT.textPosAngle = (pt.startangle + pt.stopangle) / 2;\n allTransforms.push(newT);\n }\n\n var id = 0;\n var maxScale = 0;\n for(var k = 0; k < allTransforms.length; k++) {\n var s = allTransforms[k].scale;\n if(maxScale < s) {\n maxScale = s;\n id = k;\n }\n\n if(!isAuto && maxScale >= 1) {\n // respect test order for non-auto options\n break;\n }\n }\n return allTransforms[id];\n}\n\nfunction isCrossing(pt, angle) {\n var start = pt.startangle;\n var stop = pt.stopangle;\n return (\n (start > angle && angle > stop) ||\n (start < angle && angle < stop)\n );\n}\n\nfunction calcRadTransform(textBB, r, ring, halfAngle, midAngle) {\n r = Math.max(0, r - 2 * TEXTPAD);\n\n // max size if text is rotated radially\n var a = textBB.width / textBB.height;\n var s = calcMaxHalfSize(a, halfAngle, r, ring);\n return {\n scale: s * 2 / textBB.height,\n rCenter: calcRCenter(a, s / r),\n rotate: calcRotate(midAngle)\n };\n}\n\nfunction calcTanTransform(textBB, r, ring, halfAngle, midAngle) {\n r = Math.max(0, r - 2 * TEXTPAD);\n\n // max size if text is rotated tangentially\n var a = textBB.height / textBB.width;\n var s = calcMaxHalfSize(a, halfAngle, r, ring);\n return {\n scale: s * 2 / textBB.width,\n rCenter: calcRCenter(a, s / r),\n rotate: calcRotate(midAngle + Math.PI / 2)\n };\n}\n\nfunction calcRCenter(a, b) {\n return Math.cos(b) - a * b;\n}\n\nfunction calcRotate(t) {\n return (180 / Math.PI * t + 720) % 180 - 90;\n}\n\nfunction calcMaxHalfSize(a, halfAngle, r, ring) {\n var q = a + 1 / (2 * Math.tan(halfAngle));\n return r * Math.min(\n 1 / (Math.sqrt(q * q + 0.5) + q),\n ring / (Math.sqrt(a * a + ring / 2) + a)\n );\n}\n\nfunction getInscribedRadiusFraction(pt, cd0) {\n if(pt.v === cd0.vTotal && !cd0.trace.hole) return 1;// special case of 100% with no hole\n\n return Math.min(1 / (1 + 1 / Math.sin(pt.halfangle)), pt.ring / 2);\n}\n\nfunction transformOutsideText(textBB, pt) {\n var x = pt.pxmid[0];\n var y = pt.pxmid[1];\n var dx = textBB.width / 2;\n var dy = textBB.height / 2;\n\n if(x < 0) dx *= -1;\n if(y < 0) dy *= -1;\n\n return {\n scale: 1,\n rCenter: 1,\n rotate: 0,\n x: dx + Math.abs(dy) * (dx > 0 ? 1 : -1) / 2,\n y: dy / (1 + x * x / (y * y)),\n outside: true\n };\n}\n\nfunction positionTitleInside(cd0) {\n var textDiameter =\n Math.sqrt(cd0.titleBox.width * cd0.titleBox.width + cd0.titleBox.height * cd0.titleBox.height);\n return {\n x: cd0.cx,\n y: cd0.cy,\n scale: cd0.trace.hole * cd0.r * 2 / textDiameter,\n tx: 0,\n ty: - cd0.titleBox.height / 2 + cd0.trace.title.font.size\n };\n}\n\nfunction positionTitleOutside(cd0, plotSize) {\n var scaleX = 1;\n var scaleY = 1;\n var maxPull;\n\n var trace = cd0.trace;\n // position of the baseline point of the text box in the plot, before scaling.\n // we anchored the text in the middle, so the baseline is on the bottom middle\n // of the first line of text.\n var topMiddle = {\n x: cd0.cx,\n y: cd0.cy\n };\n // relative translation of the text box after scaling\n var translate = {\n tx: 0,\n ty: 0\n };\n\n // we reason below as if the baseline is the top middle point of the text box.\n // so we must add the font size to approximate the y-coord. of the top.\n // note that this correction must happen after scaling.\n translate.ty += trace.title.font.size;\n maxPull = getMaxPull(trace);\n\n if(trace.title.position.indexOf('top') !== -1) {\n topMiddle.y -= (1 + maxPull) * cd0.r;\n translate.ty -= cd0.titleBox.height;\n } else if(trace.title.position.indexOf('bottom') !== -1) {\n topMiddle.y += (1 + maxPull) * cd0.r;\n }\n\n var rx = applyAspectRatio(cd0.r, cd0.trace.aspectratio);\n\n var maxWidth = plotSize.w * (trace.domain.x[1] - trace.domain.x[0]) / 2;\n if(trace.title.position.indexOf('left') !== -1) {\n // we start the text at the left edge of the pie\n maxWidth = maxWidth + rx;\n topMiddle.x -= (1 + maxPull) * rx;\n translate.tx += cd0.titleBox.width / 2;\n } else if(trace.title.position.indexOf('center') !== -1) {\n maxWidth *= 2;\n } else if(trace.title.position.indexOf('right') !== -1) {\n maxWidth = maxWidth + rx;\n topMiddle.x += (1 + maxPull) * rx;\n translate.tx -= cd0.titleBox.width / 2;\n }\n scaleX = maxWidth / cd0.titleBox.width;\n scaleY = getTitleSpace(cd0, plotSize) / cd0.titleBox.height;\n return {\n x: topMiddle.x,\n y: topMiddle.y,\n scale: Math.min(scaleX, scaleY),\n tx: translate.tx,\n ty: translate.ty\n };\n}\n\nfunction applyAspectRatio(x, aspectratio) {\n return x / ((aspectratio === undefined) ? 1 : aspectratio);\n}\n\nfunction getTitleSpace(cd0, plotSize) {\n var trace = cd0.trace;\n var pieBoxHeight = plotSize.h * (trace.domain.y[1] - trace.domain.y[0]);\n // use at most half of the plot for the title\n return Math.min(cd0.titleBox.height, pieBoxHeight / 2);\n}\n\nfunction getMaxPull(trace) {\n var maxPull = trace.pull;\n if(!maxPull) return 0;\n\n var j;\n if(Array.isArray(maxPull)) {\n maxPull = 0;\n for(j = 0; j < trace.pull.length; j++) {\n if(trace.pull[j] > maxPull) maxPull = trace.pull[j];\n }\n }\n return maxPull;\n}\n\nfunction scootLabels(quadrants, trace) {\n var xHalf, yHalf, equatorFirst, farthestX, farthestY,\n xDiffSign, yDiffSign, thisQuad, oppositeQuad,\n wholeSide, i, thisQuadOutside, firstOppositeOutsidePt;\n\n function topFirst(a, b) { return a.pxmid[1] - b.pxmid[1]; }\n function bottomFirst(a, b) { return b.pxmid[1] - a.pxmid[1]; }\n\n function scootOneLabel(thisPt, prevPt) {\n if(!prevPt) prevPt = {};\n\n var prevOuterY = prevPt.labelExtraY + (yHalf ? prevPt.yLabelMax : prevPt.yLabelMin);\n var thisInnerY = yHalf ? thisPt.yLabelMin : thisPt.yLabelMax;\n var thisOuterY = yHalf ? thisPt.yLabelMax : thisPt.yLabelMin;\n var thisSliceOuterY = thisPt.cyFinal + farthestY(thisPt.px0[1], thisPt.px1[1]);\n var newExtraY = prevOuterY - thisInnerY;\n\n var xBuffer, i, otherPt, otherOuterY, otherOuterX, newExtraX;\n\n // make sure this label doesn't overlap other labels\n // this *only* has us move these labels vertically\n if(newExtraY * yDiffSign > 0) thisPt.labelExtraY = newExtraY;\n\n // make sure this label doesn't overlap any slices\n if(!Array.isArray(trace.pull)) return; // this can only happen with array pulls\n\n for(i = 0; i < wholeSide.length; i++) {\n otherPt = wholeSide[i];\n\n // overlap can only happen if the other point is pulled more than this one\n if(otherPt === thisPt || (\n (helpers.castOption(trace.pull, thisPt.pts) || 0) >=\n (helpers.castOption(trace.pull, otherPt.pts) || 0))\n ) {\n continue;\n }\n\n if((thisPt.pxmid[1] - otherPt.pxmid[1]) * yDiffSign > 0) {\n // closer to the equator - by construction all of these happen first\n // move the text vertically to get away from these slices\n otherOuterY = otherPt.cyFinal + farthestY(otherPt.px0[1], otherPt.px1[1]);\n newExtraY = otherOuterY - thisInnerY - thisPt.labelExtraY;\n\n if(newExtraY * yDiffSign > 0) thisPt.labelExtraY += newExtraY;\n } else if((thisOuterY + thisPt.labelExtraY - thisSliceOuterY) * yDiffSign > 0) {\n // farther from the equator - happens after we've done all the\n // vertical moving we're going to do\n // move horizontally to get away from these more polar slices\n\n // if we're moving horz. based on a slice that's several slices away from this one\n // then we need some extra space for the lines to labels between them\n xBuffer = 3 * xDiffSign * Math.abs(i - wholeSide.indexOf(thisPt));\n\n otherOuterX = otherPt.cxFinal + farthestX(otherPt.px0[0], otherPt.px1[0]);\n newExtraX = otherOuterX + xBuffer - (thisPt.cxFinal + thisPt.pxmid[0]) - thisPt.labelExtraX;\n\n if(newExtraX * xDiffSign > 0) thisPt.labelExtraX += newExtraX;\n }\n }\n }\n\n for(yHalf = 0; yHalf < 2; yHalf++) {\n equatorFirst = yHalf ? topFirst : bottomFirst;\n farthestY = yHalf ? Math.max : Math.min;\n yDiffSign = yHalf ? 1 : -1;\n\n for(xHalf = 0; xHalf < 2; xHalf++) {\n farthestX = xHalf ? Math.max : Math.min;\n xDiffSign = xHalf ? 1 : -1;\n\n // first sort the array\n // note this is a copy of cd, so cd itself doesn't get sorted\n // but we can still modify points in place.\n thisQuad = quadrants[yHalf][xHalf];\n thisQuad.sort(equatorFirst);\n\n oppositeQuad = quadrants[1 - yHalf][xHalf];\n wholeSide = oppositeQuad.concat(thisQuad);\n\n thisQuadOutside = [];\n for(i = 0; i < thisQuad.length; i++) {\n if(thisQuad[i].yLabelMid !== undefined) thisQuadOutside.push(thisQuad[i]);\n }\n\n firstOppositeOutsidePt = false;\n for(i = 0; yHalf && i < oppositeQuad.length; i++) {\n if(oppositeQuad[i].yLabelMid !== undefined) {\n firstOppositeOutsidePt = oppositeQuad[i];\n break;\n }\n }\n\n // each needs to avoid the previous\n for(i = 0; i < thisQuadOutside.length; i++) {\n var prevPt = i && thisQuadOutside[i - 1];\n // bottom half needs to avoid the first label of the top half\n // top half we still need to call scootOneLabel on the first slice\n // so we can avoid other slices, but we don't pass a prevPt\n if(firstOppositeOutsidePt && !i) prevPt = firstOppositeOutsidePt;\n scootOneLabel(thisQuadOutside[i], prevPt);\n }\n }\n }\n}\n\nfunction layoutAreas(cdModule, plotSize) {\n var scaleGroups = [];\n\n // figure out the center and maximum radius\n for(var i = 0; i < cdModule.length; i++) {\n var cd0 = cdModule[i][0];\n var trace = cd0.trace;\n\n var domain = trace.domain;\n var width = plotSize.w * (domain.x[1] - domain.x[0]);\n var height = plotSize.h * (domain.y[1] - domain.y[0]);\n // leave some space for the title, if it will be displayed outside\n if(trace.title.text && trace.title.position !== 'middle center') {\n height -= getTitleSpace(cd0, plotSize);\n }\n\n var rx = width / 2;\n var ry = height / 2;\n if(trace.type === 'funnelarea' && !trace.scalegroup) {\n ry /= trace.aspectratio;\n }\n\n cd0.r = Math.min(rx, ry) / (1 + getMaxPull(trace));\n\n cd0.cx = plotSize.l + plotSize.w * (trace.domain.x[1] + trace.domain.x[0]) / 2;\n cd0.cy = plotSize.t + plotSize.h * (1 - trace.domain.y[0]) - height / 2;\n if(trace.title.text && trace.title.position.indexOf('bottom') !== -1) {\n cd0.cy -= getTitleSpace(cd0, plotSize);\n }\n\n if(trace.scalegroup && scaleGroups.indexOf(trace.scalegroup) === -1) {\n scaleGroups.push(trace.scalegroup);\n }\n }\n\n groupScale(cdModule, scaleGroups);\n}\n\nfunction groupScale(cdModule, scaleGroups) {\n var cd0, i, trace;\n\n // scale those that are grouped\n for(var k = 0; k < scaleGroups.length; k++) {\n var min = Infinity;\n var g = scaleGroups[k];\n\n for(i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n\n if(trace.scalegroup === g) {\n var area;\n if(trace.type === 'pie') {\n area = cd0.r * cd0.r;\n } else if(trace.type === 'funnelarea') {\n var rx, ry;\n\n if(trace.aspectratio > 1) {\n rx = cd0.r;\n ry = rx / trace.aspectratio;\n } else {\n ry = cd0.r;\n rx = ry * trace.aspectratio;\n }\n\n rx *= (1 + trace.baseratio) / 2;\n\n area = rx * ry;\n }\n\n min = Math.min(min, area / cd0.vTotal);\n }\n }\n\n for(i = 0; i < cdModule.length; i++) {\n cd0 = cdModule[i][0];\n trace = cd0.trace;\n if(trace.scalegroup === g) {\n var v = min * cd0.vTotal;\n if(trace.type === 'funnelarea') {\n v /= (1 + trace.baseratio) / 2;\n v /= trace.aspectratio;\n }\n\n cd0.r = Math.sqrt(v);\n }\n }\n }\n}\n\nfunction setCoords(cd) {\n var cd0 = cd[0];\n var r = cd0.r;\n var trace = cd0.trace;\n var currentAngle = trace.rotation * Math.PI / 180;\n var angleFactor = 2 * Math.PI / cd0.vTotal;\n var firstPt = 'px0';\n var lastPt = 'px1';\n\n var i, cdi, currentCoords;\n\n if(trace.direction === 'counterclockwise') {\n for(i = 0; i < cd.length; i++) {\n if(!cd[i].hidden) break; // find the first non-hidden slice\n }\n if(i === cd.length) return; // all slices hidden\n\n currentAngle += angleFactor * cd[i].v;\n angleFactor *= -1;\n firstPt = 'px1';\n lastPt = 'px0';\n }\n\n currentCoords = getCoords(r, currentAngle);\n\n for(i = 0; i < cd.length; i++) {\n cdi = cd[i];\n if(cdi.hidden) continue;\n\n cdi[firstPt] = currentCoords;\n\n cdi.startangle = currentAngle;\n currentAngle += angleFactor * cdi.v / 2;\n cdi.pxmid = getCoords(r, currentAngle);\n cdi.midangle = currentAngle;\n currentAngle += angleFactor * cdi.v / 2;\n currentCoords = getCoords(r, currentAngle);\n cdi.stopangle = currentAngle;\n\n cdi[lastPt] = currentCoords;\n\n cdi.largeArc = (cdi.v > cd0.vTotal / 2) ? 1 : 0;\n\n cdi.halfangle = Math.PI * Math.min(cdi.v / cd0.vTotal, 0.5);\n cdi.ring = 1 - trace.hole;\n cdi.rInscribed = getInscribedRadiusFraction(cdi, cd0);\n }\n}\n\nfunction getCoords(r, angle) {\n return [r * Math.sin(angle), -r * Math.cos(angle)];\n}\n\nfunction formatSliceLabel(gd, pt, cd0) {\n var fullLayout = gd._fullLayout;\n var trace = cd0.trace;\n // look for textemplate\n var texttemplate = trace.texttemplate;\n\n // now insert text\n var textinfo = trace.textinfo;\n if(!texttemplate && textinfo && textinfo !== 'none') {\n var parts = textinfo.split('+');\n var hasFlag = function(flag) { return parts.indexOf(flag) !== -1; };\n var hasLabel = hasFlag('label');\n var hasText = hasFlag('text');\n var hasValue = hasFlag('value');\n var hasPercent = hasFlag('percent');\n\n var separators = fullLayout.separators;\n var text;\n\n text = hasLabel ? [pt.label] : [];\n if(hasText) {\n var tx = helpers.getFirstFilled(trace.text, pt.pts);\n if(isValidTextValue(tx)) text.push(tx);\n }\n if(hasValue) text.push(helpers.formatPieValue(pt.v, separators));\n if(hasPercent) text.push(helpers.formatPiePercent(pt.v / cd0.vTotal, separators));\n pt.text = text.join('
');\n }\n\n function makeTemplateVariables(pt) {\n return {\n label: pt.label,\n value: pt.v,\n valueLabel: helpers.formatPieValue(pt.v, fullLayout.separators),\n percent: pt.v / cd0.vTotal,\n percentLabel: helpers.formatPiePercent(pt.v / cd0.vTotal, fullLayout.separators),\n color: pt.color,\n text: pt.text,\n customdata: Lib.castOption(trace, pt.i, 'customdata')\n };\n }\n\n if(texttemplate) {\n var txt = Lib.castOption(trace, pt.i, 'texttemplate');\n if(!txt) {\n pt.text = '';\n } else {\n var obj = makeTemplateVariables(pt);\n var ptTx = helpers.getFirstFilled(trace.text, pt.pts);\n if(isValidTextValue(ptTx) || ptTx === '') obj.text = ptTx;\n pt.text = Lib.texttemplateString(txt, obj, gd._fullLayout._d3locale, obj, trace._meta || {});\n }\n }\n}\n\nfunction computeTransform(\n transform, // inout\n textBB // in\n) {\n var a = transform.rotate * Math.PI / 180;\n var cosA = Math.cos(a);\n var sinA = Math.sin(a);\n var midX = (textBB.left + textBB.right) / 2;\n var midY = (textBB.top + textBB.bottom) / 2;\n transform.textX = midX * cosA - midY * sinA;\n transform.textY = midX * sinA + midY * cosA;\n transform.noCenter = true;\n}\n\nmodule.exports = {\n plot: plot,\n formatSliceLabel: formatSliceLabel,\n transformInsideText: transformInsideText,\n determineInsideTextFont: determineInsideTextFont,\n positionTitleOutside: positionTitleOutside,\n prerenderTitles: prerenderTitles,\n layoutAreas: layoutAreas,\n attachFxHandlers: attachFxHandlers,\n computeTransform: computeTransform\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\nvar layoutAttributes = require('./layout_attributes');\n\nmodule.exports = function supplyLayoutGlobalDefaults(layoutIn, layoutOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n handleHoverLabelDefaults(layoutIn, layoutOut, coerce);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\n\nvar Axes = require('../../plots/cartesian/axes');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar subTypes = require('./subtypes');\nvar calcColorscale = require('./colorscale_calc');\nvar arraysToCalcdata = require('./arrays_to_calcdata');\nvar calcSelection = require('./calc_selection');\n\nfunction calc(gd, trace) {\n var fullLayout = gd._fullLayout;\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var x = xa.makeCalcdata(trace, 'x');\n var y = ya.makeCalcdata(trace, 'y');\n var serieslen = trace._length;\n var cd = new Array(serieslen);\n var ids = trace.ids;\n var stackGroupOpts = getStackOpts(trace, fullLayout, xa, ya);\n var interpolateGaps = false;\n var isV, i, j, k, interpolate, vali;\n\n setFirstScatter(fullLayout, trace);\n\n var xAttr = 'x';\n var yAttr = 'y';\n var posAttr;\n if(stackGroupOpts) {\n Lib.pushUnique(stackGroupOpts.traceIndices, trace._expandedIndex);\n isV = stackGroupOpts.orientation === 'v';\n\n // size, like we use for bar\n if(isV) {\n yAttr = 's';\n posAttr = 'x';\n } else {\n xAttr = 's';\n posAttr = 'y';\n }\n interpolate = stackGroupOpts.stackgaps === 'interpolate';\n } else {\n var ppad = calcMarkerSize(trace, serieslen);\n calcAxisExpansion(gd, trace, xa, ya, x, y, ppad);\n }\n\n for(i = 0; i < serieslen; i++) {\n var cdi = cd[i] = {};\n var xValid = isNumeric(x[i]);\n var yValid = isNumeric(y[i]);\n if(xValid && yValid) {\n cdi[xAttr] = x[i];\n cdi[yAttr] = y[i];\n } else if(stackGroupOpts && (isV ? xValid : yValid)) {\n // if we're stacking we need to hold on to all valid positions\n // even with invalid sizes\n\n cdi[posAttr] = isV ? x[i] : y[i];\n cdi.gap = true;\n if(interpolate) {\n cdi.s = BADNUM;\n interpolateGaps = true;\n } else {\n cdi.s = 0;\n }\n } else {\n cdi[xAttr] = cdi[yAttr] = BADNUM;\n }\n\n if(ids) {\n cdi.id = String(ids[i]);\n }\n }\n\n arraysToCalcdata(cd, trace);\n calcColorscale(gd, trace);\n calcSelection(cd, trace);\n\n if(stackGroupOpts) {\n // remove bad positions and sort\n // note that original indices get added to cd in arraysToCalcdata\n i = 0;\n while(i < cd.length) {\n if(cd[i][posAttr] === BADNUM) {\n cd.splice(i, 1);\n } else i++;\n }\n\n Lib.sort(cd, function(a, b) {\n return (a[posAttr] - b[posAttr]) || (a.i - b.i);\n });\n\n if(interpolateGaps) {\n // first fill the beginning with constant from the first point\n i = 0;\n while(i < cd.length - 1 && cd[i].gap) {\n i++;\n }\n vali = cd[i].s;\n if(!vali) vali = cd[i].s = 0; // in case of no data AT ALL in this trace - use 0\n for(j = 0; j < i; j++) {\n cd[j].s = vali;\n }\n // then fill the end with constant from the last point\n k = cd.length - 1;\n while(k > i && cd[k].gap) {\n k--;\n }\n vali = cd[k].s;\n for(j = cd.length - 1; j > k; j--) {\n cd[j].s = vali;\n }\n // now interpolate internal gaps linearly\n while(i < k) {\n i++;\n if(cd[i].gap) {\n j = i + 1;\n while(cd[j].gap) {\n j++;\n }\n var pos0 = cd[i - 1][posAttr];\n var size0 = cd[i - 1].s;\n var m = (cd[j].s - size0) / (cd[j][posAttr] - pos0);\n while(i < j) {\n cd[i].s = size0 + (cd[i][posAttr] - pos0) * m;\n i++;\n }\n }\n }\n }\n }\n\n return cd;\n}\n\nfunction calcAxisExpansion(gd, trace, xa, ya, x, y, ppad) {\n var serieslen = trace._length;\n var fullLayout = gd._fullLayout;\n var xId = xa._id;\n var yId = ya._id;\n var firstScatter = fullLayout._firstScatter[firstScatterGroup(trace)] === trace.uid;\n var stackOrientation = (getStackOpts(trace, fullLayout, xa, ya) || {}).orientation;\n var fill = trace.fill;\n\n // cancel minimum tick spacings (only applies to bars and boxes)\n xa._minDtick = 0;\n ya._minDtick = 0;\n\n // check whether bounds should be tight, padded, extended to zero...\n // most cases both should be padded on both ends, so start with that.\n var xOptions = {padded: true};\n var yOptions = {padded: true};\n\n if(ppad) {\n xOptions.ppad = yOptions.ppad = ppad;\n }\n\n // TODO: text size\n\n var openEnded = serieslen < 2 || (x[0] !== x[serieslen - 1]) || (y[0] !== y[serieslen - 1]);\n\n if(openEnded && (\n (fill === 'tozerox') ||\n ((fill === 'tonextx') && (firstScatter || stackOrientation === 'h'))\n )) {\n // include zero (tight) and extremes (padded) if fill to zero\n // (unless the shape is closed, then it's just filling the shape regardless)\n\n xOptions.tozero = true;\n } else if(!(trace.error_y || {}).visible && (\n // if no error bars, markers or text, or fill to y=0 remove x padding\n\n (fill === 'tonexty' || fill === 'tozeroy') ||\n (!subTypes.hasMarkers(trace) && !subTypes.hasText(trace))\n )) {\n xOptions.padded = false;\n xOptions.ppad = 0;\n }\n\n if(openEnded && (\n (fill === 'tozeroy') ||\n ((fill === 'tonexty') && (firstScatter || stackOrientation === 'v'))\n )) {\n // now check for y - rather different logic, though still mostly padded both ends\n // include zero (tight) and extremes (padded) if fill to zero\n // (unless the shape is closed, then it's just filling the shape regardless)\n\n yOptions.tozero = true;\n } else if(fill === 'tonextx' || fill === 'tozerox') {\n // tight y: any x fill\n\n yOptions.padded = false;\n }\n\n // N.B. asymmetric splom traces call this with blank {} xa or ya\n if(xId) trace._extremes[xId] = Axes.findExtremes(xa, x, xOptions);\n if(yId) trace._extremes[yId] = Axes.findExtremes(ya, y, yOptions);\n}\n\nfunction calcMarkerSize(trace, serieslen) {\n if(!subTypes.hasMarkers(trace)) return;\n\n // Treat size like x or y arrays --- Run d2c\n // this needs to go before ppad computation\n var marker = trace.marker;\n var sizeref = 1.6 * (trace.marker.sizeref || 1);\n var markerTrans;\n\n if(trace.marker.sizemode === 'area') {\n markerTrans = function(v) {\n return Math.max(Math.sqrt((v || 0) / sizeref), 3);\n };\n } else {\n markerTrans = function(v) {\n return Math.max((v || 0) / sizeref, 3);\n };\n }\n\n if(Lib.isArrayOrTypedArray(marker.size)) {\n // I tried auto-type but category and dates dont make much sense.\n var ax = {type: 'linear'};\n Axes.setConvert(ax);\n\n var s = ax.makeCalcdata(trace.marker, 'size');\n\n var sizeOut = new Array(serieslen);\n for(var i = 0; i < serieslen; i++) {\n sizeOut[i] = markerTrans(s[i]);\n }\n return sizeOut;\n } else {\n return markerTrans(marker.size);\n }\n}\n\n/**\n * mark the first scatter trace for each subplot\n * note that scatter and scattergl each get their own first trace\n * note also that I'm doing this during calc rather than supplyDefaults\n * so I don't need to worry about transforms, but if we ever do\n * per-trace calc this will get confused.\n */\nfunction setFirstScatter(fullLayout, trace) {\n var group = firstScatterGroup(trace);\n var firstScatter = fullLayout._firstScatter;\n if(!firstScatter[group]) firstScatter[group] = trace.uid;\n}\n\nfunction firstScatterGroup(trace) {\n var stackGroup = trace.stackgroup;\n return trace.xaxis + trace.yaxis + trace.type +\n (stackGroup ? '-' + stackGroup : '');\n}\n\nfunction getStackOpts(trace, fullLayout, xa, ya) {\n var stackGroup = trace.stackgroup;\n if(!stackGroup) return;\n var stackOpts = fullLayout._scatterStackOpts[xa._id + ya._id][stackGroup];\n var stackAx = stackOpts.orientation === 'v' ? ya : xa;\n // Allow stacking only on numeric axes\n // calc is a little late to be figuring this out, but during supplyDefaults\n // we don't know the axis type yet\n if(stackAx.type === 'linear' || stackAx.type === 'log') return stackOpts;\n}\n\nmodule.exports = {\n calc: calc,\n calcMarkerSize: calcMarkerSize,\n calcAxisExpansion: calcAxisExpansion,\n setFirstScatter: setFirstScatter,\n getStackOpts: getStackOpts\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nvar Registry = require('../../registry');\nvar Axes = require('../../plots/cartesian/axes');\nvar getAxisGroup = require('../../plots/cartesian/axis_ids').getAxisGroup;\nvar Sieve = require('./sieve.js');\n\n/*\n * Bar chart stacking/grouping positioning and autoscaling calculations\n * for each direction separately calculate the ranges and positions\n * note that this handles histograms too\n * now doing this one subplot at a time\n */\n\nfunction crossTraceCalc(gd, plotinfo) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var fullLayout = gd._fullLayout;\n var fullTraces = gd._fullData;\n var calcTraces = gd.calcdata;\n var calcTracesHorz = [];\n var calcTracesVert = [];\n\n for(var i = 0; i < fullTraces.length; i++) {\n var fullTrace = fullTraces[i];\n if(\n fullTrace.visible === true &&\n Registry.traceIs(fullTrace, 'bar') &&\n fullTrace.xaxis === xa._id &&\n fullTrace.yaxis === ya._id\n ) {\n if(fullTrace.orientation === 'h') {\n calcTracesHorz.push(calcTraces[i]);\n } else {\n calcTracesVert.push(calcTraces[i]);\n }\n\n if(fullTrace._computePh) {\n var cd = gd.calcdata[i];\n for(var j = 0; j < cd.length; j++) {\n if(typeof cd[j].ph0 === 'function') cd[j].ph0 = cd[j].ph0();\n if(typeof cd[j].ph1 === 'function') cd[j].ph1 = cd[j].ph1();\n }\n }\n }\n }\n\n var opts = {\n mode: fullLayout.barmode,\n norm: fullLayout.barnorm,\n gap: fullLayout.bargap,\n groupgap: fullLayout.bargroupgap\n };\n\n setGroupPositions(gd, xa, ya, calcTracesVert, opts);\n setGroupPositions(gd, ya, xa, calcTracesHorz, opts);\n}\n\nfunction setGroupPositions(gd, pa, sa, calcTraces, opts) {\n if(!calcTraces.length) return;\n\n var excluded;\n var included;\n var i, calcTrace, fullTrace;\n\n initBase(sa, calcTraces);\n\n switch(opts.mode) {\n case 'overlay':\n setGroupPositionsInOverlayMode(pa, sa, calcTraces, opts);\n break;\n\n case 'group':\n // exclude from the group those traces for which the user set an offset\n excluded = [];\n included = [];\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.offset === undefined) included.push(calcTrace);\n else excluded.push(calcTrace);\n }\n\n if(included.length) {\n setGroupPositionsInGroupMode(gd, pa, sa, included, opts);\n }\n if(excluded.length) {\n setGroupPositionsInOverlayMode(pa, sa, excluded, opts);\n }\n break;\n\n case 'stack':\n case 'relative':\n // exclude from the stack those traces for which the user set a base\n excluded = [];\n included = [];\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.base === undefined) included.push(calcTrace);\n else excluded.push(calcTrace);\n }\n\n if(included.length) {\n setGroupPositionsInStackOrRelativeMode(gd, pa, sa, included, opts);\n }\n if(excluded.length) {\n setGroupPositionsInOverlayMode(pa, sa, excluded, opts);\n }\n break;\n }\n\n collectExtents(calcTraces, pa);\n}\n\nfunction initBase(sa, calcTraces) {\n var i, j;\n\n for(i = 0; i < calcTraces.length; i++) {\n var cd = calcTraces[i];\n var trace = cd[0].trace;\n var base = (trace.type === 'funnel') ? trace._base : trace.base;\n var b;\n\n // not sure if it really makes sense to have dates for bar size data...\n // ideally if we want to make gantt charts or something we'd treat\n // the actual size (trace.x or y) as time delta but base as absolute\n // time. But included here for completeness.\n var scalendar = trace.orientation === 'h' ? trace.xcalendar : trace.ycalendar;\n\n // 'base' on categorical axes makes no sense\n var d2c = sa.type === 'category' || sa.type === 'multicategory' ?\n function() { return null; } :\n sa.d2c;\n\n if(isArrayOrTypedArray(base)) {\n for(j = 0; j < Math.min(base.length, cd.length); j++) {\n b = d2c(base[j], 0, scalendar);\n if(isNumeric(b)) {\n cd[j].b = +b;\n cd[j].hasB = 1;\n } else cd[j].b = 0;\n }\n for(; j < cd.length; j++) {\n cd[j].b = 0;\n }\n } else {\n b = d2c(base, 0, scalendar);\n var hasBase = isNumeric(b);\n b = hasBase ? b : 0;\n for(j = 0; j < cd.length; j++) {\n cd[j].b = b;\n if(hasBase) cd[j].hasB = 1;\n }\n }\n }\n}\n\nfunction setGroupPositionsInOverlayMode(pa, sa, calcTraces, opts) {\n // update position axis and set bar offsets and widths\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n var sieve = new Sieve([calcTrace], {\n sepNegVal: false,\n overlapNoMerge: !opts.norm\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidth(pa, sieve, opts);\n\n // set bar bases and sizes, and update size axis\n //\n // (note that `setGroupPositionsInOverlayMode` handles the case barnorm\n // is defined, because this function is also invoked for traces that\n // can't be grouped or stacked)\n if(opts.norm) {\n sieveBars(sieve);\n normalizeBars(sa, sieve, opts);\n } else {\n setBaseAndTop(sa, sieve);\n }\n }\n}\n\nfunction setGroupPositionsInGroupMode(gd, pa, sa, calcTraces, opts) {\n var sieve = new Sieve(calcTraces, {\n sepNegVal: false,\n overlapNoMerge: !opts.norm\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidthInGroupMode(gd, pa, sieve, opts);\n\n // relative-stack bars within the same trace that would otherwise\n // be hidden\n unhideBarsWithinTrace(sieve);\n\n // set bar bases and sizes, and update size axis\n if(opts.norm) {\n sieveBars(sieve);\n normalizeBars(sa, sieve, opts);\n } else {\n setBaseAndTop(sa, sieve);\n }\n}\n\nfunction setGroupPositionsInStackOrRelativeMode(gd, pa, sa, calcTraces, opts) {\n var sieve = new Sieve(calcTraces, {\n sepNegVal: opts.mode === 'relative',\n overlapNoMerge: !(opts.norm || opts.mode === 'stack' || opts.mode === 'relative')\n });\n\n // set bar offsets and widths, and update position axis\n setOffsetAndWidth(pa, sieve, opts);\n\n // set bar bases and sizes, and update size axis\n stackBars(sa, sieve, opts);\n\n // flag the outmost bar (for text display purposes)\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n var isOutmostBar = ((bar.b + bar.s) === sieve.get(bar.p, bar.s));\n if(isOutmostBar) bar._outmost = true;\n }\n }\n }\n\n // Note that marking the outmost bars has to be done\n // before `normalizeBars` changes `bar.b` and `bar.s`.\n if(opts.norm) normalizeBars(sa, sieve, opts);\n}\n\nfunction setOffsetAndWidth(pa, sieve, opts) {\n var minDiff = sieve.minDiff;\n var calcTraces = sieve.traces;\n\n // set bar offsets and widths\n var barGroupWidth = minDiff * (1 - opts.gap);\n var barWidthPlusGap = barGroupWidth;\n var barWidth = barWidthPlusGap * (1 - (opts.groupgap || 0));\n\n // computer bar group center and bar offset\n var offsetFromCenter = -barWidth / 2;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var t = calcTrace[0].t;\n\n // store bar width and offset for this trace\n t.barwidth = barWidth;\n t.poffset = offsetFromCenter;\n t.bargroupwidth = barGroupWidth;\n t.bardelta = minDiff;\n }\n\n // stack bars that only differ by rounding\n sieve.binWidth = calcTraces[0][0].t.barwidth / 100;\n\n // if defined, apply trace offset and width\n applyAttributes(sieve);\n\n // store the bar center in each calcdata item\n setBarCenterAndWidth(pa, sieve);\n\n // update position axes\n updatePositionAxis(pa, sieve);\n}\n\nfunction setOffsetAndWidthInGroupMode(gd, pa, sieve, opts) {\n var fullLayout = gd._fullLayout;\n var positions = sieve.positions;\n var distinctPositions = sieve.distinctPositions;\n var minDiff = sieve.minDiff;\n var calcTraces = sieve.traces;\n var nTraces = calcTraces.length;\n\n // if there aren't any overlapping positions,\n // let them have full width even if mode is group\n var overlap = (positions.length !== distinctPositions.length);\n var barGroupWidth = minDiff * (1 - opts.gap);\n\n var groupId = getAxisGroup(fullLayout, pa._id) + calcTraces[0][0].trace.orientation;\n var alignmentGroups = fullLayout._alignmentOpts[groupId] || {};\n\n for(var i = 0; i < nTraces; i++) {\n var calcTrace = calcTraces[i];\n var trace = calcTrace[0].trace;\n\n var alignmentGroupOpts = alignmentGroups[trace.alignmentgroup] || {};\n var nOffsetGroups = Object.keys(alignmentGroupOpts.offsetGroups || {}).length;\n\n var barWidthPlusGap;\n if(nOffsetGroups) {\n barWidthPlusGap = barGroupWidth / nOffsetGroups;\n } else {\n barWidthPlusGap = overlap ? barGroupWidth / nTraces : barGroupWidth;\n }\n\n var barWidth = barWidthPlusGap * (1 - (opts.groupgap || 0));\n\n var offsetFromCenter;\n if(nOffsetGroups) {\n offsetFromCenter = ((2 * trace._offsetIndex + 1 - nOffsetGroups) * barWidthPlusGap - barWidth) / 2;\n } else {\n offsetFromCenter = overlap ?\n ((2 * i + 1 - nTraces) * barWidthPlusGap - barWidth) / 2 :\n -barWidth / 2;\n }\n\n var t = calcTrace[0].t;\n t.barwidth = barWidth;\n t.poffset = offsetFromCenter;\n t.bargroupwidth = barGroupWidth;\n t.bardelta = minDiff;\n }\n\n // stack bars that only differ by rounding\n sieve.binWidth = calcTraces[0][0].t.barwidth / 100;\n\n // if defined, apply trace width\n applyAttributes(sieve);\n\n // store the bar center in each calcdata item\n setBarCenterAndWidth(pa, sieve);\n\n // update position axes\n updatePositionAxis(pa, sieve, overlap);\n}\n\nfunction applyAttributes(sieve) {\n var calcTraces = sieve.traces;\n var i, j;\n\n for(i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var calcTrace0 = calcTrace[0];\n var fullTrace = calcTrace0.trace;\n var t = calcTrace0.t;\n var offset = fullTrace._offset || fullTrace.offset;\n var initialPoffset = t.poffset;\n var newPoffset;\n\n if(isArrayOrTypedArray(offset)) {\n // if offset is an array, then clone it into t.poffset.\n newPoffset = Array.prototype.slice.call(offset, 0, calcTrace.length);\n\n // guard against non-numeric items\n for(j = 0; j < newPoffset.length; j++) {\n if(!isNumeric(newPoffset[j])) {\n newPoffset[j] = initialPoffset;\n }\n }\n\n // if the length of the array is too short,\n // then extend it with the initial value of t.poffset\n for(j = newPoffset.length; j < calcTrace.length; j++) {\n newPoffset.push(initialPoffset);\n }\n\n t.poffset = newPoffset;\n } else if(offset !== undefined) {\n t.poffset = offset;\n }\n\n var width = fullTrace._width || fullTrace.width;\n var initialBarwidth = t.barwidth;\n\n if(isArrayOrTypedArray(width)) {\n // if width is an array, then clone it into t.barwidth.\n var newBarwidth = Array.prototype.slice.call(width, 0, calcTrace.length);\n\n // guard against non-numeric items\n for(j = 0; j < newBarwidth.length; j++) {\n if(!isNumeric(newBarwidth[j])) newBarwidth[j] = initialBarwidth;\n }\n\n // if the length of the array is too short,\n // then extend it with the initial value of t.barwidth\n for(j = newBarwidth.length; j < calcTrace.length; j++) {\n newBarwidth.push(initialBarwidth);\n }\n\n t.barwidth = newBarwidth;\n\n // if user didn't set offset,\n // then correct t.poffset to ensure bars remain centered\n if(offset === undefined) {\n newPoffset = [];\n for(j = 0; j < calcTrace.length; j++) {\n newPoffset.push(\n initialPoffset + (initialBarwidth - newBarwidth[j]) / 2\n );\n }\n t.poffset = newPoffset;\n }\n } else if(width !== undefined) {\n t.barwidth = width;\n\n // if user didn't set offset,\n // then correct t.poffset to ensure bars remain centered\n if(offset === undefined) {\n t.poffset = initialPoffset + (initialBarwidth - width) / 2;\n }\n }\n }\n}\n\nfunction setBarCenterAndWidth(pa, sieve) {\n var calcTraces = sieve.traces;\n var pLetter = getAxisLetter(pa);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var t = calcTrace[0].t;\n var poffset = t.poffset;\n var poffsetIsArray = Array.isArray(poffset);\n var barwidth = t.barwidth;\n var barwidthIsArray = Array.isArray(barwidth);\n\n for(var j = 0; j < calcTrace.length; j++) {\n var calcBar = calcTrace[j];\n\n // store the actual bar width and position, for use by hover\n var width = calcBar.w = barwidthIsArray ? barwidth[j] : barwidth;\n calcBar[pLetter] = calcBar.p + (poffsetIsArray ? poffset[j] : poffset) + width / 2;\n }\n }\n}\n\nfunction updatePositionAxis(pa, sieve, allowMinDtick) {\n var calcTraces = sieve.traces;\n var minDiff = sieve.minDiff;\n var vpad = minDiff / 2;\n\n Axes.minDtick(pa, sieve.minDiff, sieve.distinctPositions[0], allowMinDtick);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var calcTrace0 = calcTrace[0];\n var fullTrace = calcTrace0.trace;\n var pts = [];\n var bar, l, r, j;\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n l = bar.p - vpad;\n r = bar.p + vpad;\n pts.push(l, r);\n }\n\n if(fullTrace.width || fullTrace.offset) {\n var t = calcTrace0.t;\n var poffset = t.poffset;\n var barwidth = t.barwidth;\n var poffsetIsArray = Array.isArray(poffset);\n var barwidthIsArray = Array.isArray(barwidth);\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n var calcBarOffset = poffsetIsArray ? poffset[j] : poffset;\n var calcBarWidth = barwidthIsArray ? barwidth[j] : barwidth;\n l = bar.p + calcBarOffset;\n r = l + calcBarWidth;\n pts.push(l, r);\n }\n }\n\n fullTrace._extremes[pa._id] = Axes.findExtremes(pa, pts, {padded: false});\n }\n}\n\n// store these bar bases and tops in calcdata\n// and make sure the size axis includes zero,\n// along with the bases and tops of each bar.\nfunction setBaseAndTop(sa, sieve) {\n var calcTraces = sieve.traces;\n var sLetter = getAxisLetter(sa);\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n var pts = [];\n var allBaseAboveZero = true;\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n var base = bar.b;\n var top = base + bar.s;\n\n bar[sLetter] = top;\n pts.push(top);\n if(bar.hasB) pts.push(base);\n\n if(!bar.hasB || !(bar.b > 0 && bar.s > 0)) {\n allBaseAboveZero = false;\n }\n }\n\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n tozero: !allBaseAboveZero,\n padded: true\n });\n }\n}\n\nfunction stackBars(sa, sieve, opts) {\n var sLetter = getAxisLetter(sa);\n var calcTraces = sieve.traces;\n var calcTrace;\n var fullTrace;\n var isFunnel;\n var i, j;\n var bar;\n\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n if(fullTrace.type === 'funnel') {\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n // create base of funnels\n sieve.put(bar.p, -0.5 * bar.s);\n }\n }\n }\n }\n\n for(i = 0; i < calcTraces.length; i++) {\n calcTrace = calcTraces[i];\n fullTrace = calcTrace[0].trace;\n\n isFunnel = (fullTrace.type === 'funnel');\n\n var pts = [];\n\n for(j = 0; j < calcTrace.length; j++) {\n bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n // stack current bar and get previous sum\n var value;\n if(isFunnel) {\n value = bar.s;\n } else {\n value = bar.s + bar.b;\n }\n\n var base = sieve.put(bar.p, value);\n\n var top = base + value;\n\n // store the bar base and top in each calcdata item\n bar.b = base;\n bar[sLetter] = top;\n\n if(!opts.norm) {\n pts.push(top);\n if(bar.hasB) {\n pts.push(base);\n }\n }\n }\n }\n\n // if barnorm is set, let normalizeBars update the axis range\n if(!opts.norm) {\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n // N.B. we don't stack base with 'base',\n // so set tozero:true always!\n tozero: true,\n padded: true\n });\n }\n }\n}\n\nfunction sieveBars(sieve) {\n var calcTraces = sieve.traces;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n sieve.put(bar.p, bar.b + bar.s);\n }\n }\n }\n}\n\nfunction unhideBarsWithinTrace(sieve) {\n var calcTraces = sieve.traces;\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n\n if(fullTrace.base === undefined) {\n var inTraceSieve = new Sieve([calcTrace], {\n sepNegVal: true,\n overlapNoMerge: true\n });\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.p !== BADNUM) {\n // stack current bar and get previous sum\n var base = inTraceSieve.put(bar.p, bar.b + bar.s);\n\n // if previous sum if non-zero, this means:\n // multiple bars have same starting point are potentially hidden,\n // shift them vertically so that all bars are visible by default\n if(base) bar.b = base;\n }\n }\n }\n }\n}\n\n// Note:\n//\n// normalizeBars requires that either sieveBars or stackBars has been\n// previously invoked.\nfunction normalizeBars(sa, sieve, opts) {\n var calcTraces = sieve.traces;\n var sLetter = getAxisLetter(sa);\n var sTop = opts.norm === 'fraction' ? 1 : 100;\n var sTiny = sTop / 1e9; // in case of rounding error in sum\n var sMin = sa.l2c(sa.c2l(0));\n var sMax = opts.mode === 'stack' ? sTop : sMin;\n\n function needsPadding(v) {\n return (\n isNumeric(sa.c2l(v)) &&\n ((v < sMin - sTiny) || (v > sMax + sTiny) || !isNumeric(sMin))\n );\n }\n\n for(var i = 0; i < calcTraces.length; i++) {\n var calcTrace = calcTraces[i];\n var fullTrace = calcTrace[0].trace;\n var pts = [];\n var allBaseAboveZero = true;\n var padded = false;\n\n for(var j = 0; j < calcTrace.length; j++) {\n var bar = calcTrace[j];\n\n if(bar.s !== BADNUM) {\n var scale = Math.abs(sTop / sieve.get(bar.p, bar.s));\n bar.b *= scale;\n bar.s *= scale;\n\n var base = bar.b;\n var top = base + bar.s;\n\n bar[sLetter] = top;\n pts.push(top);\n padded = padded || needsPadding(top);\n\n if(bar.hasB) {\n pts.push(base);\n padded = padded || needsPadding(base);\n }\n\n if(!bar.hasB || !(bar.b > 0 && bar.s > 0)) {\n allBaseAboveZero = false;\n }\n }\n }\n\n fullTrace._extremes[sa._id] = Axes.findExtremes(sa, pts, {\n tozero: !allBaseAboveZero,\n padded: padded\n });\n }\n}\n\n// find the full position span of bars at each position\n// for use by hover, to ensure labels move in if bars are\n// narrower than the space they're in.\n// run once per trace group (subplot & direction) and\n// the same mapping is attached to all calcdata traces\nfunction collectExtents(calcTraces, pa) {\n var pLetter = getAxisLetter(pa);\n var extents = {};\n var i, j, cd;\n\n var pMin = Infinity;\n var pMax = -Infinity;\n\n for(i = 0; i < calcTraces.length; i++) {\n cd = calcTraces[i];\n for(j = 0; j < cd.length; j++) {\n var p = cd[j].p;\n if(isNumeric(p)) {\n pMin = Math.min(pMin, p);\n pMax = Math.max(pMax, p);\n }\n }\n }\n\n // this is just for positioning of hover labels, and nobody will care if\n // the label is 1px too far out; so round positions to 1/10K in case\n // position values don't exactly match from trace to trace\n var roundFactor = 10000 / (pMax - pMin);\n var round = extents.round = function(p) {\n return String(Math.round(roundFactor * (p - pMin)));\n };\n\n for(i = 0; i < calcTraces.length; i++) {\n cd = calcTraces[i];\n cd[0].t.extents = extents;\n\n var poffset = cd[0].t.poffset;\n var poffsetIsArray = Array.isArray(poffset);\n\n for(j = 0; j < cd.length; j++) {\n var di = cd[j];\n var p0 = di[pLetter] - di.w / 2;\n\n if(isNumeric(p0)) {\n var p1 = di[pLetter] + di.w / 2;\n var pVal = round(di.p);\n if(extents[pVal]) {\n extents[pVal] = [Math.min(p0, extents[pVal][0]), Math.max(p1, extents[pVal][1])];\n } else {\n extents[pVal] = [p0, p1];\n }\n }\n\n di.p0 = di.p + (poffsetIsArray ? poffset[j] : poffset);\n di.p1 = di.p0 + di.w;\n di.s0 = di.b;\n di.s1 = di.s0 + di.s;\n }\n }\n}\n\nfunction getAxisLetter(ax) {\n return ax._id.charAt(0);\n}\n\nmodule.exports = {\n crossTraceCalc: crossTraceCalc,\n setGroupPositions: setGroupPositions\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Registry = require('../../registry');\n\nmodule.exports = function calc(gd) {\n var calcdata = gd.calcdata;\n var fullLayout = gd._fullLayout;\n\n function makeCoerceHoverInfo(trace) {\n return function(val) {\n return Lib.coerceHoverinfo({hoverinfo: val}, {_module: trace._module}, fullLayout);\n };\n }\n\n for(var i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var trace = cd[0].trace;\n\n // don't include hover calc fields for pie traces\n // as calcdata items might be sorted by value and\n // won't match the data array order.\n if(Registry.traceIs(trace, 'pie-like')) continue;\n\n var fillFn = Registry.traceIs(trace, '2dMap') ? paste : Lib.fillArray;\n\n fillFn(trace.hoverinfo, cd, 'hi', makeCoerceHoverInfo(trace));\n\n if(trace.hovertemplate) fillFn(trace.hovertemplate, cd, 'ht');\n\n if(!trace.hoverlabel) continue;\n\n fillFn(trace.hoverlabel.bgcolor, cd, 'hbg');\n fillFn(trace.hoverlabel.bordercolor, cd, 'hbc');\n fillFn(trace.hoverlabel.font.size, cd, 'hts');\n fillFn(trace.hoverlabel.font.color, cd, 'htc');\n fillFn(trace.hoverlabel.font.family, cd, 'htf');\n fillFn(trace.hoverlabel.namelength, cd, 'hnl');\n fillFn(trace.hoverlabel.align, cd, 'hta');\n }\n};\n\nfunction paste(traceAttr, cd, cdAttr, fn) {\n fn = fn || Lib.identity;\n\n if(Array.isArray(traceAttr)) {\n cd[0][cdAttr] = fn(traceAttr);\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = require('../src/traces/bar');\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// converts a list of segments into a list of regions, while also removing unnecessary verticies\n//\n\nfunction SegmentChainer(segments, eps, buildLog){\n\tvar chains = [];\n\tvar regions = [];\n\n\tsegments.forEach(function(seg){\n\t\tvar pt1 = seg.start;\n\t\tvar pt2 = seg.end;\n\t\tif (eps.pointsSame(pt1, pt2)){\n\t\t\tconsole.warn('PolyBool: Warning: Zero-length segment detected; your epsilon is ' +\n\t\t\t\t'probably too small or too large');\n\t\t\treturn;\n\t\t}\n\n\t\tif (buildLog)\n\t\t\tbuildLog.chainStart(seg);\n\n\t\t// search for two chains that this segment matches\n\t\tvar first_match = {\n\t\t\tindex: 0,\n\t\t\tmatches_head: false,\n\t\t\tmatches_pt1: false\n\t\t};\n\t\tvar second_match = {\n\t\t\tindex: 0,\n\t\t\tmatches_head: false,\n\t\t\tmatches_pt1: false\n\t\t};\n\t\tvar next_match = first_match;\n\t\tfunction setMatch(index, matches_head, matches_pt1){\n\t\t\t// return true if we've matched twice\n\t\t\tnext_match.index = index;\n\t\t\tnext_match.matches_head = matches_head;\n\t\t\tnext_match.matches_pt1 = matches_pt1;\n\t\t\tif (next_match === first_match){\n\t\t\t\tnext_match = second_match;\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tnext_match = null;\n\t\t\treturn true; // we've matched twice, we're done here\n\t\t}\n\t\tfor (var i = 0; i < chains.length; i++){\n\t\t\tvar chain = chains[i];\n\t\t\tvar head = chain[0];\n\t\t\tvar head2 = chain[1];\n\t\t\tvar tail = chain[chain.length - 1];\n\t\t\tvar tail2 = chain[chain.length - 2];\n\t\t\tif (eps.pointsSame(head, pt1)){\n\t\t\t\tif (setMatch(i, true, true))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(head, pt2)){\n\t\t\t\tif (setMatch(i, true, false))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(tail, pt1)){\n\t\t\t\tif (setMatch(i, false, true))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\telse if (eps.pointsSame(tail, pt2)){\n\t\t\t\tif (setMatch(i, false, false))\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (next_match === first_match){\n\t\t\t// we didn't match anything, so create a new chain\n\t\t\tchains.push([ pt1, pt2 ]);\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainNew(pt1, pt2);\n\t\t\treturn;\n\t\t}\n\n\t\tif (next_match === second_match){\n\t\t\t// we matched a single chain\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainMatch(first_match.index);\n\n\t\t\t// add the other point to the apporpriate end, and check to see if we've closed the\n\t\t\t// chain into a loop\n\n\t\t\tvar index = first_match.index;\n\t\t\tvar pt = first_match.matches_pt1 ? pt2 : pt1; // if we matched pt1, then we add pt2, etc\n\t\t\tvar addToHead = first_match.matches_head; // if we matched at head, then add to the head\n\n\t\t\tvar chain = chains[index];\n\t\t\tvar grow = addToHead ? chain[0] : chain[chain.length - 1];\n\t\t\tvar grow2 = addToHead ? chain[1] : chain[chain.length - 2];\n\t\t\tvar oppo = addToHead ? chain[chain.length - 1] : chain[0];\n\t\t\tvar oppo2 = addToHead ? chain[chain.length - 2] : chain[1];\n\n\t\t\tif (eps.pointsCollinear(grow2, grow, pt)){\n\t\t\t\t// grow isn't needed because it's directly between grow2 and pt:\n\t\t\t\t// grow2 ---grow---> pt\n\t\t\t\tif (addToHead){\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.chainRemoveHead(first_match.index, pt);\n\t\t\t\t\tchain.shift();\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\tbuildLog.chainRemoveTail(first_match.index, pt);\n\t\t\t\t\tchain.pop();\n\t\t\t\t}\n\t\t\t\tgrow = grow2; // old grow is gone... new grow is what grow2 was\n\t\t\t}\n\n\t\t\tif (eps.pointsSame(oppo, pt)){\n\t\t\t\t// we're closing the loop, so remove chain from chains\n\t\t\t\tchains.splice(index, 1);\n\n\t\t\t\tif (eps.pointsCollinear(oppo2, oppo, grow)){\n\t\t\t\t\t// oppo isn't needed because it's directly between oppo2 and grow:\n\t\t\t\t\t// oppo2 ---oppo--->grow\n\t\t\t\t\tif (addToHead){\n\t\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\t\tbuildLog.chainRemoveTail(first_match.index, grow);\n\t\t\t\t\t\tchain.pop();\n\t\t\t\t\t}\n\t\t\t\t\telse{\n\t\t\t\t\t\tif (buildLog)\n\t\t\t\t\t\t\tbuildLog.chainRemoveHead(first_match.index, grow);\n\t\t\t\t\t\tchain.shift();\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainClose(first_match.index);\n\n\t\t\t\t// we have a closed chain!\n\t\t\t\tregions.push(chain);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// not closing a loop, so just add it to the apporpriate side\n\t\t\tif (addToHead){\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainAddHead(first_match.index, pt);\n\t\t\t\tchain.unshift(pt);\n\t\t\t}\n\t\t\telse{\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainAddTail(first_match.index, pt);\n\t\t\t\tchain.push(pt);\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\n\t\t// otherwise, we matched two chains, so we need to combine those chains together\n\n\t\tfunction reverseChain(index){\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainReverse(index);\n\t\t\tchains[index].reverse(); // gee, that's easy\n\t\t}\n\n\t\tfunction appendChain(index1, index2){\n\t\t\t// index1 gets index2 appended to it, and index2 is removed\n\t\t\tvar chain1 = chains[index1];\n\t\t\tvar chain2 = chains[index2];\n\t\t\tvar tail = chain1[chain1.length - 1];\n\t\t\tvar tail2 = chain1[chain1.length - 2];\n\t\t\tvar head = chain2[0];\n\t\t\tvar head2 = chain2[1];\n\n\t\t\tif (eps.pointsCollinear(tail2, tail, head)){\n\t\t\t\t// tail isn't needed because it's directly between tail2 and head\n\t\t\t\t// tail2 ---tail---> head\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainRemoveTail(index1, tail);\n\t\t\t\tchain1.pop();\n\t\t\t\ttail = tail2; // old tail is gone... new tail is what tail2 was\n\t\t\t}\n\n\t\t\tif (eps.pointsCollinear(tail, head, head2)){\n\t\t\t\t// head isn't needed because it's directly between tail and head2\n\t\t\t\t// tail ---head---> head2\n\t\t\t\tif (buildLog)\n\t\t\t\t\tbuildLog.chainRemoveHead(index2, head);\n\t\t\t\tchain2.shift();\n\t\t\t}\n\n\t\t\tif (buildLog)\n\t\t\t\tbuildLog.chainJoin(index1, index2);\n\t\t\tchains[index1] = chain1.concat(chain2);\n\t\t\tchains.splice(index2, 1);\n\t\t}\n\n\t\tvar F = first_match.index;\n\t\tvar S = second_match.index;\n\n\t\tif (buildLog)\n\t\t\tbuildLog.chainConnect(F, S);\n\n\t\tvar reverseF = chains[F].length < chains[S].length; // reverse the shorter chain, if needed\n\t\tif (first_match.matches_head){\n\t\t\tif (second_match.matches_head){\n\t\t\t\tif (reverseF){\n\t\t\t\t\t// <<<< F <<<< --- >>>> S >>>>\n\t\t\t\t\treverseChain(F);\n\t\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\t\tappendChain(F, S);\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// <<<< F <<<< --- >>>> S >>>>\n\t\t\t\t\treverseChain(S);\n\t\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\t\tappendChain(S, F);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse{\n\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\tappendChain(S, F);\n\t\t\t}\n\t\t}\n\t\telse{\n\t\t\tif (second_match.matches_head){\n\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\tappendChain(F, S);\n\t\t\t}\n\t\t\telse{\n\t\t\t\tif (reverseF){\n\t\t\t\t\t// >>>> F >>>> --- <<<< S <<<<\n\t\t\t\t\treverseChain(F);\n\t\t\t\t\t// <<<< F <<<< --- <<<< S <<<< logically same as:\n\t\t\t\t\t// >>>> S >>>> --- >>>> F >>>>\n\t\t\t\t\tappendChain(S, F);\n\t\t\t\t}\n\t\t\t\telse{\n\t\t\t\t\t// >>>> F >>>> --- <<<< S <<<<\n\t\t\t\t\treverseChain(S);\n\t\t\t\t\t// >>>> F >>>> --- >>>> S >>>>\n\t\t\t\t\tappendChain(F, S);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n\n\treturn regions;\n}\n\nmodule.exports = SegmentChainer;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar binFunctions = require('../histogram/bin_functions');\nvar normFunctions = require('../histogram/norm_functions');\nvar doAvg = require('../histogram/average');\nvar getBinSpanLabelRound = require('../histogram/bin_label_vals');\nvar calcAllAutoBins = require('../histogram/calc').calcAllAutoBins;\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis);\n var ya = Axes.getFromId(gd, trace.yaxis);\n\n var xcalendar = trace.xcalendar;\n var ycalendar = trace.ycalendar;\n var xr2c = function(v) { return xa.r2c(v, 0, xcalendar); };\n var yr2c = function(v) { return ya.r2c(v, 0, ycalendar); };\n var xc2r = function(v) { return xa.c2r(v, 0, xcalendar); };\n var yc2r = function(v) { return ya.c2r(v, 0, ycalendar); };\n\n var i, j, n, m;\n\n // calculate the bins\n var xBinsAndPos = calcAllAutoBins(gd, trace, xa, 'x');\n var xBinSpec = xBinsAndPos[0];\n var xPos0 = xBinsAndPos[1];\n var yBinsAndPos = calcAllAutoBins(gd, trace, ya, 'y');\n var yBinSpec = yBinsAndPos[0];\n var yPos0 = yBinsAndPos[1];\n\n var serieslen = trace._length;\n if(xPos0.length > serieslen) xPos0.splice(serieslen, xPos0.length - serieslen);\n if(yPos0.length > serieslen) yPos0.splice(serieslen, yPos0.length - serieslen);\n\n // make the empty bin array & scale the map\n var z = [];\n var onecol = [];\n var zerocol = [];\n var nonuniformBinsX = typeof xBinSpec.size === 'string';\n var nonuniformBinsY = typeof yBinSpec.size === 'string';\n var xEdges = [];\n var yEdges = [];\n var xbins = nonuniformBinsX ? xEdges : xBinSpec;\n var ybins = nonuniformBinsY ? yEdges : yBinSpec;\n var total = 0;\n var counts = [];\n var inputPoints = [];\n var norm = trace.histnorm;\n var func = trace.histfunc;\n var densitynorm = norm.indexOf('density') !== -1;\n var extremefunc = func === 'max' || func === 'min';\n var sizeinit = extremefunc ? null : 0;\n var binfunc = binFunctions.count;\n var normfunc = normFunctions[norm];\n var doavg = false;\n var xinc = [];\n var yinc = [];\n\n // set a binning function other than count?\n // for binning functions: check first for 'z',\n // then 'mc' in case we had a colored scatter plot\n // and want to transfer these colors to the 2D histo\n // TODO: axe this, make it the responsibility of the app changing type? or an impliedEdit?\n var rawCounterData = ('z' in trace) ?\n trace.z :\n (('marker' in trace && Array.isArray(trace.marker.color)) ?\n trace.marker.color : '');\n if(rawCounterData && func !== 'count') {\n doavg = func === 'avg';\n binfunc = binFunctions[func];\n }\n\n // decrease end a little in case of rounding errors\n var xBinSize = xBinSpec.size;\n var xBinStart = xr2c(xBinSpec.start);\n var xBinEnd = xr2c(xBinSpec.end) +\n (xBinStart - Axes.tickIncrement(xBinStart, xBinSize, false, xcalendar)) / 1e6;\n\n for(i = xBinStart; i < xBinEnd; i = Axes.tickIncrement(i, xBinSize, false, xcalendar)) {\n onecol.push(sizeinit);\n xEdges.push(i);\n if(doavg) zerocol.push(0);\n }\n xEdges.push(i);\n\n var nx = onecol.length;\n var dx = (i - xBinStart) / nx;\n var x0 = xc2r(xBinStart + dx / 2);\n\n var yBinSize = yBinSpec.size;\n var yBinStart = yr2c(yBinSpec.start);\n var yBinEnd = yr2c(yBinSpec.end) +\n (yBinStart - Axes.tickIncrement(yBinStart, yBinSize, false, ycalendar)) / 1e6;\n\n for(i = yBinStart; i < yBinEnd; i = Axes.tickIncrement(i, yBinSize, false, ycalendar)) {\n z.push(onecol.slice());\n yEdges.push(i);\n var ipCol = new Array(nx);\n for(j = 0; j < nx; j++) ipCol[j] = [];\n inputPoints.push(ipCol);\n if(doavg) counts.push(zerocol.slice());\n }\n yEdges.push(i);\n\n var ny = z.length;\n var dy = (i - yBinStart) / ny;\n var y0 = yc2r(yBinStart + dy / 2);\n\n if(densitynorm) {\n xinc = makeIncrements(onecol.length, xbins, dx, nonuniformBinsX);\n yinc = makeIncrements(z.length, ybins, dy, nonuniformBinsY);\n }\n\n // for date axes we need bin bounds to be calcdata. For nonuniform bins\n // we already have this, but uniform with start/end/size they're still strings.\n if(!nonuniformBinsX && xa.type === 'date') xbins = binsToCalc(xr2c, xbins);\n if(!nonuniformBinsY && ya.type === 'date') ybins = binsToCalc(yr2c, ybins);\n\n // put data into bins\n var uniqueValsPerX = true;\n var uniqueValsPerY = true;\n var xVals = new Array(nx);\n var yVals = new Array(ny);\n var xGapLow = Infinity;\n var xGapHigh = Infinity;\n var yGapLow = Infinity;\n var yGapHigh = Infinity;\n for(i = 0; i < serieslen; i++) {\n var xi = xPos0[i];\n var yi = yPos0[i];\n n = Lib.findBin(xi, xbins);\n m = Lib.findBin(yi, ybins);\n if(n >= 0 && n < nx && m >= 0 && m < ny) {\n total += binfunc(n, i, z[m], rawCounterData, counts[m]);\n inputPoints[m][n].push(i);\n\n if(uniqueValsPerX) {\n if(xVals[n] === undefined) xVals[n] = xi;\n else if(xVals[n] !== xi) uniqueValsPerX = false;\n }\n if(uniqueValsPerY) {\n if(yVals[m] === undefined) yVals[m] = yi;\n else if(yVals[m] !== yi) uniqueValsPerY = false;\n }\n\n xGapLow = Math.min(xGapLow, xi - xEdges[n]);\n xGapHigh = Math.min(xGapHigh, xEdges[n + 1] - xi);\n yGapLow = Math.min(yGapLow, yi - yEdges[m]);\n yGapHigh = Math.min(yGapHigh, yEdges[m + 1] - yi);\n }\n }\n // normalize, if needed\n if(doavg) {\n for(m = 0; m < ny; m++) total += doAvg(z[m], counts[m]);\n }\n if(normfunc) {\n for(m = 0; m < ny; m++) normfunc(z[m], total, xinc, yinc[m]);\n }\n\n return {\n x: xPos0,\n xRanges: getRanges(xEdges, uniqueValsPerX && xVals, xGapLow, xGapHigh, xa, xcalendar),\n x0: x0,\n dx: dx,\n y: yPos0,\n yRanges: getRanges(yEdges, uniqueValsPerY && yVals, yGapLow, yGapHigh, ya, ycalendar),\n y0: y0,\n dy: dy,\n z: z,\n pts: inputPoints\n };\n};\n\nfunction makeIncrements(len, bins, dv, nonuniform) {\n var out = new Array(len);\n var i;\n if(nonuniform) {\n for(i = 0; i < len; i++) out[i] = 1 / (bins[i + 1] - bins[i]);\n } else {\n var inc = 1 / dv;\n for(i = 0; i < len; i++) out[i] = inc;\n }\n return out;\n}\n\nfunction binsToCalc(r2c, bins) {\n return {\n start: r2c(bins.start),\n end: r2c(bins.end),\n size: bins.size\n };\n}\n\nfunction getRanges(edges, uniqueVals, gapLow, gapHigh, ax, calendar) {\n var i;\n var len = edges.length - 1;\n var out = new Array(len);\n var roundFn = getBinSpanLabelRound(gapLow, gapHigh, edges, ax, calendar);\n\n for(i = 0; i < len; i++) {\n var v = (uniqueVals || [])[i];\n out[i] = v === undefined ?\n [roundFn(edges[i]), roundFn(edges[i + 1], true)] :\n [v, v];\n }\n return out;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Events = require('../../lib/events');\nvar throttle = require('../../lib/throttle');\nvar getGraphDiv = require('../../lib/dom').getGraphDiv;\n\nvar hoverConstants = require('../fx/constants');\n\nvar unhover = module.exports = {};\n\nunhover.wrapped = function(gd, evt, subplot) {\n gd = getGraphDiv(gd);\n\n // Important, clear any queued hovers\n if(gd._fullLayout) {\n throttle.clear(gd._fullLayout._uid + hoverConstants.HOVERID);\n }\n\n unhover.raw(gd, evt, subplot);\n};\n\n\n// remove hover effects on mouse out, and emit unhover event\nunhover.raw = function raw(gd, evt) {\n var fullLayout = gd._fullLayout;\n var oldhoverdata = gd._hoverdata;\n\n if(!evt) evt = {};\n if(evt.target &&\n Events.triggerHandler(gd, 'plotly_beforehover', evt) === false) {\n return;\n }\n\n fullLayout._hoverlayer.selectAll('g').remove();\n fullLayout._hoverlayer.selectAll('line').remove();\n fullLayout._hoverlayer.selectAll('circle').remove();\n gd._hoverdata = undefined;\n\n if(evt.target && oldhoverdata) {\n gd.emit('plotly_unhover', {\n event: evt,\n points: oldhoverdata\n });\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/* eslint-disable no-console */\n\nvar dfltConfig = require('../plot_api/plot_config').dfltConfig;\n\nvar notifier = require('./notifier');\n\nvar loggers = module.exports = {};\n\n/**\n * ------------------------------------------\n * debugging tools\n * ------------------------------------------\n */\n\nloggers.log = function() {\n var i;\n\n if(dfltConfig.logging > 1) {\n var messages = ['LOG:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n apply(console.trace || console.log, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 1) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'long');\n }\n};\n\nloggers.warn = function() {\n var i;\n\n if(dfltConfig.logging > 0) {\n var messages = ['WARN:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n apply(console.trace || console.log, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 0) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'stick');\n }\n};\n\nloggers.error = function() {\n var i;\n\n if(dfltConfig.logging > 0) {\n var messages = ['ERROR:'];\n for(i = 0; i < arguments.length; i++) {\n messages.push(arguments[i]);\n }\n apply(console.error, messages);\n }\n\n if(dfltConfig.notifyOnLogging > 0) {\n var lines = [];\n for(i = 0; i < arguments.length; i++) {\n lines.push(arguments[i]);\n }\n notifier(lines.join('
'), 'stick');\n }\n};\n\n/*\n * Robust apply, for IE9 where console.log doesn't support\n * apply like other functions do\n */\nfunction apply(f, args) {\n if(f && f.apply) {\n try {\n // `this` should always be console, since here we're always\n // applying a method of the console object.\n f.apply(console, args);\n return;\n } catch(e) { /* in case apply failed, fall back on the code below */ }\n }\n\n // no apply - just try calling the function on each arg independently\n for(var i = 0; i < args.length; i++) {\n try {\n f(args[i]);\n } catch(e) {\n // still fails - last resort simple console.log\n console.log(args[i]);\n }\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n// Simple helper functions\n// none of these need any external deps\n\nmodule.exports = function identity(d) { return d; };\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Color = require('../../components/color');\nvar Registry = require('../../registry');\n\nvar handleXYDefaults = require('../scatter/xy_defaults');\nvar handleStyleDefaults = require('./style_defaults');\nvar getAxisGroup = require('../../plots/cartesian/axis_ids').getAxisGroup;\nvar attributes = require('./attributes');\n\nvar coerceFont = Lib.coerceFont;\n\nfunction supplyDefaults(traceIn, traceOut, defaultColor, layout) {\n function coerce(attr, dflt) {\n return Lib.coerce(traceIn, traceOut, attributes, attr, dflt);\n }\n\n var len = handleXYDefaults(traceIn, traceOut, layout, coerce);\n if(!len) {\n traceOut.visible = false;\n return;\n }\n\n coerce('orientation', (traceOut.x && !traceOut.y) ? 'h' : 'v');\n coerce('base');\n coerce('offset');\n coerce('width');\n\n coerce('text');\n coerce('hovertext');\n coerce('hovertemplate');\n\n var textposition = coerce('textposition');\n handleText(traceIn, traceOut, layout, coerce, textposition, {\n moduleHasSelected: true,\n moduleHasUnselected: true,\n moduleHasConstrain: true,\n moduleHasCliponaxis: true,\n moduleHasTextangle: true,\n moduleHasInsideanchor: true\n });\n\n handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout);\n\n var lineColor = (traceOut.marker.line || {}).color;\n\n // override defaultColor for error bars with defaultLine\n var errorBarsSupplyDefaults = Registry.getComponentMethod('errorbars', 'supplyDefaults');\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'y'});\n errorBarsSupplyDefaults(traceIn, traceOut, lineColor || Color.defaultLine, {axis: 'x', inherit: 'y'});\n\n Lib.coerceSelectionMarkerOpacity(traceOut, coerce);\n}\n\nfunction handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce) {\n var orientation = traceOut.orientation;\n // N.B. grouping is done across all trace types that support it\n var posAxId = traceOut[{v: 'x', h: 'y'}[orientation] + 'axis'];\n var groupId = getAxisGroup(fullLayout, posAxId) + orientation;\n\n var alignmentOpts = fullLayout._alignmentOpts || {};\n var alignmentgroup = coerce('alignmentgroup');\n\n var alignmentGroups = alignmentOpts[groupId];\n if(!alignmentGroups) alignmentGroups = alignmentOpts[groupId] = {};\n\n var alignmentGroupOpts = alignmentGroups[alignmentgroup];\n\n if(alignmentGroupOpts) {\n alignmentGroupOpts.traces.push(traceOut);\n } else {\n alignmentGroupOpts = alignmentGroups[alignmentgroup] = {\n traces: [traceOut],\n alignmentIndex: Object.keys(alignmentGroups).length,\n offsetGroups: {}\n };\n }\n\n var offsetgroup = coerce('offsetgroup');\n var offsetGroups = alignmentGroupOpts.offsetGroups;\n var offsetGroupOpts = offsetGroups[offsetgroup];\n\n if(offsetgroup) {\n if(!offsetGroupOpts) {\n offsetGroupOpts = offsetGroups[offsetgroup] = {\n offsetIndex: Object.keys(offsetGroups).length\n };\n }\n\n traceOut._offsetIndex = offsetGroupOpts.offsetIndex;\n }\n}\n\nfunction crossTraceDefaults(fullData, fullLayout) {\n var traceIn, traceOut;\n\n function coerce(attr) {\n return Lib.coerce(traceOut._input, traceOut, attributes, attr);\n }\n\n if(fullLayout.barmode === 'group') {\n for(var i = 0; i < fullData.length; i++) {\n traceOut = fullData[i];\n\n if(traceOut.type === 'bar') {\n traceIn = traceOut._input;\n handleGroupingDefaults(traceIn, traceOut, fullLayout, coerce);\n }\n }\n }\n}\n\nfunction handleText(traceIn, traceOut, layout, coerce, textposition, opts) {\n opts = opts || {};\n var moduleHasSelected = !(opts.moduleHasSelected === false);\n var moduleHasUnselected = !(opts.moduleHasUnselected === false);\n var moduleHasConstrain = !(opts.moduleHasConstrain === false);\n var moduleHasCliponaxis = !(opts.moduleHasCliponaxis === false);\n var moduleHasTextangle = !(opts.moduleHasTextangle === false);\n var moduleHasInsideanchor = !(opts.moduleHasInsideanchor === false);\n var hasPathbar = !!opts.hasPathbar;\n\n var hasBoth = Array.isArray(textposition) || textposition === 'auto';\n var hasInside = hasBoth || textposition === 'inside';\n var hasOutside = hasBoth || textposition === 'outside';\n\n if(hasInside || hasOutside) {\n var dfltFont = coerceFont(coerce, 'textfont', layout.font);\n\n // Note that coercing `insidetextfont` is always needed –\n // even if `textposition` is `outside` for each trace – since\n // an outside label can become an inside one, for example because\n // of a bar being stacked on top of it.\n var insideTextFontDefault = Lib.extendFlat({}, dfltFont);\n var isTraceTextfontColorSet = traceIn.textfont && traceIn.textfont.color;\n var isColorInheritedFromLayoutFont = !isTraceTextfontColorSet;\n if(isColorInheritedFromLayoutFont) {\n delete insideTextFontDefault.color;\n }\n coerceFont(coerce, 'insidetextfont', insideTextFontDefault);\n\n if(hasPathbar) {\n var pathbarTextFontDefault = Lib.extendFlat({}, dfltFont);\n if(isColorInheritedFromLayoutFont) {\n delete pathbarTextFontDefault.color;\n }\n coerceFont(coerce, 'pathbar.textfont', pathbarTextFontDefault);\n }\n\n if(hasOutside) coerceFont(coerce, 'outsidetextfont', dfltFont);\n\n if(moduleHasSelected) coerce('selected.textfont.color');\n if(moduleHasUnselected) coerce('unselected.textfont.color');\n if(moduleHasConstrain) coerce('constraintext');\n if(moduleHasCliponaxis) coerce('cliponaxis');\n if(moduleHasTextangle) coerce('textangle');\n\n coerce('texttemplate');\n }\n\n if(hasInside) {\n if(moduleHasInsideanchor) coerce('insidetextanchor');\n }\n}\n\nmodule.exports = {\n supplyDefaults: supplyDefaults,\n crossTraceDefaults: crossTraceDefaults,\n handleGroupingDefaults: handleGroupingDefaults,\n handleText: handleText\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar isUnifiedHover = require('./helpers').isUnifiedHover;\nvar layoutAttributes = require('./layout_attributes');\nvar handleHoverModeDefaults = require('./hovermode_defaults');\nvar handleHoverLabelDefaults = require('./hoverlabel_defaults');\n\nmodule.exports = function supplyLayoutDefaults(layoutIn, layoutOut, fullData) {\n function coerce(attr, dflt) {\n return Lib.coerce(layoutIn, layoutOut, layoutAttributes, attr, dflt);\n }\n\n var hoverMode = handleHoverModeDefaults(layoutIn, layoutOut, fullData);\n if(hoverMode) {\n coerce('hoverdistance');\n coerce('spikedistance', isUnifiedHover(hoverMode) ? -1 : undefined);\n }\n\n var dragMode = coerce('dragmode');\n if(dragMode === 'select') coerce('selectdirection');\n\n // if only mapbox or geo subplots is present on graph,\n // reset 'zoom' dragmode to 'pan' until 'zoom' is implemented,\n // so that the correct modebar button is active\n var hasMapbox = layoutOut._has('mapbox');\n var hasGeo = layoutOut._has('geo');\n var len = layoutOut._basePlotModules.length;\n\n if(layoutOut.dragmode === 'zoom' && (\n ((hasMapbox || hasGeo) && len === 1) ||\n (hasMapbox && hasGeo && len === 2)\n )) {\n layoutOut.dragmode = 'pan';\n }\n\n handleHoverLabelDefaults(layoutIn, layoutOut, coerce);\n};\n","var rootPosition = { left: 0, top: 0 }\n\nmodule.exports = mouseEventOffset\nfunction mouseEventOffset (ev, target, out) {\n target = target || ev.currentTarget || ev.srcElement\n if (!Array.isArray(out)) {\n out = [ 0, 0 ]\n }\n var cx = ev.clientX || 0\n var cy = ev.clientY || 0\n var rect = getBoundingClientOffset(target)\n out[0] = cx - rect.left\n out[1] = cy - rect.top\n return out\n}\n\nfunction getBoundingClientOffset (element) {\n if (element === window ||\n element === document ||\n element === document.body) {\n return rootPosition\n } else {\n return element.getBoundingClientRect()\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar axesAttrs = require('../../plots/cartesian/layout_attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\n\n\nmodule.exports = overrideAll({\n// TODO: only right is supported currently\n// orient: {\n// valType: 'enumerated',\n// role: 'info',\n// values: ['left', 'right', 'top', 'bottom'],\n// dflt: 'right',\n// description: [\n// 'Determines which side are the labels on',\n// '(so left and right make vertical bars, etc.)'\n// ].join(' ')\n// },\n thicknessmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n role: 'style',\n dflt: 'pixels',\n description: [\n 'Determines whether this color bar\\'s thickness',\n '(i.e. the measure in the constant color direction)',\n 'is set in units of plot *fraction* or in *pixels*.',\n 'Use `thickness` to set the value.'\n ].join(' ')\n },\n thickness: {\n valType: 'number',\n role: 'style',\n min: 0,\n dflt: 30,\n description: [\n 'Sets the thickness of the color bar',\n 'This measure excludes the size of the padding, ticks and labels.'\n ].join(' ')\n },\n lenmode: {\n valType: 'enumerated',\n values: ['fraction', 'pixels'],\n role: 'info',\n dflt: 'fraction',\n description: [\n 'Determines whether this color bar\\'s length',\n '(i.e. the measure in the color variation direction)',\n 'is set in units of plot *fraction* or in *pixels.',\n 'Use `len` to set the value.'\n ].join(' ')\n },\n len: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n description: [\n 'Sets the length of the color bar',\n 'This measure excludes the padding of both ends.',\n 'That is, the color bar length is this length minus the',\n 'padding on both ends.'\n ].join(' ')\n },\n x: {\n valType: 'number',\n dflt: 1.02,\n min: -2,\n max: 3,\n role: 'style',\n description: [\n 'Sets the x position of the color bar (in plot fraction).'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['left', 'center', 'right'],\n dflt: 'left',\n role: 'style',\n description: [\n 'Sets this color bar\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the color bar.'\n ].join(' ')\n },\n xpad: {\n valType: 'number',\n role: 'style',\n min: 0,\n dflt: 10,\n description: 'Sets the amount of padding (in px) along the x direction.'\n },\n y: {\n valType: 'number',\n role: 'style',\n dflt: 0.5,\n min: -2,\n max: 3,\n description: [\n 'Sets the y position of the color bar (in plot fraction).'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n role: 'style',\n dflt: 'middle',\n description: [\n 'Sets this color bar\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the color bar.'\n ].join(' ')\n },\n ypad: {\n valType: 'number',\n role: 'style',\n min: 0,\n dflt: 10,\n description: 'Sets the amount of padding (in px) along the y direction.'\n },\n // a possible line around the bar itself\n outlinecolor: axesAttrs.linecolor,\n outlinewidth: axesAttrs.linewidth,\n // Should outlinewidth have {dflt: 0} ?\n // another possible line outside the padding and tick labels\n bordercolor: axesAttrs.linecolor,\n borderwidth: {\n valType: 'number',\n role: 'style',\n min: 0,\n dflt: 0,\n description: [\n 'Sets the width (in px) or the border enclosing this color bar.'\n ].join(' ')\n },\n bgcolor: {\n valType: 'color',\n role: 'style',\n dflt: 'rgba(0,0,0,0)',\n description: 'Sets the color of padded area.'\n },\n // tick and title properties named and function exactly as in axes\n tickmode: axesAttrs.tickmode,\n nticks: axesAttrs.nticks,\n tick0: axesAttrs.tick0,\n dtick: axesAttrs.dtick,\n tickvals: axesAttrs.tickvals,\n ticktext: axesAttrs.ticktext,\n ticks: extendFlat({}, axesAttrs.ticks, {dflt: ''}),\n ticklen: axesAttrs.ticklen,\n tickwidth: axesAttrs.tickwidth,\n tickcolor: axesAttrs.tickcolor,\n showticklabels: axesAttrs.showticklabels,\n tickfont: fontAttrs({\n description: 'Sets the color bar\\'s tick label font'\n }),\n tickangle: axesAttrs.tickangle,\n tickformat: axesAttrs.tickformat,\n tickformatstops: axesAttrs.tickformatstops,\n tickprefix: axesAttrs.tickprefix,\n showtickprefix: axesAttrs.showtickprefix,\n ticksuffix: axesAttrs.ticksuffix,\n showticksuffix: axesAttrs.showticksuffix,\n separatethousands: axesAttrs.separatethousands,\n exponentformat: axesAttrs.exponentformat,\n showexponent: axesAttrs.showexponent,\n title: {\n text: {\n valType: 'string',\n role: 'info',\n description: [\n 'Sets the title of the color bar.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n description: [\n 'Sets this color bar\\'s title font.',\n 'Note that the title\\'s font used to be set',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n side: {\n valType: 'enumerated',\n values: ['right', 'top', 'bottom'],\n role: 'style',\n dflt: 'top',\n description: [\n 'Determines the location of color bar\\'s title',\n 'with respect to the color bar.',\n 'Note that the title\\'s location used to be set',\n 'by the now deprecated `titleside` attribute.'\n ].join(' ')\n }\n },\n\n _deprecated: {\n title: {\n valType: 'string',\n role: 'info',\n description: [\n 'Deprecated in favor of color bar\\'s `title.text`.',\n 'Note that value of color bar\\'s `title` is no longer a simple',\n '*string* but a set of sub-attributes.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n description: 'Deprecated in favor of color bar\\'s `title.font`.'\n }),\n titleside: {\n valType: 'enumerated',\n values: ['right', 'top', 'bottom'],\n role: 'style',\n dflt: 'top',\n description: 'Deprecated in favor of color bar\\'s `title.side`.'\n }\n }\n}, 'colorbars', 'from-root');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Plots = require('../../plots/plots');\nvar Color = require('../color');\nvar Drawing = require('../drawing');\nvar Lib = require('../../lib');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar arrayEditor = require('../../plot_api/plot_template').arrayEditor;\n\nvar constants = require('./constants');\nvar alignmentConstants = require('../../constants/alignment');\nvar LINE_SPACING = alignmentConstants.LINE_SPACING;\nvar FROM_TL = alignmentConstants.FROM_TL;\nvar FROM_BR = alignmentConstants.FROM_BR;\n\nmodule.exports = function draw(gd) {\n var fullLayout = gd._fullLayout;\n var sliderData = makeSliderData(fullLayout, gd);\n\n // draw a container for *all* sliders:\n var sliders = fullLayout._infolayer\n .selectAll('g.' + constants.containerClassName)\n .data(sliderData.length > 0 ? [0] : []);\n\n sliders.enter().append('g')\n .classed(constants.containerClassName, true)\n .style('cursor', 'ew-resize');\n\n function clearSlider(sliderOpts) {\n if(sliderOpts._commandObserver) {\n sliderOpts._commandObserver.remove();\n delete sliderOpts._commandObserver;\n }\n\n // Most components don't need to explicitly remove autoMargin, because\n // marginPushers does this - but slider updates don't go through\n // a full replot so we need to explicitly remove it.\n Plots.autoMargin(gd, autoMarginId(sliderOpts));\n }\n\n sliders.exit().each(function() {\n d3.select(this).selectAll('g.' + constants.groupClassName)\n .each(clearSlider);\n })\n .remove();\n\n // Return early if no menus visible:\n if(sliderData.length === 0) return;\n\n var sliderGroups = sliders.selectAll('g.' + constants.groupClassName)\n .data(sliderData, keyFunction);\n\n sliderGroups.enter().append('g')\n .classed(constants.groupClassName, true);\n\n sliderGroups.exit()\n .each(clearSlider)\n .remove();\n\n // Find the dimensions of the sliders:\n for(var i = 0; i < sliderData.length; i++) {\n var sliderOpts = sliderData[i];\n findDimensions(gd, sliderOpts);\n }\n\n sliderGroups.each(function(sliderOpts) {\n var gSlider = d3.select(this);\n\n computeLabelSteps(sliderOpts);\n\n Plots.manageCommandObserver(gd, sliderOpts, sliderOpts._visibleSteps, function(data) {\n // NB: Same as below. This is *not* always the same as sliderOpts since\n // if a new set of steps comes in, the reference in this callback would\n // be invalid. We need to refetch it from the slider group, which is\n // the join data that creates this slider. So if this slider still exists,\n // the group should be valid, *to the best of my knowledge.* If not,\n // we'd have to look it up by d3 data join index/key.\n var opts = gSlider.data()[0];\n\n if(opts.active === data.index) return;\n if(opts._dragging) return;\n\n setActive(gd, gSlider, opts, data.index, false, true);\n });\n\n drawSlider(gd, d3.select(this), sliderOpts);\n });\n};\n\nfunction autoMarginId(sliderOpts) {\n return constants.autoMarginIdRoot + sliderOpts._index;\n}\n\n// This really only just filters by visibility:\nfunction makeSliderData(fullLayout, gd) {\n var contOpts = fullLayout[constants.name];\n var sliderData = [];\n\n for(var i = 0; i < contOpts.length; i++) {\n var item = contOpts[i];\n if(!item.visible) continue;\n item._gd = gd;\n sliderData.push(item);\n }\n\n return sliderData;\n}\n\n// This is set in the defaults step:\nfunction keyFunction(opts) {\n return opts._index;\n}\n\n// Compute the dimensions (mutates sliderOpts):\nfunction findDimensions(gd, sliderOpts) {\n var sliderLabels = Drawing.tester.selectAll('g.' + constants.labelGroupClass)\n .data(sliderOpts._visibleSteps);\n\n sliderLabels.enter().append('g')\n .classed(constants.labelGroupClass, true);\n\n // loop over fake buttons to find width / height\n var maxLabelWidth = 0;\n var labelHeight = 0;\n sliderLabels.each(function(stepOpts) {\n var labelGroup = d3.select(this);\n\n var text = drawLabel(labelGroup, {step: stepOpts}, sliderOpts);\n\n var textNode = text.node();\n if(textNode) {\n var bBox = Drawing.bBox(textNode);\n labelHeight = Math.max(labelHeight, bBox.height);\n maxLabelWidth = Math.max(maxLabelWidth, bBox.width);\n }\n });\n\n sliderLabels.remove();\n\n var dims = sliderOpts._dims = {};\n\n dims.inputAreaWidth = Math.max(\n constants.railWidth,\n constants.gripHeight\n );\n\n // calculate some overall dimensions - some of these are needed for\n // calculating the currentValue dimensions\n var graphSize = gd._fullLayout._size;\n dims.lx = graphSize.l + graphSize.w * sliderOpts.x;\n dims.ly = graphSize.t + graphSize.h * (1 - sliderOpts.y);\n\n if(sliderOpts.lenmode === 'fraction') {\n // fraction:\n dims.outerLength = Math.round(graphSize.w * sliderOpts.len);\n } else {\n // pixels:\n dims.outerLength = sliderOpts.len;\n }\n\n // The length of the rail, *excluding* padding on either end:\n dims.inputAreaStart = 0;\n dims.inputAreaLength = Math.round(dims.outerLength - sliderOpts.pad.l - sliderOpts.pad.r);\n\n var textableInputLength = dims.inputAreaLength - 2 * constants.stepInset;\n var availableSpacePerLabel = textableInputLength / (sliderOpts._stepCount - 1);\n var computedSpacePerLabel = maxLabelWidth + constants.labelPadding;\n dims.labelStride = Math.max(1, Math.ceil(computedSpacePerLabel / availableSpacePerLabel));\n dims.labelHeight = labelHeight;\n\n // loop over all possible values for currentValue to find the\n // area we need for it\n dims.currentValueMaxWidth = 0;\n dims.currentValueHeight = 0;\n dims.currentValueTotalHeight = 0;\n dims.currentValueMaxLines = 1;\n\n if(sliderOpts.currentvalue.visible) {\n // Get the dimensions of the current value label:\n var dummyGroup = Drawing.tester.append('g');\n\n sliderLabels.each(function(stepOpts) {\n var curValPrefix = drawCurrentValue(dummyGroup, sliderOpts, stepOpts.label);\n var curValSize = (curValPrefix.node() && Drawing.bBox(curValPrefix.node())) || {width: 0, height: 0};\n var lines = svgTextUtils.lineCount(curValPrefix);\n dims.currentValueMaxWidth = Math.max(dims.currentValueMaxWidth, Math.ceil(curValSize.width));\n dims.currentValueHeight = Math.max(dims.currentValueHeight, Math.ceil(curValSize.height));\n dims.currentValueMaxLines = Math.max(dims.currentValueMaxLines, lines);\n });\n\n dims.currentValueTotalHeight = dims.currentValueHeight + sliderOpts.currentvalue.offset;\n\n dummyGroup.remove();\n }\n\n dims.height = dims.currentValueTotalHeight + constants.tickOffset + sliderOpts.ticklen + constants.labelOffset + dims.labelHeight + sliderOpts.pad.t + sliderOpts.pad.b;\n\n var xanchor = 'left';\n if(Lib.isRightAnchor(sliderOpts)) {\n dims.lx -= dims.outerLength;\n xanchor = 'right';\n }\n if(Lib.isCenterAnchor(sliderOpts)) {\n dims.lx -= dims.outerLength / 2;\n xanchor = 'center';\n }\n\n var yanchor = 'top';\n if(Lib.isBottomAnchor(sliderOpts)) {\n dims.ly -= dims.height;\n yanchor = 'bottom';\n }\n if(Lib.isMiddleAnchor(sliderOpts)) {\n dims.ly -= dims.height / 2;\n yanchor = 'middle';\n }\n\n dims.outerLength = Math.ceil(dims.outerLength);\n dims.height = Math.ceil(dims.height);\n dims.lx = Math.round(dims.lx);\n dims.ly = Math.round(dims.ly);\n\n var marginOpts = {\n y: sliderOpts.y,\n b: dims.height * FROM_BR[yanchor],\n t: dims.height * FROM_TL[yanchor]\n };\n\n if(sliderOpts.lenmode === 'fraction') {\n marginOpts.l = 0;\n marginOpts.xl = sliderOpts.x - sliderOpts.len * FROM_TL[xanchor];\n marginOpts.r = 0;\n marginOpts.xr = sliderOpts.x + sliderOpts.len * FROM_BR[xanchor];\n } else {\n marginOpts.x = sliderOpts.x;\n marginOpts.l = dims.outerLength * FROM_TL[xanchor];\n marginOpts.r = dims.outerLength * FROM_BR[xanchor];\n }\n\n Plots.autoMargin(gd, autoMarginId(sliderOpts), marginOpts);\n}\n\nfunction drawSlider(gd, sliderGroup, sliderOpts) {\n // This is related to the other long notes in this file regarding what happens\n // when slider steps disappear. This particular fix handles what happens when\n // the *current* slider step is removed. The drawing functions will error out\n // when they fail to find it, so the fix for now is that it will just draw the\n // slider in the first position but will not execute the command.\n if(!((sliderOpts.steps[sliderOpts.active] || {}).visible)) {\n sliderOpts.active = sliderOpts._visibleSteps[0]._index;\n }\n\n // These are carefully ordered for proper z-ordering:\n sliderGroup\n .call(drawCurrentValue, sliderOpts)\n .call(drawRail, sliderOpts)\n .call(drawLabelGroup, sliderOpts)\n .call(drawTicks, sliderOpts)\n .call(drawTouchRect, gd, sliderOpts)\n .call(drawGrip, gd, sliderOpts);\n\n var dims = sliderOpts._dims;\n\n // Position the rectangle:\n Drawing.setTranslate(sliderGroup, dims.lx + sliderOpts.pad.l, dims.ly + sliderOpts.pad.t);\n\n sliderGroup.call(setGripPosition, sliderOpts, false);\n sliderGroup.call(drawCurrentValue, sliderOpts);\n}\n\nfunction drawCurrentValue(sliderGroup, sliderOpts, valueOverride) {\n if(!sliderOpts.currentvalue.visible) return;\n\n var dims = sliderOpts._dims;\n var x0, textAnchor;\n\n switch(sliderOpts.currentvalue.xanchor) {\n case 'right':\n // This is anchored left and adjusted by the width of the longest label\n // so that the prefix doesn't move. The goal of this is to emphasize\n // what's actually changing and make the update less distracting.\n x0 = dims.inputAreaLength - constants.currentValueInset - dims.currentValueMaxWidth;\n textAnchor = 'left';\n break;\n case 'center':\n x0 = dims.inputAreaLength * 0.5;\n textAnchor = 'middle';\n break;\n default:\n x0 = constants.currentValueInset;\n textAnchor = 'left';\n }\n\n var text = Lib.ensureSingle(sliderGroup, 'text', constants.labelClass, function(s) {\n s.classed('user-select-none', true)\n .attr({\n 'text-anchor': textAnchor,\n 'data-notex': 1\n });\n });\n\n var str = sliderOpts.currentvalue.prefix ? sliderOpts.currentvalue.prefix : '';\n\n if(typeof valueOverride === 'string') {\n str += valueOverride;\n } else {\n var curVal = sliderOpts.steps[sliderOpts.active].label;\n var _meta = sliderOpts._gd._fullLayout._meta;\n if(_meta) curVal = Lib.templateString(curVal, _meta);\n str += curVal;\n }\n\n if(sliderOpts.currentvalue.suffix) {\n str += sliderOpts.currentvalue.suffix;\n }\n\n text.call(Drawing.font, sliderOpts.currentvalue.font)\n .text(str)\n .call(svgTextUtils.convertToTspans, sliderOpts._gd);\n\n var lines = svgTextUtils.lineCount(text);\n\n var y0 = (dims.currentValueMaxLines + 1 - lines) *\n sliderOpts.currentvalue.font.size * LINE_SPACING;\n\n svgTextUtils.positionText(text, x0, y0);\n\n return text;\n}\n\nfunction drawGrip(sliderGroup, gd, sliderOpts) {\n var grip = Lib.ensureSingle(sliderGroup, 'rect', constants.gripRectClass, function(s) {\n s.call(attachGripEvents, gd, sliderGroup, sliderOpts)\n .style('pointer-events', 'all');\n });\n\n grip.attr({\n width: constants.gripWidth,\n height: constants.gripHeight,\n rx: constants.gripRadius,\n ry: constants.gripRadius,\n })\n .call(Color.stroke, sliderOpts.bordercolor)\n .call(Color.fill, sliderOpts.bgcolor)\n .style('stroke-width', sliderOpts.borderwidth + 'px');\n}\n\nfunction drawLabel(item, data, sliderOpts) {\n var text = Lib.ensureSingle(item, 'text', constants.labelClass, function(s) {\n s.classed('user-select-none', true)\n .attr({\n 'text-anchor': 'middle',\n 'data-notex': 1\n });\n });\n\n var tx = data.step.label;\n var _meta = sliderOpts._gd._fullLayout._meta;\n if(_meta) tx = Lib.templateString(tx, _meta);\n\n text.call(Drawing.font, sliderOpts.font)\n .text(tx)\n .call(svgTextUtils.convertToTspans, sliderOpts._gd);\n\n return text;\n}\n\nfunction drawLabelGroup(sliderGroup, sliderOpts) {\n var labels = Lib.ensureSingle(sliderGroup, 'g', constants.labelsClass);\n var dims = sliderOpts._dims;\n\n var labelItems = labels.selectAll('g.' + constants.labelGroupClass)\n .data(dims.labelSteps);\n\n labelItems.enter().append('g')\n .classed(constants.labelGroupClass, true);\n\n labelItems.exit().remove();\n\n labelItems.each(function(d) {\n var item = d3.select(this);\n\n item.call(drawLabel, d, sliderOpts);\n\n Drawing.setTranslate(item,\n normalizedValueToPosition(sliderOpts, d.fraction),\n constants.tickOffset +\n sliderOpts.ticklen +\n // position is the baseline of the top line of text only, even\n // if the label spans multiple lines\n sliderOpts.font.size * LINE_SPACING +\n constants.labelOffset +\n dims.currentValueTotalHeight\n );\n });\n}\n\nfunction handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, doTransition) {\n var quantizedPosition = Math.round(normalizedPosition * (sliderOpts._stepCount - 1));\n var quantizedIndex = sliderOpts._visibleSteps[quantizedPosition]._index;\n\n if(quantizedIndex !== sliderOpts.active) {\n setActive(gd, sliderGroup, sliderOpts, quantizedIndex, true, doTransition);\n }\n}\n\nfunction setActive(gd, sliderGroup, sliderOpts, index, doCallback, doTransition) {\n var previousActive = sliderOpts.active;\n sliderOpts.active = index;\n\n // due to templating, it's possible this slider doesn't even exist yet\n arrayEditor(gd.layout, constants.name, sliderOpts)\n .applyUpdate('active', index);\n\n var step = sliderOpts.steps[sliderOpts.active];\n\n sliderGroup.call(setGripPosition, sliderOpts, doTransition);\n sliderGroup.call(drawCurrentValue, sliderOpts);\n\n gd.emit('plotly_sliderchange', {\n slider: sliderOpts,\n step: sliderOpts.steps[sliderOpts.active],\n interaction: doCallback,\n previousActive: previousActive\n });\n\n if(step && step.method && doCallback) {\n if(sliderGroup._nextMethod) {\n // If we've already queued up an update, just overwrite it with the most recent:\n sliderGroup._nextMethod.step = step;\n sliderGroup._nextMethod.doCallback = doCallback;\n sliderGroup._nextMethod.doTransition = doTransition;\n } else {\n sliderGroup._nextMethod = {step: step, doCallback: doCallback, doTransition: doTransition};\n sliderGroup._nextMethodRaf = window.requestAnimationFrame(function() {\n var _step = sliderGroup._nextMethod.step;\n if(!_step.method) return;\n\n if(_step.execute) {\n Plots.executeAPICommand(gd, _step.method, _step.args);\n }\n\n sliderGroup._nextMethod = null;\n sliderGroup._nextMethodRaf = null;\n });\n }\n }\n}\n\nfunction attachGripEvents(item, gd, sliderGroup) {\n var node = sliderGroup.node();\n var $gd = d3.select(gd);\n\n // NB: This is *not* the same as sliderOpts itself! These callbacks\n // are in a closure so this array won't actually be correct if the\n // steps have changed since this was initialized. The sliderGroup,\n // however, has not changed since that *is* the slider, so it must\n // be present to receive mouse events.\n function getSliderOpts() {\n return sliderGroup.data()[0];\n }\n\n item.on('mousedown', function() {\n var sliderOpts = getSliderOpts();\n gd.emit('plotly_sliderstart', {slider: sliderOpts});\n\n var grip = sliderGroup.select('.' + constants.gripRectClass);\n\n d3.event.stopPropagation();\n d3.event.preventDefault();\n grip.call(Color.fill, sliderOpts.activebgcolor);\n\n var normalizedPosition = positionToNormalizedValue(sliderOpts, d3.mouse(node)[0]);\n handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, true);\n sliderOpts._dragging = true;\n\n $gd.on('mousemove', function() {\n var sliderOpts = getSliderOpts();\n var normalizedPosition = positionToNormalizedValue(sliderOpts, d3.mouse(node)[0]);\n handleInput(gd, sliderGroup, sliderOpts, normalizedPosition, false);\n });\n\n $gd.on('mouseup', function() {\n var sliderOpts = getSliderOpts();\n sliderOpts._dragging = false;\n grip.call(Color.fill, sliderOpts.bgcolor);\n $gd.on('mouseup', null);\n $gd.on('mousemove', null);\n\n gd.emit('plotly_sliderend', {\n slider: sliderOpts,\n step: sliderOpts.steps[sliderOpts.active]\n });\n });\n });\n}\n\nfunction drawTicks(sliderGroup, sliderOpts) {\n var tick = sliderGroup.selectAll('rect.' + constants.tickRectClass)\n .data(sliderOpts._visibleSteps);\n var dims = sliderOpts._dims;\n\n tick.enter().append('rect')\n .classed(constants.tickRectClass, true);\n\n tick.exit().remove();\n\n tick.attr({\n width: sliderOpts.tickwidth + 'px',\n 'shape-rendering': 'crispEdges'\n });\n\n tick.each(function(d, i) {\n var isMajor = i % dims.labelStride === 0;\n var item = d3.select(this);\n\n item\n .attr({height: isMajor ? sliderOpts.ticklen : sliderOpts.minorticklen})\n .call(Color.fill, isMajor ? sliderOpts.tickcolor : sliderOpts.tickcolor);\n\n Drawing.setTranslate(item,\n normalizedValueToPosition(sliderOpts, i / (sliderOpts._stepCount - 1)) - 0.5 * sliderOpts.tickwidth,\n (isMajor ? constants.tickOffset : constants.minorTickOffset) + dims.currentValueTotalHeight\n );\n });\n}\n\nfunction computeLabelSteps(sliderOpts) {\n var dims = sliderOpts._dims;\n dims.labelSteps = [];\n var nsteps = sliderOpts._stepCount;\n\n for(var i = 0; i < nsteps; i += dims.labelStride) {\n dims.labelSteps.push({\n fraction: i / (nsteps - 1),\n step: sliderOpts._visibleSteps[i]\n });\n }\n}\n\nfunction setGripPosition(sliderGroup, sliderOpts, doTransition) {\n var grip = sliderGroup.select('rect.' + constants.gripRectClass);\n\n var quantizedIndex = 0;\n for(var i = 0; i < sliderOpts._stepCount; i++) {\n if(sliderOpts._visibleSteps[i]._index === sliderOpts.active) {\n quantizedIndex = i;\n break;\n }\n }\n\n var x = normalizedValueToPosition(sliderOpts, quantizedIndex / (sliderOpts._stepCount - 1));\n\n // If this is true, then *this component* is already invoking its own command\n // and has triggered its own animation.\n if(sliderOpts._invokingCommand) return;\n\n var el = grip;\n if(doTransition && sliderOpts.transition.duration > 0) {\n el = el.transition()\n .duration(sliderOpts.transition.duration)\n .ease(sliderOpts.transition.easing);\n }\n\n // Drawing.setTranslate doesn't work here becasue of the transition duck-typing.\n // It's also not necessary because there are no other transitions to preserve.\n el.attr('transform', 'translate(' + (x - constants.gripWidth * 0.5) + ',' + (sliderOpts._dims.currentValueTotalHeight) + ')');\n}\n\n// Convert a number from [0-1] to a pixel position relative to the slider group container:\nfunction normalizedValueToPosition(sliderOpts, normalizedPosition) {\n var dims = sliderOpts._dims;\n return dims.inputAreaStart + constants.stepInset +\n (dims.inputAreaLength - 2 * constants.stepInset) * Math.min(1, Math.max(0, normalizedPosition));\n}\n\n// Convert a position relative to the slider group to a nubmer in [0, 1]\nfunction positionToNormalizedValue(sliderOpts, position) {\n var dims = sliderOpts._dims;\n return Math.min(1, Math.max(0, (position - constants.stepInset - dims.inputAreaStart) / (dims.inputAreaLength - 2 * constants.stepInset - 2 * dims.inputAreaStart)));\n}\n\nfunction drawTouchRect(sliderGroup, gd, sliderOpts) {\n var dims = sliderOpts._dims;\n var rect = Lib.ensureSingle(sliderGroup, 'rect', constants.railTouchRectClass, function(s) {\n s.call(attachGripEvents, gd, sliderGroup, sliderOpts)\n .style('pointer-events', 'all');\n });\n\n rect.attr({\n width: dims.inputAreaLength,\n height: Math.max(dims.inputAreaWidth, constants.tickOffset + sliderOpts.ticklen + dims.labelHeight)\n })\n .call(Color.fill, sliderOpts.bgcolor)\n .attr('opacity', 0);\n\n Drawing.setTranslate(rect, 0, dims.currentValueTotalHeight);\n}\n\nfunction drawRail(sliderGroup, sliderOpts) {\n var dims = sliderOpts._dims;\n var computedLength = dims.inputAreaLength - constants.railInset * 2;\n var rect = Lib.ensureSingle(sliderGroup, 'rect', constants.railRectClass);\n\n rect.attr({\n width: computedLength,\n height: constants.railWidth,\n rx: constants.railRadius,\n ry: constants.railRadius,\n 'shape-rendering': 'crispEdges'\n })\n .call(Color.stroke, sliderOpts.bordercolor)\n .call(Color.fill, sliderOpts.bgcolor)\n .style('stroke-width', sliderOpts.borderwidth + 'px');\n\n Drawing.setTranslate(rect,\n constants.railInset,\n (dims.inputAreaWidth - constants.railWidth) * 0.5 + dims.currentValueTotalHeight\n );\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Drawing = require('../../components/drawing');\nvar Axes = require('./axes');\n\n/**\n * transitionAxes\n *\n * transition axes from one set of ranges to another, using a svg\n * transformations, similar to during panning.\n *\n * @param {DOM element | object} gd\n * @param {array} edits : array of 'edits', each item with\n * - plotinfo {object} subplot object\n * - xr0 {array} initial x-range\n * - xr1 {array} end x-range\n * - yr0 {array} initial y-range\n * - yr1 {array} end y-range\n * @param {object} transitionOpts\n * @param {function} makeOnCompleteCallback\n */\nmodule.exports = function transitionAxes(gd, edits, transitionOpts, makeOnCompleteCallback) {\n var fullLayout = gd._fullLayout;\n\n // special case for redraw:false Plotly.animate that relies on this\n // to update axis-referenced layout components\n if(edits.length === 0) {\n Axes.redrawComponents(gd);\n return;\n }\n\n function unsetSubplotTransform(subplot) {\n var xa = subplot.xaxis;\n var ya = subplot.yaxis;\n\n fullLayout._defs.select('#' + subplot.clipId + '> rect')\n .call(Drawing.setTranslate, 0, 0)\n .call(Drawing.setScale, 1, 1);\n\n subplot.plot\n .call(Drawing.setTranslate, xa._offset, ya._offset)\n .call(Drawing.setScale, 1, 1);\n\n var traceGroups = subplot.plot.selectAll('.scatterlayer .trace');\n\n // This is specifically directed at scatter traces, applying an inverse\n // scale to individual points to counteract the scale of the trace\n // as a whole:\n traceGroups.selectAll('.point')\n .call(Drawing.setPointGroupScale, 1, 1);\n traceGroups.selectAll('.textpoint')\n .call(Drawing.setTextPointsScale, 1, 1);\n traceGroups\n .call(Drawing.hideOutsideRangePoints, subplot);\n }\n\n function updateSubplot(edit, progress) {\n var plotinfo = edit.plotinfo;\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xlen = xa._length;\n var ylen = ya._length;\n var editX = !!edit.xr1;\n var editY = !!edit.yr1;\n var viewBox = [];\n\n if(editX) {\n var xr0 = Lib.simpleMap(edit.xr0, xa.r2l);\n var xr1 = Lib.simpleMap(edit.xr1, xa.r2l);\n var dx0 = xr0[1] - xr0[0];\n var dx1 = xr1[1] - xr1[0];\n viewBox[0] = (xr0[0] * (1 - progress) + progress * xr1[0] - xr0[0]) / (xr0[1] - xr0[0]) * xlen;\n viewBox[2] = xlen * ((1 - progress) + progress * dx1 / dx0);\n xa.range[0] = xa.l2r(xr0[0] * (1 - progress) + progress * xr1[0]);\n xa.range[1] = xa.l2r(xr0[1] * (1 - progress) + progress * xr1[1]);\n } else {\n viewBox[0] = 0;\n viewBox[2] = xlen;\n }\n\n if(editY) {\n var yr0 = Lib.simpleMap(edit.yr0, ya.r2l);\n var yr1 = Lib.simpleMap(edit.yr1, ya.r2l);\n var dy0 = yr0[1] - yr0[0];\n var dy1 = yr1[1] - yr1[0];\n viewBox[1] = (yr0[1] * (1 - progress) + progress * yr1[1] - yr0[1]) / (yr0[0] - yr0[1]) * ylen;\n viewBox[3] = ylen * ((1 - progress) + progress * dy1 / dy0);\n ya.range[0] = xa.l2r(yr0[0] * (1 - progress) + progress * yr1[0]);\n ya.range[1] = ya.l2r(yr0[1] * (1 - progress) + progress * yr1[1]);\n } else {\n viewBox[1] = 0;\n viewBox[3] = ylen;\n }\n\n Axes.drawOne(gd, xa, {skipTitle: true});\n Axes.drawOne(gd, ya, {skipTitle: true});\n Axes.redrawComponents(gd, [xa._id, ya._id]);\n\n var xScaleFactor = editX ? xlen / viewBox[2] : 1;\n var yScaleFactor = editY ? ylen / viewBox[3] : 1;\n var clipDx = editX ? viewBox[0] : 0;\n var clipDy = editY ? viewBox[1] : 0;\n var fracDx = editX ? (viewBox[0] / viewBox[2] * xlen) : 0;\n var fracDy = editY ? (viewBox[1] / viewBox[3] * ylen) : 0;\n var plotDx = xa._offset - fracDx;\n var plotDy = ya._offset - fracDy;\n\n plotinfo.clipRect\n .call(Drawing.setTranslate, clipDx, clipDy)\n .call(Drawing.setScale, 1 / xScaleFactor, 1 / yScaleFactor);\n\n plotinfo.plot\n .call(Drawing.setTranslate, plotDx, plotDy)\n .call(Drawing.setScale, xScaleFactor, yScaleFactor);\n\n // apply an inverse scale to individual points to counteract\n // the scale of the trace group.\n Drawing.setPointGroupScale(plotinfo.zoomScalePts, 1 / xScaleFactor, 1 / yScaleFactor);\n Drawing.setTextPointsScale(plotinfo.zoomScaleTxt, 1 / xScaleFactor, 1 / yScaleFactor);\n }\n\n var onComplete;\n if(makeOnCompleteCallback) {\n // This module makes the choice whether or not it notifies Plotly.transition\n // about completion:\n onComplete = makeOnCompleteCallback();\n }\n\n function transitionComplete() {\n var aobj = {};\n\n for(var i = 0; i < edits.length; i++) {\n var edit = edits[i];\n var xa = edit.plotinfo.xaxis;\n var ya = edit.plotinfo.yaxis;\n if(edit.xr1) aobj[xa._name + '.range'] = edit.xr1.slice();\n if(edit.yr1) aobj[ya._name + '.range'] = edit.yr1.slice();\n }\n\n // Signal that this transition has completed:\n onComplete && onComplete();\n\n return Registry.call('relayout', gd, aobj).then(function() {\n for(var i = 0; i < edits.length; i++) {\n unsetSubplotTransform(edits[i].plotinfo);\n }\n });\n }\n\n function transitionInterrupt() {\n var aobj = {};\n\n for(var i = 0; i < edits.length; i++) {\n var edit = edits[i];\n var xa = edit.plotinfo.xaxis;\n var ya = edit.plotinfo.yaxis;\n if(edit.xr0) aobj[xa._name + '.range'] = edit.xr0.slice();\n if(edit.yr0) aobj[ya._name + '.range'] = edit.yr0.slice();\n }\n\n return Registry.call('relayout', gd, aobj).then(function() {\n for(var i = 0; i < edits.length; i++) {\n unsetSubplotTransform(edits[i].plotinfo);\n }\n });\n }\n\n var t1, t2, raf;\n var easeFn = d3.ease(transitionOpts.easing);\n\n gd._transitionData._interruptCallbacks.push(function() {\n window.cancelAnimationFrame(raf);\n raf = null;\n return transitionInterrupt();\n });\n\n function doFrame() {\n t2 = Date.now();\n\n var tInterp = Math.min(1, (t2 - t1) / transitionOpts.duration);\n var progress = easeFn(tInterp);\n\n for(var i = 0; i < edits.length; i++) {\n updateSubplot(edits[i], progress);\n }\n\n if(t2 - t1 > transitionOpts.duration) {\n transitionComplete();\n raf = window.cancelAnimationFrame(doFrame);\n } else {\n raf = window.requestAnimationFrame(doFrame);\n }\n }\n\n t1 = Date.now();\n raf = window.requestAnimationFrame(doFrame);\n\n return Promise.resolve();\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\n\n\nmodule.exports = function handlePositionDefaults(containerIn, containerOut, coerce, options) {\n var counterAxes = options.counterAxes || [];\n var overlayableAxes = options.overlayableAxes || [];\n var letter = options.letter;\n var grid = options.grid;\n\n var dfltAnchor, dfltDomain, dfltSide, dfltPosition;\n\n if(grid) {\n dfltDomain = grid._domains[letter][grid._axisMap[containerOut._id]];\n dfltAnchor = grid._anchors[containerOut._id];\n if(dfltDomain) {\n dfltSide = grid[letter + 'side'].split(' ')[0];\n dfltPosition = grid.domain[letter][dfltSide === 'right' || dfltSide === 'top' ? 1 : 0];\n }\n }\n\n // Even if there's a grid, this axis may not be in it - fall back on non-grid defaults\n dfltDomain = dfltDomain || [0, 1];\n dfltAnchor = dfltAnchor || (isNumeric(containerIn.position) ? 'free' : (counterAxes[0] || 'free'));\n dfltSide = dfltSide || (letter === 'x' ? 'bottom' : 'left');\n dfltPosition = dfltPosition || 0;\n\n var anchor = Lib.coerce(containerIn, containerOut, {\n anchor: {\n valType: 'enumerated',\n values: ['free'].concat(counterAxes),\n dflt: dfltAnchor\n }\n }, 'anchor');\n\n if(anchor === 'free') coerce('position', dfltPosition);\n\n Lib.coerce(containerIn, containerOut, {\n side: {\n valType: 'enumerated',\n values: letter === 'x' ? ['bottom', 'top'] : ['left', 'right'],\n dflt: dfltSide\n }\n }, 'side');\n\n var overlaying = false;\n if(overlayableAxes.length) {\n overlaying = Lib.coerce(containerIn, containerOut, {\n overlaying: {\n valType: 'enumerated',\n values: [false].concat(overlayableAxes),\n dflt: false\n }\n }, 'overlaying');\n }\n\n if(!overlaying) {\n // TODO: right now I'm copying this domain over to overlaying axes\n // in ax.setscale()... but this means we still need (imperfect) logic\n // in the axes popover to hide domain for the overlaying axis.\n // perhaps I should make a private version _domain that all axes get???\n var domain = coerce('domain', dfltDomain);\n\n // according to https://www.npmjs.com/package/canvas-size\n // the minimum value of max canvas width across browsers and devices is 4096\n // which applied in the calculation below:\n if(domain[0] > domain[1] - 1 / 4096) containerOut.domain = dfltDomain;\n Lib.noneOrAll(containerIn.domain, containerOut.domain, dfltDomain);\n }\n\n coerce('layer');\n\n return containerOut;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n// fraction of some size to get to a named position\nmodule.exports = {\n // from bottom left: this is the origin of our paper-reference\n // positioning system\n FROM_BL: {\n left: 0,\n center: 0.5,\n right: 1,\n bottom: 0,\n middle: 0.5,\n top: 1\n },\n // from top left: this is the screen pixel positioning origin\n FROM_TL: {\n left: 0,\n center: 0.5,\n right: 1,\n bottom: 1,\n middle: 0.5,\n top: 0\n },\n // from bottom right: sometimes you just need the opposite of ^^\n FROM_BR: {\n left: 1,\n center: 0.5,\n right: 0,\n bottom: 0,\n middle: 0.5,\n top: 1\n },\n // multiple of fontSize to get the vertical offset between lines\n LINE_SPACING: 1.3,\n\n // multiple of fontSize to shift from the baseline\n // to the cap (captical letter) line\n // (to use when we don't calculate this shift from Drawing.bBox)\n // This is an approximation since in reality cap height can differ\n // from font to font. However, according to Wikipedia\n // an \"average\" font might have a cap height of 70% of the em\n // https://en.wikipedia.org/wiki/Em_(typography)#History\n CAP_SHIFT: 0.70,\n\n // half the cap height (distance between baseline and cap line)\n // of an \"average\" font (for more info see above).\n MID_SHIFT: 0.35,\n\n OPPOSITE_SIDE: {\n left: 'right',\n right: 'left',\n top: 'bottom',\n bottom: 'top'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isPlainObject = require('../lib/is_plain_object');\nvar noop = require('../lib/noop');\nvar Loggers = require('../lib/loggers');\nvar sorterAsc = require('../lib/search').sorterAsc;\nvar Registry = require('../registry');\n\n\nexports.containerArrayMatch = require('./container_array_match');\n\nvar isAddVal = exports.isAddVal = function isAddVal(val) {\n return val === 'add' || isPlainObject(val);\n};\n\nvar isRemoveVal = exports.isRemoveVal = function isRemoveVal(val) {\n return val === null || val === 'remove';\n};\n\n/*\n * applyContainerArrayChanges: for managing arrays of layout components in relayout\n * handles them all with a consistent interface.\n *\n * Here are the supported actions -> relayout calls -> edits we get here\n * (as prepared in _relayout):\n *\n * add an empty obj -> {'annotations[2]': 'add'} -> {2: {'': 'add'}}\n * add a specific obj -> {'annotations[2]': {attrs}} -> {2: {'': {attrs}}}\n * delete an obj -> {'annotations[2]': 'remove'} -> {2: {'': 'remove'}}\n * -> {'annotations[2]': null} -> {2: {'': null}}\n * delete the whole array -> {'annotations': 'remove'} -> {'': {'': 'remove'}}\n * -> {'annotations': null} -> {'': {'': null}}\n * edit an object -> {'annotations[2].text': 'boo'} -> {2: {'text': 'boo'}}\n *\n * You can combine many edits to different objects. Objects are added and edited\n * in ascending order, then removed in descending order.\n * For example, starting with [a, b, c], if you want to:\n * - replace b with d:\n * {'annotations[1]': d, 'annotations[2]': null} (b is item 2 after adding d)\n * - add a new item d between a and b, and edit b:\n * {'annotations[1]': d, 'annotations[2].x': newX} (b is item 2 after adding d)\n * - delete b and edit c:\n * {'annotations[1]': null, 'annotations[2].x': newX} (c is edited before b is removed)\n *\n * You CANNOT combine adding/deleting an item at index `i` with edits to the same index `i`\n * You CANNOT combine replacing/deleting the whole array with anything else (for the same array).\n *\n * @param {HTMLDivElement} gd\n * the DOM element of the graph container div\n * @param {Lib.nestedProperty} componentType: the array we are editing\n * @param {Object} edits\n * the changes to make; keys are indices to edit, values are themselves objects:\n * {attr: newValue} of changes to make to that index (with add/remove behavior\n * in special values of the empty attr)\n * @param {Object} flags\n * the flags for which actions we're going to perform to display these (and\n * any other) changes. If we're already `recalc`ing, we don't need to redraw\n * individual items\n * @param {function} _nestedProperty\n * a (possibly modified for gui edits) nestedProperty constructor\n * The modified version takes a 3rd argument, for a prefix to the attribute\n * string necessary for storing GUI edits\n *\n * @returns {bool} `true` if it managed to complete drawing of the changes\n * `false` would mean the parent should replot.\n */\nexports.applyContainerArrayChanges = function applyContainerArrayChanges(gd, np, edits, flags, _nestedProperty) {\n var componentType = np.astr;\n var supplyComponentDefaults = Registry.getComponentMethod(componentType, 'supplyLayoutDefaults');\n var draw = Registry.getComponentMethod(componentType, 'draw');\n var drawOne = Registry.getComponentMethod(componentType, 'drawOne');\n var replotLater = flags.replot || flags.recalc || (supplyComponentDefaults === noop) || (draw === noop);\n var layout = gd.layout;\n var fullLayout = gd._fullLayout;\n\n if(edits['']) {\n if(Object.keys(edits).length > 1) {\n Loggers.warn('Full array edits are incompatible with other edits',\n componentType);\n }\n\n var fullVal = edits[''][''];\n\n if(isRemoveVal(fullVal)) np.set(null);\n else if(Array.isArray(fullVal)) np.set(fullVal);\n else {\n Loggers.warn('Unrecognized full array edit value', componentType, fullVal);\n return true;\n }\n\n if(replotLater) return false;\n\n supplyComponentDefaults(layout, fullLayout);\n draw(gd);\n return true;\n }\n\n var componentNums = Object.keys(edits).map(Number).sort(sorterAsc);\n var componentArrayIn = np.get();\n var componentArray = componentArrayIn || [];\n // componentArrayFull is used just to keep splices in line between\n // full and input arrays, so private keys can be copied over after\n // redoing supplyDefaults\n // TODO: this assumes componentArray is in gd.layout - which will not be\n // true after we extend this to restyle\n var componentArrayFull = _nestedProperty(fullLayout, componentType).get();\n\n var deletes = [];\n var firstIndexChange = -1;\n var maxIndex = componentArray.length;\n var i;\n var j;\n var componentNum;\n var objEdits;\n var objKeys;\n var objVal;\n var adding, prefix;\n\n // first make the add and edit changes\n for(i = 0; i < componentNums.length; i++) {\n componentNum = componentNums[i];\n objEdits = edits[componentNum];\n objKeys = Object.keys(objEdits);\n objVal = objEdits[''],\n adding = isAddVal(objVal);\n\n if(componentNum < 0 || componentNum > componentArray.length - (adding ? 0 : 1)) {\n Loggers.warn('index out of range', componentType, componentNum);\n continue;\n }\n\n if(objVal !== undefined) {\n if(objKeys.length > 1) {\n Loggers.warn(\n 'Insertion & removal are incompatible with edits to the same index.',\n componentType, componentNum);\n }\n\n if(isRemoveVal(objVal)) {\n deletes.push(componentNum);\n } else if(adding) {\n if(objVal === 'add') objVal = {};\n componentArray.splice(componentNum, 0, objVal);\n if(componentArrayFull) componentArrayFull.splice(componentNum, 0, {});\n } else {\n Loggers.warn('Unrecognized full object edit value',\n componentType, componentNum, objVal);\n }\n\n if(firstIndexChange === -1) firstIndexChange = componentNum;\n } else {\n for(j = 0; j < objKeys.length; j++) {\n prefix = componentType + '[' + componentNum + '].';\n _nestedProperty(componentArray[componentNum], objKeys[j], prefix)\n .set(objEdits[objKeys[j]]);\n }\n }\n }\n\n // now do deletes\n for(i = deletes.length - 1; i >= 0; i--) {\n componentArray.splice(deletes[i], 1);\n // TODO: this drops private keys that had been stored in componentArrayFull\n // does this have any ill effects?\n if(componentArrayFull) componentArrayFull.splice(deletes[i], 1);\n }\n\n if(!componentArray.length) np.set(null);\n else if(!componentArrayIn) np.set(componentArray);\n\n if(replotLater) return false;\n\n supplyComponentDefaults(layout, fullLayout);\n\n // finally draw all the components we need to\n // if we added or removed any, redraw all after it\n if(drawOne !== noop) {\n var indicesToDraw;\n if(firstIndexChange === -1) {\n // there's no re-indexing to do, so only redraw components that changed\n indicesToDraw = componentNums;\n } else {\n // in case the component array was shortened, we still need do call\n // drawOne on the latter items so they get properly removed\n maxIndex = Math.max(componentArray.length, maxIndex);\n indicesToDraw = [];\n for(i = 0; i < componentNums.length; i++) {\n componentNum = componentNums[i];\n if(componentNum >= firstIndexChange) break;\n indicesToDraw.push(componentNum);\n }\n for(i = firstIndexChange; i < maxIndex; i++) {\n indicesToDraw.push(i);\n }\n }\n for(i = 0; i < indicesToDraw.length; i++) {\n drawOne(gd, indicesToDraw[i]);\n }\n } else draw(gd);\n\n return true;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\n\n\n// arrayOk attributes, merge them into calcdata array\nmodule.exports = function arraysToCalcdata(cd, trace) {\n // so each point knows which index it originally came from\n for(var i = 0; i < cd.length; i++) cd[i].i = i;\n\n Lib.mergeArray(trace.text, cd, 'tx');\n Lib.mergeArray(trace.texttemplate, cd, 'txt');\n Lib.mergeArray(trace.hovertext, cd, 'htx');\n Lib.mergeArray(trace.customdata, cd, 'data');\n Lib.mergeArray(trace.textposition, cd, 'tp');\n if(trace.textfont) {\n Lib.mergeArrayCastPositive(trace.textfont.size, cd, 'ts');\n Lib.mergeArray(trace.textfont.color, cd, 'tc');\n Lib.mergeArray(trace.textfont.family, cd, 'tf');\n }\n\n var marker = trace.marker;\n if(marker) {\n Lib.mergeArrayCastPositive(marker.size, cd, 'ms');\n Lib.mergeArrayCastPositive(marker.opacity, cd, 'mo');\n Lib.mergeArray(marker.symbol, cd, 'mx');\n Lib.mergeArray(marker.color, cd, 'mc');\n\n var markerLine = marker.line;\n if(marker.line) {\n Lib.mergeArray(markerLine.color, cd, 'mlc');\n Lib.mergeArrayCastPositive(markerLine.width, cd, 'mlw');\n }\n\n var markerGradient = marker.gradient;\n if(markerGradient && markerGradient.type !== 'none') {\n Lib.mergeArray(markerGradient.type, cd, 'mgt');\n Lib.mergeArray(markerGradient.color, cd, 'mgc');\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar colorbarAttrs = require('../colorbar/attributes');\nvar counterRegex = require('../../lib/regex').counter;\n\nvar palettes = require('./scales.js').scales;\nvar paletteStr = Object.keys(palettes);\n\nfunction code(s) {\n return '`' + s + '`';\n}\n\n/**\n * Make colorscale attribute declarations for\n *\n * - colorscale,\n * - (c|z)auto, (c|z)min, (c|z)max,\n * - autocolorscale, reversescale,\n * - showscale (optionally)\n * - color (optionally)\n *\n * @param {string} context (dflt: '', i.e. from trace root):\n * the container this is in ('', *marker*, *marker.line* etc)\n *\n * @param {object} opts:\n * - cLetter {string} (dflt: 'c'):\n * leading letter for 'min', 'max and 'auto' attribute (either 'z' or 'c')\n *\n * - colorAttr {string} (dflt: 'z' if `cLetter: 'z'`, 'color' if `cLetter: 'c'`):\n * (for descriptions) sets the name of the color attribute that maps to the colorscale.\n *\n * N.B. if `colorAttr: 'color'`, we include the `color` declaration here.\n *\n * - onlyIfNumerical {string} (dflt: false' if `cLetter: 'z'`, true if `cLetter: 'c'`):\n * (for descriptions) set to true if colorscale attribute only\n *\n * - colorscaleDflt {string}:\n * overrides the colorscale dflt\n *\n * - autoColorDflt {boolean} (dflt true):\n * normally autocolorscale.dflt is `true`, but pass `false` to override\n *\n * - noScale {boolean} (dflt: true if `context: 'marker.line'`, false otherwise):\n * set to `false` to not include showscale attribute (e.g. for 'marker.line')\n *\n * - showScaleDflt {boolean} (dflt: true if `cLetter: 'z'`, false otherwise)\n *\n * - editTypeOverride {boolean} (dflt: ''):\n * most of these attributes already require a recalc, but the ones that do not\n * have editType *style* or *plot* unless you override (presumably with *calc*)\n *\n * - anim {boolean) (dflt: undefined): is 'color' animatable?\n *\n * @return {object}\n */\nmodule.exports = function colorScaleAttrs(context, opts) {\n context = context || '';\n opts = opts || {};\n\n var cLetter = opts.cLetter || 'c';\n var onlyIfNumerical = ('onlyIfNumerical' in opts) ? opts.onlyIfNumerical : Boolean(context);\n var noScale = ('noScale' in opts) ? opts.noScale : context === 'marker.line';\n var showScaleDflt = ('showScaleDflt' in opts) ? opts.showScaleDflt : cLetter === 'z';\n var colorscaleDflt = typeof opts.colorscaleDflt === 'string' ? palettes[opts.colorscaleDflt] : null;\n var editTypeOverride = opts.editTypeOverride || '';\n var contextHead = context ? (context + '.') : '';\n\n var colorAttr, colorAttrFull;\n\n if('colorAttr' in opts) {\n colorAttr = opts.colorAttr;\n colorAttrFull = opts.colorAttr;\n } else {\n colorAttr = {z: 'z', c: 'color'}[cLetter];\n colorAttrFull = 'in ' + code(contextHead + colorAttr);\n }\n\n var effectDesc = onlyIfNumerical ?\n ' Has an effect only if ' + colorAttrFull + 'is set to a numerical array.' :\n '';\n\n var auto = cLetter + 'auto';\n var min = cLetter + 'min';\n var max = cLetter + 'max';\n var mid = cLetter + 'mid';\n var autoFull = code(contextHead + auto);\n var minFull = code(contextHead + min);\n var maxFull = code(contextHead + max);\n var minmaxFull = minFull + ' and ' + maxFull;\n var autoImpliedEdits = {};\n autoImpliedEdits[min] = autoImpliedEdits[max] = undefined;\n var minmaxImpliedEdits = {};\n minmaxImpliedEdits[auto] = false;\n\n var attrs = {};\n\n if(colorAttr === 'color') {\n attrs.color = {\n valType: 'color',\n arrayOk: true,\n role: 'style',\n editType: editTypeOverride || 'style',\n description: [\n 'Sets the', context, 'color.',\n ' It accepts either a specific color',\n ' or an array of numbers that are mapped to the colorscale',\n ' relative to the max and min values of the array or relative to',\n ' ' + minmaxFull + ' if set.'\n ].join('')\n };\n\n if(opts.anim) {\n attrs.color.anim = true;\n }\n }\n\n attrs[auto] = {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'calc',\n impliedEdits: autoImpliedEdits,\n description: [\n 'Determines whether or not the color domain is computed',\n ' with respect to the input data (here ' + colorAttrFull + ') or the bounds set in',\n ' ', minmaxFull,\n ' ', effectDesc,\n ' Defaults to `false` when ', minmaxFull, ' are set by the user.'\n ].join('')\n };\n\n attrs[min] = {\n valType: 'number',\n role: 'info',\n dflt: null,\n editType: editTypeOverride || 'plot',\n impliedEdits: minmaxImpliedEdits,\n description: [\n 'Sets the lower bound of the color domain.',\n effectDesc,\n ' Value should have the same units as ', colorAttrFull,\n ' and if set, ', maxFull, ' must be set as well.'\n ].join('')\n };\n\n attrs[max] = {\n valType: 'number',\n role: 'info',\n dflt: null,\n editType: editTypeOverride || 'plot',\n impliedEdits: minmaxImpliedEdits,\n description: [\n 'Sets the upper bound of the color domain.',\n effectDesc,\n ' Value should have the same units as ', colorAttrFull,\n ' and if set, ', minFull, ' must be set as well.'\n ].join('')\n };\n\n attrs[mid] = {\n valType: 'number',\n role: 'info',\n dflt: null,\n editType: 'calc',\n impliedEdits: autoImpliedEdits,\n description: [\n 'Sets the mid-point of the color domain by scaling ', minFull,\n ' and/or ', maxFull, ' to be equidistant to this point.',\n effectDesc,\n ' Value should have the same units as ', colorAttrFull, '. ',\n 'Has no effect when ', autoFull, ' is `false`.'\n ].join('')\n };\n\n attrs.colorscale = {\n valType: 'colorscale',\n role: 'style',\n editType: 'calc',\n dflt: colorscaleDflt,\n impliedEdits: {autocolorscale: false},\n description: [\n 'Sets the colorscale.',\n effectDesc,\n ' The colorscale must be an array containing',\n ' arrays mapping a normalized value to an',\n ' rgb, rgba, hex, hsl, hsv, or named color string.',\n ' At minimum, a mapping for the lowest (0) and highest (1)',\n ' values are required. For example,',\n ' `[[0, \\'rgb(0,0,255)\\'], [1, \\'rgb(255,0,0)\\']]`.',\n ' To control the bounds of the colorscale in color space,',\n ' use', minmaxFull, '.',\n ' Alternatively, `colorscale` may be a palette name string',\n ' of the following list: ' + paletteStr + '.'\n ].join('')\n };\n\n attrs.autocolorscale = {\n valType: 'boolean',\n role: 'style',\n // gets overrode in 'heatmap' & 'surface' for backwards comp.\n dflt: opts.autoColorDflt === false ? false : true,\n editType: 'calc',\n impliedEdits: {colorscale: undefined},\n description: [\n 'Determines whether the colorscale is a default palette (`autocolorscale: true`)',\n ' or the palette determined by ', code(contextHead + 'colorscale'), '.',\n effectDesc,\n ' In case `colorscale` is unspecified or `autocolorscale` is true, the default ',\n ' palette will be chosen according to whether numbers in the `color` array are',\n ' all positive, all negative or mixed.'\n ].join('')\n };\n\n attrs.reversescale = {\n valType: 'boolean',\n role: 'style',\n dflt: false,\n editType: 'plot',\n description: [\n 'Reverses the color mapping if true.',\n effectDesc,\n ' If true, ', minFull, ' will correspond to the last color',\n ' in the array and ', maxFull, ' will correspond to the first color.'\n ].join('')\n };\n\n if(!noScale) {\n attrs.showscale = {\n valType: 'boolean',\n role: 'info',\n dflt: showScaleDflt,\n editType: 'calc',\n description: [\n 'Determines whether or not a colorbar is displayed for this trace.',\n effectDesc\n ].join('')\n };\n\n attrs.colorbar = colorbarAttrs;\n }\n\n if(!opts.noColorAxis) {\n attrs.coloraxis = {\n valType: 'subplotid',\n role: 'info',\n regex: counterRegex('coloraxis'),\n dflt: null,\n editType: 'calc',\n description: [\n 'Sets a reference to a shared color axis.',\n 'References to these shared color axes are *coloraxis*, *coloraxis2*, *coloraxis3*, etc.',\n 'Settings for these shared color axes are set in the layout, under',\n '`layout.coloraxis`, `layout.coloraxis2`, etc.',\n 'Note that multiple color scales can be linked to the same color axis.'\n ].join(' ')\n };\n }\n\n return attrs;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\n/**\n * Factory function for checking component arrays for subplot references.\n *\n * @param {string} containerArrayName: the top-level array in gd.layout to check\n * If an item in this container is found that references a cartesian x and/or y axis,\n * ensure cartesian is marked as a base plot module and record the axes (and subplot\n * if both refs are axes) in gd._fullLayout\n *\n * @return {function}: with args layoutIn (gd.layout) and layoutOut (gd._fullLayout)\n * as expected of a component includeBasePlot method\n */\nmodule.exports = function makeIncludeComponents(containerArrayName) {\n return function includeComponents(layoutIn, layoutOut) {\n var array = layoutIn[containerArrayName];\n if(!Array.isArray(array)) return;\n\n var Cartesian = Registry.subplotsRegistry.cartesian;\n var idRegex = Cartesian.idRegex;\n var subplots = layoutOut._subplots;\n var xaList = subplots.xaxis;\n var yaList = subplots.yaxis;\n var cartesianList = subplots.cartesian;\n var hasCartesianOrGL2D = layoutOut._has('cartesian') || layoutOut._has('gl2d');\n\n for(var i = 0; i < array.length; i++) {\n var itemi = array[i];\n if(!Lib.isPlainObject(itemi)) continue;\n\n var xref = itemi.xref;\n var yref = itemi.yref;\n\n var hasXref = idRegex.x.test(xref);\n var hasYref = idRegex.y.test(yref);\n if(hasXref || hasYref) {\n if(!hasCartesianOrGL2D) Lib.pushUnique(layoutOut._basePlotModules, Cartesian);\n\n var newAxis = false;\n if(hasXref && xaList.indexOf(xref) === -1) {\n xaList.push(xref);\n newAxis = true;\n }\n if(hasYref && yaList.indexOf(yref) === -1) {\n yaList.push(yref);\n newAxis = true;\n }\n\n /*\n * Notice the logic here: only add a subplot for a component if\n * it's referencing both x and y axes AND it's creating a new axis\n * so for example if your plot already has xy and x2y2, an annotation\n * on x2y or xy2 will not create a new subplot.\n */\n if(newAxis && hasXref && hasYref) {\n cartesianList.push(xref + yref);\n }\n }\n }\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n// Simple helper functions\n// none of these need any external deps\n\nmodule.exports = function noop() {};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Color = require('../../components/color');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleDefaults = require('../../components/colorscale/defaults');\n\nmodule.exports = function handleStyleDefaults(traceIn, traceOut, coerce, defaultColor, layout) {\n coerce('marker.color', defaultColor);\n\n if(hasColorscale(traceIn, 'marker')) {\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: 'marker.', cLetter: 'c'}\n );\n }\n\n coerce('marker.line.color', Color.defaultLine);\n\n if(hasColorscale(traceIn, 'marker.line')) {\n colorscaleDefaults(\n traceIn, traceOut, layout, coerce, {prefix: 'marker.line.', cLetter: 'c'}\n );\n }\n\n coerce('marker.line.width');\n coerce('marker.opacity');\n coerce('selected.marker.color');\n coerce('unselected.marker.color');\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Axes = require('../../plots/cartesian/axes');\nvar hasColorscale = require('../../components/colorscale/helpers').hasColorscale;\nvar colorscaleCalc = require('../../components/colorscale/calc');\nvar arraysToCalcdata = require('./arrays_to_calcdata');\nvar calcSelection = require('../scatter/calc_selection');\n\nmodule.exports = function calc(gd, trace) {\n var xa = Axes.getFromId(gd, trace.xaxis || 'x');\n var ya = Axes.getFromId(gd, trace.yaxis || 'y');\n var size, pos;\n\n if(trace.orientation === 'h') {\n size = xa.makeCalcdata(trace, 'x');\n pos = ya.makeCalcdata(trace, 'y');\n } else {\n size = ya.makeCalcdata(trace, 'y');\n pos = xa.makeCalcdata(trace, 'x');\n }\n\n // create the \"calculated data\" to plot\n var serieslen = Math.min(pos.length, size.length);\n var cd = new Array(serieslen);\n\n // set position and size\n for(var i = 0; i < serieslen; i++) {\n cd[i] = { p: pos[i], s: size[i] };\n\n if(trace.ids) {\n cd[i].id = String(trace.ids[i]);\n }\n }\n\n // auto-z and autocolorscale if applicable\n if(hasColorscale(trace, 'marker')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.color,\n containerStr: 'marker',\n cLetter: 'c'\n });\n }\n if(hasColorscale(trace, 'marker.line')) {\n colorscaleCalc(gd, trace, {\n vals: trace.marker.line.color,\n containerStr: 'marker.line',\n cLetter: 'c'\n });\n }\n\n arraysToCalcdata(cd, trace);\n calcSelection(cd, trace);\n\n return cd;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar extractOpts = require('./helpers').extractOpts;\n\nmodule.exports = function calc(gd, trace, opts) {\n var fullLayout = gd._fullLayout;\n var vals = opts.vals;\n var containerStr = opts.containerStr;\n\n var container = containerStr ?\n Lib.nestedProperty(trace, containerStr).get() :\n trace;\n\n var cOpts = extractOpts(container);\n var auto = cOpts.auto !== false;\n var min = cOpts.min;\n var max = cOpts.max;\n var mid = cOpts.mid;\n\n var minVal = function() { return Lib.aggNums(Math.min, null, vals); };\n var maxVal = function() { return Lib.aggNums(Math.max, null, vals); };\n\n if(min === undefined) {\n min = minVal();\n } else if(auto) {\n if(container._colorAx && isNumeric(min)) {\n min = Math.min(min, minVal());\n } else {\n min = minVal();\n }\n }\n\n if(max === undefined) {\n max = maxVal();\n } else if(auto) {\n if(container._colorAx && isNumeric(max)) {\n max = Math.max(max, maxVal());\n } else {\n max = maxVal();\n }\n }\n\n if(auto && mid !== undefined) {\n if(max - mid > mid - min) {\n min = mid - (max - mid);\n } else if(max - mid < mid - min) {\n max = mid + (mid - min);\n }\n }\n\n if(min === max) {\n min -= 0.5;\n max += 0.5;\n }\n\n cOpts._sync('min', min);\n cOpts._sync('max', max);\n\n if(cOpts.autocolorscale) {\n var scl;\n if(min * max < 0) scl = fullLayout.colorscale.diverging;\n else if(min >= 0) scl = fullLayout.colorscale.sequential;\n else scl = fullLayout.colorscale.sequentialminus;\n cOpts._sync('colorscale', scl);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar helpers = require('./helpers');\n\nmodule.exports = function getLegendData(calcdata, opts) {\n var lgroupToTraces = {};\n var lgroups = [];\n var hasOneNonBlankGroup = false;\n var slicesShown = {};\n var lgroupi = 0;\n var maxNameLength = 0;\n var i, j;\n var main = opts._main;\n\n function addOneItem(legendGroup, legendItem) {\n // each '' legend group is treated as a separate group\n if(legendGroup === '' || !helpers.isGrouped(opts)) {\n // TODO: check this against fullData legendgroups?\n var uniqueGroup = '~~i' + lgroupi;\n lgroups.push(uniqueGroup);\n lgroupToTraces[uniqueGroup] = [[legendItem]];\n lgroupi++;\n } else if(lgroups.indexOf(legendGroup) === -1) {\n lgroups.push(legendGroup);\n hasOneNonBlankGroup = true;\n lgroupToTraces[legendGroup] = [[legendItem]];\n } else {\n lgroupToTraces[legendGroup].push([legendItem]);\n }\n }\n\n // build an { legendgroup: [cd0, cd0], ... } object\n for(i = 0; i < calcdata.length; i++) {\n var cd = calcdata[i];\n var cd0 = cd[0];\n var trace = cd0.trace;\n var lgroup = trace.legendgroup;\n\n if(main && (!trace.visible || !trace.showlegend)) continue;\n\n if(Registry.traceIs(trace, 'pie-like')) {\n if(!slicesShown[lgroup]) slicesShown[lgroup] = {};\n\n for(j = 0; j < cd.length; j++) {\n var labelj = cd[j].label;\n\n if(!slicesShown[lgroup][labelj]) {\n addOneItem(lgroup, {\n label: labelj,\n color: cd[j].color,\n i: cd[j].i,\n trace: trace,\n pts: cd[j].pts\n });\n\n slicesShown[lgroup][labelj] = true;\n maxNameLength = Math.max(maxNameLength, (labelj || '').length);\n }\n }\n } else {\n addOneItem(lgroup, cd0);\n maxNameLength = Math.max(maxNameLength, (trace.name || '').length);\n }\n }\n\n // won't draw a legend in this case\n if(!lgroups.length) return [];\n\n // rearrange lgroupToTraces into a d3-friendly array of arrays\n var lgroupsLength = lgroups.length;\n var ltraces;\n var legendData;\n\n if(hasOneNonBlankGroup && helpers.isGrouped(opts)) {\n legendData = new Array(lgroupsLength);\n\n for(i = 0; i < lgroupsLength; i++) {\n ltraces = lgroupToTraces[lgroups[i]];\n legendData[i] = helpers.isReversed(opts) ? ltraces.reverse() : ltraces;\n }\n } else {\n // collapse all groups into one if all groups are blank\n legendData = [new Array(lgroupsLength)];\n\n for(i = 0; i < lgroupsLength; i++) {\n ltraces = lgroupToTraces[lgroups[i]][0];\n legendData[0][helpers.isReversed(opts) ? lgroupsLength - i - 1 : i] = ltraces;\n }\n lgroupsLength = 1;\n }\n\n // number of legend groups - needed in legend/draw.js\n opts._lgroupsLength = lgroupsLength;\n // maximum name/label length - needed in legend/draw.js\n opts._maxNameLength = maxNameLength;\n\n return legendData;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/*\n * make a font attribute group\n *\n * @param {object} opts\n * @param {string}\n * opts.description: where & how this font is used\n * @param {optional bool} arrayOk:\n * should each part (family, size, color) be arrayOk? default false.\n * @param {string} editType:\n * the editType for all pieces of this font\n * @param {optional string} colorEditType:\n * a separate editType just for color\n *\n * @return {object} attributes object containing {family, size, color} as specified\n */\nmodule.exports = function(opts) {\n var editType = opts.editType;\n var colorEditType = opts.colorEditType;\n if(colorEditType === undefined) colorEditType = editType;\n var attrs = {\n family: {\n valType: 'string',\n role: 'style',\n noBlank: true,\n strict: true,\n editType: editType,\n description: [\n 'HTML font family - the typeface that will be applied by the web browser.',\n 'The web browser will only be able to apply a font if it is available on the system',\n 'which it operates. Provide multiple font families, separated by commas, to indicate',\n 'the preference in which to apply fonts if they aren\\'t available on the system.',\n 'The Chart Studio Cloud (at https://chart-studio.plotly.com or on-premise) generates images on a server,',\n 'where only a select number of',\n 'fonts are installed and supported.',\n 'These include *Arial*, *Balto*, *Courier New*, *Droid Sans*,, *Droid Serif*,',\n '*Droid Sans Mono*, *Gravitas One*, *Old Standard TT*, *Open Sans*, *Overpass*,',\n '*PT Sans Narrow*, *Raleway*, *Times New Roman*.'\n ].join(' ')\n },\n size: {\n valType: 'number',\n role: 'style',\n min: 1,\n editType: editType\n },\n color: {\n valType: 'color',\n role: 'style',\n editType: colorEditType\n },\n editType: editType,\n // blank strings so compress_attributes can remove\n // TODO - that's uber hacky... better solution?\n description: '' + (opts.description || '') + ''\n };\n\n if(opts.arrayOk) {\n attrs.family.arrayOk = true;\n attrs.size.arrayOk = true;\n attrs.color.arrayOk = true;\n }\n\n return attrs;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n 'undo': {\n 'width': 857.1,\n 'height': 1000,\n 'path': 'm857 350q0-87-34-166t-91-137-137-92-166-34q-96 0-183 41t-147 114q-4 6-4 13t5 11l76 77q6 5 14 5 9-1 13-7 41-53 100-82t126-29q58 0 110 23t92 61 61 91 22 111-22 111-61 91-92 61-110 23q-55 0-105-20t-90-57l77-77q17-16 8-38-10-23-33-23h-250q-15 0-25 11t-11 25v250q0 24 22 33 22 10 39-8l72-72q60 57 137 88t159 31q87 0 166-34t137-92 91-137 34-166z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'home': {\n 'width': 928.6,\n 'height': 1000,\n 'path': 'm786 296v-267q0-15-11-26t-25-10h-214v214h-143v-214h-214q-15 0-25 10t-11 26v267q0 1 0 2t0 2l321 264 321-264q1-1 1-4z m124 39l-34-41q-5-5-12-6h-2q-7 0-12 3l-386 322-386-322q-7-4-13-4-7 2-12 7l-35 41q-4 5-3 13t6 12l401 334q18 15 42 15t43-15l136-114v109q0 8 5 13t13 5h107q8 0 13-5t5-13v-227l122-102q5-5 6-12t-4-13z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'camera-retro': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm518 386q0 8-5 13t-13 5q-37 0-63-27t-26-63q0-8 5-13t13-5 12 5 5 13q0 23 16 38t38 16q8 0 13 5t5 13z m125-73q0-59-42-101t-101-42-101 42-42 101 42 101 101 42 101-42 42-101z m-572-320h858v71h-858v-71z m643 320q0 89-62 152t-152 62-151-62-63-152 63-151 151-63 152 63 62 151z m-571 358h214v72h-214v-72z m-72-107h858v143h-462l-36-71h-360v-72z m929 143v-714q0-30-21-51t-50-21h-858q-29 0-50 21t-21 51v714q0 30 21 51t50 21h858q29 0 50-21t21-51z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'zoombox': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm1000-25l-250 251c40 63 63 138 63 218 0 224-182 406-407 406-224 0-406-182-406-406s183-406 407-406c80 0 155 22 218 62l250-250 125 125z m-812 250l0 438 437 0 0-438-437 0z m62 375l313 0 0-312-313 0 0 312z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'pan': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm1000 350l-187 188 0-125-250 0 0 250 125 0-188 187-187-187 125 0 0-250-250 0 0 125-188-188 186-187 0 125 252 0 0-250-125 0 187-188 188 188-125 0 0 250 250 0 0-126 187 188z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'zoom_plus': {\n 'width': 875,\n 'height': 1000,\n 'path': 'm1 787l0-875 875 0 0 875-875 0z m687-500l-187 0 0-187-125 0 0 187-188 0 0 125 188 0 0 187 125 0 0-187 187 0 0-125z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'zoom_minus': {\n 'width': 875,\n 'height': 1000,\n 'path': 'm0 788l0-876 875 0 0 876-875 0z m688-500l-500 0 0 125 500 0 0-125z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'autoscale': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm250 850l-187 0-63 0 0-62 0-188 63 0 0 188 187 0 0 62z m688 0l-188 0 0-62 188 0 0-188 62 0 0 188 0 62-62 0z m-875-938l0 188-63 0 0-188 0-62 63 0 187 0 0 62-187 0z m875 188l0-188-188 0 0-62 188 0 62 0 0 62 0 188-62 0z m-125 188l-1 0-93-94-156 156 156 156 92-93 2 0 0 250-250 0 0-2 93-92-156-156-156 156 94 92 0 2-250 0 0-250 0 0 93 93 157-156-157-156-93 94 0 0 0-250 250 0 0 0-94 93 156 157 156-157-93-93 0 0 250 0 0 250z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'tooltip_basic': {\n 'width': 1500,\n 'height': 1000,\n 'path': 'm375 725l0 0-375-375 375-374 0-1 1125 0 0 750-1125 0z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'tooltip_compare': {\n 'width': 1125,\n 'height': 1000,\n 'path': 'm187 786l0 2-187-188 188-187 0 0 937 0 0 373-938 0z m0-499l0 1-187-188 188-188 0 0 937 0 0 376-938-1z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'plotlylogo': {\n 'width': 1542,\n 'height': 1000,\n 'path': 'm0-10h182v-140h-182v140z m228 146h183v-286h-183v286z m225 714h182v-1000h-182v1000z m225-285h182v-715h-182v715z m225 142h183v-857h-183v857z m231-428h182v-429h-182v429z m225-291h183v-138h-183v138z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'z-axis': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm833 5l-17 108v41l-130-65 130-66c0 0 0 38 0 39 0-1 36-14 39-25 4-15-6-22-16-30-15-12-39-16-56-20-90-22-187-23-279-23-261 0-341 34-353 59 3 60 228 110 228 110-140-8-351-35-351-116 0-120 293-142 474-142 155 0 477 22 477 142 0 50-74 79-163 96z m-374 94c-58-5-99-21-99-40 0-24 65-43 144-43 79 0 143 19 143 43 0 19-42 34-98 40v216h87l-132 135-133-135h88v-216z m167 515h-136v1c16 16 31 34 46 52l84 109v54h-230v-71h124v-1c-16-17-28-32-44-51l-89-114v-51h245v72z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n '3d_rotate': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm922 660c-5 4-9 7-14 11-359 263-580-31-580-31l-102 28 58-400c0 1 1 1 2 2 118 108 351 249 351 249s-62 27-100 42c88 83 222 183 347 122 16-8 30-17 44-27-2 1-4 2-6 4z m36-329c0 0 64 229-88 296-62 27-124 14-175-11 157-78 225-208 249-266 8-19 11-31 11-31 2 5 6 15 11 32-5-13-8-20-8-20z m-775-239c70-31 117-50 198-32-121 80-199 346-199 346l-96-15-58-12c0 0 55-226 155-287z m603 133l-317-139c0 0 4-4 19-14 7-5 24-15 24-15s-177-147-389 4c235-287 536-112 536-112l31-22 100 299-4-1z m-298-153c6-4 14-9 24-15 0 0-17 10-24 15z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'camera': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm500 450c-83 0-150-67-150-150 0-83 67-150 150-150 83 0 150 67 150 150 0 83-67 150-150 150z m400 150h-120c-16 0-34 13-39 29l-31 93c-6 15-23 28-40 28h-340c-16 0-34-13-39-28l-31-94c-6-15-23-28-40-28h-120c-55 0-100-45-100-100v-450c0-55 45-100 100-100h800c55 0 100 45 100 100v450c0 55-45 100-100 100z m-400-550c-138 0-250 112-250 250 0 138 112 250 250 250 138 0 250-112 250-250 0-138-112-250-250-250z m365 380c-19 0-35 16-35 35 0 19 16 35 35 35 19 0 35-16 35-35 0-19-16-35-35-35z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'movie': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm938 413l-188-125c0 37-17 71-44 94 64 38 107 107 107 187 0 121-98 219-219 219-121 0-219-98-219-219 0-61 25-117 66-156h-115c30 33 49 76 49 125 0 103-84 187-187 187s-188-84-188-187c0-57 26-107 65-141-38-22-65-62-65-109v-250c0-70 56-126 125-126h500c69 0 125 56 125 126l188-126c34 0 62 28 62 63v375c0 35-28 63-62 63z m-750 0c-69 0-125 56-125 125s56 125 125 125 125-56 125-125-56-125-125-125z m406-1c-87 0-157 70-157 157 0 86 70 156 157 156s156-70 156-156-70-157-156-157z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'question': {\n 'width': 857.1,\n 'height': 1000,\n 'path': 'm500 82v107q0 8-5 13t-13 5h-107q-8 0-13-5t-5-13v-107q0-8 5-13t13-5h107q8 0 13 5t5 13z m143 375q0 49-31 91t-77 65-95 23q-136 0-207-119-9-14 4-24l74-55q4-4 10-4 9 0 14 7 30 38 48 51 19 14 48 14 27 0 48-15t21-33q0-21-11-34t-38-25q-35-16-65-48t-29-70v-20q0-8 5-13t13-5h107q8 0 13 5t5 13q0 10 12 27t30 28q18 10 28 16t25 19 25 27 16 34 7 45z m214-107q0-117-57-215t-156-156-215-58-216 58-155 156-58 215 58 215 155 156 216 58 215-58 156-156 57-215z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'disk': {\n 'width': 857.1,\n 'height': 1000,\n 'path': 'm214-7h429v214h-429v-214z m500 0h72v500q0 8-6 21t-11 20l-157 156q-5 6-19 12t-22 5v-232q0-22-15-38t-38-16h-322q-22 0-37 16t-16 38v232h-72v-714h72v232q0 22 16 38t37 16h465q22 0 38-16t15-38v-232z m-214 518v178q0 8-5 13t-13 5h-107q-7 0-13-5t-5-13v-178q0-8 5-13t13-5h107q7 0 13 5t5 13z m357-18v-518q0-22-15-38t-38-16h-750q-23 0-38 16t-16 38v750q0 22 16 38t38 16h517q23 0 50-12t42-26l156-157q16-15 27-42t11-49z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'lasso': {\n 'width': 1031,\n 'height': 1000,\n 'path': 'm1018 538c-36 207-290 336-568 286-277-48-473-256-436-463 10-57 36-108 76-151-13-66 11-137 68-183 34-28 75-41 114-42l-55-70 0 0c-2-1-3-2-4-3-10-14-8-34 5-45 14-11 34-8 45 4 1 1 2 3 2 5l0 0 113 140c16 11 31 24 45 40 4 3 6 7 8 11 48-3 100 0 151 9 278 48 473 255 436 462z m-624-379c-80 14-149 48-197 96 42 42 109 47 156 9 33-26 47-66 41-105z m-187-74c-19 16-33 37-39 60 50-32 109-55 174-68-42-25-95-24-135 8z m360 75c-34-7-69-9-102-8 8 62-16 128-68 170-73 59-175 54-244-5-9 20-16 40-20 61-28 159 121 317 333 354s407-60 434-217c28-159-121-318-333-355z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'selectbox': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'm0 850l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-285l0-143 143 0 0 143-143 0z m857 0l0-143 143 0 0 143-143 0z m-857-286l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z m285 0l0-143 143 0 0 143-143 0z m286 0l0-143 143 0 0 143-143 0z',\n 'transform': 'matrix(1 0 0 -1 0 850)'\n },\n 'spikeline': {\n 'width': 1000,\n 'height': 1000,\n 'path': 'M512 409c0-57-46-104-103-104-57 0-104 47-104 104 0 57 47 103 104 103 57 0 103-46 103-103z m-327-39l92 0 0 92-92 0z m-185 0l92 0 0 92-92 0z m370-186l92 0 0 93-92 0z m0-184l92 0 0 92-92 0z',\n 'transform': 'matrix(1.5 0 0 -1.5 0 850)'\n },\n 'pencil': {\n 'width': 1792,\n 'height': 1792,\n 'path': 'M491 1536l91-91-235-235-91 91v107h128v128h107zm523-928q0-22-22-22-10 0-17 7l-542 542q-7 7-7 17 0 22 22 22 10 0 17-7l542-542q7-7 7-17zm-54-192l416 416-832 832h-416v-416zm683 96q0 53-37 90l-166 166-416-416 166-165q36-38 90-38 53 0 91 38l235 234q37 39 37 91z',\n 'transform': 'matrix(1 0 0 1 0 1)'\n },\n 'newplotlylogo': {\n 'name': 'newplotlylogo',\n 'svg': 'plotly-logomark'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar constants = require('./constants');\n\nmodule.exports = {\n moduleType: 'component',\n name: constants.name,\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n\n draw: require('./draw')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nexports.init2dArray = function(rowLength, colLength) {\n var array = new Array(rowLength);\n for(var i = 0; i < rowLength; i++) array[i] = new Array(colLength);\n return array;\n};\n\n/**\n * transpose a (possibly ragged) 2d array z. inspired by\n * http://stackoverflow.com/questions/17428587/\n * transposing-a-2d-array-in-javascript\n */\nexports.transposeRagged = function(z) {\n var maxlen = 0;\n var zlen = z.length;\n var i, j;\n // Maximum row length:\n for(i = 0; i < zlen; i++) maxlen = Math.max(maxlen, z[i].length);\n\n var t = new Array(maxlen);\n for(i = 0; i < maxlen; i++) {\n t[i] = new Array(zlen);\n for(j = 0; j < zlen; j++) t[i][j] = z[j][i];\n }\n\n return t;\n};\n\n// our own dot function so that we don't need to include numeric\nexports.dot = function(x, y) {\n if(!(x.length && y.length) || x.length !== y.length) return null;\n\n var len = x.length;\n var out;\n var i;\n\n if(x[0].length) {\n // mat-vec or mat-mat\n out = new Array(len);\n for(i = 0; i < len; i++) out[i] = exports.dot(x[i], y);\n } else if(y[0].length) {\n // vec-mat\n var yTranspose = exports.transposeRagged(y);\n out = new Array(yTranspose.length);\n for(i = 0; i < yTranspose.length; i++) out[i] = exports.dot(x, yTranspose[i]);\n } else {\n // vec-vec\n out = 0;\n for(i = 0; i < len; i++) out += x[i] * y[i];\n }\n\n return out;\n};\n\n// translate by (x,y)\nexports.translationMatrix = function(x, y) {\n return [[1, 0, x], [0, 1, y], [0, 0, 1]];\n};\n\n// rotate by alpha around (0,0)\nexports.rotationMatrix = function(alpha) {\n var a = alpha * Math.PI / 180;\n return [[Math.cos(a), -Math.sin(a), 0],\n [Math.sin(a), Math.cos(a), 0],\n [0, 0, 1]];\n};\n\n// rotate by alpha around (x,y)\nexports.rotationXYMatrix = function(a, x, y) {\n return exports.dot(\n exports.dot(exports.translationMatrix(x, y),\n exports.rotationMatrix(a)),\n exports.translationMatrix(-x, -y));\n};\n\n// applies a 2D transformation matrix to either x and y params or an [x,y] array\nexports.apply2DTransform = function(transform) {\n return function() {\n var args = arguments;\n if(args.length === 3) {\n args = args[0];\n }// from map\n var xy = arguments.length === 1 ? args[0] : [args[0], args[1]];\n return exports.dot(transform, [xy[0], xy[1], 1]).slice(0, 2);\n };\n};\n\n// applies a 2D transformation matrix to an [x1,y1,x2,y2] array (to transform a segment)\nexports.apply2DTransform2 = function(transform) {\n var at = exports.apply2DTransform(transform);\n return function(xys) {\n return at(xys.slice(0, 2)).concat(at(xys.slice(2, 4)));\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar scatterAttrs = require('../scatter/attributes');\nvar hovertemplateAttrs = require('../../plots/template_attributes').hovertemplateAttrs;\nvar texttemplateAttrs = require('../../plots/template_attributes').texttemplateAttrs;\nvar colorScaleAttrs = require('../../components/colorscale/attributes');\nvar fontAttrs = require('../../plots/font_attributes');\nvar constants = require('./constants');\n\nvar extendFlat = require('../../lib/extend').extendFlat;\n\nvar textFontAttrs = fontAttrs({\n editType: 'calc',\n arrayOk: true,\n colorEditType: 'style',\n description: ''\n});\n\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar scatterMarkerLineAttrs = scatterMarkerAttrs.line;\n\nvar markerLineWidth = extendFlat({},\n scatterMarkerLineAttrs.width, { dflt: 0 });\n\nvar markerLine = extendFlat({\n width: markerLineWidth,\n editType: 'calc'\n}, colorScaleAttrs('marker.line'));\n\nvar marker = extendFlat({\n line: markerLine,\n editType: 'calc'\n}, colorScaleAttrs('marker'), {\n opacity: {\n valType: 'number',\n arrayOk: true,\n dflt: 1,\n min: 0,\n max: 1,\n role: 'style',\n editType: 'style',\n description: 'Sets the opacity of the bars.'\n }\n});\n\nmodule.exports = {\n x: scatterAttrs.x,\n x0: scatterAttrs.x0,\n dx: scatterAttrs.dx,\n y: scatterAttrs.y,\n y0: scatterAttrs.y0,\n dy: scatterAttrs.dy,\n\n text: scatterAttrs.text,\n texttemplate: texttemplateAttrs({editType: 'plot'}, {\n keys: constants.eventDataKeys\n }),\n hovertext: scatterAttrs.hovertext,\n hovertemplate: hovertemplateAttrs({}, {\n keys: constants.eventDataKeys\n }),\n\n textposition: {\n valType: 'enumerated',\n role: 'info',\n values: ['inside', 'outside', 'auto', 'none'],\n dflt: 'none',\n arrayOk: true,\n editType: 'calc',\n description: [\n 'Specifies the location of the `text`.',\n '*inside* positions `text` inside, next to the bar end',\n '(rotated and scaled if needed).',\n '*outside* positions `text` outside, next to the bar end',\n '(scaled if needed), unless there is another bar stacked on',\n 'this one, then the text gets pushed inside.',\n '*auto* tries to position `text` inside the bar, but if',\n 'the bar is too small and no bar is stacked on this one',\n 'the text is moved outside.'\n ].join(' ')\n },\n\n insidetextanchor: {\n valType: 'enumerated',\n values: ['end', 'middle', 'start'],\n dflt: 'end',\n role: 'info',\n editType: 'plot',\n description: [\n 'Determines if texts are kept at center or start/end points in `textposition` *inside* mode.'\n ].join(' ')\n },\n\n textangle: {\n valType: 'angle',\n dflt: 'auto',\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets the angle of the tick labels with respect to the bar.',\n 'For example, a `tickangle` of -90 draws the tick labels',\n 'vertically. With *auto* the texts may automatically be',\n 'rotated to fit with the maximum size in bars.'\n ].join(' ')\n },\n\n textfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text`.'\n }),\n\n insidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text` lying inside the bar.'\n }),\n\n outsidetextfont: extendFlat({}, textFontAttrs, {\n description: 'Sets the font used for `text` lying outside the bar.'\n }),\n\n constraintext: {\n valType: 'enumerated',\n values: ['inside', 'outside', 'both', 'none'],\n role: 'info',\n dflt: 'both',\n editType: 'calc',\n description: [\n 'Constrain the size of text inside or outside a bar to be no',\n 'larger than the bar itself.'\n ].join(' ')\n },\n\n cliponaxis: extendFlat({}, scatterAttrs.cliponaxis, {\n description: [\n 'Determines whether the text nodes',\n 'are clipped about the subplot axes.',\n 'To show the text nodes above axis lines and tick labels,',\n 'make sure to set `xaxis.layer` and `yaxis.layer` to *below traces*.'\n ].join(' ')\n }),\n\n orientation: {\n valType: 'enumerated',\n role: 'info',\n values: ['v', 'h'],\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets the orientation of the bars.',\n 'With *v* (*h*), the value of the each bar spans',\n 'along the vertical (horizontal).'\n ].join(' ')\n },\n\n base: {\n valType: 'any',\n dflt: null,\n arrayOk: true,\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets where the bar base is drawn (in position axis units).',\n 'In *stack* or *relative* barmode,',\n 'traces that set *base* will be excluded',\n 'and drawn in *overlay* mode instead.'\n ].join(' ')\n },\n\n offset: {\n valType: 'number',\n dflt: null,\n arrayOk: true,\n role: 'info',\n editType: 'calc',\n description: [\n 'Shifts the position where the bar is drawn',\n '(in position axis units).',\n 'In *group* barmode,',\n 'traces that set *offset* will be excluded',\n 'and drawn in *overlay* mode instead.'\n ].join(' ')\n },\n\n width: {\n valType: 'number',\n dflt: null,\n min: 0,\n arrayOk: true,\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the bar width (in position axis units).'\n ].join(' ')\n },\n\n marker: marker,\n\n offsetgroup: {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several traces linked to the same position axis',\n 'or matching axes to the same',\n 'offsetgroup where bars of the same position coordinate will line up.'\n ].join(' ')\n },\n alignmentgroup: {\n valType: 'string',\n role: 'info',\n dflt: '',\n editType: 'calc',\n description: [\n 'Set several traces linked to the same position axis',\n 'or matching axes to the same',\n 'alignmentgroup. This controls whether bars compute their positional',\n 'range dependently or independently.'\n ].join(' ')\n },\n\n selected: {\n marker: {\n opacity: scatterAttrs.selected.marker.opacity,\n color: scatterAttrs.selected.marker.color,\n editType: 'style'\n },\n textfont: scatterAttrs.selected.textfont,\n editType: 'style'\n },\n unselected: {\n marker: {\n opacity: scatterAttrs.unselected.marker.opacity,\n color: scatterAttrs.unselected.marker.color,\n editType: 'style'\n },\n textfont: scatterAttrs.unselected.textfont,\n editType: 'style'\n },\n\n r: scatterAttrs.r,\n t: scatterAttrs.t,\n\n _deprecated: {\n bardir: {\n valType: 'enumerated',\n role: 'info',\n editType: 'calc',\n values: ['v', 'h'],\n description: 'Renamed to `orientation`.'\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar scales = require('./scales');\nvar helpers = require('./helpers');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'colorscale',\n\n attributes: require('./attributes'),\n layoutAttributes: require('./layout_attributes'),\n\n supplyLayoutDefaults: require('./layout_defaults'),\n handleDefaults: require('./defaults'),\n crossTraceDefaults: require('./cross_trace_defaults'),\n\n calc: require('./calc'),\n\n // ./scales.js is required in lib/coerce.js ;\n // it needs to be a seperate module to avoid circular a dependency\n scales: scales.scales,\n defaultScale: scales.defaultScale,\n getScale: scales.get,\n isValidScale: scales.isValid,\n\n hasColorscale: helpers.hasColorscale,\n extractOpts: helpers.extractOpts,\n extractScale: helpers.extractScale,\n flipScale: helpers.flipScale,\n makeColorScaleFunc: helpers.makeColorScaleFunc,\n makeColorScaleFuncFromTrace: helpers.makeColorScaleFuncFromTrace\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar nestedProperty = require('./nested_property');\n\nvar SIMPLE_PROPERTY_REGEX = /^\\w*$/;\n\n// bitmask for deciding what's updated. Sometimes the name needs to be updated,\n// sometimes the value needs to be updated, and sometimes both do. This is just\n// a simple way to track what's updated such that it's a simple OR operation to\n// assimilate new updates.\n//\n// The only exception is the UNSET bit that tracks when we need to explicitly\n// unset and remove the property. This concrn arises because of the special\n// way in which nestedProperty handles null/undefined. When you specify `null`,\n// it prunes any unused items in the tree. I ran into some issues with it getting\n// null vs undefined confused, so UNSET is just a bit that forces the property\n// update to send `null`, removing the property explicitly rather than setting\n// it to undefined.\nvar NONE = 0;\nvar NAME = 1;\nvar VALUE = 2;\nvar BOTH = 3;\nvar UNSET = 4;\n\nmodule.exports = function keyedContainer(baseObj, path, keyName, valueName) {\n keyName = keyName || 'name';\n valueName = valueName || 'value';\n var i, arr, baseProp;\n var changeTypes = {};\n\n if(path && path.length) {\n baseProp = nestedProperty(baseObj, path);\n arr = baseProp.get();\n } else {\n arr = baseObj;\n }\n\n path = path || '';\n\n // Construct an index:\n var indexLookup = {};\n if(arr) {\n for(i = 0; i < arr.length; i++) {\n indexLookup[arr[i][keyName]] = i;\n }\n }\n\n var isSimpleValueProp = SIMPLE_PROPERTY_REGEX.test(valueName);\n\n var obj = {\n set: function(name, value) {\n var changeType = value === null ? UNSET : NONE;\n\n // create the base array if necessary\n if(!arr) {\n if(!baseProp || changeType === UNSET) return;\n\n arr = [];\n baseProp.set(arr);\n }\n\n var idx = indexLookup[name];\n if(idx === undefined) {\n if(changeType === UNSET) return;\n\n changeType = changeType | BOTH;\n idx = arr.length;\n indexLookup[name] = idx;\n } else if(value !== (isSimpleValueProp ? arr[idx][valueName] : nestedProperty(arr[idx], valueName).get())) {\n changeType = changeType | VALUE;\n }\n\n var newValue = arr[idx] = arr[idx] || {};\n newValue[keyName] = name;\n\n if(isSimpleValueProp) {\n newValue[valueName] = value;\n } else {\n nestedProperty(newValue, valueName).set(value);\n }\n\n // If it's not an unset, force that bit to be unset. This is all related to the fact\n // that undefined and null are a bit specially implemented in nestedProperties.\n if(value !== null) {\n changeType = changeType & ~UNSET;\n }\n\n changeTypes[idx] = changeTypes[idx] | changeType;\n\n return obj;\n },\n get: function(name) {\n if(!arr) return;\n\n var idx = indexLookup[name];\n\n if(idx === undefined) {\n return undefined;\n } else if(isSimpleValueProp) {\n return arr[idx][valueName];\n } else {\n return nestedProperty(arr[idx], valueName).get();\n }\n },\n rename: function(name, newName) {\n var idx = indexLookup[name];\n\n if(idx === undefined) return obj;\n changeTypes[idx] = changeTypes[idx] | NAME;\n\n indexLookup[newName] = idx;\n delete indexLookup[name];\n\n arr[idx][keyName] = newName;\n\n return obj;\n },\n remove: function(name) {\n var idx = indexLookup[name];\n\n if(idx === undefined) return obj;\n\n var object = arr[idx];\n if(Object.keys(object).length > 2) {\n // This object contains more than just the key/value, so unset\n // the value without modifying the entry otherwise:\n changeTypes[idx] = changeTypes[idx] | VALUE;\n return obj.set(name, null);\n }\n\n if(isSimpleValueProp) {\n for(i = idx; i < arr.length; i++) {\n changeTypes[i] = changeTypes[i] | BOTH;\n }\n for(i = idx; i < arr.length; i++) {\n indexLookup[arr[i][keyName]]--;\n }\n arr.splice(idx, 1);\n delete(indexLookup[name]);\n } else {\n // Perform this update *strictly* so we can check whether the result's\n // been pruned. If so, it's a removal. If not, it's a value unset only.\n nestedProperty(object, valueName).set(null);\n\n // Now check if the top level nested property has any keys left. If so,\n // the object still has values so we only want to unset the key. If not,\n // the entire object can be removed since there's no other data.\n // var topLevelKeys = Object.keys(object[valueName.split('.')[0]] || []);\n\n changeTypes[idx] = changeTypes[idx] | VALUE | UNSET;\n }\n\n return obj;\n },\n constructUpdate: function() {\n var astr, idx;\n var update = {};\n var changed = Object.keys(changeTypes);\n for(var i = 0; i < changed.length; i++) {\n idx = changed[i];\n astr = path + '[' + idx + ']';\n if(arr[idx]) {\n if(changeTypes[idx] & NAME) {\n update[astr + '.' + keyName] = arr[idx][keyName];\n }\n if(changeTypes[idx] & VALUE) {\n if(isSimpleValueProp) {\n update[astr + '.' + valueName] = (changeTypes[idx] & UNSET) ? null : arr[idx][valueName];\n } else {\n update[astr + '.' + valueName] = (changeTypes[idx] & UNSET) ? null : nestedProperty(arr[idx], valueName).get();\n }\n }\n } else {\n update[astr] = null;\n }\n }\n\n return update;\n }\n };\n\n return obj;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../lib');\nvar dfltConfig = require('../plot_api/plot_config').dfltConfig;\n\n/**\n * Copy arg array *without* removing `undefined` values from objects.\n *\n * @param gd\n * @param args\n * @returns {Array}\n */\nfunction copyArgArray(gd, args) {\n var copy = [];\n var arg;\n\n for(var i = 0; i < args.length; i++) {\n arg = args[i];\n\n if(arg === gd) copy[i] = arg;\n else if(typeof arg === 'object') {\n copy[i] = Array.isArray(arg) ?\n Lib.extendDeep([], arg) :\n Lib.extendDeepAll({}, arg);\n } else copy[i] = arg;\n }\n\n return copy;\n}\n\n\n// -----------------------------------------------------\n// Undo/Redo queue for plots\n// -----------------------------------------------------\n\n\nvar queue = {};\n\n// TODO: disable/enable undo and redo buttons appropriately\n\n/**\n * Add an item to the undoQueue for a graphDiv\n *\n * @param gd\n * @param undoFunc Function undo this operation\n * @param undoArgs Args to supply undoFunc with\n * @param redoFunc Function to redo this operation\n * @param redoArgs Args to supply redoFunc with\n */\nqueue.add = function(gd, undoFunc, undoArgs, redoFunc, redoArgs) {\n var queueObj,\n queueIndex;\n\n // make sure we have the queue and our position in it\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n queueIndex = gd.undoQueue.index;\n\n // if we're already playing an undo or redo, or if this is an auto operation\n // (like pane resize... any others?) then we don't save this to the undo queue\n if(gd.autoplay) {\n if(!gd.undoQueue.inSequence) gd.autoplay = false;\n return;\n }\n\n // if we're not in a sequence or are just starting, we need a new queue item\n if(!gd.undoQueue.sequence || gd.undoQueue.beginSequence) {\n queueObj = {undo: {calls: [], args: []}, redo: {calls: [], args: []}};\n gd.undoQueue.queue.splice(queueIndex, gd.undoQueue.queue.length - queueIndex, queueObj);\n gd.undoQueue.index += 1;\n } else {\n queueObj = gd.undoQueue.queue[queueIndex - 1];\n }\n gd.undoQueue.beginSequence = false;\n\n // we unshift to handle calls for undo in a forward for loop later\n if(queueObj) {\n queueObj.undo.calls.unshift(undoFunc);\n queueObj.undo.args.unshift(undoArgs);\n queueObj.redo.calls.push(redoFunc);\n queueObj.redo.args.push(redoArgs);\n }\n\n if(gd.undoQueue.queue.length > dfltConfig.queueLength) {\n gd.undoQueue.queue.shift();\n gd.undoQueue.index--;\n }\n};\n\n/**\n * Begin a sequence of undoQueue changes\n *\n * @param gd\n */\nqueue.startSequence = function(gd) {\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n gd.undoQueue.sequence = true;\n gd.undoQueue.beginSequence = true;\n};\n\n/**\n * Stop a sequence of undoQueue changes\n *\n * Call this *after* you're sure your undo chain has ended\n *\n * @param gd\n */\nqueue.stopSequence = function(gd) {\n gd.undoQueue = gd.undoQueue || {index: 0, queue: [], sequence: false};\n gd.undoQueue.sequence = false;\n gd.undoQueue.beginSequence = false;\n};\n\n/**\n * Move one step back in the undo queue, and undo the object there.\n *\n * @param gd\n */\nqueue.undo = function undo(gd) {\n var queueObj, i;\n\n if(gd.framework && gd.framework.isPolar) {\n gd.framework.undo();\n return;\n }\n if(gd.undoQueue === undefined ||\n isNaN(gd.undoQueue.index) ||\n gd.undoQueue.index <= 0) {\n return;\n }\n\n // index is pointing to next *forward* queueObj, point to the one we're undoing\n gd.undoQueue.index--;\n\n // get the queueObj for instructions on how to undo\n queueObj = gd.undoQueue.queue[gd.undoQueue.index];\n\n // this sequence keeps things from adding to the queue during undo/redo\n gd.undoQueue.inSequence = true;\n for(i = 0; i < queueObj.undo.calls.length; i++) {\n queue.plotDo(gd, queueObj.undo.calls[i], queueObj.undo.args[i]);\n }\n gd.undoQueue.inSequence = false;\n gd.autoplay = false;\n};\n\n/**\n * Redo the current object in the undo, then move forward in the queue.\n *\n * @param gd\n */\nqueue.redo = function redo(gd) {\n var queueObj, i;\n\n if(gd.framework && gd.framework.isPolar) {\n gd.framework.redo();\n return;\n }\n if(gd.undoQueue === undefined ||\n isNaN(gd.undoQueue.index) ||\n gd.undoQueue.index >= gd.undoQueue.queue.length) {\n return;\n }\n\n // get the queueObj for instructions on how to undo\n queueObj = gd.undoQueue.queue[gd.undoQueue.index];\n\n // this sequence keeps things from adding to the queue during undo/redo\n gd.undoQueue.inSequence = true;\n for(i = 0; i < queueObj.redo.calls.length; i++) {\n queue.plotDo(gd, queueObj.redo.calls[i], queueObj.redo.args[i]);\n }\n gd.undoQueue.inSequence = false;\n gd.autoplay = false;\n\n // index is pointing to the thing we just redid, move it\n gd.undoQueue.index++;\n};\n\n/**\n * Called by undo/redo to make the actual changes.\n *\n * Not meant to be called publically, but included for mocking out in tests.\n *\n * @param gd\n * @param func\n * @param args\n */\nqueue.plotDo = function(gd, func, args) {\n gd.autoplay = true;\n\n // this *won't* copy gd and it preserves `undefined` properties!\n args = copyArgArray(gd, args);\n\n // call the supplied function\n func.apply(null, args);\n};\n\nmodule.exports = queue;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nmodule.exports = {\n segmentRE: /[MLHVQCTSZ][^MLHVQCTSZ]*/g,\n paramRE: /[^\\s,]+/g,\n\n // which numbers in each path segment are x (or y) values\n // drawn is which param is a drawn point, as opposed to a\n // control point (which doesn't count toward autorange.\n // TODO: this means curved paths could extend beyond the\n // autorange bounds. This is a bit tricky to get right\n // unless we revert to bounding boxes, but perhaps there's\n // a calculation we could do...)\n paramIsX: {\n M: {0: true, drawn: 0},\n L: {0: true, drawn: 0},\n H: {0: true, drawn: 0},\n V: {},\n Q: {0: true, 2: true, drawn: 2},\n C: {0: true, 2: true, 4: true, drawn: 4},\n T: {0: true, drawn: 0},\n S: {0: true, 2: true, drawn: 2},\n // A: {0: true, 5: true},\n Z: {}\n },\n\n paramIsY: {\n M: {1: true, drawn: 1},\n L: {1: true, drawn: 1},\n H: {},\n V: {0: true, drawn: 0},\n Q: {1: true, 3: true, drawn: 3},\n C: {1: true, 3: true, 5: true, drawn: 5},\n T: {1: true, drawn: 1},\n S: {1: true, 3: true, drawn: 5},\n // A: {1: true, 6: true},\n Z: {}\n },\n\n numParams: {\n M: 2,\n L: 2,\n H: 1,\n V: 1,\n Q: 4,\n C: 6,\n T: 2,\n S: 4,\n // A: 7,\n Z: 0\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Color = require('../../components/color');\nvar isArrayOrTypedArray = require('../../lib').isArrayOrTypedArray;\n\nmodule.exports = function fillColorDefaults(traceIn, traceOut, defaultColor, coerce) {\n var inheritColorFromMarker = false;\n\n if(traceOut.marker) {\n // don't try to inherit a color array\n var markerColor = traceOut.marker.color;\n var markerLineColor = (traceOut.marker.line || {}).color;\n\n if(markerColor && !isArrayOrTypedArray(markerColor)) {\n inheritColorFromMarker = markerColor;\n } else if(markerLineColor && !isArrayOrTypedArray(markerLineColor)) {\n inheritColorFromMarker = markerLineColor;\n }\n }\n\n coerce('fillcolor', Color.addOpacity(\n (traceOut.line || {}).color ||\n inheritColorFromMarker ||\n defaultColor, 0.5\n ));\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\n\nvar constants = require('./constants');\n\n\n// convert between axis names (xaxis, xaxis2, etc, elements of gd.layout)\n// and axis id's (x, x2, etc). Would probably have ditched 'xaxis'\n// completely in favor of just 'x' if it weren't ingrained in the API etc.\nexports.id2name = function id2name(id) {\n if(typeof id !== 'string' || !id.match(constants.AX_ID_PATTERN)) return;\n var axNum = id.substr(1);\n if(axNum === '1') axNum = '';\n return id.charAt(0) + 'axis' + axNum;\n};\n\nexports.name2id = function name2id(name) {\n if(!name.match(constants.AX_NAME_PATTERN)) return;\n var axNum = name.substr(5);\n if(axNum === '1') axNum = '';\n return name.charAt(0) + axNum;\n};\n\nexports.cleanId = function cleanId(id, axLetter) {\n if(!id.match(constants.AX_ID_PATTERN)) return;\n if(axLetter && id.charAt(0) !== axLetter) return;\n\n var axNum = id.substr(1).replace(/^0+/, '');\n if(axNum === '1') axNum = '';\n return id.charAt(0) + axNum;\n};\n\n// get all axis objects, as restricted in listNames\nexports.list = function(gd, axLetter, only2d) {\n var fullLayout = gd._fullLayout;\n if(!fullLayout) return [];\n\n var idList = exports.listIds(gd, axLetter);\n var out = new Array(idList.length);\n var i;\n\n for(i = 0; i < idList.length; i++) {\n var idi = idList[i];\n out[i] = fullLayout[idi.charAt(0) + 'axis' + idi.substr(1)];\n }\n\n if(!only2d) {\n var sceneIds3D = fullLayout._subplots.gl3d || [];\n\n for(i = 0; i < sceneIds3D.length; i++) {\n var scene = fullLayout[sceneIds3D[i]];\n\n if(axLetter) out.push(scene[axLetter + 'axis']);\n else out.push(scene.xaxis, scene.yaxis, scene.zaxis);\n }\n }\n\n return out;\n};\n\n// get all axis ids, optionally restricted by letter\n// this only makes sense for 2d axes\nexports.listIds = function(gd, axLetter) {\n var fullLayout = gd._fullLayout;\n if(!fullLayout) return [];\n\n var subplotLists = fullLayout._subplots;\n if(axLetter) return subplotLists[axLetter + 'axis'];\n return subplotLists.xaxis.concat(subplotLists.yaxis);\n};\n\n// get an axis object from its id 'x','x2' etc\n// optionally, id can be a subplot (ie 'x2y3') and type gets x or y from it\nexports.getFromId = function(gd, id, type) {\n var fullLayout = gd._fullLayout;\n\n if(type === 'x') id = id.replace(/y[0-9]*/, '');\n else if(type === 'y') id = id.replace(/x[0-9]*/, '');\n\n return fullLayout[exports.id2name(id)];\n};\n\n// get an axis object of specified type from the containing trace\nexports.getFromTrace = function(gd, fullTrace, type) {\n var fullLayout = gd._fullLayout;\n var ax = null;\n\n if(Registry.traceIs(fullTrace, 'gl3d')) {\n var scene = fullTrace.scene;\n if(scene.substr(0, 5) === 'scene') {\n ax = fullLayout[scene][type + 'axis'];\n }\n } else {\n ax = exports.getFromId(gd, fullTrace[type + 'axis'] || type);\n }\n\n return ax;\n};\n\n// sort x, x2, x10, y, y2, y10...\nexports.idSort = function(id1, id2) {\n var letter1 = id1.charAt(0);\n var letter2 = id2.charAt(0);\n if(letter1 !== letter2) return letter1 > letter2 ? 1 : -1;\n return +(id1.substr(1) || 1) - +(id2.substr(1) || 1);\n};\n\nexports.getAxisGroup = function getAxisGroup(fullLayout, axId) {\n var matchGroups = fullLayout._axisMatchGroups;\n\n for(var i = 0; i < matchGroups.length; i++) {\n var group = matchGroups[i];\n if(group[axId]) return 'g' + i;\n }\n return axId;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Drawing = require('../drawing');\nvar subTypes = require('../../traces/scatter/subtypes');\n\nmodule.exports = function plot(gd, traces, plotinfo, transitionOpts) {\n var isNew;\n\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var hasAnimation = transitionOpts && transitionOpts.duration > 0;\n\n traces.each(function(d) {\n var trace = d[0].trace;\n // || {} is in case the trace (specifically scatterternary)\n // doesn't support error bars at all, but does go through\n // the scatter.plot mechanics, which calls ErrorBars.plot\n // internally\n var xObj = trace.error_x || {};\n var yObj = trace.error_y || {};\n\n var keyFunc;\n\n if(trace.ids) {\n keyFunc = function(d) {return d.id;};\n }\n\n var sparse = (\n subTypes.hasMarkers(trace) &&\n trace.marker.maxdisplayed > 0\n );\n\n if(!yObj.visible && !xObj.visible) d = [];\n\n var errorbars = d3.select(this).selectAll('g.errorbar')\n .data(d, keyFunc);\n\n errorbars.exit().remove();\n\n if(!d.length) return;\n\n if(!xObj.visible) errorbars.selectAll('path.xerror').remove();\n if(!yObj.visible) errorbars.selectAll('path.yerror').remove();\n\n errorbars.style('opacity', 1);\n\n var enter = errorbars.enter().append('g')\n .classed('errorbar', true);\n\n if(hasAnimation) {\n enter.style('opacity', 0).transition()\n .duration(transitionOpts.duration)\n .style('opacity', 1);\n }\n\n Drawing.setClipUrl(errorbars, plotinfo.layerClipId, gd);\n\n errorbars.each(function(d) {\n var errorbar = d3.select(this);\n var coords = errorCoords(d, xa, ya);\n\n if(sparse && !d.vis) return;\n\n var path;\n\n var yerror = errorbar.select('path.yerror');\n if(yObj.visible && isNumeric(coords.x) &&\n isNumeric(coords.yh) &&\n isNumeric(coords.ys)) {\n var yw = yObj.width;\n\n path = 'M' + (coords.x - yw) + ',' +\n coords.yh + 'h' + (2 * yw) + // hat\n 'm-' + yw + ',0V' + coords.ys; // bar\n\n\n if(!coords.noYS) path += 'm-' + yw + ',0h' + (2 * yw); // shoe\n\n isNew = !yerror.size();\n\n if(isNew) {\n yerror = errorbar.append('path')\n .style('vector-effect', 'non-scaling-stroke')\n .classed('yerror', true);\n } else if(hasAnimation) {\n yerror = yerror\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing);\n }\n\n yerror.attr('d', path);\n } else yerror.remove();\n\n var xerror = errorbar.select('path.xerror');\n if(xObj.visible && isNumeric(coords.y) &&\n isNumeric(coords.xh) &&\n isNumeric(coords.xs)) {\n var xw = (xObj.copy_ystyle ? yObj : xObj).width;\n\n path = 'M' + coords.xh + ',' +\n (coords.y - xw) + 'v' + (2 * xw) + // hat\n 'm0,-' + xw + 'H' + coords.xs; // bar\n\n if(!coords.noXS) path += 'm0,-' + xw + 'v' + (2 * xw); // shoe\n\n isNew = !xerror.size();\n\n if(isNew) {\n xerror = errorbar.append('path')\n .style('vector-effect', 'non-scaling-stroke')\n .classed('xerror', true);\n } else if(hasAnimation) {\n xerror = xerror\n .transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing);\n }\n\n xerror.attr('d', path);\n } else xerror.remove();\n });\n });\n};\n\n// compute the coordinates of the error-bar objects\nfunction errorCoords(d, xa, ya) {\n var out = {\n x: xa.c2p(d.x),\n y: ya.c2p(d.y)\n };\n\n // calculate the error bar size and hat and shoe locations\n if(d.yh !== undefined) {\n out.yh = ya.c2p(d.yh);\n out.ys = ya.c2p(d.ys);\n\n // if the shoes go off-scale (ie log scale, error bars past zero)\n // clip the bar and hide the shoes\n if(!isNumeric(out.ys)) {\n out.noYS = true;\n out.ys = ya.c2p(d.ys, true);\n }\n }\n\n if(d.xh !== undefined) {\n out.xh = xa.c2p(d.xh);\n out.xs = xa.c2p(d.xs);\n\n if(!isNumeric(out.xs)) {\n out.noXS = true;\n out.xs = xa.c2p(d.xs, true);\n }\n }\n\n return out;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\nexports.xmlns = 'http://www.w3.org/2000/xmlns/';\nexports.svg = 'http://www.w3.org/2000/svg';\nexports.xlink = 'http://www.w3.org/1999/xlink';\n\n// the 'old' d3 quirk got fix in v3.5.7\n// https://github.com/mbostock/d3/commit/a6f66e9dd37f764403fc7c1f26be09ab4af24fed\nexports.svgAttrs = {\n xmlns: exports.svg,\n 'xmlns:xlink': exports.xlink\n};\n","/*\n * @copyright 2016 Sean Connelly (@voidqk), http://syntheti.cc\n * @license MIT\n * @preserve Project Home: https://github.com/voidqk/polybooljs\n */\n\nvar BuildLog = require('./lib/build-log');\nvar Epsilon = require('./lib/epsilon');\nvar Intersecter = require('./lib/intersecter');\nvar SegmentChainer = require('./lib/segment-chainer');\nvar SegmentSelector = require('./lib/segment-selector');\nvar GeoJSON = require('./lib/geojson');\n\nvar buildLog = false;\nvar epsilon = Epsilon();\n\nvar PolyBool;\nPolyBool = {\n\t// getter/setter for buildLog\n\tbuildLog: function(bl){\n\t\tif (bl === true)\n\t\t\tbuildLog = BuildLog();\n\t\telse if (bl === false)\n\t\t\tbuildLog = false;\n\t\treturn buildLog === false ? false : buildLog.list;\n\t},\n\t// getter/setter for epsilon\n\tepsilon: function(v){\n\t\treturn epsilon.epsilon(v);\n\t},\n\n\t// core API\n\tsegments: function(poly){\n\t\tvar i = Intersecter(true, epsilon, buildLog);\n\t\tpoly.regions.forEach(i.addRegion);\n\t\treturn {\n\t\t\tsegments: i.calculate(poly.inverted),\n\t\t\tinverted: poly.inverted\n\t\t};\n\t},\n\tcombine: function(segments1, segments2){\n\t\tvar i3 = Intersecter(false, epsilon, buildLog);\n\t\treturn {\n\t\t\tcombined: i3.calculate(\n\t\t\t\tsegments1.segments, segments1.inverted,\n\t\t\t\tsegments2.segments, segments2.inverted\n\t\t\t),\n\t\t\tinverted1: segments1.inverted,\n\t\t\tinverted2: segments2.inverted\n\t\t};\n\t},\n\tselectUnion: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.union(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 || combined.inverted2\n\t\t}\n\t},\n\tselectIntersect: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.intersect(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 && combined.inverted2\n\t\t}\n\t},\n\tselectDifference: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.difference(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 && !combined.inverted2\n\t\t}\n\t},\n\tselectDifferenceRev: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.differenceRev(combined.combined, buildLog),\n\t\t\tinverted: !combined.inverted1 && combined.inverted2\n\t\t}\n\t},\n\tselectXor: function(combined){\n\t\treturn {\n\t\t\tsegments: SegmentSelector.xor(combined.combined, buildLog),\n\t\t\tinverted: combined.inverted1 !== combined.inverted2\n\t\t}\n\t},\n\tpolygon: function(segments){\n\t\treturn {\n\t\t\tregions: SegmentChainer(segments.segments, epsilon, buildLog),\n\t\t\tinverted: segments.inverted\n\t\t};\n\t},\n\n\t// GeoJSON converters\n\tpolygonFromGeoJSON: function(geojson){\n\t\treturn GeoJSON.toPolygon(PolyBool, geojson);\n\t},\n\tpolygonToGeoJSON: function(poly){\n\t\treturn GeoJSON.fromPolygon(PolyBool, epsilon, poly);\n\t},\n\n\t// helper functions for common operations\n\tunion: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectUnion);\n\t},\n\tintersect: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectIntersect);\n\t},\n\tdifference: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectDifference);\n\t},\n\tdifferenceRev: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectDifferenceRev);\n\t},\n\txor: function(poly1, poly2){\n\t\treturn operate(poly1, poly2, PolyBool.selectXor);\n\t}\n};\n\nfunction operate(poly1, poly2, selector){\n\tvar seg1 = PolyBool.segments(poly1);\n\tvar seg2 = PolyBool.segments(poly2);\n\tvar comb = PolyBool.combine(seg1, seg2);\n\tvar seg3 = selector(comb);\n\treturn PolyBool.polygon(seg3);\n}\n\nif (typeof window === 'object')\n\twindow.PolyBool = PolyBool;\n\nmodule.exports = PolyBool;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar modModule = require('./mod');\nvar mod = modModule.mod;\nvar modHalf = modModule.modHalf;\n\nvar PI = Math.PI;\nvar twoPI = 2 * PI;\n\nfunction deg2rad(deg) { return deg / 180 * PI; }\n\nfunction rad2deg(rad) { return rad / PI * 180; }\n\n/**\n * is sector a full circle?\n * ... this comes up a lot in SVG path-drawing routines\n *\n * N.B. we consider all sectors that span more that 2pi 'full' circles\n *\n * @param {2-item array} aBnds : angular bounds in *radians*\n * @return {boolean}\n */\nfunction isFullCircle(aBnds) {\n return Math.abs(aBnds[1] - aBnds[0]) > twoPI - 1e-14;\n}\n\n/**\n * angular delta between angle 'a' and 'b'\n * solution taken from: https://stackoverflow.com/a/2007279\n *\n * @param {number} a : first angle in *radians*\n * @param {number} b : second angle in *radians*\n * @return {number} angular delta in *radians*\n */\nfunction angleDelta(a, b) {\n return modHalf(b - a, twoPI);\n}\n\n/**\n * angular distance between angle 'a' and 'b'\n *\n * @param {number} a : first angle in *radians*\n * @param {number} b : second angle in *radians*\n * @return {number} angular distance in *radians*\n */\nfunction angleDist(a, b) {\n return Math.abs(angleDelta(a, b));\n}\n\n/**\n * is angle inside sector?\n *\n * @param {number} a : angle to test in *radians*\n * @param {2-item array} aBnds : sector's angular bounds in *radians*\n * @param {boolean}\n */\nfunction isAngleInsideSector(a, aBnds) {\n if(isFullCircle(aBnds)) return true;\n\n var s0, s1;\n\n if(aBnds[0] < aBnds[1]) {\n s0 = aBnds[0];\n s1 = aBnds[1];\n } else {\n s0 = aBnds[1];\n s1 = aBnds[0];\n }\n\n s0 = mod(s0, twoPI);\n s1 = mod(s1, twoPI);\n if(s0 > s1) s1 += twoPI;\n\n var a0 = mod(a, twoPI);\n var a1 = a0 + twoPI;\n\n return (a0 >= s0 && a0 <= s1) || (a1 >= s0 && a1 <= s1);\n}\n\n/**\n * is pt (r,a) inside sector?\n *\n * @param {number} r : pt's radial coordinate\n * @param {number} a : pt's angular coordinate in *radians*\n * @param {2-item array} rBnds : sector's radial bounds\n * @param {2-item array} aBnds : sector's angular bounds in *radians*\n * @return {boolean}\n */\nfunction isPtInsideSector(r, a, rBnds, aBnds) {\n if(!isAngleInsideSector(a, aBnds)) return false;\n\n var r0, r1;\n\n if(rBnds[0] < rBnds[1]) {\n r0 = rBnds[0];\n r1 = rBnds[1];\n } else {\n r0 = rBnds[1];\n r1 = rBnds[0];\n }\n\n return r >= r0 && r <= r1;\n}\n\n// common to pathArc, pathSector and pathAnnulus\nfunction _path(r0, r1, a0, a1, cx, cy, isClosed) {\n cx = cx || 0;\n cy = cy || 0;\n\n var isCircle = isFullCircle([a0, a1]);\n var aStart, aMid, aEnd;\n var rStart, rEnd;\n\n if(isCircle) {\n aStart = 0;\n aMid = PI;\n aEnd = twoPI;\n } else {\n if(a0 < a1) {\n aStart = a0;\n aEnd = a1;\n } else {\n aStart = a1;\n aEnd = a0;\n }\n }\n\n if(r0 < r1) {\n rStart = r0;\n rEnd = r1;\n } else {\n rStart = r1;\n rEnd = r0;\n }\n\n // N.B. svg coordinates here, where y increases downward\n function pt(r, a) {\n return [r * Math.cos(a) + cx, cy - r * Math.sin(a)];\n }\n\n var largeArc = Math.abs(aEnd - aStart) <= PI ? 0 : 1;\n function arc(r, a, cw) {\n return 'A' + [r, r] + ' ' + [0, largeArc, cw] + ' ' + pt(r, a);\n }\n\n var p;\n\n if(isCircle) {\n if(rStart === null) {\n p = 'M' + pt(rEnd, aStart) +\n arc(rEnd, aMid, 0) +\n arc(rEnd, aEnd, 0) + 'Z';\n } else {\n p = 'M' + pt(rStart, aStart) +\n arc(rStart, aMid, 0) +\n arc(rStart, aEnd, 0) + 'Z' +\n 'M' + pt(rEnd, aStart) +\n arc(rEnd, aMid, 1) +\n arc(rEnd, aEnd, 1) + 'Z';\n }\n } else {\n if(rStart === null) {\n p = 'M' + pt(rEnd, aStart) + arc(rEnd, aEnd, 0);\n if(isClosed) p += 'L0,0Z';\n } else {\n p = 'M' + pt(rStart, aStart) +\n 'L' + pt(rEnd, aStart) +\n arc(rEnd, aEnd, 0) +\n 'L' + pt(rStart, aEnd) +\n arc(rStart, aStart, 1) + 'Z';\n }\n }\n\n return p;\n}\n\n/**\n * path an arc\n *\n * @param {number} r : radius\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathArc(r, a0, a1, cx, cy) {\n return _path(null, r, a0, a1, cx, cy, 0);\n}\n\n/**\n * path a sector\n *\n * @param {number} r : radius\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathSector(r, a0, a1, cx, cy) {\n return _path(null, r, a0, a1, cx, cy, 1);\n}\n\n/**\n * path an annulus\n *\n * @param {number} r0 : first radial coordinate\n * @param {number} r1 : second radial coordinate\n * @param {number} a0 : first angular coordinate in *radians*\n * @param {number} a1 : second angular coordinate in *radians*\n * @param {number (optional)} cx : x coordinate of center\n * @param {number (optional)} cy : y coordinate of center\n * @return {string} svg path\n */\nfunction pathAnnulus(r0, r1, a0, a1, cx, cy) {\n return _path(r0, r1, a0, a1, cx, cy, 1);\n}\n\nmodule.exports = {\n deg2rad: deg2rad,\n rad2deg: rad2deg,\n angleDelta: angleDelta,\n angleDist: angleDist,\n isFullCircle: isFullCircle,\n isAngleInsideSector: isAngleInsideSector,\n isPtInsideSector: isPtInsideSector,\n pathArc: pathArc,\n pathSector: pathSector,\n pathAnnulus: pathAnnulus\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n// Modified from https://github.com/ArthurClemens/Javascript-Undo-Manager\n// Copyright (c) 2010-2013 Arthur Clemens, [email protected]\nmodule.exports = function UndoManager() {\n var undoCommands = [];\n var index = -1;\n var isExecuting = false;\n var callback;\n\n function execute(command, action) {\n if(!command) return this;\n\n isExecuting = true;\n command[action]();\n isExecuting = false;\n\n return this;\n }\n\n return {\n add: function(command) {\n if(isExecuting) return this;\n undoCommands.splice(index + 1, undoCommands.length - index);\n undoCommands.push(command);\n index = undoCommands.length - 1;\n return this;\n },\n setCallback: function(callbackFunc) { callback = callbackFunc; },\n undo: function() {\n var command = undoCommands[index];\n if(!command) return this;\n execute(command, 'undo');\n index -= 1;\n if(callback) callback(command.undo);\n return this;\n },\n redo: function() {\n var command = undoCommands[index + 1];\n if(!command) return this;\n execute(command, 'redo');\n index += 1;\n if(callback) callback(command.redo);\n return this;\n },\n clear: function() {\n undoCommands = [];\n index = -1;\n },\n hasUndo: function() { return index !== -1; },\n hasRedo: function() { return index < (undoCommands.length - 1); },\n getCommands: function() { return undoCommands; },\n getPreviousCommand: function() { return undoCommands[index - 1]; },\n getIndex: function() { return index; }\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n/*\n * make a regex for matching counter ids/names ie xaxis, xaxis2, xaxis10...\n *\n * @param {string} head: the head of the pattern, eg 'x' matches 'x', 'x2', 'x10' etc.\n * 'xy' is a special case for cartesian subplots: it matches 'x2y3' etc\n * @param {Optional(string)} tail: a fixed piece after the id\n * eg counterRegex('scene', '.annotations') for scene2.annotations etc.\n * @param {boolean} openEnded: if true, the string may continue past the match.\n * @param {boolean} matchBeginning: if false, the string may start before the match.\n */\nexports.counter = function(head, tail, openEnded, matchBeginning) {\n var fullTail = (tail || '') + (openEnded ? '' : '$');\n var startWithPrefix = matchBeginning === false ? '' : '^';\n if(head === 'xy') {\n return new RegExp(startWithPrefix + 'x([2-9]|[1-9][0-9]+)?y([2-9]|[1-9][0-9]+)?' + fullTail);\n }\n return new RegExp(startWithPrefix + head + '([2-9]|[1-9][0-9]+)?' + fullTail);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar NOTEDATA = [];\n\n/**\n * notifier\n * @param {String} text The person's user name\n * @param {Number} [delay=1000] The delay time in milliseconds\n * or 'long' which provides 2000 ms delay time.\n * @return {undefined} this function does not return a value\n */\nmodule.exports = function(text, displayLength) {\n if(NOTEDATA.indexOf(text) !== -1) return;\n\n NOTEDATA.push(text);\n\n var ts = 1000;\n if(isNumeric(displayLength)) ts = displayLength;\n else if(displayLength === 'long') ts = 3000;\n\n var notifierContainer = d3.select('body')\n .selectAll('.plotly-notifier')\n .data([0]);\n notifierContainer.enter()\n .append('div')\n .classed('plotly-notifier', true);\n\n var notes = notifierContainer.selectAll('.notifier-note').data(NOTEDATA);\n\n function killNote(transition) {\n transition\n .duration(700)\n .style('opacity', 0)\n .each('end', function(thisText) {\n var thisIndex = NOTEDATA.indexOf(thisText);\n if(thisIndex !== -1) NOTEDATA.splice(thisIndex, 1);\n d3.select(this).remove();\n });\n }\n\n notes.enter().append('div')\n .classed('notifier-note', true)\n .style('opacity', 0)\n .each(function(thisText) {\n var note = d3.select(this);\n\n note.append('button')\n .classed('notifier-close', true)\n .html('×')\n .on('click', function() {\n note.transition().call(killNote);\n });\n\n var p = note.append('p');\n var lines = thisText.split(//g);\n for(var i = 0; i < lines.length; i++) {\n if(i) p.append('br');\n p.append('span').text(lines[i]);\n }\n\n if(displayLength === 'stick') {\n note.transition()\n .duration(350)\n .style('opacity', 1);\n } else {\n note.transition()\n .duration(700)\n .style('opacity', 1)\n .transition()\n .delay(ts)\n .call(killNote);\n }\n });\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Color = require('../../components/color');\nvar subtypes = require('./subtypes');\n\n\nmodule.exports = function getTraceColor(trace, di) {\n var lc, tc;\n\n // TODO: text modes\n\n if(trace.mode === 'lines') {\n lc = trace.line.color;\n return (lc && Color.opacity(lc)) ?\n lc : trace.fillcolor;\n } else if(trace.mode === 'none') {\n return trace.fill ? trace.fillcolor : '';\n } else {\n var mc = di.mcc || (trace.marker || {}).color;\n var mlc = di.mlcc || ((trace.marker || {}).line || {}).color;\n\n tc = (mc && Color.opacity(mc)) ? mc :\n (mlc && Color.opacity(mlc) &&\n (di.mlw || ((trace.marker || {}).line || {}).width)) ? mlc : '';\n\n if(tc) {\n // make sure the points aren't TOO transparent\n if(Color.opacity(tc) < 0.3) {\n return Color.addOpacity(tc, 0.3);\n } else return tc;\n } else {\n lc = (trace.line || {}).color;\n return (lc && Color.opacity(lc) &&\n subtypes.hasLines(trace) && trace.line.width) ?\n lc : trace.fillcolor;\n }\n }\n};\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// provides the raw computation functions that takes epsilon into account\n//\n// zero is defined to be between (-epsilon, epsilon) exclusive\n//\n\nfunction Epsilon(eps){\n\tif (typeof eps !== 'number')\n\t\teps = 0.0000000001; // sane default? sure why not\n\tvar my = {\n\t\tepsilon: function(v){\n\t\t\tif (typeof v === 'number')\n\t\t\t\teps = v;\n\t\t\treturn eps;\n\t\t},\n\t\tpointAboveOrOnLine: function(pt, left, right){\n\t\t\tvar Ax = left[0];\n\t\t\tvar Ay = left[1];\n\t\t\tvar Bx = right[0];\n\t\t\tvar By = right[1];\n\t\t\tvar Cx = pt[0];\n\t\t\tvar Cy = pt[1];\n\t\t\treturn (Bx - Ax) * (Cy - Ay) - (By - Ay) * (Cx - Ax) >= -eps;\n\t\t},\n\t\tpointBetween: function(p, left, right){\n\t\t\t// p must be collinear with left->right\n\t\t\t// returns false if p == left, p == right, or left == right\n\t\t\tvar d_py_ly = p[1] - left[1];\n\t\t\tvar d_rx_lx = right[0] - left[0];\n\t\t\tvar d_px_lx = p[0] - left[0];\n\t\t\tvar d_ry_ly = right[1] - left[1];\n\n\t\t\tvar dot = d_px_lx * d_rx_lx + d_py_ly * d_ry_ly;\n\t\t\t// if `dot` is 0, then `p` == `left` or `left` == `right` (reject)\n\t\t\t// if `dot` is less than 0, then `p` is to the left of `left` (reject)\n\t\t\tif (dot < eps)\n\t\t\t\treturn false;\n\n\t\t\tvar sqlen = d_rx_lx * d_rx_lx + d_ry_ly * d_ry_ly;\n\t\t\t// if `dot` > `sqlen`, then `p` is to the right of `right` (reject)\n\t\t\t// therefore, if `dot - sqlen` is greater than 0, then `p` is to the right of `right` (reject)\n\t\t\tif (dot - sqlen > -eps)\n\t\t\t\treturn false;\n\n\t\t\treturn true;\n\t\t},\n\t\tpointsSameX: function(p1, p2){\n\t\t\treturn Math.abs(p1[0] - p2[0]) < eps;\n\t\t},\n\t\tpointsSameY: function(p1, p2){\n\t\t\treturn Math.abs(p1[1] - p2[1]) < eps;\n\t\t},\n\t\tpointsSame: function(p1, p2){\n\t\t\treturn my.pointsSameX(p1, p2) && my.pointsSameY(p1, p2);\n\t\t},\n\t\tpointsCompare: function(p1, p2){\n\t\t\t// returns -1 if p1 is smaller, 1 if p2 is smaller, 0 if equal\n\t\t\tif (my.pointsSameX(p1, p2))\n\t\t\t\treturn my.pointsSameY(p1, p2) ? 0 : (p1[1] < p2[1] ? -1 : 1);\n\t\t\treturn p1[0] < p2[0] ? -1 : 1;\n\t\t},\n\t\tpointsCollinear: function(pt1, pt2, pt3){\n\t\t\t// does pt1->pt2->pt3 make a straight line?\n\t\t\t// essentially this is just checking to see if the slope(pt1->pt2) === slope(pt2->pt3)\n\t\t\t// if slopes are equal, then they must be collinear, because they share pt2\n\t\t\tvar dx1 = pt1[0] - pt2[0];\n\t\t\tvar dy1 = pt1[1] - pt2[1];\n\t\t\tvar dx2 = pt2[0] - pt3[0];\n\t\t\tvar dy2 = pt2[1] - pt3[1];\n\t\t\treturn Math.abs(dx1 * dy2 - dx2 * dy1) < eps;\n\t\t},\n\t\tlinesIntersect: function(a0, a1, b0, b1){\n\t\t\t// returns false if the lines are coincident (e.g., parallel or on top of each other)\n\t\t\t//\n\t\t\t// returns an object if the lines intersect:\n\t\t\t// {\n\t\t\t// pt: [x, y], where the intersection point is at\n\t\t\t// alongA: where intersection point is along A,\n\t\t\t// alongB: where intersection point is along B\n\t\t\t// }\n\t\t\t//\n\t\t\t// alongA and alongB will each be one of: -2, -1, 0, 1, 2\n\t\t\t//\n\t\t\t// with the following meaning:\n\t\t\t//\n\t\t\t// -2 intersection point is before segment's first point\n\t\t\t// -1 intersection point is directly on segment's first point\n\t\t\t// 0 intersection point is between segment's first and second points (exclusive)\n\t\t\t// 1 intersection point is directly on segment's second point\n\t\t\t// 2 intersection point is after segment's second point\n\t\t\tvar adx = a1[0] - a0[0];\n\t\t\tvar ady = a1[1] - a0[1];\n\t\t\tvar bdx = b1[0] - b0[0];\n\t\t\tvar bdy = b1[1] - b0[1];\n\n\t\t\tvar axb = adx * bdy - ady * bdx;\n\t\t\tif (Math.abs(axb) < eps)\n\t\t\t\treturn false; // lines are coincident\n\n\t\t\tvar dx = a0[0] - b0[0];\n\t\t\tvar dy = a0[1] - b0[1];\n\n\t\t\tvar A = (bdx * dy - bdy * dx) / axb;\n\t\t\tvar B = (adx * dy - ady * dx) / axb;\n\n\t\t\tvar ret = {\n\t\t\t\talongA: 0,\n\t\t\t\talongB: 0,\n\t\t\t\tpt: [\n\t\t\t\t\ta0[0] + A * adx,\n\t\t\t\t\ta0[1] + A * ady\n\t\t\t\t]\n\t\t\t};\n\n\t\t\t// categorize where intersection point is along A and B\n\n\t\t\tif (A <= -eps)\n\t\t\t\tret.alongA = -2;\n\t\t\telse if (A < eps)\n\t\t\t\tret.alongA = -1;\n\t\t\telse if (A - 1 <= -eps)\n\t\t\t\tret.alongA = 0;\n\t\t\telse if (A - 1 < eps)\n\t\t\t\tret.alongA = 1;\n\t\t\telse\n\t\t\t\tret.alongA = 2;\n\n\t\t\tif (B <= -eps)\n\t\t\t\tret.alongB = -2;\n\t\t\telse if (B < eps)\n\t\t\t\tret.alongB = -1;\n\t\t\telse if (B - 1 <= -eps)\n\t\t\t\tret.alongB = 0;\n\t\t\telse if (B - 1 < eps)\n\t\t\t\tret.alongB = 1;\n\t\t\telse\n\t\t\t\tret.alongB = 2;\n\n\t\t\treturn ret;\n\t\t},\n\t\tpointInsideRegion: function(pt, region){\n\t\t\tvar x = pt[0];\n\t\t\tvar y = pt[1];\n\t\t\tvar last_x = region[region.length - 1][0];\n\t\t\tvar last_y = region[region.length - 1][1];\n\t\t\tvar inside = false;\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tvar curr_x = region[i][0];\n\t\t\t\tvar curr_y = region[i][1];\n\n\t\t\t\t// if y is between curr_y and last_y, and\n\t\t\t\t// x is to the right of the boundary created by the line\n\t\t\t\tif ((curr_y - y > eps) != (last_y - y > eps) &&\n\t\t\t\t\t(last_x - curr_x) * (y - curr_y) / (last_y - curr_y) + curr_x - x > eps)\n\t\t\t\t\tinside = !inside\n\n\t\t\t\tlast_x = curr_x;\n\t\t\t\tlast_y = curr_y;\n\t\t\t}\n\t\t\treturn inside;\n\t\t}\n\t};\n\treturn my;\n}\n\nmodule.exports = Epsilon;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar calc = require('./calc');\n\n/*\n * Scatter stacking & normalization calculations\n * runs per subplot, and can handle multiple stacking groups\n */\n\nmodule.exports = function crossTraceCalc(gd, plotinfo) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var subplot = xa._id + ya._id;\n\n var subplotStackOpts = gd._fullLayout._scatterStackOpts[subplot];\n if(!subplotStackOpts) return;\n\n var calcTraces = gd.calcdata;\n\n var i, j, k, i2, cd, cd0, posj, sumj, norm;\n var groupOpts, interpolate, groupnorm, posAttr, valAttr;\n var hasAnyBlanks;\n\n for(var stackGroup in subplotStackOpts) {\n groupOpts = subplotStackOpts[stackGroup];\n var indices = groupOpts.traceIndices;\n\n // can get here with no indices if the stack axis is non-numeric\n if(!indices.length) continue;\n\n interpolate = groupOpts.stackgaps === 'interpolate';\n groupnorm = groupOpts.groupnorm;\n if(groupOpts.orientation === 'v') {\n posAttr = 'x';\n valAttr = 'y';\n } else {\n posAttr = 'y';\n valAttr = 'x';\n }\n hasAnyBlanks = new Array(indices.length);\n for(i = 0; i < hasAnyBlanks.length; i++) {\n hasAnyBlanks[i] = false;\n }\n\n // Collect the complete set of all positions across ALL traces.\n // Start with the first trace, then interleave items from later traces\n // as needed.\n // Fill in mising items as we go.\n cd0 = calcTraces[indices[0]];\n var allPositions = new Array(cd0.length);\n for(i = 0; i < cd0.length; i++) {\n allPositions[i] = cd0[i][posAttr];\n }\n\n for(i = 1; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n\n for(j = k = 0; j < cd.length; j++) {\n posj = cd[j][posAttr];\n for(; posj > allPositions[k] && k < allPositions.length; k++) {\n // the current trace is missing a position from some previous trace(s)\n insertBlank(cd, j, allPositions[k], i, hasAnyBlanks, interpolate, posAttr);\n j++;\n }\n if(posj !== allPositions[k]) {\n // previous trace(s) are missing a position from the current trace\n for(i2 = 0; i2 < i; i2++) {\n insertBlank(calcTraces[indices[i2]], k, posj, i2, hasAnyBlanks, interpolate, posAttr);\n }\n allPositions.splice(k, 0, posj);\n }\n k++;\n }\n for(; k < allPositions.length; k++) {\n insertBlank(cd, j, allPositions[k], i, hasAnyBlanks, interpolate, posAttr);\n j++;\n }\n }\n\n var serieslen = allPositions.length;\n\n // stack (and normalize)!\n for(j = 0; j < cd0.length; j++) {\n sumj = cd0[j][valAttr] = cd0[j].s;\n for(i = 1; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n cd[0].trace._rawLength = cd[0].trace._length;\n cd[0].trace._length = serieslen;\n sumj += cd[j].s;\n cd[j][valAttr] = sumj;\n }\n\n if(groupnorm) {\n norm = ((groupnorm === 'fraction') ? sumj : (sumj / 100)) || 1;\n for(i = 0; i < indices.length; i++) {\n var cdj = calcTraces[indices[i]][j];\n cdj[valAttr] /= norm;\n cdj.sNorm = cdj.s / norm;\n }\n }\n }\n\n // autorange\n for(i = 0; i < indices.length; i++) {\n cd = calcTraces[indices[i]];\n var trace = cd[0].trace;\n var ppad = calc.calcMarkerSize(trace, trace._rawLength);\n var arrayPad = Array.isArray(ppad);\n if((ppad && hasAnyBlanks[i]) || arrayPad) {\n var ppadRaw = ppad;\n ppad = new Array(serieslen);\n for(j = 0; j < serieslen; j++) {\n ppad[j] = cd[j].gap ? 0 : (arrayPad ? ppadRaw[cd[j].i] : ppadRaw);\n }\n }\n var x = new Array(serieslen);\n var y = new Array(serieslen);\n for(j = 0; j < serieslen; j++) {\n x[j] = cd[j].x;\n y[j] = cd[j].y;\n }\n calc.calcAxisExpansion(gd, trace, xa, ya, x, y, ppad);\n\n // while we're here (in a loop over all traces in the stack)\n // record the orientation, so hover can find it easily\n cd[0].t.orientation = groupOpts.orientation;\n }\n }\n};\n\nfunction insertBlank(calcTrace, index, position, traceIndex, hasAnyBlanks, interpolate, posAttr) {\n hasAnyBlanks[traceIndex] = true;\n var newEntry = {\n i: null,\n gap: true,\n s: 0\n };\n newEntry[posAttr] = position;\n calcTrace.splice(index, 0, newEntry);\n // Even if we're not interpolating, if one trace has multiple\n // values at the same position and this trace only has one value there,\n // we just duplicate that one value rather than insert a zero.\n // We also make it look like a real point - because it's ambiguous which\n // one really is the real one!\n if(index && position === calcTrace[index - 1][posAttr]) {\n var prevEntry = calcTrace[index - 1];\n newEntry.s = prevEntry.s;\n // TODO is it going to cause any problems to have multiple\n // calcdata points with the same index?\n newEntry.i = prevEntry.i;\n newEntry.gap = prevEntry.gap;\n } else if(interpolate) {\n newEntry.s = getInterp(calcTrace, index, position, posAttr);\n }\n if(!index) {\n // t and trace need to stay on the first cd entry\n calcTrace[0].t = calcTrace[1].t;\n calcTrace[0].trace = calcTrace[1].trace;\n delete calcTrace[1].t;\n delete calcTrace[1].trace;\n }\n}\n\nfunction getInterp(calcTrace, index, position, posAttr) {\n var pt0 = calcTrace[index - 1];\n var pt1 = calcTrace[index + 1];\n if(!pt1) return pt0.s;\n if(!pt0) return pt1.s;\n return pt0.s + (pt1.s - pt0.s) * (position - pt0[posAttr]) / (pt1[posAttr] - pt0[posAttr]);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Color = require('../color');\n\nvar ARROWPATHS = require('./arrow_paths');\n\n/**\n * Add arrowhead(s) to a path or line element\n *\n * @param {d3.selection} el3: a d3-selected line or path element\n *\n * @param {string} ends: 'none', 'start', 'end', or 'start+end' for which ends get arrowheads\n *\n * @param {object} options: style information. Must have all the following:\n * @param {number} options.arrowhead: end head style - see ./arrow_paths\n * @param {number} options.startarrowhead: start head style - see ./arrow_paths\n * @param {number} options.arrowsize: relative size of the end head vs line width\n * @param {number} options.startarrowsize: relative size of the start head vs line width\n * @param {number} options.standoff: distance in px to move the end arrow point from its target\n * @param {number} options.startstandoff: distance in px to move the start arrow point from its target\n * @param {number} options.arrowwidth: width of the arrow line\n * @param {string} options.arrowcolor: color of the arrow line, for the head to match\n * Note that the opacity of this color is ignored, as it's assumed the container\n * of both the line and head has opacity applied to it so there isn't greater opacity\n * where they overlap.\n */\nmodule.exports = function drawArrowHead(el3, ends, options) {\n var el = el3.node();\n var headStyle = ARROWPATHS[options.arrowhead || 0];\n var startHeadStyle = ARROWPATHS[options.startarrowhead || 0];\n var scale = (options.arrowwidth || 1) * (options.arrowsize || 1);\n var startScale = (options.arrowwidth || 1) * (options.startarrowsize || 1);\n var doStart = ends.indexOf('start') >= 0;\n var doEnd = ends.indexOf('end') >= 0;\n var backOff = headStyle.backoff * scale + options.standoff;\n var startBackOff = startHeadStyle.backoff * startScale + options.startstandoff;\n\n var start, end, startRot, endRot;\n\n if(el.nodeName === 'line') {\n start = {x: +el3.attr('x1'), y: +el3.attr('y1')};\n end = {x: +el3.attr('x2'), y: +el3.attr('y2')};\n\n var dx = start.x - end.x;\n var dy = start.y - end.y;\n\n startRot = Math.atan2(dy, dx);\n endRot = startRot + Math.PI;\n if(backOff && startBackOff) {\n if(backOff + startBackOff > Math.sqrt(dx * dx + dy * dy)) {\n hideLine();\n return;\n }\n }\n\n if(backOff) {\n if(backOff * backOff > dx * dx + dy * dy) {\n hideLine();\n return;\n }\n var backOffX = backOff * Math.cos(startRot);\n var backOffY = backOff * Math.sin(startRot);\n\n end.x += backOffX;\n end.y += backOffY;\n el3.attr({x2: end.x, y2: end.y});\n }\n\n if(startBackOff) {\n if(startBackOff * startBackOff > dx * dx + dy * dy) {\n hideLine();\n return;\n }\n var startBackOffX = startBackOff * Math.cos(startRot);\n var startbackOffY = startBackOff * Math.sin(startRot);\n\n start.x -= startBackOffX;\n start.y -= startbackOffY;\n el3.attr({x1: start.x, y1: start.y});\n }\n } else if(el.nodeName === 'path') {\n var pathlen = el.getTotalLength();\n // using dash to hide the backOff region of the path.\n // if we ever allow dash for the arrow we'll have to\n // do better than this hack... maybe just manually\n // combine the two\n var dashArray = '';\n\n if(pathlen < backOff + startBackOff) {\n hideLine();\n return;\n }\n\n\n var start0 = el.getPointAtLength(0);\n var dstart = el.getPointAtLength(0.1);\n\n startRot = Math.atan2(start0.y - dstart.y, start0.x - dstart.x);\n start = el.getPointAtLength(Math.min(startBackOff, pathlen));\n\n dashArray = '0px,' + startBackOff + 'px,';\n\n var end0 = el.getPointAtLength(pathlen);\n var dend = el.getPointAtLength(pathlen - 0.1);\n\n endRot = Math.atan2(end0.y - dend.y, end0.x - dend.x);\n end = el.getPointAtLength(Math.max(0, pathlen - backOff));\n\n var shortening = dashArray ? startBackOff + backOff : backOff;\n dashArray += (pathlen - shortening) + 'px,' + pathlen + 'px';\n\n el3.style('stroke-dasharray', dashArray);\n }\n\n function hideLine() { el3.style('stroke-dasharray', '0px,100px'); }\n\n function drawhead(arrowHeadStyle, p, rot, arrowScale) {\n if(!arrowHeadStyle.path) return;\n if(arrowHeadStyle.noRotate) rot = 0;\n\n d3.select(el.parentNode).append('path')\n .attr({\n 'class': el3.attr('class'),\n d: arrowHeadStyle.path,\n transform:\n 'translate(' + p.x + ',' + p.y + ')' +\n (rot ? 'rotate(' + (rot * 180 / Math.PI) + ')' : '') +\n 'scale(' + arrowScale + ')'\n })\n .style({\n fill: Color.rgb(options.arrowcolor),\n 'stroke-width': 0\n });\n }\n\n if(doStart) drawhead(startHeadStyle, start, startRot, startScale);\n if(doEnd) drawhead(headStyle, end, endRot, scale);\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar layoutAttributes = require('./layout_attributes');\nvar handleArrayContainerDefaults = require('../array_container_defaults');\n\nmodule.exports = function handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options, config) {\n if(!config || config.pass === 1) {\n handlePrefixSuffix(containerIn, containerOut, coerce, axType, options);\n }\n\n if(!config || config.pass === 2) {\n handleOtherDefaults(containerIn, containerOut, coerce, axType, options);\n }\n};\n\nfunction handlePrefixSuffix(containerIn, containerOut, coerce, axType, options) {\n var showAttrDflt = getShowAttrDflt(containerIn);\n\n var tickPrefix = coerce('tickprefix');\n if(tickPrefix) coerce('showtickprefix', showAttrDflt);\n\n var tickSuffix = coerce('ticksuffix', options.tickSuffixDflt);\n if(tickSuffix) coerce('showticksuffix', showAttrDflt);\n}\n\nfunction handleOtherDefaults(containerIn, containerOut, coerce, axType, options) {\n var showAttrDflt = getShowAttrDflt(containerIn);\n\n var tickPrefix = coerce('tickprefix');\n if(tickPrefix) coerce('showtickprefix', showAttrDflt);\n\n var tickSuffix = coerce('ticksuffix', options.tickSuffixDflt);\n if(tickSuffix) coerce('showticksuffix', showAttrDflt);\n\n var showTickLabels = coerce('showticklabels');\n if(showTickLabels) {\n var font = options.font || {};\n var contColor = containerOut.color;\n // as with titlefont.color, inherit axis.color only if one was\n // explicitly provided\n var dfltFontColor = (contColor && contColor !== layoutAttributes.color.dflt) ?\n contColor : font.color;\n Lib.coerceFont(coerce, 'tickfont', {\n family: font.family,\n size: font.size,\n color: dfltFontColor\n });\n coerce('tickangle');\n\n if(axType !== 'category') {\n var tickFormat = coerce('tickformat');\n\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'tickformatstops',\n inclusionAttr: 'enabled',\n handleItemDefaults: tickformatstopDefaults\n });\n if(!containerOut.tickformatstops.length) {\n delete containerOut.tickformatstops;\n }\n\n if(!tickFormat && axType !== 'date') {\n coerce('showexponent', showAttrDflt);\n coerce('exponentformat');\n coerce('separatethousands');\n }\n }\n }\n}\n\n/*\n * Attributes 'showexponent', 'showtickprefix' and 'showticksuffix'\n * share values.\n *\n * If only 1 attribute is set,\n * the remaining attributes inherit that value.\n *\n * If 2 attributes are set to the same value,\n * the remaining attribute inherits that value.\n *\n * If 2 attributes are set to different values,\n * the remaining is set to its dflt value.\n *\n */\nfunction getShowAttrDflt(containerIn) {\n var showAttrsAll = ['showexponent', 'showtickprefix', 'showticksuffix'];\n var showAttrs = showAttrsAll.filter(function(a) {\n return containerIn[a] !== undefined;\n });\n var sameVal = function(a) {\n return containerIn[a] === containerIn[showAttrs[0]];\n };\n\n if(showAttrs.every(sameVal) || showAttrs.length === 1) {\n return containerIn[showAttrs[0]];\n }\n}\n\nfunction tickformatstopDefaults(valueIn, valueOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(valueIn, valueOut, layoutAttributes.tickformatstops, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n if(enabled) {\n coerce('dtickrange');\n coerce('value');\n }\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Lib = require('../lib');\nvar Drawing = require('../components/drawing');\nvar Color = require('../components/color');\n\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar DOUBLEQUOTE_REGEX = /\"/g;\nvar DUMMY_SUB = 'TOBESTRIPPED';\nvar DUMMY_REGEX = new RegExp('(\"' + DUMMY_SUB + ')|(' + DUMMY_SUB + '\")', 'g');\n\nfunction htmlEntityDecode(s) {\n var hiddenDiv = d3.select('body').append('div').style({display: 'none'}).html('');\n var replaced = s.replace(/(&[^;]*;)/gi, function(d) {\n if(d === '<') { return '<'; } // special handling for brackets\n if(d === '&rt;') { return '>'; }\n if(d.indexOf('<') !== -1 || d.indexOf('>') !== -1) { return ''; }\n return hiddenDiv.html(d).text(); // everything else, let the browser decode it to unicode\n });\n hiddenDiv.remove();\n return replaced;\n}\n\nfunction xmlEntityEncode(str) {\n return str.replace(/&(?!\\w+;|\\#[0-9]+;| \\#x[0-9A-F]+;)/g, '&');\n}\n\nmodule.exports = function toSVG(gd, format, scale) {\n var fullLayout = gd._fullLayout;\n var svg = fullLayout._paper;\n var toppaper = fullLayout._toppaper;\n var width = fullLayout.width;\n var height = fullLayout.height;\n var i;\n\n // make background color a rect in the svg, then revert after scraping\n // all other alterations have been dealt with by properly preparing the svg\n // in the first place... like setting cursors with css classes so we don't\n // have to remove them, and providing the right namespaces in the svg to\n // begin with\n svg.insert('rect', ':first-child')\n .call(Drawing.setRect, 0, 0, width, height)\n .call(Color.fill, fullLayout.paper_bgcolor);\n\n // subplot-specific to-SVG methods\n // which notably add the contents of the gl-container\n // into the main svg node\n var basePlotModules = fullLayout._basePlotModules || [];\n for(i = 0; i < basePlotModules.length; i++) {\n var _module = basePlotModules[i];\n\n if(_module.toSVG) _module.toSVG(gd);\n }\n\n // add top items above them assumes everything in toppaper is either\n // a group or a defs, and if it's empty (like hoverlayer) we can ignore it.\n if(toppaper) {\n var nodes = toppaper.node().childNodes;\n\n // make copy of nodes as childNodes prop gets mutated in loop below\n var topGroups = Array.prototype.slice.call(nodes);\n\n for(i = 0; i < topGroups.length; i++) {\n var topGroup = topGroups[i];\n\n if(topGroup.childNodes.length) svg.node().appendChild(topGroup);\n }\n }\n\n // remove draglayer for Adobe Illustrator compatibility\n if(fullLayout._draggers) {\n fullLayout._draggers.remove();\n }\n\n // in case the svg element had an explicit background color, remove this\n // we want the rect to get the color so it's the right size; svg bg will\n // fill whatever container it's displayed in regardless of plot size.\n svg.node().style.background = '';\n\n svg.selectAll('text')\n .attr({'data-unformatted': null, 'data-math': null})\n .each(function() {\n var txt = d3.select(this);\n\n // hidden text is pre-formatting mathjax, the browser ignores it\n // but in a static plot it's useless and it can confuse batik\n // we've tried to standardize on display:none but make sure we still\n // catch visibility:hidden if it ever arises\n if(this.style.visibility === 'hidden' || this.style.display === 'none') {\n txt.remove();\n return;\n } else {\n // clear other visibility/display values to default\n // to not potentially confuse non-browser SVG implementations\n txt.style({visibility: null, display: null});\n }\n\n // Font family styles break things because of quotation marks,\n // so we must remove them *after* the SVG DOM has been serialized\n // to a string (browsers convert singles back)\n var ff = this.style.fontFamily;\n if(ff && ff.indexOf('\"') !== -1) {\n txt.style('font-family', ff.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n });\n\n\n if(fullLayout._gradientUrlQueryParts) {\n var queryParts = [];\n for(var k in fullLayout._gradientUrlQueryParts) queryParts.push(k);\n\n if(queryParts.length) {\n svg.selectAll(queryParts.join(',')).each(function() {\n var pt = d3.select(this);\n\n // similar to font family styles above,\n // we must remove \" after the SVG DOM has been serialized\n var fill = this.style.fill;\n if(fill && fill.indexOf('url(') !== -1) {\n pt.style('fill', fill.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n\n var stroke = this.style.stroke;\n if(stroke && stroke.indexOf('url(') !== -1) {\n pt.style('stroke', stroke.replace(DOUBLEQUOTE_REGEX, DUMMY_SUB));\n }\n });\n }\n }\n\n if(format === 'pdf' || format === 'eps') {\n // these formats make the extra line MathJax adds around symbols look super thick in some cases\n // it looks better if this is removed entirely.\n svg.selectAll('#MathJax_SVG_glyphs path')\n .attr('stroke-width', 0);\n }\n\n // fix for IE namespacing quirk?\n // http://stackoverflow.com/questions/19610089/unwanted-namespaces-on-svg-markup-when-using-xmlserializer-in-javascript-with-ie\n svg.node().setAttributeNS(xmlnsNamespaces.xmlns, 'xmlns', xmlnsNamespaces.svg);\n svg.node().setAttributeNS(xmlnsNamespaces.xmlns, 'xmlns:xlink', xmlnsNamespaces.xlink);\n\n if(format === 'svg' && scale) {\n svg.attr('width', scale * width);\n svg.attr('height', scale * height);\n svg.attr('viewBox', '0 0 ' + width + ' ' + height);\n }\n\n var s = new window.XMLSerializer().serializeToString(svg.node());\n s = htmlEntityDecode(s);\n s = xmlEntityEncode(s);\n\n // Fix quotations around font strings and gradient URLs\n s = s.replace(DUMMY_REGEX, '\\'');\n\n // IE is very strict, so we will need to clean\n // svg with the following regex\n // yes this is messy, but do not know a better way\n // Even with this IE will not work due to tainted canvas\n // see https://github.com/kangax/fabric.js/issues/1957\n // http://stackoverflow.com/questions/18112047/canvas-todataurl-working-in-all-browsers-except-ie10\n // Leave here just in case the CORS/tainted IE issue gets resolved\n if(Lib.isIE()) {\n // replace double quote with single quote\n s = s.replace(/\"/gi, '\\'');\n // url in svg are single quoted\n // since we changed double to single\n // we'll need to change these to double-quoted\n s = s.replace(/(\\('#)([^']*)('\\))/gi, '(\\\"#$2\\\")');\n // font names with spaces will be escaped single-quoted\n // we'll need to change these to double-quoted\n s = s.replace(/(\\\\')/gi, '\\\"');\n }\n\n return s;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function autoType(array, calendar, opts) {\n opts = opts || {};\n\n if(!opts.noMultiCategory && multiCategory(array)) return 'multicategory';\n if(moreDates(array, calendar)) return 'date';\n if(category(array)) return 'category';\n if(linearOK(array)) return 'linear';\n else return '-';\n};\n\n// is there at least one number in array? If not, we should leave\n// ax.type empty so it can be autoset later\nfunction linearOK(array) {\n if(!array) return false;\n\n for(var i = 0; i < array.length; i++) {\n if(isNumeric(array[i])) return true;\n }\n\n return false;\n}\n\n// does the array a have mostly dates rather than numbers?\n// note: some values can be neither (such as blanks, text)\n// 2- or 4-digit integers can be both, so require twice as many\n// dates as non-dates, to exclude cases with mostly 2 & 4 digit\n// numbers and a few dates\n// as with categories, consider DISTINCT values only.\nfunction moreDates(a, calendar) {\n // test at most 1000 points, evenly spaced\n var inc = Math.max(1, (a.length - 1) / 1000);\n var dcnt = 0;\n var ncnt = 0;\n var seen = {};\n\n for(var i = 0; i < a.length; i += inc) {\n var ai = a[Math.round(i)];\n var stri = String(ai);\n if(seen[stri]) continue;\n seen[stri] = 1;\n\n if(Lib.isDateTime(ai, calendar)) dcnt += 1;\n if(isNumeric(ai)) ncnt += 1;\n }\n\n return (dcnt > ncnt * 2);\n}\n\n// are the (x,y)-values in gd.data mostly text?\n// require twice as many DISTINCT categories as distinct numbers\nfunction category(a) {\n // test at most 1000 points\n var inc = Math.max(1, (a.length - 1) / 1000);\n var curvenums = 0;\n var curvecats = 0;\n var seen = {};\n\n for(var i = 0; i < a.length; i += inc) {\n var ai = a[Math.round(i)];\n var stri = String(ai);\n if(seen[stri]) continue;\n seen[stri] = 1;\n\n if(typeof ai === 'boolean') curvecats++;\n else if(Lib.cleanNumber(ai) !== BADNUM) curvenums++;\n else if(typeof ai === 'string') curvecats++;\n }\n\n return curvecats > curvenums * 2;\n}\n\n// very-loose requirements for multicategory,\n// trace modules that should never auto-type to multicategory\n// should be declared with 'noMultiCategory'\nfunction multiCategory(a) {\n return Lib.isArrayOrTypedArray(a[0]) && Lib.isArrayOrTypedArray(a[1]);\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar extendFlat = require('../lib/extend').extendFlat;\n\n/**\n * Make a xy domain attribute group\n *\n * @param {object} opts\n * @param {string}\n * opts.name: name to be inserted in the default description\n * @param {boolean}\n * opts.trace: set to true for trace containers\n * @param {string}\n * opts.editType: editType for all pieces\n * @param {boolean}\n * opts.noGridCell: set to true to omit `row` and `column`\n *\n * @param {object} extra\n * @param {string}\n * extra.description: extra description. N.B we use\n * a separate extra container to make it compatible with\n * the compress_attributes transform.\n *\n * @return {object} attributes object containing {x,y} as specified\n */\nexports.attributes = function(opts, extra) {\n opts = opts || {};\n extra = extra || {};\n\n var base = {\n valType: 'info_array',\n role: 'info',\n editType: opts.editType,\n items: [\n {valType: 'number', min: 0, max: 1, editType: opts.editType},\n {valType: 'number', min: 0, max: 1, editType: opts.editType}\n ],\n dflt: [0, 1]\n };\n\n var namePart = opts.name ? opts.name + ' ' : '';\n var contPart = opts.trace ? 'trace ' : 'subplot ';\n var descPart = extra.description ? ' ' + extra.description : '';\n\n var out = {\n x: extendFlat({}, base, {\n description: [\n 'Sets the horizontal domain of this ',\n namePart,\n contPart,\n '(in plot fraction).',\n descPart\n ].join('')\n }),\n y: extendFlat({}, base, {\n description: [\n 'Sets the vertical domain of this ',\n namePart,\n contPart,\n '(in plot fraction).',\n descPart\n ].join('')\n }),\n editType: opts.editType\n };\n\n if(!opts.noGridCell) {\n out.row = {\n valType: 'integer',\n min: 0,\n dflt: 0,\n role: 'info',\n editType: opts.editType,\n description: [\n 'If there is a layout grid, use the domain ',\n 'for this row in the grid for this ',\n namePart,\n contPart,\n '.',\n descPart\n ].join('')\n };\n out.column = {\n valType: 'integer',\n min: 0,\n dflt: 0,\n role: 'info',\n editType: opts.editType,\n description: [\n 'If there is a layout grid, use the domain ',\n 'for this column in the grid for this ',\n namePart,\n contPart,\n '.',\n descPart\n ].join('')\n };\n }\n\n return out;\n};\n\nexports.defaults = function(containerOut, layout, coerce, dfltDomains) {\n var dfltX = (dfltDomains && dfltDomains.x) || [0, 1];\n var dfltY = (dfltDomains && dfltDomains.y) || [0, 1];\n\n var grid = layout.grid;\n if(grid) {\n var column = coerce('domain.column');\n if(column !== undefined) {\n if(column < grid.columns) dfltX = grid._domains.x[column];\n else delete containerOut.domain.column;\n }\n\n var row = coerce('domain.row');\n if(row !== undefined) {\n if(row < grid.rows) dfltY = grid._domains.y[row];\n else delete containerOut.domain.row;\n }\n }\n\n var x = coerce('domain.x', dfltX);\n var y = coerce('domain.y', dfltY);\n\n // don't accept bad input data\n if(!(x[0] < x[1])) containerOut.domain.x = dfltX.slice();\n if(!(y[0] < y[1])) containerOut.domain.y = dfltY.slice();\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../../plots/font_attributes');\nvar colorAttrs = require('../color/attributes');\n\n\nmodule.exports = {\n bgcolor: {\n valType: 'color',\n role: 'style',\n editType: 'legend',\n description: [\n 'Sets the legend background color.',\n 'Defaults to `layout.paper_bgcolor`.'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'legend',\n description: 'Sets the color of the border enclosing the legend.'\n },\n borderwidth: {\n valType: 'number',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'legend',\n description: 'Sets the width (in px) of the border enclosing the legend.'\n },\n font: fontAttrs({\n editType: 'legend',\n description: 'Sets the font used to text the legend items.'\n }),\n orientation: {\n valType: 'enumerated',\n values: ['v', 'h'],\n dflt: 'v',\n role: 'info',\n editType: 'legend',\n description: 'Sets the orientation of the legend.'\n },\n traceorder: {\n valType: 'flaglist',\n flags: ['reversed', 'grouped'],\n extras: ['normal'],\n role: 'style',\n editType: 'legend',\n description: [\n 'Determines the order at which the legend items are displayed.',\n\n 'If *normal*, the items are displayed top-to-bottom in the same',\n 'order as the input data.',\n\n 'If *reversed*, the items are displayed in the opposite order',\n 'as *normal*.',\n\n 'If *grouped*, the items are displayed in groups',\n '(when a trace `legendgroup` is provided).',\n\n 'if *grouped+reversed*, the items are displayed in the opposite order',\n 'as *grouped*.'\n ].join(' ')\n },\n tracegroupgap: {\n valType: 'number',\n min: 0,\n dflt: 10,\n role: 'style',\n editType: 'legend',\n description: [\n 'Sets the amount of vertical space (in px) between legend groups.'\n ].join(' ')\n },\n itemsizing: {\n valType: 'enumerated',\n values: ['trace', 'constant'],\n dflt: 'trace',\n role: 'style',\n editType: 'legend',\n description: [\n 'Determines if the legend items symbols scale with their corresponding *trace* attributes',\n 'or remain *constant* independent of the symbol size on the graph.'\n ].join(' ')\n },\n\n itemclick: {\n valType: 'enumerated',\n values: ['toggle', 'toggleothers', false],\n dflt: 'toggle',\n role: 'info',\n editType: 'legend',\n description: [\n 'Determines the behavior on legend item click.',\n '*toggle* toggles the visibility of the item clicked on the graph.',\n '*toggleothers* makes the clicked item the sole visible item on the graph.',\n '*false* disable legend item click interactions.'\n ].join(' ')\n },\n itemdoubleclick: {\n valType: 'enumerated',\n values: ['toggle', 'toggleothers', false],\n dflt: 'toggleothers',\n role: 'info',\n editType: 'legend',\n description: [\n 'Determines the behavior on legend item double-click.',\n '*toggle* toggles the visibility of the item clicked on the graph.',\n '*toggleothers* makes the clicked item the sole visible item on the graph.',\n '*false* disable legend item double-click interactions.'\n ].join(' ')\n },\n\n x: {\n valType: 'number',\n min: -2,\n max: 3,\n role: 'style',\n editType: 'legend',\n description: [\n 'Sets the x position (in normalized coordinates) of the legend.',\n 'Defaults to *1.02* for vertical legends and',\n 'defaults to *0* for horizontal legends.'\n ].join(' ')\n },\n xanchor: {\n valType: 'enumerated',\n values: ['auto', 'left', 'center', 'right'],\n dflt: 'left',\n role: 'info',\n editType: 'legend',\n description: [\n 'Sets the legend\\'s horizontal position anchor.',\n 'This anchor binds the `x` position to the *left*, *center*',\n 'or *right* of the legend.',\n 'Value *auto* anchors legends to the right for `x` values greater than or equal to 2/3,',\n 'anchors legends to the left for `x` values less than or equal to 1/3 and',\n 'anchors legends with respect to their center otherwise.'\n ].join(' ')\n },\n y: {\n valType: 'number',\n min: -2,\n max: 3,\n role: 'style',\n editType: 'legend',\n description: [\n 'Sets the y position (in normalized coordinates) of the legend.',\n 'Defaults to *1* for vertical legends,',\n 'defaults to *-0.1* for horizontal legends on graphs w/o range sliders and',\n 'defaults to *1.1* for horizontal legends on graph with one or multiple range sliders.'\n ].join(' ')\n },\n yanchor: {\n valType: 'enumerated',\n values: ['auto', 'top', 'middle', 'bottom'],\n role: 'info',\n editType: 'legend',\n description: [\n 'Sets the legend\\'s vertical position anchor',\n 'This anchor binds the `y` position to the *top*, *middle*',\n 'or *bottom* of the legend.',\n 'Value *auto* anchors legends at their bottom for `y` values less than or equal to 1/3,',\n 'anchors legends to at their top for `y` values greater than or equal to 2/3 and',\n 'anchors legends with respect to their middle otherwise.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of legend-driven changes in trace and pie label',\n 'visibility. Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n valign: {\n valType: 'enumerated',\n values: ['top', 'middle', 'bottom'],\n dflt: 'middle',\n role: 'style',\n editType: 'legend',\n description: [\n 'Sets the vertical alignment of the symbols with respect to their associated text.',\n ].join(' ')\n },\n title: {\n text: {\n valType: 'string',\n dflt: '',\n role: 'info',\n editType: 'legend',\n description: [\n 'Sets the title of the legend.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'legend',\n description: [\n 'Sets this legend\\'s title font.'\n ].join(' '),\n }),\n side: {\n valType: 'enumerated',\n values: ['top', 'left', 'top left'],\n role: 'style',\n editType: 'legend',\n description: [\n 'Determines the location of legend\\'s title',\n 'with respect to the legend items.',\n 'Defaulted to *top* with `orientation` is *h*.',\n 'Defaulted to *left* with `orientation` is *v*.',\n 'The *top left* options could be used to expand',\n 'legend area in both x and y sides.'\n ].join(' ')\n },\n editType: 'legend',\n },\n\n editType: 'legend'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar main = require('./plot_api');\n\nexports.plot = main.plot;\nexports.newPlot = main.newPlot;\nexports.restyle = main.restyle;\nexports.relayout = main.relayout;\nexports.redraw = main.redraw;\nexports.update = main.update;\nexports._guiRestyle = main._guiRestyle;\nexports._guiRelayout = main._guiRelayout;\nexports._guiUpdate = main._guiUpdate;\nexports._storeDirectGUIEdit = main._storeDirectGUIEdit;\nexports.react = main.react;\nexports.extendTraces = main.extendTraces;\nexports.prependTraces = main.prependTraces;\nexports.addTraces = main.addTraces;\nexports.deleteTraces = main.deleteTraces;\nexports.moveTraces = main.moveTraces;\nexports.purge = main.purge;\nexports.addFrames = main.addFrames;\nexports.deleteFrames = main.deleteFrames;\nexports.animate = main.animate;\nexports.setPlotConfig = main.setPlotConfig;\n\nexports.toImage = require('./to_image');\nexports.validate = require('./validate');\nexports.downloadImage = require('../snapshot/download');\n\nvar templateApi = require('./template_api');\nexports.makeTemplate = templateApi.makeTemplate;\nexports.validateTemplate = templateApi.validateTemplate;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n // not really a 'subplot' attribute container,\n // but this is the flag we use to denote attributes that\n // support yaxis, yaxis2, yaxis3, ... counters\n _isSubplotObj: true,\n\n rangemode: {\n valType: 'enumerated',\n values: ['auto', 'fixed', 'match'],\n dflt: 'match',\n role: 'style',\n editType: 'calc',\n description: [\n 'Determines whether or not the range of this axis in',\n 'the rangeslider use the same value than in the main plot',\n 'when zooming in/out.',\n 'If *auto*, the autorange will be used.',\n 'If *fixed*, the `range` is used.',\n 'If *match*, the current range of the corresponding y-axis on the main subplot is used.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n role: 'style',\n items: [\n {valType: 'any', editType: 'plot'},\n {valType: 'any', editType: 'plot'}\n ],\n editType: 'plot',\n description: [\n 'Sets the range of this axis for the rangeslider.'\n ].join(' ')\n },\n editType: 'calc'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Axes = require('../../plots/cartesian/axes');\n\nvar constants = require('./constants');\nvar helpers = require('./helpers');\n\n\nmodule.exports = function calcAutorange(gd) {\n var fullLayout = gd._fullLayout;\n var shapeList = Lib.filterVisible(fullLayout.shapes);\n\n if(!shapeList.length || !gd._fullData.length) return;\n\n for(var i = 0; i < shapeList.length; i++) {\n var shape = shapeList[i];\n shape._extremes = {};\n\n var ax, bounds;\n\n if(shape.xref !== 'paper') {\n var vx0 = shape.xsizemode === 'pixel' ? shape.xanchor : shape.x0;\n var vx1 = shape.xsizemode === 'pixel' ? shape.xanchor : shape.x1;\n ax = Axes.getFromId(gd, shape.xref);\n\n bounds = shapeBounds(ax, vx0, vx1, shape.path, constants.paramIsX);\n if(bounds) {\n shape._extremes[ax._id] = Axes.findExtremes(ax, bounds, calcXPaddingOptions(shape));\n }\n }\n\n if(shape.yref !== 'paper') {\n var vy0 = shape.ysizemode === 'pixel' ? shape.yanchor : shape.y0;\n var vy1 = shape.ysizemode === 'pixel' ? shape.yanchor : shape.y1;\n ax = Axes.getFromId(gd, shape.yref);\n\n bounds = shapeBounds(ax, vy0, vy1, shape.path, constants.paramIsY);\n if(bounds) {\n shape._extremes[ax._id] = Axes.findExtremes(ax, bounds, calcYPaddingOptions(shape));\n }\n }\n }\n};\n\nfunction calcXPaddingOptions(shape) {\n return calcPaddingOptions(shape.line.width, shape.xsizemode, shape.x0, shape.x1, shape.path, false);\n}\n\nfunction calcYPaddingOptions(shape) {\n return calcPaddingOptions(shape.line.width, shape.ysizemode, shape.y0, shape.y1, shape.path, true);\n}\n\nfunction calcPaddingOptions(lineWidth, sizeMode, v0, v1, path, isYAxis) {\n var ppad = lineWidth / 2;\n var axisDirectionReverted = isYAxis;\n\n if(sizeMode === 'pixel') {\n var coords = path ?\n helpers.extractPathCoords(path, isYAxis ? constants.paramIsY : constants.paramIsX) :\n [v0, v1];\n var maxValue = Lib.aggNums(Math.max, null, coords);\n var minValue = Lib.aggNums(Math.min, null, coords);\n var beforePad = minValue < 0 ? Math.abs(minValue) + ppad : ppad;\n var afterPad = maxValue > 0 ? maxValue + ppad : ppad;\n\n return {\n ppad: ppad,\n ppadplus: axisDirectionReverted ? beforePad : afterPad,\n ppadminus: axisDirectionReverted ? afterPad : beforePad\n };\n } else {\n return {ppad: ppad};\n }\n}\n\nfunction shapeBounds(ax, v0, v1, path, paramsToUse) {\n var convertVal = (ax.type === 'category' || ax.type === 'multicategory') ? ax.r2c : ax.d2c;\n\n if(v0 !== undefined) return [convertVal(v0), convertVal(v1)];\n if(!path) return;\n\n var min = Infinity;\n var max = -Infinity;\n var segments = path.match(constants.segmentRE);\n var i;\n var segment;\n var drawnParam;\n var params;\n var val;\n\n if(ax.type === 'date') convertVal = helpers.decodeDate(convertVal);\n\n for(i = 0; i < segments.length; i++) {\n segment = segments[i];\n drawnParam = paramsToUse[segment.charAt(0)].drawn;\n if(drawnParam === undefined) continue;\n\n params = segments[i].substr(1).match(constants.paramRE);\n if(!params || params.length < drawnParam) continue;\n\n val = convertVal(params[drawnParam]);\n if(val < min) min = val;\n if(val > max) max = val;\n }\n if(max >= min) return [min, max];\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\nvar hasHover = require('has-hover');\n\nvar Lib = require('../lib');\nvar nestedProperty = Lib.nestedProperty;\n\nvar Events = require('../lib/events');\nvar Queue = require('../lib/queue');\n\nvar Registry = require('../registry');\nvar PlotSchema = require('./plot_schema');\nvar Plots = require('../plots/plots');\nvar Polar = require('../plots/polar/legacy');\n\nvar Axes = require('../plots/cartesian/axes');\nvar Drawing = require('../components/drawing');\nvar Color = require('../components/color');\nvar initInteractions = require('../plots/cartesian/graph_interact').initInteractions;\nvar xmlnsNamespaces = require('../constants/xmlns_namespaces');\nvar svgTextUtils = require('../lib/svg_text_utils');\nvar clearSelect = require('../plots/cartesian/select').clearSelect;\n\nvar dfltConfig = require('./plot_config').dfltConfig;\nvar manageArrays = require('./manage_arrays');\nvar helpers = require('./helpers');\nvar subroutines = require('./subroutines');\nvar editTypes = require('./edit_types');\n\nvar AX_NAME_PATTERN = require('../plots/cartesian/constants').AX_NAME_PATTERN;\n\nvar numericNameWarningCount = 0;\nvar numericNameWarningCountLimit = 5;\n\n/**\n * Main plot-creation function\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {array of objects} data\n * array of traces, containing the data and display information for each trace\n * @param {object} layout\n * object describing the overall display of the plot,\n * all the stuff that doesn't pertain to any individual trace\n * @param {object} config\n * configuration options (see ./plot_config.js for more info)\n *\n * OR\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {object} figure\n * object containing `data`, `layout`, `config`, and `frames` members\n *\n */\nfunction plot(gd, data, layout, config) {\n var frames;\n\n gd = Lib.getGraphDiv(gd);\n\n // Events.init is idempotent and bails early if gd has already been init'd\n Events.init(gd);\n\n if(Lib.isPlainObject(data)) {\n var obj = data;\n data = obj.data;\n layout = obj.layout;\n config = obj.config;\n frames = obj.frames;\n }\n\n var okToPlot = Events.triggerHandler(gd, 'plotly_beforeplot', [data, layout, config]);\n if(okToPlot === false) return Promise.reject();\n\n // if there's no data or layout, and this isn't yet a plotly plot\n // container, log a warning to help plotly.js users debug\n if(!data && !layout && !Lib.isPlotDiv(gd)) {\n Lib.warn('Calling Plotly.plot as if redrawing ' +\n 'but this container doesn\\'t yet have a plot.', gd);\n }\n\n function addFrames() {\n if(frames) {\n return exports.addFrames(gd, frames);\n }\n }\n\n // transfer configuration options to gd until we move over to\n // a more OO like model\n setPlotContext(gd, config);\n\n if(!layout) layout = {};\n\n // hook class for plots main container (in case of plotly.js\n // this won't be #embedded-graph or .js-tab-contents)\n d3.select(gd).classed('js-plotly-plot', true);\n\n // off-screen getBoundingClientRect testing space,\n // in #js-plotly-tester (and stored as Drawing.tester)\n // so we can share cached text across tabs\n Drawing.makeTester();\n\n // collect promises for any async actions during plotting\n // any part of the plotting code can push to gd._promises, then\n // before we move to the next step, we check that they're all\n // complete, and empty out the promise list again.\n if(!Array.isArray(gd._promises)) gd._promises = [];\n\n var graphWasEmpty = ((gd.data || []).length === 0 && Array.isArray(data));\n\n // if there is already data on the graph, append the new data\n // if you only want to redraw, pass a non-array for data\n if(Array.isArray(data)) {\n helpers.cleanData(data);\n\n if(graphWasEmpty) gd.data = data;\n else gd.data.push.apply(gd.data, data);\n\n // for routines outside graph_obj that want a clean tab\n // (rather than appending to an existing one) gd.empty\n // is used to determine whether to make a new tab\n gd.empty = false;\n }\n\n if(!gd.layout || graphWasEmpty) {\n gd.layout = helpers.cleanLayout(layout);\n }\n\n Plots.supplyDefaults(gd);\n\n var fullLayout = gd._fullLayout;\n var hasCartesian = fullLayout._has('cartesian');\n\n // Legacy polar plots\n if(!fullLayout._has('polar') && data && data[0] && data[0].r) {\n Lib.log('Legacy polar charts are deprecated!');\n return plotLegacyPolar(gd, data, layout);\n }\n\n // so we don't try to re-call Plotly.plot from inside\n // legend and colorbar, if margins changed\n fullLayout._replotting = true;\n\n // make or remake the framework if we need to\n if(graphWasEmpty) makePlotFramework(gd);\n\n // polar need a different framework\n if(gd.framework !== makePlotFramework) {\n gd.framework = makePlotFramework;\n makePlotFramework(gd);\n }\n\n // clear gradient defs on each .plot call, because we know we'll loop through all traces\n Drawing.initGradients(gd);\n\n // save initial show spikes once per graph\n if(graphWasEmpty) Axes.saveShowSpikeInitial(gd);\n\n // prepare the data and find the autorange\n\n // generate calcdata, if we need to\n // to force redoing calcdata, just delete it before calling Plotly.plot\n var recalc = !gd.calcdata || gd.calcdata.length !== (gd._fullData || []).length;\n if(recalc) Plots.doCalcdata(gd);\n\n // in case it has changed, attach fullData traces to calcdata\n for(var i = 0; i < gd.calcdata.length; i++) {\n gd.calcdata[i][0].trace = gd._fullData[i];\n }\n\n // make the figure responsive\n if(gd._context.responsive) {\n if(!gd._responsiveChartHandler) {\n // Keep a reference to the resize handler to purge it down the road\n gd._responsiveChartHandler = function() { if(!Lib.isHidden(gd)) Plots.resize(gd); };\n\n // Listen to window resize\n window.addEventListener('resize', gd._responsiveChartHandler);\n }\n } else {\n Lib.clearResponsive(gd);\n }\n\n /*\n * start async-friendly code - now we're actually drawing things\n */\n\n var oldMargins = Lib.extendFlat({}, fullLayout._size);\n\n // draw framework first so that margin-pushing\n // components can position themselves correctly\n var drawFrameworkCalls = 0;\n function drawFramework() {\n var basePlotModules = fullLayout._basePlotModules;\n\n for(var i = 0; i < basePlotModules.length; i++) {\n if(basePlotModules[i].drawFramework) {\n basePlotModules[i].drawFramework(gd);\n }\n }\n\n if(!fullLayout._glcanvas && fullLayout._has('gl')) {\n fullLayout._glcanvas = fullLayout._glcontainer.selectAll('.gl-canvas').data([{\n key: 'contextLayer',\n context: true,\n pick: false\n }, {\n key: 'focusLayer',\n context: false,\n pick: false\n }, {\n key: 'pickLayer',\n context: false,\n pick: true\n }], function(d) { return d.key; });\n\n fullLayout._glcanvas.enter().append('canvas')\n .attr('class', function(d) {\n return 'gl-canvas gl-canvas-' + d.key.replace('Layer', '');\n })\n .style({\n position: 'absolute',\n top: 0,\n left: 0,\n overflow: 'visible',\n 'pointer-events': 'none'\n });\n }\n\n if(fullLayout._glcanvas) {\n fullLayout._glcanvas\n .attr('width', fullLayout.width)\n .attr('height', fullLayout.height);\n\n var regl = fullLayout._glcanvas.data()[0].regl;\n if(regl) {\n // Unfortunately, this can happen when relayouting to large\n // width/height on some browsers.\n if(Math.floor(fullLayout.width) !== regl._gl.drawingBufferWidth ||\n Math.floor(fullLayout.height) !== regl._gl.drawingBufferHeight\n ) {\n var msg = 'WebGL context buffer and canvas dimensions do not match due to browser/WebGL bug.';\n if(drawFrameworkCalls) {\n Lib.error(msg);\n } else {\n Lib.log(msg + ' Clearing graph and plotting again.');\n Plots.cleanPlot([], {}, gd._fullData, fullLayout);\n Plots.supplyDefaults(gd);\n fullLayout = gd._fullLayout;\n Plots.doCalcdata(gd);\n drawFrameworkCalls++;\n return drawFramework();\n }\n }\n }\n }\n\n if(fullLayout.modebar.orientation === 'h') {\n fullLayout._modebardiv\n .style('height', null)\n .style('width', '100%');\n } else {\n fullLayout._modebardiv\n .style('width', null)\n .style('height', fullLayout.height + 'px');\n }\n\n return Plots.previousPromises(gd);\n }\n\n // draw anything that can affect margins.\n function marginPushers() {\n // First reset the list of things that are allowed to change the margins\n // So any deleted traces or components will be wiped out of the\n // automargin calculation.\n // This means *every* margin pusher must be listed here, even if it\n // doesn't actually try to push the margins until later.\n Plots.clearAutoMarginIds(gd);\n\n subroutines.drawMarginPushers(gd);\n Axes.allowAutoMargin(gd);\n\n // TODO can this be moved elsewhere?\n if(fullLayout._has('pie')) {\n var fullData = gd._fullData;\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n if(trace.type === 'pie' && trace.automargin) {\n Plots.allowAutoMargin(gd, 'pie.' + trace.uid + '.automargin');\n }\n }\n }\n\n Plots.doAutoMargin(gd);\n return Plots.previousPromises(gd);\n }\n\n // in case the margins changed, draw margin pushers again\n function marginPushersAgain() {\n if(!Plots.didMarginChange(oldMargins, fullLayout._size)) return;\n\n return Lib.syncOrAsync([\n marginPushers,\n subroutines.layoutStyles\n ], gd);\n }\n\n function positionAndAutorange() {\n if(!recalc) {\n doAutoRangeAndConstraints();\n return;\n }\n\n // TODO: autosize extra for text markers and images\n // see https://github.com/plotly/plotly.js/issues/1111\n return Lib.syncOrAsync([\n Registry.getComponentMethod('shapes', 'calcAutorange'),\n Registry.getComponentMethod('annotations', 'calcAutorange'),\n doAutoRangeAndConstraints\n ], gd);\n }\n\n function doAutoRangeAndConstraints() {\n if(gd._transitioning) return;\n\n subroutines.doAutoRangeAndConstraints(gd);\n\n // store initial ranges *after* enforcing constraints, otherwise\n // we will never look like we're at the initial ranges\n if(graphWasEmpty) Axes.saveRangeInitial(gd);\n\n // this one is different from shapes/annotations calcAutorange\n // the others incorporate those components into ax._extremes,\n // this one actually sets the ranges in rangesliders.\n Registry.getComponentMethod('rangeslider', 'calcAutorange')(gd);\n }\n\n // draw ticks, titles, and calculate axis scaling (._b, ._m)\n function drawAxes() {\n return Axes.draw(gd, graphWasEmpty ? '' : 'redraw');\n }\n\n var seq = [\n Plots.previousPromises,\n addFrames,\n drawFramework,\n marginPushers,\n marginPushersAgain\n ];\n\n if(hasCartesian) seq.push(positionAndAutorange);\n\n seq.push(subroutines.layoutStyles);\n if(hasCartesian) seq.push(drawAxes);\n\n seq.push(\n subroutines.drawData,\n subroutines.finalDraw,\n initInteractions,\n Plots.addLinks,\n Plots.rehover,\n Plots.redrag,\n // TODO: doAutoMargin is only needed here for axis automargin, which\n // happens outside of marginPushers where all the other automargins are\n // calculated. Would be much better to separate margin calculations from\n // component drawing - see https://github.com/plotly/plotly.js/issues/2704\n Plots.doAutoMargin,\n Plots.previousPromises\n );\n\n // even if everything we did was synchronous, return a promise\n // so that the caller doesn't care which route we took\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve();\n\n return plotDone.then(function() {\n emitAfterPlot(gd);\n return gd;\n });\n}\n\nfunction emitAfterPlot(gd) {\n var fullLayout = gd._fullLayout;\n\n if(fullLayout._redrawFromAutoMarginCount) {\n fullLayout._redrawFromAutoMarginCount--;\n } else {\n gd.emit('plotly_afterplot');\n }\n}\n\nfunction setPlotConfig(obj) {\n return Lib.extendFlat(dfltConfig, obj);\n}\n\nfunction setBackground(gd, bgColor) {\n try {\n gd._fullLayout._paper.style('background', bgColor);\n } catch(e) {\n Lib.error(e);\n }\n}\n\nfunction opaqueSetBackground(gd, bgColor) {\n var blend = Color.combine(bgColor, 'white');\n setBackground(gd, blend);\n}\n\nfunction setPlotContext(gd, config) {\n if(!gd._context) {\n gd._context = Lib.extendDeep({}, dfltConfig);\n\n // stash href, used to make robust clipPath URLs\n var base = d3.select('base');\n gd._context._baseUrl = base.size() && base.attr('href') ?\n window.location.href.split('#')[0] :\n '';\n }\n\n var context = gd._context;\n\n var i, keys, key;\n\n if(config) {\n keys = Object.keys(config);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n if(key === 'editable' || key === 'edits') continue;\n if(key in context) {\n if(key === 'setBackground' && config[key] === 'opaque') {\n context[key] = opaqueSetBackground;\n } else {\n context[key] = config[key];\n }\n }\n }\n\n // map plot3dPixelRatio to plotGlPixelRatio for backward compatibility\n if(config.plot3dPixelRatio && !context.plotGlPixelRatio) {\n context.plotGlPixelRatio = context.plot3dPixelRatio;\n }\n\n // now deal with editable and edits - first editable overrides\n // everything, then edits refines\n var editable = config.editable;\n if(editable !== undefined) {\n // we're not going to *use* context.editable, we're only going to\n // use context.edits... but keep it for the record\n context.editable = editable;\n\n keys = Object.keys(context.edits);\n for(i = 0; i < keys.length; i++) {\n context.edits[keys[i]] = editable;\n }\n }\n if(config.edits) {\n keys = Object.keys(config.edits);\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n if(key in context.edits) {\n context.edits[key] = config.edits[key];\n }\n }\n }\n\n // not part of the user-facing config options\n context._exportedPlot = config._exportedPlot;\n }\n\n // staticPlot forces a bunch of others:\n if(context.staticPlot) {\n context.editable = false;\n context.edits = {};\n context.autosizable = false;\n context.scrollZoom = false;\n context.doubleClick = false;\n context.showTips = false;\n context.showLink = false;\n context.displayModeBar = false;\n }\n\n // make sure hover-only devices have mode bar visible\n if(context.displayModeBar === 'hover' && !hasHover) {\n context.displayModeBar = true;\n }\n\n // default and fallback for setBackground\n if(context.setBackground === 'transparent' || typeof context.setBackground !== 'function') {\n context.setBackground = setBackground;\n }\n\n // Check if gd has a specified widht/height to begin with\n context._hasZeroHeight = context._hasZeroHeight || gd.clientHeight === 0;\n context._hasZeroWidth = context._hasZeroWidth || gd.clientWidth === 0;\n\n // fill context._scrollZoom helper to help manage scrollZoom flaglist\n var szIn = context.scrollZoom;\n var szOut = context._scrollZoom = {};\n if(szIn === true) {\n szOut.cartesian = 1;\n szOut.gl3d = 1;\n szOut.geo = 1;\n szOut.mapbox = 1;\n } else if(typeof szIn === 'string') {\n var parts = szIn.split('+');\n for(i = 0; i < parts.length; i++) {\n szOut[parts[i]] = 1;\n }\n } else if(szIn !== false) {\n szOut.gl3d = 1;\n szOut.geo = 1;\n szOut.mapbox = 1;\n }\n}\n\nfunction plotLegacyPolar(gd, data, layout) {\n // build or reuse the container skeleton\n var plotContainer = d3.select(gd).selectAll('.plot-container')\n .data([0]);\n plotContainer.enter()\n .insert('div', ':first-child')\n .classed('plot-container plotly', true);\n var paperDiv = plotContainer.selectAll('.svg-container')\n .data([0]);\n paperDiv.enter().append('div')\n .classed('svg-container', true)\n .style('position', 'relative');\n\n // empty it everytime for now\n paperDiv.html('');\n\n // fulfill gd requirements\n if(data) gd.data = data;\n if(layout) gd.layout = layout;\n Polar.manager.fillLayout(gd);\n\n // resize canvas\n paperDiv.style({\n width: gd._fullLayout.width + 'px',\n height: gd._fullLayout.height + 'px'\n });\n\n // instantiate framework\n gd.framework = Polar.manager.framework(gd);\n\n // plot\n gd.framework({data: gd.data, layout: gd.layout}, paperDiv.node());\n\n // set undo point\n gd.framework.setUndoPoint();\n\n // get the resulting svg for extending it\n var polarPlotSVG = gd.framework.svg();\n\n // editable title\n var opacity = 1;\n var txt = gd._fullLayout.title ? gd._fullLayout.title.text : '';\n if(txt === '' || !txt) opacity = 0;\n\n var titleLayout = function() {\n this.call(svgTextUtils.convertToTspans, gd);\n // TODO: html/mathjax\n // TODO: center title\n };\n\n var title = polarPlotSVG.select('.title-group text')\n .call(titleLayout);\n\n if(gd._context.edits.titleText) {\n var placeholderText = Lib._(gd, 'Click to enter Plot title');\n if(!txt || txt === placeholderText) {\n opacity = 0.2;\n // placeholder is not going through convertToTspans\n // so needs explicit data-unformatted\n title.attr({'data-unformatted': placeholderText})\n .text(placeholderText)\n .style({opacity: opacity})\n .on('mouseover.opacity', function() {\n d3.select(this).transition().duration(100)\n .style('opacity', 1);\n })\n .on('mouseout.opacity', function() {\n d3.select(this).transition().duration(1000)\n .style('opacity', 0);\n });\n }\n\n var setContenteditable = function() {\n this.call(svgTextUtils.makeEditable, {gd: gd})\n .on('edit', function(text) {\n gd.framework({layout: {title: {text: text}}});\n this.text(text)\n .call(titleLayout);\n this.call(setContenteditable);\n })\n .on('cancel', function() {\n var txt = this.attr('data-unformatted');\n this.text(txt).call(titleLayout);\n });\n };\n title.call(setContenteditable);\n }\n\n gd._context.setBackground(gd, gd._fullLayout.paper_bgcolor);\n Plots.addLinks(gd);\n\n return Promise.resolve();\n}\n\n// convenience function to force a full redraw, mostly for use by plotly.js\nfunction redraw(gd) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error('This element is not a Plotly plot: ' + gd);\n }\n\n helpers.cleanData(gd.data);\n helpers.cleanLayout(gd.layout);\n\n gd.calcdata = undefined;\n return exports.plot(gd).then(function() {\n gd.emit('plotly_redraw');\n return gd;\n });\n}\n\n/**\n * Convenience function to make idempotent plot option obvious to users.\n *\n * @param gd\n * @param {Object[]} data\n * @param {Object} layout\n * @param {Object} config\n */\nfunction newPlot(gd, data, layout, config) {\n gd = Lib.getGraphDiv(gd);\n\n // remove gl contexts\n Plots.cleanPlot([], {}, gd._fullData || [], gd._fullLayout || {});\n\n Plots.purge(gd);\n return exports.plot(gd, data, layout, config);\n}\n\n/**\n * Wrap negative indicies to their positive counterparts.\n *\n * @param {Number[]} indices An array of indices\n * @param {Number} maxIndex The maximum index allowable (arr.length - 1)\n */\nfunction positivifyIndices(indices, maxIndex) {\n var parentLength = maxIndex + 1;\n var positiveIndices = [];\n var i;\n var index;\n\n for(i = 0; i < indices.length; i++) {\n index = indices[i];\n if(index < 0) {\n positiveIndices.push(parentLength + index);\n } else {\n positiveIndices.push(index);\n }\n }\n return positiveIndices;\n}\n\n/**\n * Ensures that an index array for manipulating gd.data is valid.\n *\n * Intended for use with addTraces, deleteTraces, and moveTraces.\n *\n * @param gd\n * @param indices\n * @param arrayName\n */\nfunction assertIndexArray(gd, indices, arrayName) {\n var i,\n index;\n\n for(i = 0; i < indices.length; i++) {\n index = indices[i];\n\n // validate that indices are indeed integers\n if(index !== parseInt(index, 10)) {\n throw new Error('all values in ' + arrayName + ' must be integers');\n }\n\n // check that all indices are in bounds for given gd.data array length\n if(index >= gd.data.length || index < -gd.data.length) {\n throw new Error(arrayName + ' must be valid indices for gd.data.');\n }\n\n // check that indices aren't repeated\n if(indices.indexOf(index, i + 1) > -1 ||\n index >= 0 && indices.indexOf(-gd.data.length + index) > -1 ||\n index < 0 && indices.indexOf(gd.data.length + index) > -1) {\n throw new Error('each index in ' + arrayName + ' must be unique.');\n }\n }\n}\n\n/**\n * Private function used by Plotly.moveTraces to check input args\n *\n * @param gd\n * @param currentIndices\n * @param newIndices\n */\nfunction checkMoveTracesArgs(gd, currentIndices, newIndices) {\n // check that gd has attribute 'data' and 'data' is array\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array.');\n }\n\n // validate currentIndices array\n if(typeof currentIndices === 'undefined') {\n throw new Error('currentIndices is a required argument.');\n } else if(!Array.isArray(currentIndices)) {\n currentIndices = [currentIndices];\n }\n assertIndexArray(gd, currentIndices, 'currentIndices');\n\n // validate newIndices array if it exists\n if(typeof newIndices !== 'undefined' && !Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n if(typeof newIndices !== 'undefined') {\n assertIndexArray(gd, newIndices, 'newIndices');\n }\n\n // check currentIndices and newIndices are the same length if newIdices exists\n if(typeof newIndices !== 'undefined' && currentIndices.length !== newIndices.length) {\n throw new Error('current and new indices must be of equal length.');\n }\n}\n/**\n * A private function to reduce the type checking clutter in addTraces.\n *\n * @param gd\n * @param traces\n * @param newIndices\n */\nfunction checkAddTracesArgs(gd, traces, newIndices) {\n var i, value;\n\n // check that gd has attribute 'data' and 'data' is array\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array.');\n }\n\n // make sure traces exists\n if(typeof traces === 'undefined') {\n throw new Error('traces must be defined.');\n }\n\n // make sure traces is an array\n if(!Array.isArray(traces)) {\n traces = [traces];\n }\n\n // make sure each value in traces is an object\n for(i = 0; i < traces.length; i++) {\n value = traces[i];\n if(typeof value !== 'object' || (Array.isArray(value) || value === null)) {\n throw new Error('all values in traces array must be non-array objects');\n }\n }\n\n // make sure we have an index for each trace\n if(typeof newIndices !== 'undefined' && !Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n if(typeof newIndices !== 'undefined' && newIndices.length !== traces.length) {\n throw new Error(\n 'if indices is specified, traces.length must equal indices.length'\n );\n }\n}\n\n/**\n * A private function to reduce the type checking clutter in spliceTraces.\n * Get all update Properties from gd.data. Validate inputs and outputs.\n * Used by prependTrace and extendTraces\n *\n * @param gd\n * @param update\n * @param indices\n * @param maxPoints\n */\nfunction assertExtendTracesArgs(gd, update, indices, maxPoints) {\n var maxPointsIsObject = Lib.isPlainObject(maxPoints);\n\n if(!Array.isArray(gd.data)) {\n throw new Error('gd.data must be an array');\n }\n if(!Lib.isPlainObject(update)) {\n throw new Error('update must be a key:value object');\n }\n\n if(typeof indices === 'undefined') {\n throw new Error('indices must be an integer or array of integers');\n }\n\n assertIndexArray(gd, indices, 'indices');\n\n for(var key in update) {\n /*\n * Verify that the attribute to be updated contains as many trace updates\n * as indices. Failure must result in throw and no-op\n */\n if(!Array.isArray(update[key]) || update[key].length !== indices.length) {\n throw new Error('attribute ' + key + ' must be an array of length equal to indices array length');\n }\n\n /*\n * if maxPoints is an object it must match keys and array lengths of 'update' 1:1\n */\n if(maxPointsIsObject &&\n (!(key in maxPoints) || !Array.isArray(maxPoints[key]) ||\n maxPoints[key].length !== update[key].length)) {\n throw new Error('when maxPoints is set as a key:value object it must contain a 1:1 ' +\n 'corrispondence with the keys and number of traces in the update object');\n }\n }\n}\n\n/**\n * A private function to reduce the type checking clutter in spliceTraces.\n *\n * @param {Object|HTMLDivElement} gd\n * @param {Object} update\n * @param {Number[]} indices\n * @param {Number||Object} maxPoints\n * @return {Object[]}\n */\nfunction getExtendProperties(gd, update, indices, maxPoints) {\n var maxPointsIsObject = Lib.isPlainObject(maxPoints);\n var updateProps = [];\n var trace, target, prop, insert, maxp;\n\n // allow scalar index to represent a single trace position\n if(!Array.isArray(indices)) indices = [indices];\n\n // negative indices are wrapped around to their positive value. Equivalent to python indexing.\n indices = positivifyIndices(indices, gd.data.length - 1);\n\n // loop through all update keys and traces and harvest validated data.\n for(var key in update) {\n for(var j = 0; j < indices.length; j++) {\n /*\n * Choose the trace indexed by the indices map argument and get the prop setter-getter\n * instance that references the key and value for this particular trace.\n */\n trace = gd.data[indices[j]];\n prop = nestedProperty(trace, key);\n\n /*\n * Target is the existing gd.data.trace.dataArray value like \"x\" or \"marker.size\"\n * Target must exist as an Array to allow the extend operation to be performed.\n */\n target = prop.get();\n insert = update[key][j];\n\n if(!Lib.isArrayOrTypedArray(insert)) {\n throw new Error('attribute: ' + key + ' index: ' + j + ' must be an array');\n }\n if(!Lib.isArrayOrTypedArray(target)) {\n throw new Error('cannot extend missing or non-array attribute: ' + key);\n }\n if(target.constructor !== insert.constructor) {\n throw new Error('cannot extend array with an array of a different type: ' + key);\n }\n\n /*\n * maxPoints may be an object map or a scalar. If object select the key:value, else\n * Use the scalar maxPoints for all key and trace combinations.\n */\n maxp = maxPointsIsObject ? maxPoints[key][j] : maxPoints;\n\n // could have chosen null here, -1 just tells us to not take a window\n if(!isNumeric(maxp)) maxp = -1;\n\n /*\n * Wrap the nestedProperty in an object containing required data\n * for lengthening and windowing this particular trace - key combination.\n * Flooring maxp mirrors the behaviour of floats in the Array.slice JSnative function.\n */\n updateProps.push({\n prop: prop,\n target: target,\n insert: insert,\n maxp: Math.floor(maxp)\n });\n }\n }\n\n // all target and insertion data now validated\n return updateProps;\n}\n\n/**\n * A private function to key Extend and Prepend traces DRY\n *\n * @param {Object|HTMLDivElement} gd\n * @param {Object} update\n * @param {Number[]} indices\n * @param {Number||Object} maxPoints\n * @param {Function} updateArray\n * @return {Object}\n */\nfunction spliceTraces(gd, update, indices, maxPoints, updateArray) {\n assertExtendTracesArgs(gd, update, indices, maxPoints);\n\n var updateProps = getExtendProperties(gd, update, indices, maxPoints);\n var undoUpdate = {};\n var undoPoints = {};\n\n for(var i = 0; i < updateProps.length; i++) {\n var prop = updateProps[i].prop;\n var maxp = updateProps[i].maxp;\n\n // return new array and remainder\n var out = updateArray(updateProps[i].target, updateProps[i].insert, maxp);\n prop.set(out[0]);\n\n // build the inverse update object for the undo operation\n if(!Array.isArray(undoUpdate[prop.astr])) undoUpdate[prop.astr] = [];\n undoUpdate[prop.astr].push(out[1]);\n\n // build the matching maxPoints undo object containing original trace lengths\n if(!Array.isArray(undoPoints[prop.astr])) undoPoints[prop.astr] = [];\n undoPoints[prop.astr].push(updateProps[i].target.length);\n }\n\n return {update: undoUpdate, maxPoints: undoPoints};\n}\n\nfunction concatTypedArray(arr0, arr1) {\n var arr2 = new arr0.constructor(arr0.length + arr1.length);\n arr2.set(arr0);\n arr2.set(arr1, arr0.length);\n return arr2;\n}\n\n/**\n * extend && prepend traces at indices with update arrays, window trace lengths to maxPoints\n *\n * Extend and Prepend have identical APIs. Prepend inserts an array at the head while Extend\n * inserts an array off the tail. Prepend truncates the tail of the array - counting maxPoints\n * from the head, whereas Extend truncates the head of the array, counting backward maxPoints\n * from the tail.\n *\n * If maxPoints is undefined, nonNumeric, negative or greater than extended trace length no\n * truncation / windowing will be performed. If its zero, well the whole trace is truncated.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object} update The key:array map of target attributes to extend\n * @param {Number|Number[]} indices The locations of traces to be extended\n * @param {Number|Object} [maxPoints] Number of points for trace window after lengthening.\n *\n */\nfunction extendTraces(gd, update, indices, maxPoints) {\n gd = Lib.getGraphDiv(gd);\n\n function updateArray(target, insert, maxp) {\n var newArray, remainder;\n\n if(Lib.isTypedArray(target)) {\n if(maxp < 0) {\n var none = new target.constructor(0);\n var both = concatTypedArray(target, insert);\n\n if(maxp < 0) {\n newArray = both;\n remainder = none;\n } else {\n newArray = none;\n remainder = both;\n }\n } else {\n newArray = new target.constructor(maxp);\n remainder = new target.constructor(target.length + insert.length - maxp);\n\n if(maxp === insert.length) {\n newArray.set(insert);\n remainder.set(target);\n } else if(maxp < insert.length) {\n var numberOfItemsFromInsert = insert.length - maxp;\n\n newArray.set(insert.subarray(numberOfItemsFromInsert));\n remainder.set(target);\n remainder.set(insert.subarray(0, numberOfItemsFromInsert), target.length);\n } else {\n var numberOfItemsFromTarget = maxp - insert.length;\n var targetBegin = target.length - numberOfItemsFromTarget;\n\n newArray.set(target.subarray(targetBegin));\n newArray.set(insert, numberOfItemsFromTarget);\n remainder.set(target.subarray(0, targetBegin));\n }\n }\n } else {\n newArray = target.concat(insert);\n remainder = (maxp >= 0 && maxp < newArray.length) ?\n newArray.splice(0, newArray.length - maxp) :\n [];\n }\n\n return [newArray, remainder];\n }\n\n var undo = spliceTraces(gd, update, indices, maxPoints, updateArray);\n var promise = exports.redraw(gd);\n var undoArgs = [gd, undo.update, indices, undo.maxPoints];\n Queue.add(gd, exports.prependTraces, undoArgs, extendTraces, arguments);\n\n return promise;\n}\n\nfunction prependTraces(gd, update, indices, maxPoints) {\n gd = Lib.getGraphDiv(gd);\n\n function updateArray(target, insert, maxp) {\n var newArray, remainder;\n\n if(Lib.isTypedArray(target)) {\n if(maxp <= 0) {\n var none = new target.constructor(0);\n var both = concatTypedArray(insert, target);\n\n if(maxp < 0) {\n newArray = both;\n remainder = none;\n } else {\n newArray = none;\n remainder = both;\n }\n } else {\n newArray = new target.constructor(maxp);\n remainder = new target.constructor(target.length + insert.length - maxp);\n\n if(maxp === insert.length) {\n newArray.set(insert);\n remainder.set(target);\n } else if(maxp < insert.length) {\n var numberOfItemsFromInsert = insert.length - maxp;\n\n newArray.set(insert.subarray(0, numberOfItemsFromInsert));\n remainder.set(insert.subarray(numberOfItemsFromInsert));\n remainder.set(target, numberOfItemsFromInsert);\n } else {\n var numberOfItemsFromTarget = maxp - insert.length;\n\n newArray.set(insert);\n newArray.set(target.subarray(0, numberOfItemsFromTarget), insert.length);\n remainder.set(target.subarray(numberOfItemsFromTarget));\n }\n }\n } else {\n newArray = insert.concat(target);\n remainder = (maxp >= 0 && maxp < newArray.length) ?\n newArray.splice(maxp, newArray.length) :\n [];\n }\n\n return [newArray, remainder];\n }\n\n var undo = spliceTraces(gd, update, indices, maxPoints, updateArray);\n var promise = exports.redraw(gd);\n var undoArgs = [gd, undo.update, indices, undo.maxPoints];\n Queue.add(gd, exports.extendTraces, undoArgs, prependTraces, arguments);\n\n return promise;\n}\n\n/**\n * Add data traces to an existing graph div.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're adding to\n * @param {Object[]|Object} traces The object or array of objects to add\n * @param {Number[]|Number} [newIndices=[gd.data.length]] Locations to add traces\n *\n */\nfunction addTraces(gd, traces, newIndices) {\n gd = Lib.getGraphDiv(gd);\n\n var currentIndices = [];\n var undoFunc = exports.deleteTraces;\n var redoFunc = addTraces;\n var undoArgs = [gd, currentIndices];\n var redoArgs = [gd, traces]; // no newIndices here\n var i;\n var promise;\n\n // all validation is done elsewhere to remove clutter here\n checkAddTracesArgs(gd, traces, newIndices);\n\n // make sure traces is an array\n if(!Array.isArray(traces)) {\n traces = [traces];\n }\n\n // make sure traces do not repeat existing ones\n traces = traces.map(function(trace) {\n return Lib.extendFlat({}, trace);\n });\n\n helpers.cleanData(traces);\n\n // add the traces to gd.data (no redrawing yet!)\n for(i = 0; i < traces.length; i++) {\n gd.data.push(traces[i]);\n }\n\n // to continue, we need to call moveTraces which requires currentIndices\n for(i = 0; i < traces.length; i++) {\n currentIndices.push(-traces.length + i);\n }\n\n // if the user didn't define newIndices, they just want the traces appended\n // i.e., we can simply redraw and be done\n if(typeof newIndices === 'undefined') {\n promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n return promise;\n }\n\n // make sure indices is property defined\n if(!Array.isArray(newIndices)) {\n newIndices = [newIndices];\n }\n\n try {\n // this is redundant, but necessary to not catch later possible errors!\n checkMoveTracesArgs(gd, currentIndices, newIndices);\n } catch(error) {\n // something went wrong, reset gd to be safe and rethrow error\n gd.data.splice(gd.data.length - traces.length, traces.length);\n throw error;\n }\n\n // if we're here, the user has defined specific places to place the new traces\n // this requires some extra work that moveTraces will do\n Queue.startSequence(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n promise = exports.moveTraces(gd, currentIndices, newIndices);\n Queue.stopSequence(gd);\n return promise;\n}\n\n/**\n * Delete traces at `indices` from gd.data array.\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're removing from\n * @param {Number|Number[]} indices The indices\n */\nfunction deleteTraces(gd, indices) {\n gd = Lib.getGraphDiv(gd);\n\n var traces = [];\n var undoFunc = exports.addTraces;\n var redoFunc = deleteTraces;\n var undoArgs = [gd, traces, indices];\n var redoArgs = [gd, indices];\n var i;\n var deletedTrace;\n\n // make sure indices are defined\n if(typeof indices === 'undefined') {\n throw new Error('indices must be an integer or array of integers.');\n } else if(!Array.isArray(indices)) {\n indices = [indices];\n }\n assertIndexArray(gd, indices, 'indices');\n\n // convert negative indices to positive indices\n indices = positivifyIndices(indices, gd.data.length - 1);\n\n // we want descending here so that splicing later doesn't affect indexing\n indices.sort(Lib.sorterDes);\n for(i = 0; i < indices.length; i += 1) {\n deletedTrace = gd.data.splice(indices[i], 1)[0];\n traces.push(deletedTrace);\n }\n\n var promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return promise;\n}\n\n/**\n * Move traces at currentIndices array to locations in newIndices array.\n *\n * If newIndices is omitted, currentIndices will be moved to the end. E.g.,\n * these are equivalent:\n *\n * Plotly.moveTraces(gd, [1, 2, 3], [-3, -2, -1])\n * Plotly.moveTraces(gd, [1, 2, 3])\n *\n * @param {Object|HTMLDivElement} gd The graph div\n * @param {Object[]} gd.data The array of traces we're removing from\n * @param {Number|Number[]} currentIndices The locations of traces to be moved\n * @param {Number|Number[]} [newIndices] The locations to move traces to\n *\n * Example calls:\n *\n * // move trace i to location x\n * Plotly.moveTraces(gd, i, x)\n *\n * // move trace i to end of array\n * Plotly.moveTraces(gd, i)\n *\n * // move traces i, j, k to end of array (i != j != k)\n * Plotly.moveTraces(gd, [i, j, k])\n *\n * // move traces [i, j, k] to [x, y, z] (i != j != k) (x != y != z)\n * Plotly.moveTraces(gd, [i, j, k], [x, y, z])\n *\n * // reorder all traces (assume there are 5--a, b, c, d, e)\n * Plotly.moveTraces(gd, [b, d, e, a, c]) // same as 'move to end'\n */\nfunction moveTraces(gd, currentIndices, newIndices) {\n gd = Lib.getGraphDiv(gd);\n\n var newData = [];\n var movingTraceMap = [];\n var undoFunc = moveTraces;\n var redoFunc = moveTraces;\n var undoArgs = [gd, newIndices, currentIndices];\n var redoArgs = [gd, currentIndices, newIndices];\n var i;\n\n // to reduce complexity here, check args elsewhere\n // this throws errors where appropriate\n checkMoveTracesArgs(gd, currentIndices, newIndices);\n\n // make sure currentIndices is an array\n currentIndices = Array.isArray(currentIndices) ? currentIndices : [currentIndices];\n\n // if undefined, define newIndices to point to the end of gd.data array\n if(typeof newIndices === 'undefined') {\n newIndices = [];\n for(i = 0; i < currentIndices.length; i++) {\n newIndices.push(-currentIndices.length + i);\n }\n }\n\n // make sure newIndices is an array if it's user-defined\n newIndices = Array.isArray(newIndices) ? newIndices : [newIndices];\n\n // convert negative indices to positive indices (they're the same length)\n currentIndices = positivifyIndices(currentIndices, gd.data.length - 1);\n newIndices = positivifyIndices(newIndices, gd.data.length - 1);\n\n // at this point, we've coerced the index arrays into predictable forms\n\n // get the traces that aren't being moved around\n for(i = 0; i < gd.data.length; i++) {\n // if index isn't in currentIndices, include it in ignored!\n if(currentIndices.indexOf(i) === -1) {\n newData.push(gd.data[i]);\n }\n }\n\n // get a mapping of indices to moving traces\n for(i = 0; i < currentIndices.length; i++) {\n movingTraceMap.push({newIndex: newIndices[i], trace: gd.data[currentIndices[i]]});\n }\n\n // reorder this mapping by newIndex, ascending\n movingTraceMap.sort(function(a, b) {\n return a.newIndex - b.newIndex;\n });\n\n // now, add the moving traces back in, in order!\n for(i = 0; i < movingTraceMap.length; i += 1) {\n newData.splice(movingTraceMap[i].newIndex, 0, movingTraceMap[i].trace);\n }\n\n gd.data = newData;\n\n var promise = exports.redraw(gd);\n Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return promise;\n}\n\n/**\n * restyle: update trace attributes of an existing plot\n *\n * Can be called two ways.\n *\n * Signature 1:\n * @param {String | HTMLDivElement} gd\n * the id or DOM element of the graph container div\n * @param {String} astr\n * attribute string (like `'marker.symbol'`) to update\n * @param {*} val\n * value to give this attribute\n * @param {Number[] | Number} [traces]\n * integer or array of integers for the traces to alter (all if omitted)\n *\n * Signature 2:\n * @param {String | HTMLDivElement} gd\n * (as in signature 1)\n * @param {Object} aobj\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * allows setting multiple attributes simultaneously\n * @param {Number[] | Number} [traces]\n * (as in signature 1)\n *\n * `val` (or `val1`, `val2` ... in the object form) can be an array,\n * to apply different values to each trace.\n *\n * If the array is too short, it will wrap around (useful for\n * style files that want to specify cyclical default values).\n */\nfunction restyle(gd, astr, val, _traces) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n var aobj = {};\n if(typeof astr === 'string') aobj[astr] = val;\n else if(Lib.isPlainObject(astr)) {\n // the 3-arg form\n aobj = Lib.extendFlat({}, astr);\n if(_traces === undefined) _traces = val;\n } else {\n Lib.warn('Restyle fail.', astr, val, _traces);\n return Promise.reject();\n }\n\n if(Object.keys(aobj).length) gd.changed = true;\n\n var traces = helpers.coerceTraceIndices(gd, _traces);\n\n var specs = _restyle(gd, aobj, traces);\n var flags = specs.flags;\n\n // clear calcdata and/or axis types if required so they get regenerated\n if(flags.calc) gd.calcdata = undefined;\n if(flags.clearAxisTypes) helpers.clearAxisTypes(gd, traces, {});\n\n // fill in redraw sequence\n var seq = [];\n\n if(flags.fullReplot) {\n seq.push(exports.plot);\n } else {\n seq.push(Plots.previousPromises);\n\n // maybe only call Plots.supplyDataDefaults in the splom case,\n // to skip over long and slow axes defaults\n Plots.supplyDefaults(gd);\n\n if(flags.markerSize) {\n Plots.doCalcdata(gd);\n addAxRangeSequence(seq);\n\n // TODO\n // if all axes have autorange:false, then\n // proceed to subroutines.doTraceStyle(),\n // otherwise we must go through addAxRangeSequence,\n // which in general must redraws 'all' axes\n }\n\n if(flags.style) seq.push(subroutines.doTraceStyle);\n if(flags.colorbars) seq.push(subroutines.doColorBars);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(Plots.rehover, Plots.redrag);\n\n Queue.add(gd,\n restyle, [gd, specs.undoit, specs.traces],\n restyle, [gd, specs.redoit, specs.traces]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve();\n\n return plotDone.then(function() {\n gd.emit('plotly_restyle', specs.eventData);\n return gd;\n });\n}\n\n// for undo: undefined initial vals must be turned into nulls\n// so that we unset rather than ignore them\nfunction undefinedToNull(val) {\n if(val === undefined) return null;\n return val;\n}\n\n/**\n * Factory function to wrap nestedProperty with GUI edits if necessary\n * with GUI edits we add an optional prefix to the nestedProperty constructor\n * to prepend to the attribute string in the preGUI store.\n */\nfunction makeNP(preGUI, guiEditFlag) {\n if(!guiEditFlag) return nestedProperty;\n\n return function(container, attr, prefix) {\n var np = nestedProperty(container, attr);\n var npSet = np.set;\n np.set = function(val) {\n var fullAttr = (prefix || '') + attr;\n storeCurrent(fullAttr, np.get(), val, preGUI);\n npSet(val);\n };\n return np;\n };\n}\n\nfunction storeCurrent(attr, val, newVal, preGUI) {\n if(Array.isArray(val) || Array.isArray(newVal)) {\n var arrayVal = Array.isArray(val) ? val : [];\n var arrayNew = Array.isArray(newVal) ? newVal : [];\n var maxLen = Math.max(arrayVal.length, arrayNew.length);\n for(var i = 0; i < maxLen; i++) {\n storeCurrent(attr + '[' + i + ']', arrayVal[i], arrayNew[i], preGUI);\n }\n } else if(Lib.isPlainObject(val) || Lib.isPlainObject(newVal)) {\n var objVal = Lib.isPlainObject(val) ? val : {};\n var objNew = Lib.isPlainObject(newVal) ? newVal : {};\n var objBoth = Lib.extendFlat({}, objVal, objNew);\n for(var key in objBoth) {\n storeCurrent(attr + '.' + key, objVal[key], objNew[key], preGUI);\n }\n } else if(preGUI[attr] === undefined) {\n preGUI[attr] = undefinedToNull(val);\n }\n}\n\n/**\n * storeDirectGUIEdit: for routines that skip restyle/relayout and mock it\n * by emitting a plotly_restyle or plotly_relayout event, this routine\n * keeps track of the initial state in _preGUI for use by uirevision\n * Does *not* apply these changes to data/layout - that's the responsibility\n * of the calling routine.\n *\n * @param {object} container: the input attributes container (eg `layout` or a `trace`)\n * @param {object} preGUI: where original values should be stored, either\n * `layout._preGUI` or `layout._tracePreGUI[uid]`\n * @param {object} edits: the {attr: val} object as normally passed to `relayout` etc\n */\nfunction _storeDirectGUIEdit(container, preGUI, edits) {\n for(var attr in edits) {\n var np = nestedProperty(container, attr);\n storeCurrent(attr, np.get(), edits[attr], preGUI);\n }\n}\n\nfunction _restyle(gd, aobj, traces) {\n var fullLayout = gd._fullLayout;\n var fullData = gd._fullData;\n var data = gd.data;\n var guiEditFlag = fullLayout._guiEditing;\n var layoutNP = makeNP(fullLayout._preGUI, guiEditFlag);\n var eventData = Lib.extendDeepAll({}, aobj);\n var i;\n\n cleanDeprecatedAttributeKeys(aobj);\n\n // initialize flags\n var flags = editTypes.traceFlags();\n\n // copies of the change (and previous values of anything affected)\n // for the undo / redo queue\n var redoit = {};\n var undoit = {};\n var axlist;\n\n // make a new empty vals array for undoit\n function a0() { return traces.map(function() { return undefined; }); }\n\n // for autoranging multiple axes\n function addToAxlist(axid) {\n var axName = Axes.id2name(axid);\n if(axlist.indexOf(axName) === -1) axlist.push(axName);\n }\n\n function autorangeAttr(axName) { return 'LAYOUT' + axName + '.autorange'; }\n\n function rangeAttr(axName) { return 'LAYOUT' + axName + '.range'; }\n\n function getFullTrace(traceIndex) {\n // usually fullData maps 1:1 onto data, but with groupby transforms\n // the fullData index can be greater. Take the *first* matching trace.\n for(var j = traceIndex; j < fullData.length; j++) {\n if(fullData[j]._input === data[traceIndex]) return fullData[j];\n }\n // should never get here - and if we *do* it should cause an error\n // later on undefined fullTrace is passed to nestedProperty.\n }\n\n // for attrs that interact (like scales & autoscales), save the\n // old vals before making the change\n // val=undefined will not set a value, just record what the value was.\n // val=null will delete the attribute\n // attr can be an array to set several at once (all to the same val)\n function doextra(attr, val, i) {\n if(Array.isArray(attr)) {\n attr.forEach(function(a) { doextra(a, val, i); });\n return;\n }\n // quit if explicitly setting this elsewhere\n if(attr in aobj || helpers.hasParent(aobj, attr)) return;\n\n var extraparam;\n if(attr.substr(0, 6) === 'LAYOUT') {\n extraparam = layoutNP(gd.layout, attr.replace('LAYOUT', ''));\n } else {\n var tracei = traces[i];\n var preGUI = fullLayout._tracePreGUI[getFullTrace(tracei)._fullInput.uid];\n extraparam = makeNP(preGUI, guiEditFlag)(data[tracei], attr);\n }\n\n if(!(attr in undoit)) {\n undoit[attr] = a0();\n }\n if(undoit[attr][i] === undefined) {\n undoit[attr][i] = undefinedToNull(extraparam.get());\n }\n if(val !== undefined) {\n extraparam.set(val);\n }\n }\n\n function allBins(binAttr) {\n return function(j) {\n return fullData[j][binAttr];\n };\n }\n\n function arrayBins(binAttr) {\n return function(vij, j) {\n return vij === false ? fullData[traces[j]][binAttr] : null;\n };\n }\n\n // now make the changes to gd.data (and occasionally gd.layout)\n // and figure out what kind of graphics update we need to do\n for(var ai in aobj) {\n if(helpers.hasParent(aobj, ai)) {\n throw new Error('cannot set ' + ai + ' and a parent attribute simultaneously');\n }\n\n var vi = aobj[ai];\n var cont;\n var contFull;\n var param;\n var oldVal;\n var newVal;\n var valObject;\n\n // Backward compatibility shim for turning histogram autobin on,\n // or freezing previous autobinned values.\n // Replace obsolete `autobin(x|y): true` with `(x|y)bins: null`\n // and `autobin(x|y): false` with the `(x|y)bins` in `fullData`\n if(ai === 'autobinx' || ai === 'autobiny') {\n ai = ai.charAt(ai.length - 1) + 'bins';\n if(Array.isArray(vi)) vi = vi.map(arrayBins(ai));\n else if(vi === false) vi = traces.map(allBins(ai));\n else vi = null;\n }\n\n redoit[ai] = vi;\n\n if(ai.substr(0, 6) === 'LAYOUT') {\n param = layoutNP(gd.layout, ai.replace('LAYOUT', ''));\n undoit[ai] = [undefinedToNull(param.get())];\n // since we're allowing val to be an array, allow it here too,\n // even though that's meaningless\n param.set(Array.isArray(vi) ? vi[0] : vi);\n // ironically, the layout attrs in restyle only require replot,\n // not relayout\n flags.calc = true;\n continue;\n }\n\n // set attribute in gd.data\n undoit[ai] = a0();\n for(i = 0; i < traces.length; i++) {\n cont = data[traces[i]];\n contFull = getFullTrace(traces[i]);\n var preGUI = fullLayout._tracePreGUI[contFull._fullInput.uid];\n param = makeNP(preGUI, guiEditFlag)(cont, ai);\n oldVal = param.get();\n newVal = Array.isArray(vi) ? vi[i % vi.length] : vi;\n\n if(newVal === undefined) continue;\n\n var finalPart = param.parts[param.parts.length - 1];\n var prefix = ai.substr(0, ai.length - finalPart.length - 1);\n var prefixDot = prefix ? prefix + '.' : '';\n var innerContFull = prefix ?\n nestedProperty(contFull, prefix).get() : contFull;\n\n valObject = PlotSchema.getTraceValObject(contFull, param.parts);\n\n if(valObject && valObject.impliedEdits && newVal !== null) {\n for(var impliedKey in valObject.impliedEdits) {\n doextra(Lib.relativeAttr(ai, impliedKey), valObject.impliedEdits[impliedKey], i);\n }\n } else if((finalPart === 'thicknessmode' || finalPart === 'lenmode') &&\n oldVal !== newVal &&\n (newVal === 'fraction' || newVal === 'pixels') &&\n innerContFull\n ) {\n // changing colorbar size modes,\n // make the resulting size not change\n // note that colorbar fractional sizing is based on the\n // original plot size, before anything (like a colorbar)\n // increases the margins\n\n var gs = fullLayout._size;\n var orient = innerContFull.orient;\n var topOrBottom = (orient === 'top') || (orient === 'bottom');\n if(finalPart === 'thicknessmode') {\n var thicknorm = topOrBottom ? gs.h : gs.w;\n doextra(prefixDot + 'thickness', innerContFull.thickness *\n (newVal === 'fraction' ? 1 / thicknorm : thicknorm), i);\n } else {\n var lennorm = topOrBottom ? gs.w : gs.h;\n doextra(prefixDot + 'len', innerContFull.len *\n (newVal === 'fraction' ? 1 / lennorm : lennorm), i);\n }\n } else if(ai === 'type' && (\n (newVal === 'pie') !== (oldVal === 'pie') ||\n (newVal === 'funnelarea') !== (oldVal === 'funnelarea')\n )) {\n var labelsTo = 'x';\n var valuesTo = 'y';\n if((newVal === 'bar' || oldVal === 'bar') && cont.orientation === 'h') {\n labelsTo = 'y';\n valuesTo = 'x';\n }\n Lib.swapAttrs(cont, ['?', '?src'], 'labels', labelsTo);\n Lib.swapAttrs(cont, ['d?', '?0'], 'label', labelsTo);\n Lib.swapAttrs(cont, ['?', '?src'], 'values', valuesTo);\n\n if(oldVal === 'pie' || oldVal === 'funnelarea') {\n nestedProperty(cont, 'marker.color')\n .set(nestedProperty(cont, 'marker.colors').get());\n\n // super kludgy - but if all pies are gone we won't remove them otherwise\n fullLayout._pielayer.selectAll('g.trace').remove();\n } else if(Registry.traceIs(cont, 'cartesian')) {\n nestedProperty(cont, 'marker.colors')\n .set(nestedProperty(cont, 'marker.color').get());\n }\n }\n\n undoit[ai][i] = undefinedToNull(oldVal);\n // set the new value - if val is an array, it's one el per trace\n // first check for attributes that get more complex alterations\n var swapAttrs = [\n 'swapxy', 'swapxyaxes', 'orientation', 'orientationaxes'\n ];\n if(swapAttrs.indexOf(ai) !== -1) {\n // setting an orientation: make sure it's changing\n // before we swap everything else\n if(ai === 'orientation') {\n param.set(newVal);\n // obnoxious that we need this level of coupling... but in order to\n // properly handle setting orientation to `null` we need to mimic\n // the logic inside Bars.supplyDefaults for default orientation\n var defaultOrientation = (cont.x && !cont.y) ? 'h' : 'v';\n if((param.get() || defaultOrientation) === contFull.orientation) {\n continue;\n }\n } else if(ai === 'orientationaxes') {\n // orientationaxes has no value,\n // it flips everything and the axes\n\n cont.orientation =\n {v: 'h', h: 'v'}[contFull.orientation];\n }\n helpers.swapXYData(cont);\n flags.calc = flags.clearAxisTypes = true;\n } else if(Plots.dataArrayContainers.indexOf(param.parts[0]) !== -1) {\n // TODO: use manageArrays.applyContainerArrayChanges here too\n helpers.manageArrayContainers(param, newVal, undoit);\n flags.calc = true;\n } else {\n if(valObject) {\n // must redo calcdata when restyling array values of arrayOk attributes\n // ... but no need to this for regl-based traces\n if(valObject.arrayOk &&\n !Registry.traceIs(contFull, 'regl') &&\n (Lib.isArrayOrTypedArray(newVal) || Lib.isArrayOrTypedArray(oldVal))\n ) {\n flags.calc = true;\n } else editTypes.update(flags, valObject);\n } else {\n /*\n * if we couldn't find valObject, assume a full recalc.\n * This can happen if you're changing type and making\n * some other edits too, so the modules we're\n * looking at don't have these attributes in them.\n */\n flags.calc = true;\n }\n\n // all the other ones, just modify that one attribute\n param.set(newVal);\n }\n }\n\n // swap the data attributes of the relevant x and y axes?\n if(['swapxyaxes', 'orientationaxes'].indexOf(ai) !== -1) {\n Axes.swap(gd, traces);\n }\n\n // swap hovermode if set to \"compare x/y data\"\n if(ai === 'orientationaxes') {\n var hovermode = nestedProperty(gd.layout, 'hovermode');\n if(hovermode.get() === 'x') {\n hovermode.set('y');\n } else if(hovermode.get() === 'y') {\n hovermode.set('x');\n } else if(hovermode.get() === 'x unified') {\n hovermode.set('y unified');\n } else if(hovermode.get() === 'y unified') {\n hovermode.set('x unified');\n }\n }\n\n // Major enough changes deserve autoscale and\n // non-reversed axes so people don't get confused\n //\n // Note: autobin (or its new analog bin clearing) is not included here\n // since we're not pushing bins back to gd.data, so if we have bin\n // info it was explicitly provided by the user.\n if(['orientation', 'type'].indexOf(ai) !== -1) {\n axlist = [];\n for(i = 0; i < traces.length; i++) {\n var trace = data[traces[i]];\n\n if(Registry.traceIs(trace, 'cartesian')) {\n addToAxlist(trace.xaxis || 'x');\n addToAxlist(trace.yaxis || 'y');\n }\n }\n\n doextra(axlist.map(autorangeAttr), true, 0);\n doextra(axlist.map(rangeAttr), [0, 1], 0);\n }\n }\n\n if(flags.calc || flags.plot) {\n flags.fullReplot = true;\n }\n\n return {\n flags: flags,\n undoit: undoit,\n redoit: redoit,\n traces: traces,\n eventData: Lib.extendDeepNoArrays([], [eventData, traces])\n };\n}\n\n/**\n * Converts deprecated attribute keys to\n * the current API to ensure backwards compatibility.\n *\n * This is needed for the update mechanism to determine which\n * subroutines to run based on the actual attribute\n * definitions (that don't include the deprecated ones).\n *\n * E.g. Maps {'xaxis.title': 'A chart'} to {'xaxis.title.text': 'A chart'}\n * and {titlefont: {...}} to {'title.font': {...}}.\n *\n * @param aobj\n */\nfunction cleanDeprecatedAttributeKeys(aobj) {\n var oldAxisTitleRegex = Lib.counterRegex('axis', '\\.title', false, false);\n var colorbarRegex = /colorbar\\.title$/;\n var keys = Object.keys(aobj);\n var i, key, value;\n\n for(i = 0; i < keys.length; i++) {\n key = keys[i];\n value = aobj[key];\n\n if((key === 'title' || oldAxisTitleRegex.test(key) || colorbarRegex.test(key)) &&\n (typeof value === 'string' || typeof value === 'number')) {\n replace(key, key.replace('title', 'title.text'));\n } else if(key.indexOf('titlefont') > -1) {\n replace(key, key.replace('titlefont', 'title.font'));\n } else if(key.indexOf('titleposition') > -1) {\n replace(key, key.replace('titleposition', 'title.position'));\n } else if(key.indexOf('titleside') > -1) {\n replace(key, key.replace('titleside', 'title.side'));\n } else if(key.indexOf('titleoffset') > -1) {\n replace(key, key.replace('titleoffset', 'title.offset'));\n }\n }\n\n function replace(oldAttrStr, newAttrStr) {\n aobj[newAttrStr] = aobj[oldAttrStr];\n delete aobj[oldAttrStr];\n }\n}\n\n/**\n * relayout: update layout attributes of an existing plot\n *\n * Can be called two ways:\n *\n * Signature 1:\n * @param {String | HTMLDivElement} gd\n * the id or dom element of the graph container div\n * @param {String} astr\n * attribute string (like `'xaxis.range[0]'`) to update\n * @param {*} val\n * value to give this attribute\n *\n * Signature 2:\n * @param {String | HTMLDivElement} gd\n * (as in signature 1)\n * @param {Object} aobj\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * allows setting multiple attributes simultaneously\n */\nfunction relayout(gd, astr, val) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n if(gd.framework && gd.framework.isPolar) {\n return Promise.resolve(gd);\n }\n\n var aobj = {};\n if(typeof astr === 'string') {\n aobj[astr] = val;\n } else if(Lib.isPlainObject(astr)) {\n aobj = Lib.extendFlat({}, astr);\n } else {\n Lib.warn('Relayout fail.', astr, val);\n return Promise.reject();\n }\n\n if(Object.keys(aobj).length) gd.changed = true;\n\n var specs = _relayout(gd, aobj);\n var flags = specs.flags;\n\n // clear calcdata if required\n if(flags.calc) gd.calcdata = undefined;\n\n // fill in redraw sequence\n\n // even if we don't have anything left in aobj,\n // something may have happened within relayout that we\n // need to wait for\n var seq = [Plots.previousPromises];\n\n if(flags.layoutReplot) {\n seq.push(subroutines.layoutReplot);\n } else if(Object.keys(aobj).length) {\n axRangeSupplyDefaultsByPass(gd, flags, specs) || Plots.supplyDefaults(gd);\n\n if(flags.legend) seq.push(subroutines.doLegend);\n if(flags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(flags.axrange) addAxRangeSequence(seq, specs.rangesAltered);\n if(flags.ticks) seq.push(subroutines.doTicksRelayout);\n if(flags.modebar) seq.push(subroutines.doModeBar);\n if(flags.camera) seq.push(subroutines.doCamera);\n if(flags.colorbars) seq.push(subroutines.doColorBars);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(Plots.rehover, Plots.redrag);\n\n Queue.add(gd,\n relayout, [gd, specs.undoit],\n relayout, [gd, specs.redoit]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n\n return plotDone.then(function() {\n gd.emit('plotly_relayout', specs.eventData);\n return gd;\n });\n}\n\n// Optimization mostly for large splom traces where\n// Plots.supplyDefaults can take > 100ms\nfunction axRangeSupplyDefaultsByPass(gd, flags, specs) {\n var fullLayout = gd._fullLayout;\n\n if(!flags.axrange) return false;\n\n for(var k in flags) {\n if(k !== 'axrange' && flags[k]) return false;\n }\n\n for(var axId in specs.rangesAltered) {\n var axName = Axes.id2name(axId);\n var axIn = gd.layout[axName];\n var axOut = fullLayout[axName];\n axOut.autorange = axIn.autorange;\n axOut.range = axIn.range.slice();\n axOut.cleanRange();\n\n if(axOut._matchGroup) {\n for(var axId2 in axOut._matchGroup) {\n if(axId2 !== axId) {\n var ax2 = fullLayout[Axes.id2name(axId2)];\n ax2.autorange = axOut.autorange;\n ax2.range = axOut.range.slice();\n ax2._input.range = axOut.range.slice();\n }\n }\n }\n }\n\n return true;\n}\n\nfunction addAxRangeSequence(seq, rangesAltered) {\n // N.B. leave as sequence of subroutines (for now) instead of\n // subroutine of its own so that finalDraw always gets\n // executed after drawData\n var drawAxes = rangesAltered ?\n function(gd) {\n var axIds = [];\n var skipTitle = true;\n\n for(var id in rangesAltered) {\n var ax = Axes.getFromId(gd, id);\n axIds.push(id);\n\n if(ax._matchGroup) {\n for(var id2 in ax._matchGroup) {\n if(!rangesAltered[id2]) {\n axIds.push(id2);\n }\n }\n }\n\n if(ax.automargin) skipTitle = false;\n }\n\n return Axes.draw(gd, axIds, {skipTitle: skipTitle});\n } :\n function(gd) {\n return Axes.draw(gd, 'redraw');\n };\n\n seq.push(\n clearSelect,\n subroutines.doAutoRangeAndConstraints,\n drawAxes,\n subroutines.drawData,\n subroutines.finalDraw\n );\n}\n\nvar AX_RANGE_RE = /^[xyz]axis[0-9]*\\.range(\\[[0|1]\\])?$/;\nvar AX_AUTORANGE_RE = /^[xyz]axis[0-9]*\\.autorange$/;\nvar AX_DOMAIN_RE = /^[xyz]axis[0-9]*\\.domain(\\[[0|1]\\])?$/;\n\nfunction _relayout(gd, aobj) {\n var layout = gd.layout;\n var fullLayout = gd._fullLayout;\n var guiEditFlag = fullLayout._guiEditing;\n var layoutNP = makeNP(fullLayout._preGUI, guiEditFlag);\n var keys = Object.keys(aobj);\n var axes = Axes.list(gd);\n var eventData = Lib.extendDeepAll({}, aobj);\n var arrayEdits = {};\n\n var arrayStr, i, j;\n\n cleanDeprecatedAttributeKeys(aobj);\n keys = Object.keys(aobj);\n\n // look for 'allaxes', split out into all axes\n // in case of 3D the axis are nested within a scene which is held in _id\n for(i = 0; i < keys.length; i++) {\n if(keys[i].indexOf('allaxes') === 0) {\n for(j = 0; j < axes.length; j++) {\n var scene = axes[j]._id.substr(1);\n var axisAttr = (scene.indexOf('scene') !== -1) ? (scene + '.') : '';\n var newkey = keys[i].replace('allaxes', axisAttr + axes[j]._name);\n\n if(!aobj[newkey]) aobj[newkey] = aobj[keys[i]];\n }\n\n delete aobj[keys[i]];\n }\n }\n\n // initialize flags\n var flags = editTypes.layoutFlags();\n\n // copies of the change (and previous values of anything affected)\n // for the undo / redo queue\n var redoit = {};\n var undoit = {};\n\n // for attrs that interact (like scales & autoscales), save the\n // old vals before making the change\n // val=undefined will not set a value, just record what the value was.\n // attr can be an array to set several at once (all to the same val)\n function doextra(attr, val) {\n if(Array.isArray(attr)) {\n attr.forEach(function(a) { doextra(a, val); });\n return;\n }\n\n // if we have another value for this attribute (explicitly or\n // via a parent) do not override with this auto-generated extra\n if(attr in aobj || helpers.hasParent(aobj, attr)) return;\n\n var p = layoutNP(layout, attr);\n if(!(attr in undoit)) {\n undoit[attr] = undefinedToNull(p.get());\n }\n if(val !== undefined) p.set(val);\n }\n\n // for constraint enforcement: keep track of all axes (as {id: name})\n // we're editing the (auto)range of, so we can tell the others constrained\n // to scale with them that it's OK for them to shrink\n var rangesAltered = {};\n var axId;\n\n function recordAlteredAxis(pleafPlus) {\n var axId = Axes.name2id(pleafPlus.split('.')[0]);\n rangesAltered[axId] = 1;\n return axId;\n }\n\n // alter gd.layout\n for(var ai in aobj) {\n if(helpers.hasParent(aobj, ai)) {\n throw new Error('cannot set ' + ai + ' and a parent attribute simultaneously');\n }\n\n var p = layoutNP(layout, ai);\n var vi = aobj[ai];\n var plen = p.parts.length;\n // p.parts may end with an index integer if the property is an array\n var pend = plen - 1;\n while(pend > 0 && typeof p.parts[pend] !== 'string') pend--;\n // last property in chain (leaf node)\n var pleaf = p.parts[pend];\n // leaf plus immediate parent\n var pleafPlus = p.parts[pend - 1] + '.' + pleaf;\n // trunk nodes (everything except the leaf)\n var ptrunk = p.parts.slice(0, pend).join('.');\n var parentIn = nestedProperty(gd.layout, ptrunk).get();\n var parentFull = nestedProperty(fullLayout, ptrunk).get();\n var vOld = p.get();\n\n if(vi === undefined) continue;\n\n redoit[ai] = vi;\n\n // axis reverse is special - it is its own inverse\n // op and has no flag.\n undoit[ai] = (pleaf === 'reverse') ? vi : undefinedToNull(vOld);\n\n var valObject = PlotSchema.getLayoutValObject(fullLayout, p.parts);\n\n if(valObject && valObject.impliedEdits && vi !== null) {\n for(var impliedKey in valObject.impliedEdits) {\n doextra(Lib.relativeAttr(ai, impliedKey), valObject.impliedEdits[impliedKey]);\n }\n }\n\n // Setting width or height to null must reset the graph's width / height\n // back to its initial value as computed during the first pass in Plots.plotAutoSize.\n //\n // To do so, we must manually set them back here using the _initialAutoSize cache.\n // can't use impliedEdits for this because behavior depends on vi\n if(['width', 'height'].indexOf(ai) !== -1) {\n if(vi) {\n doextra('autosize', null);\n // currently we don't support autosize one dim only - so\n // explicitly set the other one. Note that doextra will\n // ignore this if the same relayout call also provides oppositeAttr\n var oppositeAttr = ai === 'height' ? 'width' : 'height';\n doextra(oppositeAttr, fullLayout[oppositeAttr]);\n } else {\n fullLayout[ai] = gd._initialAutoSize[ai];\n }\n } else if(ai === 'autosize') {\n // depends on vi here too, so again can't use impliedEdits\n doextra('width', vi ? null : fullLayout.width);\n doextra('height', vi ? null : fullLayout.height);\n } else if(pleafPlus.match(AX_RANGE_RE)) {\n // check autorange vs range\n\n recordAlteredAxis(pleafPlus);\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n } else if(pleafPlus.match(AX_AUTORANGE_RE)) {\n recordAlteredAxis(pleafPlus);\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n var axFull = nestedProperty(fullLayout, ptrunk).get();\n if(axFull._inputDomain) {\n // if we're autoranging and this axis has a constrained domain,\n // reset it so we don't get locked into a shrunken size\n axFull._input.domain = axFull._inputDomain.slice();\n }\n } else if(pleafPlus.match(AX_DOMAIN_RE)) {\n nestedProperty(fullLayout, ptrunk + '._inputDomain').set(null);\n }\n\n // toggling axis type between log and linear: we need to convert\n // positions for components that are still using linearized values,\n // not data values like newer components.\n // previously we did this for log <-> not-log, but now only do it\n // for log <-> linear\n if(pleaf === 'type') {\n var ax = parentIn;\n var toLog = parentFull.type === 'linear' && vi === 'log';\n var fromLog = parentFull.type === 'log' && vi === 'linear';\n\n if(toLog || fromLog) {\n if(!ax || !ax.range) {\n // 2D never gets here, but 3D does\n // I don't think this is needed, but left here in case there\n // are edge cases I'm not thinking of.\n doextra(ptrunk + '.autorange', true);\n } else if(!parentFull.autorange) {\n // toggling log without autorange: need to also recalculate ranges\n // because log axes use linearized values for range endpoints\n var r0 = ax.range[0];\n var r1 = ax.range[1];\n if(toLog) {\n // if both limits are negative, autorange\n if(r0 <= 0 && r1 <= 0) {\n doextra(ptrunk + '.autorange', true);\n }\n // if one is negative, set it 6 orders below the other.\n if(r0 <= 0) r0 = r1 / 1e6;\n else if(r1 <= 0) r1 = r0 / 1e6;\n // now set the range values as appropriate\n doextra(ptrunk + '.range[0]', Math.log(r0) / Math.LN10);\n doextra(ptrunk + '.range[1]', Math.log(r1) / Math.LN10);\n } else {\n doextra(ptrunk + '.range[0]', Math.pow(10, r0));\n doextra(ptrunk + '.range[1]', Math.pow(10, r1));\n }\n } else if(toLog) {\n // just make sure the range is positive and in the right\n // order, it'll get recalculated later\n ax.range = (ax.range[1] > ax.range[0]) ? [1, 2] : [2, 1];\n }\n\n // clear polar view initial stash for radial range so that\n // value get recomputed in correct units\n if(Array.isArray(fullLayout._subplots.polar) &&\n fullLayout._subplots.polar.length &&\n fullLayout[p.parts[0]] &&\n p.parts[1] === 'radialaxis'\n ) {\n delete fullLayout[p.parts[0]]._subplot.viewInitial['radialaxis.range'];\n }\n\n // Annotations and images also need to convert to/from linearized coords\n // Shapes do not need this :)\n Registry.getComponentMethod('annotations', 'convertCoords')(gd, parentFull, vi, doextra);\n Registry.getComponentMethod('images', 'convertCoords')(gd, parentFull, vi, doextra);\n } else {\n // any other type changes: the range from the previous type\n // will not make sense, so autorange it.\n doextra(ptrunk + '.autorange', true);\n doextra(ptrunk + '.range', null);\n }\n nestedProperty(fullLayout, ptrunk + '._inputRange').set(null);\n } else if(pleaf.match(AX_NAME_PATTERN)) {\n var fullProp = nestedProperty(fullLayout, ai).get();\n var newType = (vi || {}).type;\n\n // This can potentially cause strange behavior if the autotype is not\n // numeric (linear, because we don't auto-log) but the previous type\n // was log. That's a very strange edge case though\n if(!newType || newType === '-') newType = 'linear';\n Registry.getComponentMethod('annotations', 'convertCoords')(gd, fullProp, newType, doextra);\n Registry.getComponentMethod('images', 'convertCoords')(gd, fullProp, newType, doextra);\n }\n\n // alter gd.layout\n\n // collect array component edits for execution all together\n // so we can ensure consistent behavior adding/removing items\n // and order-independence for add/remove/edit all together in\n // one relayout call\n var containerArrayMatch = manageArrays.containerArrayMatch(ai);\n if(containerArrayMatch) {\n arrayStr = containerArrayMatch.array;\n i = containerArrayMatch.index;\n var propStr = containerArrayMatch.property;\n var updateValObject = valObject || {editType: 'calc'};\n\n if(i !== '' && propStr === '') {\n // special handling of undoit if we're adding or removing an element\n // ie 'annotations[2]' which can be {...} (add) or null,\n // does not work when replacing the entire array\n if(manageArrays.isAddVal(vi)) {\n undoit[ai] = null;\n } else if(manageArrays.isRemoveVal(vi)) {\n undoit[ai] = (nestedProperty(layout, arrayStr).get() || [])[i];\n } else {\n Lib.warn('unrecognized full object value', aobj);\n }\n }\n editTypes.update(flags, updateValObject);\n\n // prepare the edits object we'll send to applyContainerArrayChanges\n if(!arrayEdits[arrayStr]) arrayEdits[arrayStr] = {};\n var objEdits = arrayEdits[arrayStr][i];\n if(!objEdits) objEdits = arrayEdits[arrayStr][i] = {};\n objEdits[propStr] = vi;\n\n delete aobj[ai];\n } else if(pleaf === 'reverse') {\n // handle axis reversal explicitly, as there's no 'reverse' attribute\n\n if(parentIn.range) parentIn.range.reverse();\n else {\n doextra(ptrunk + '.autorange', true);\n parentIn.range = [1, 0];\n }\n\n if(parentFull.autorange) flags.calc = true;\n else flags.plot = true;\n } else {\n if((fullLayout._has('scatter-like') && fullLayout._has('regl')) &&\n (ai === 'dragmode' &&\n (vi === 'lasso' || vi === 'select') &&\n !(vOld === 'lasso' || vOld === 'select'))\n ) {\n flags.plot = true;\n } else if(fullLayout._has('gl2d')) {\n flags.plot = true;\n } else if(valObject) editTypes.update(flags, valObject);\n else flags.calc = true;\n\n p.set(vi);\n }\n }\n\n // now we've collected component edits - execute them all together\n for(arrayStr in arrayEdits) {\n var finished = manageArrays.applyContainerArrayChanges(gd,\n layoutNP(layout, arrayStr), arrayEdits[arrayStr], flags, layoutNP);\n if(!finished) flags.plot = true;\n }\n\n // figure out if we need to recalculate axis constraints\n var constraints = fullLayout._axisConstraintGroups || [];\n for(axId in rangesAltered) {\n for(i = 0; i < constraints.length; i++) {\n var group = constraints[i];\n if(group[axId]) {\n // Always recalc if we're changing constrained ranges.\n // Otherwise it's possible to violate the constraints by\n // specifying arbitrary ranges for all axes in the group.\n // this way some ranges may expand beyond what's specified,\n // as they do at first draw, to satisfy the constraints.\n flags.calc = true;\n for(var groupAxId in group) {\n if(!rangesAltered[groupAxId]) {\n Axes.getFromId(gd, groupAxId)._constraintShrinkable = true;\n }\n }\n }\n }\n }\n\n // If the autosize changed or height or width was explicitly specified,\n // this triggers a redraw\n // TODO: do we really need special aobj.height/width handling here?\n // couldn't editType do this?\n if(updateAutosize(gd) || aobj.height || aobj.width) flags.plot = true;\n\n if(flags.plot || flags.calc) {\n flags.layoutReplot = true;\n }\n\n // now all attribute mods are done, as are\n // redo and undo so we can save them\n\n return {\n flags: flags,\n rangesAltered: rangesAltered,\n undoit: undoit,\n redoit: redoit,\n eventData: eventData\n };\n}\n\n/*\n * updateAutosize: we made a change, does it change the autosize result?\n * puts the new size into fullLayout\n * returns true if either height or width changed\n */\nfunction updateAutosize(gd) {\n var fullLayout = gd._fullLayout;\n var oldWidth = fullLayout.width;\n var oldHeight = fullLayout.height;\n\n // calculate autosizing\n if(gd.layout.autosize) Plots.plotAutoSize(gd, gd.layout, fullLayout);\n\n return (fullLayout.width !== oldWidth) || (fullLayout.height !== oldHeight);\n}\n\n/**\n * update: update trace and layout attributes of an existing plot\n *\n * @param {String | HTMLDivElement} gd\n * the id or DOM element of the graph container div\n * @param {Object} traceUpdate\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * corresponding to updates in the plot's traces\n * @param {Object} layoutUpdate\n * attribute object `{astr1: val1, astr2: val2 ...}`\n * corresponding to updates in the plot's layout\n * @param {Number[] | Number} [traces]\n * integer or array of integers for the traces to alter (all if omitted)\n *\n */\nfunction update(gd, traceUpdate, layoutUpdate, _traces) {\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n if(gd.framework && gd.framework.isPolar) {\n return Promise.resolve(gd);\n }\n\n if(!Lib.isPlainObject(traceUpdate)) traceUpdate = {};\n if(!Lib.isPlainObject(layoutUpdate)) layoutUpdate = {};\n\n if(Object.keys(traceUpdate).length) gd.changed = true;\n if(Object.keys(layoutUpdate).length) gd.changed = true;\n\n var traces = helpers.coerceTraceIndices(gd, _traces);\n\n var restyleSpecs = _restyle(gd, Lib.extendFlat({}, traceUpdate), traces);\n var restyleFlags = restyleSpecs.flags;\n\n var relayoutSpecs = _relayout(gd, Lib.extendFlat({}, layoutUpdate));\n var relayoutFlags = relayoutSpecs.flags;\n\n // clear calcdata and/or axis types if required\n if(restyleFlags.calc || relayoutFlags.calc) gd.calcdata = undefined;\n if(restyleFlags.clearAxisTypes) helpers.clearAxisTypes(gd, traces, layoutUpdate);\n\n // fill in redraw sequence\n var seq = [];\n\n if(relayoutFlags.layoutReplot) {\n // N.B. works fine when both\n // relayoutFlags.layoutReplot and restyleFlags.fullReplot are true\n seq.push(subroutines.layoutReplot);\n } else if(restyleFlags.fullReplot) {\n seq.push(exports.plot);\n } else {\n seq.push(Plots.previousPromises);\n axRangeSupplyDefaultsByPass(gd, relayoutFlags, relayoutSpecs) || Plots.supplyDefaults(gd);\n\n if(restyleFlags.style) seq.push(subroutines.doTraceStyle);\n if(restyleFlags.colorbars || relayoutFlags.colorbars) seq.push(subroutines.doColorBars);\n if(relayoutFlags.legend) seq.push(subroutines.doLegend);\n if(relayoutFlags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(relayoutFlags.axrange) addAxRangeSequence(seq, relayoutSpecs.rangesAltered);\n if(relayoutFlags.ticks) seq.push(subroutines.doTicksRelayout);\n if(relayoutFlags.modebar) seq.push(subroutines.doModeBar);\n if(relayoutFlags.camera) seq.push(subroutines.doCamera);\n\n seq.push(emitAfterPlot);\n }\n\n seq.push(Plots.rehover, Plots.redrag);\n\n Queue.add(gd,\n update, [gd, restyleSpecs.undoit, relayoutSpecs.undoit, restyleSpecs.traces],\n update, [gd, restyleSpecs.redoit, relayoutSpecs.redoit, restyleSpecs.traces]\n );\n\n var plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n\n return plotDone.then(function() {\n gd.emit('plotly_update', {\n data: restyleSpecs.eventData,\n layout: relayoutSpecs.eventData\n });\n\n return gd;\n });\n}\n\n/*\n * internal-use-only restyle/relayout/update variants that record the initial\n * values in (fullLayout|fullTrace)._preGUI so changes can be persisted across\n * Plotly.react data updates, dependent on uirevision attributes\n */\nfunction guiEdit(func) {\n return function wrappedEdit(gd) {\n gd._fullLayout._guiEditing = true;\n var p = func.apply(null, arguments);\n gd._fullLayout._guiEditing = false;\n return p;\n };\n}\n\n// For connecting edited layout attributes to uirevision attrs\n// If no `attr` we use `match[1] + '.uirevision'`\n// Ordered by most common edits first, to minimize our search time\nvar layoutUIControlPatterns = [\n {pattern: /^hiddenlabels/, attr: 'legend.uirevision'},\n {pattern: /^((x|y)axis\\d*)\\.((auto)?range|title\\.text)/},\n\n // showspikes and modes include those nested inside scenes\n {pattern: /axis\\d*\\.showspikes$/, attr: 'modebar.uirevision'},\n {pattern: /(hover|drag)mode$/, attr: 'modebar.uirevision'},\n\n {pattern: /^(scene\\d*)\\.camera/},\n {pattern: /^(geo\\d*)\\.(projection|center|fitbounds)/},\n {pattern: /^(ternary\\d*\\.[abc]axis)\\.(min|title\\.text)$/},\n {pattern: /^(polar\\d*\\.radialaxis)\\.((auto)?range|angle|title\\.text)/},\n {pattern: /^(polar\\d*\\.angularaxis)\\.rotation/},\n {pattern: /^(mapbox\\d*)\\.(center|zoom|bearing|pitch)/},\n\n {pattern: /^legend\\.(x|y)$/, attr: 'editrevision'},\n {pattern: /^(shapes|annotations)/, attr: 'editrevision'},\n {pattern: /^title\\.text$/, attr: 'editrevision'}\n];\n\n// same for trace attributes: if `attr` is given it's in layout,\n// or with no `attr` we use `trace.uirevision`\nvar traceUIControlPatterns = [\n {pattern: /^selectedpoints$/, attr: 'selectionrevision'},\n // \"visible\" includes trace.transforms[i].styles[j].value.visible\n {pattern: /(^|value\\.)visible$/, attr: 'legend.uirevision'},\n {pattern: /^dimensions\\[\\d+\\]\\.constraintrange/},\n {pattern: /^node\\.(x|y|groups)/}, // for Sankey nodes\n {pattern: /^level$/}, // for Sunburst & Treemap traces\n\n // below this you must be in editable: true mode\n // TODO: I still put name and title with `trace.uirevision`\n // reasonable or should these be `editrevision`?\n // Also applies to axis titles up in the layout section\n\n // \"name\" also includes transform.styles\n {pattern: /(^|value\\.)name$/},\n // including nested colorbar attributes (ie marker.colorbar)\n {pattern: /colorbar\\.title\\.text$/},\n {pattern: /colorbar\\.(x|y)$/, attr: 'editrevision'}\n];\n\nfunction findUIPattern(key, patternSpecs) {\n for(var i = 0; i < patternSpecs.length; i++) {\n var spec = patternSpecs[i];\n var match = key.match(spec.pattern);\n if(match) {\n return {head: match[1], attr: spec.attr};\n }\n }\n}\n\n// We're finding the new uirevision before supplyDefaults, so do the\n// inheritance manually. Note that only `undefined` inherits - other\n// falsy values are returned.\nfunction getNewRev(revAttr, container) {\n var newRev = nestedProperty(container, revAttr).get();\n if(newRev !== undefined) return newRev;\n\n var parts = revAttr.split('.');\n parts.pop();\n while(parts.length > 1) {\n parts.pop();\n newRev = nestedProperty(container, parts.join('.') + '.uirevision').get();\n if(newRev !== undefined) return newRev;\n }\n\n return container.uirevision;\n}\n\nfunction getFullTraceIndexFromUid(uid, fullData) {\n for(var i = 0; i < fullData.length; i++) {\n if(fullData[i]._fullInput.uid === uid) return i;\n }\n return -1;\n}\n\nfunction getTraceIndexFromUid(uid, data, tracei) {\n for(var i = 0; i < data.length; i++) {\n if(data[i].uid === uid) return i;\n }\n // fall back on trace order, but only if user didn't provide a uid for that trace\n return (!data[tracei] || data[tracei].uid) ? -1 : tracei;\n}\n\nfunction valsMatch(v1, v2) {\n var v1IsObj = Lib.isPlainObject(v1);\n var v1IsArray = Array.isArray(v1);\n if(v1IsObj || v1IsArray) {\n return (\n (v1IsObj && Lib.isPlainObject(v2)) ||\n (v1IsArray && Array.isArray(v2))\n ) && JSON.stringify(v1) === JSON.stringify(v2);\n }\n return v1 === v2;\n}\n\nfunction applyUIRevisions(data, layout, oldFullData, oldFullLayout) {\n var layoutPreGUI = oldFullLayout._preGUI;\n var key, revAttr, oldRev, newRev, match, preGUIVal, newNP, newVal;\n var bothInheritAutorange = [];\n var newRangeAccepted = {};\n for(key in layoutPreGUI) {\n match = findUIPattern(key, layoutUIControlPatterns);\n if(match) {\n revAttr = match.attr || (match.head + '.uirevision');\n oldRev = nestedProperty(oldFullLayout, revAttr).get();\n newRev = oldRev && getNewRev(revAttr, layout);\n if(newRev && (newRev === oldRev)) {\n preGUIVal = layoutPreGUI[key];\n if(preGUIVal === null) preGUIVal = undefined;\n newNP = nestedProperty(layout, key);\n newVal = newNP.get();\n if(valsMatch(newVal, preGUIVal)) {\n if(newVal === undefined && key.substr(key.length - 9) === 'autorange') {\n bothInheritAutorange.push(key.substr(0, key.length - 10));\n }\n newNP.set(undefinedToNull(nestedProperty(oldFullLayout, key).get()));\n continue;\n }\n }\n } else {\n Lib.warn('unrecognized GUI edit: ' + key);\n }\n // if we got this far, the new value was accepted as the new starting\n // point (either because it changed or revision changed)\n // so remove it from _preGUI for next time.\n delete layoutPreGUI[key];\n\n if(key.substr(key.length - 8, 6) === 'range[') {\n newRangeAccepted[key.substr(0, key.length - 9)] = 1;\n }\n }\n\n // Special logic for `autorange`, since it interacts with `range`:\n // If the new figure's matching `range` was kept, and `autorange`\n // wasn't supplied explicitly in either the original or the new figure,\n // we shouldn't alter that - but we may just have done that, so fix it.\n for(var i = 0; i < bothInheritAutorange.length; i++) {\n var axAttr = bothInheritAutorange[i];\n if(newRangeAccepted[axAttr]) {\n var newAx = nestedProperty(layout, axAttr).get();\n if(newAx) delete newAx.autorange;\n }\n }\n\n // Now traces - try to match them up by uid (in case we added/deleted in\n // the middle), then fall back on index.\n var allTracePreGUI = oldFullLayout._tracePreGUI;\n for(var uid in allTracePreGUI) {\n var tracePreGUI = allTracePreGUI[uid];\n var newTrace = null;\n var fullInput;\n for(key in tracePreGUI) {\n // wait until we know we have preGUI values to look for traces\n // but if we don't find both, stop looking at this uid\n if(!newTrace) {\n var fulli = getFullTraceIndexFromUid(uid, oldFullData);\n if(fulli < 0) {\n // Somehow we didn't even have this trace in oldFullData...\n // I guess this could happen with `deleteTraces` or something\n delete allTracePreGUI[uid];\n break;\n }\n var fullTrace = oldFullData[fulli];\n fullInput = fullTrace._fullInput;\n\n var newTracei = getTraceIndexFromUid(uid, data, fullInput.index);\n if(newTracei < 0) {\n // No match in new data\n delete allTracePreGUI[uid];\n break;\n }\n newTrace = data[newTracei];\n }\n\n match = findUIPattern(key, traceUIControlPatterns);\n if(match) {\n if(match.attr) {\n oldRev = nestedProperty(oldFullLayout, match.attr).get();\n newRev = oldRev && getNewRev(match.attr, layout);\n } else {\n oldRev = fullInput.uirevision;\n // inheritance for trace.uirevision is simple, just layout.uirevision\n newRev = newTrace.uirevision;\n if(newRev === undefined) newRev = layout.uirevision;\n }\n\n if(newRev && newRev === oldRev) {\n preGUIVal = tracePreGUI[key];\n if(preGUIVal === null) preGUIVal = undefined;\n newNP = nestedProperty(newTrace, key);\n newVal = newNP.get();\n if(valsMatch(newVal, preGUIVal)) {\n newNP.set(undefinedToNull(nestedProperty(fullInput, key).get()));\n continue;\n }\n }\n } else {\n Lib.warn('unrecognized GUI edit: ' + key + ' in trace uid ' + uid);\n }\n delete tracePreGUI[key];\n }\n }\n}\n\n/**\n * Plotly.react:\n * A plot/update method that takes the full plot state (same API as plot/newPlot)\n * and diffs to determine the minimal update pathway\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {array of objects} data\n * array of traces, containing the data and display information for each trace\n * @param {object} layout\n * object describing the overall display of the plot,\n * all the stuff that doesn't pertain to any individual trace\n * @param {object} config\n * configuration options (see ./plot_config.js for more info)\n *\n * OR\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n * @param {object} figure\n * object containing `data`, `layout`, `config`, and `frames` members\n *\n */\nfunction react(gd, data, layout, config) {\n var frames, plotDone;\n\n function addFrames() { return exports.addFrames(gd, frames); }\n\n gd = Lib.getGraphDiv(gd);\n helpers.clearPromiseQueue(gd);\n\n var oldFullData = gd._fullData;\n var oldFullLayout = gd._fullLayout;\n\n // you can use this as the initial draw as well as to update\n if(!Lib.isPlotDiv(gd) || !oldFullData || !oldFullLayout) {\n plotDone = exports.newPlot(gd, data, layout, config);\n } else {\n if(Lib.isPlainObject(data)) {\n var obj = data;\n data = obj.data;\n layout = obj.layout;\n config = obj.config;\n frames = obj.frames;\n }\n\n var configChanged = false;\n // assume that if there's a config at all, we're reacting to it too,\n // and completely replace the previous config\n if(config) {\n var oldConfig = Lib.extendDeep({}, gd._context);\n gd._context = undefined;\n setPlotContext(gd, config);\n configChanged = diffConfig(oldConfig, gd._context);\n }\n\n gd.data = data || [];\n helpers.cleanData(gd.data);\n gd.layout = layout || {};\n helpers.cleanLayout(gd.layout);\n\n applyUIRevisions(gd.data, gd.layout, oldFullData, oldFullLayout);\n\n // \"true\" skips updating calcdata and remapping arrays from calcTransforms,\n // which supplyDefaults usually does at the end, but we may need to NOT do\n // if the diff (which we haven't determined yet) says we'll recalc\n Plots.supplyDefaults(gd, {skipUpdateCalc: true});\n\n var newFullData = gd._fullData;\n var newFullLayout = gd._fullLayout;\n var immutable = newFullLayout.datarevision === undefined;\n var transition = newFullLayout.transition;\n\n var relayoutFlags = diffLayout(gd, oldFullLayout, newFullLayout, immutable, transition);\n var newDataRevision = relayoutFlags.newDataRevision;\n var restyleFlags = diffData(gd, oldFullData, newFullData, immutable, transition, newDataRevision);\n\n // TODO: how to translate this part of relayout to Plotly.react?\n // // Setting width or height to null must reset the graph's width / height\n // // back to its initial value as computed during the first pass in Plots.plotAutoSize.\n // //\n // // To do so, we must manually set them back here using the _initialAutoSize cache.\n // if(['width', 'height'].indexOf(ai) !== -1 && vi === null) {\n // fullLayout[ai] = gd._initialAutoSize[ai];\n // }\n\n if(updateAutosize(gd)) relayoutFlags.layoutReplot = true;\n\n // clear calcdata if required\n if(restyleFlags.calc || relayoutFlags.calc) gd.calcdata = undefined;\n // otherwise do the calcdata updates and calcTransform array remaps that we skipped earlier\n else Plots.supplyDefaultsUpdateCalc(gd.calcdata, newFullData);\n\n // Note: what restyle/relayout use impliedEdits and clearAxisTypes for\n // must be handled by the user when using Plotly.react.\n\n // fill in redraw sequence\n var seq = [];\n\n if(frames) {\n gd._transitionData = {};\n Plots.createTransitionData(gd);\n seq.push(addFrames);\n }\n\n // Transition pathway,\n // only used when 'transition' is set by user and\n // when at least one animatable attribute has changed,\n // N.B. config changed aren't animatable\n if(newFullLayout.transition && !configChanged && (restyleFlags.anim || relayoutFlags.anim)) {\n Plots.doCalcdata(gd);\n subroutines.doAutoRangeAndConstraints(gd);\n\n seq.push(function() {\n return Plots.transitionFromReact(gd, restyleFlags, relayoutFlags, oldFullLayout);\n });\n } else if(restyleFlags.fullReplot || relayoutFlags.layoutReplot || configChanged) {\n gd._fullLayout._skipDefaults = true;\n seq.push(exports.plot);\n } else {\n for(var componentType in relayoutFlags.arrays) {\n var indices = relayoutFlags.arrays[componentType];\n if(indices.length) {\n var drawOne = Registry.getComponentMethod(componentType, 'drawOne');\n if(drawOne !== Lib.noop) {\n for(var i = 0; i < indices.length; i++) {\n drawOne(gd, indices[i]);\n }\n } else {\n var draw = Registry.getComponentMethod(componentType, 'draw');\n if(draw === Lib.noop) {\n throw new Error('cannot draw components: ' + componentType);\n }\n draw(gd);\n }\n }\n }\n\n seq.push(Plots.previousPromises);\n if(restyleFlags.style) seq.push(subroutines.doTraceStyle);\n if(restyleFlags.colorbars || relayoutFlags.colorbars) seq.push(subroutines.doColorBars);\n if(relayoutFlags.legend) seq.push(subroutines.doLegend);\n if(relayoutFlags.layoutstyle) seq.push(subroutines.layoutStyles);\n if(relayoutFlags.axrange) addAxRangeSequence(seq);\n if(relayoutFlags.ticks) seq.push(subroutines.doTicksRelayout);\n if(relayoutFlags.modebar) seq.push(subroutines.doModeBar);\n if(relayoutFlags.camera) seq.push(subroutines.doCamera);\n seq.push(emitAfterPlot);\n }\n\n seq.push(Plots.rehover, Plots.redrag);\n\n plotDone = Lib.syncOrAsync(seq, gd);\n if(!plotDone || !plotDone.then) plotDone = Promise.resolve(gd);\n }\n\n return plotDone.then(function() {\n gd.emit('plotly_react', {\n data: data,\n layout: layout\n });\n\n return gd;\n });\n}\n\nfunction diffData(gd, oldFullData, newFullData, immutable, transition, newDataRevision) {\n var sameTraceLength = oldFullData.length === newFullData.length;\n\n if(!transition && !sameTraceLength) {\n return {\n fullReplot: true,\n calc: true\n };\n }\n\n var flags = editTypes.traceFlags();\n flags.arrays = {};\n flags.nChanges = 0;\n flags.nChangesAnim = 0;\n\n var i, trace;\n\n function getTraceValObject(parts) {\n var out = PlotSchema.getTraceValObject(trace, parts);\n if(!trace._module.animatable && out.anim) {\n out.anim = false;\n }\n return out;\n }\n\n var diffOpts = {\n getValObject: getTraceValObject,\n flags: flags,\n immutable: immutable,\n transition: transition,\n newDataRevision: newDataRevision,\n gd: gd\n };\n\n var seenUIDs = {};\n\n for(i = 0; i < oldFullData.length; i++) {\n if(newFullData[i]) {\n trace = newFullData[i]._fullInput;\n if(Plots.hasMakesDataTransform(trace)) trace = newFullData[i];\n if(seenUIDs[trace.uid]) continue;\n seenUIDs[trace.uid] = 1;\n\n getDiffFlags(oldFullData[i]._fullInput, trace, [], diffOpts);\n }\n }\n\n if(flags.calc || flags.plot) {\n flags.fullReplot = true;\n }\n\n if(transition && flags.nChanges && flags.nChangesAnim) {\n flags.anim = (flags.nChanges === flags.nChangesAnim) && sameTraceLength ? 'all' : 'some';\n }\n\n return flags;\n}\n\nfunction diffLayout(gd, oldFullLayout, newFullLayout, immutable, transition) {\n var flags = editTypes.layoutFlags();\n flags.arrays = {};\n flags.rangesAltered = {};\n flags.nChanges = 0;\n flags.nChangesAnim = 0;\n\n function getLayoutValObject(parts) {\n return PlotSchema.getLayoutValObject(newFullLayout, parts);\n }\n\n var diffOpts = {\n getValObject: getLayoutValObject,\n flags: flags,\n immutable: immutable,\n transition: transition,\n gd: gd\n };\n\n getDiffFlags(oldFullLayout, newFullLayout, [], diffOpts);\n\n if(flags.plot || flags.calc) {\n flags.layoutReplot = true;\n }\n\n if(transition && flags.nChanges && flags.nChangesAnim) {\n flags.anim = flags.nChanges === flags.nChangesAnim ? 'all' : 'some';\n }\n\n return flags;\n}\n\nfunction getDiffFlags(oldContainer, newContainer, outerparts, opts) {\n var valObject, key, astr;\n\n var getValObject = opts.getValObject;\n var flags = opts.flags;\n var immutable = opts.immutable;\n var inArray = opts.inArray;\n var arrayIndex = opts.arrayIndex;\n\n function changed() {\n var editType = valObject.editType;\n if(inArray && editType.indexOf('arraydraw') !== -1) {\n Lib.pushUnique(flags.arrays[inArray], arrayIndex);\n return;\n }\n editTypes.update(flags, valObject);\n\n if(editType !== 'none') {\n flags.nChanges++;\n }\n\n // track animatable changes\n if(opts.transition && valObject.anim) {\n flags.nChangesAnim++;\n }\n\n // track cartesian axes with altered ranges\n if(AX_RANGE_RE.test(astr) || AX_AUTORANGE_RE.test(astr)) {\n flags.rangesAltered[outerparts[0]] = 1;\n }\n\n // clear _inputDomain on cartesian axes with altered domains\n if(AX_DOMAIN_RE.test(astr)) {\n nestedProperty(newContainer, '_inputDomain').set(null);\n }\n\n // track datarevision changes\n if(key === 'datarevision') {\n flags.newDataRevision = 1;\n }\n }\n\n function valObjectCanBeDataArray(valObject) {\n return valObject.valType === 'data_array' || valObject.arrayOk;\n }\n\n for(key in oldContainer) {\n // short-circuit based on previous calls or previous keys that already maximized the pathway\n if(flags.calc && !opts.transition) return;\n\n var oldVal = oldContainer[key];\n var newVal = newContainer[key];\n var parts = outerparts.concat(key);\n astr = parts.join('.');\n\n if(key.charAt(0) === '_' || typeof oldVal === 'function' || oldVal === newVal) continue;\n\n // FIXME: ax.tick0 and dtick get filled in during plotting (except for geo subplots),\n // and unlike other auto values they don't make it back into the input,\n // so newContainer won't have them.\n if((key === 'tick0' || key === 'dtick') && outerparts[0] !== 'geo') {\n var tickMode = newContainer.tickmode;\n if(tickMode === 'auto' || tickMode === 'array' || !tickMode) continue;\n }\n // FIXME: Similarly for axis ranges for 3D\n // contourcarpet doesn't HAVE zmin/zmax, they're just auto-added. It needs them.\n if(key === 'range' && newContainer.autorange) continue;\n if((key === 'zmin' || key === 'zmax') && newContainer.type === 'contourcarpet') continue;\n\n valObject = getValObject(parts);\n\n // in case type changed, we may not even *have* a valObject.\n if(!valObject) continue;\n\n if(valObject._compareAsJSON && JSON.stringify(oldVal) === JSON.stringify(newVal)) continue;\n\n var valType = valObject.valType;\n var i;\n\n var canBeDataArray = valObjectCanBeDataArray(valObject);\n var wasArray = Array.isArray(oldVal);\n var nowArray = Array.isArray(newVal);\n\n // hack for traces that modify the data in supplyDefaults, like\n // converting 1D to 2D arrays, which will always create new objects\n if(wasArray && nowArray) {\n var inputKey = '_input_' + key;\n var oldValIn = oldContainer[inputKey];\n var newValIn = newContainer[inputKey];\n if(Array.isArray(oldValIn) && oldValIn === newValIn) continue;\n }\n\n if(newVal === undefined) {\n if(canBeDataArray && wasArray) flags.calc = true;\n else changed();\n } else if(valObject._isLinkedToArray) {\n var arrayEditIndices = [];\n var extraIndices = false;\n if(!inArray) flags.arrays[key] = arrayEditIndices;\n\n var minLen = Math.min(oldVal.length, newVal.length);\n var maxLen = Math.max(oldVal.length, newVal.length);\n if(minLen !== maxLen) {\n if(valObject.editType === 'arraydraw') {\n extraIndices = true;\n } else {\n changed();\n continue;\n }\n }\n\n for(i = 0; i < minLen; i++) {\n getDiffFlags(oldVal[i], newVal[i], parts.concat(i),\n // add array indices, but not if we're already in an array\n Lib.extendFlat({inArray: key, arrayIndex: i}, opts));\n }\n\n // put this at the end so that we know our collected array indices are sorted\n // but the check for length changes happens up front so we can short-circuit\n // diffing if appropriate\n if(extraIndices) {\n for(i = minLen; i < maxLen; i++) {\n arrayEditIndices.push(i);\n }\n }\n } else if(!valType && Lib.isPlainObject(oldVal)) {\n getDiffFlags(oldVal, newVal, parts, opts);\n } else if(canBeDataArray) {\n if(wasArray && nowArray) {\n // don't try to diff two data arrays. If immutable we know the data changed,\n // if not, assume it didn't and let `layout.datarevision` tell us if it did\n if(immutable) {\n flags.calc = true;\n }\n\n // look for animatable attributes when the data changed\n if(immutable || opts.newDataRevision) {\n changed();\n }\n } else if(wasArray !== nowArray) {\n flags.calc = true;\n } else changed();\n } else if(wasArray && nowArray) {\n // info array, colorscale, 'any' - these are short, just stringify.\n // I don't *think* that covers up any real differences post-validation, does it?\n // otherwise we need to dive in 1 (info_array) or 2 (colorscale) levels and compare\n // all elements.\n if(oldVal.length !== newVal.length || String(oldVal) !== String(newVal)) {\n changed();\n }\n } else {\n changed();\n }\n }\n\n for(key in newContainer) {\n if(!(key in oldContainer || key.charAt(0) === '_' || typeof newContainer[key] === 'function')) {\n valObject = getValObject(outerparts.concat(key));\n\n if(valObjectCanBeDataArray(valObject) && Array.isArray(newContainer[key])) {\n flags.calc = true;\n return;\n } else changed();\n }\n }\n}\n\n/*\n * simple diff for config - for now, just treat all changes as equivalent\n */\nfunction diffConfig(oldConfig, newConfig) {\n var key;\n\n for(key in oldConfig) {\n if(key.charAt(0) === '_') continue;\n var oldVal = oldConfig[key];\n var newVal = newConfig[key];\n if(oldVal !== newVal) {\n if(Lib.isPlainObject(oldVal) && Lib.isPlainObject(newVal)) {\n if(diffConfig(oldVal, newVal)) {\n return true;\n }\n } else if(Array.isArray(oldVal) && Array.isArray(newVal)) {\n if(oldVal.length !== newVal.length) {\n return true;\n }\n for(var i = 0; i < oldVal.length; i++) {\n if(oldVal[i] !== newVal[i]) {\n if(Lib.isPlainObject(oldVal[i]) && Lib.isPlainObject(newVal[i])) {\n if(diffConfig(oldVal[i], newVal[i])) {\n return true;\n }\n } else {\n return true;\n }\n }\n }\n } else {\n return true;\n }\n }\n }\n}\n\n/**\n * Animate to a frame, sequence of frame, frame group, or frame definition\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {string or object or array of strings or array of objects} frameOrGroupNameOrFrameList\n * a single frame, array of frames, or group to which to animate. The intent is\n * inferred by the type of the input. Valid inputs are:\n *\n * - string, e.g. 'groupname': animate all frames of a given `group` in the order\n * in which they are defined via `Plotly.addFrames`.\n *\n * - array of strings, e.g. ['frame1', frame2']: a list of frames by name to which\n * to animate in sequence\n *\n * - object: {data: ...}: a frame definition to which to animate. The frame is not\n * and does not need to be added via `Plotly.addFrames`. It may contain any of\n * the properties of a frame, including `data`, `layout`, and `traces`. The\n * frame is used as provided and does not use the `baseframe` property.\n *\n * - array of objects, e.g. [{data: ...}, {data: ...}]: a list of frame objects,\n * each following the same rules as a single `object`.\n *\n * @param {object} animationOpts\n * configuration for the animation\n */\nfunction animate(gd, frameOrGroupNameOrFrameList, animationOpts) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error(\n 'This element is not a Plotly plot: ' + gd + '. It\\'s likely that you\\'ve failed ' +\n 'to create a plot before animating it. For more details, see ' +\n 'https://plotly.com/javascript/animations/'\n );\n }\n\n var trans = gd._transitionData;\n\n // This is the queue of frames that will be animated as soon as possible. They\n // are popped immediately upon the *start* of a transition:\n if(!trans._frameQueue) {\n trans._frameQueue = [];\n }\n\n animationOpts = Plots.supplyAnimationDefaults(animationOpts);\n var transitionOpts = animationOpts.transition;\n var frameOpts = animationOpts.frame;\n\n // Since frames are popped immediately, an empty queue only means all frames have\n // *started* to transition, not that the animation is complete. To solve that,\n // track a separate counter that increments at the same time as frames are added\n // to the queue, but decrements only when the transition is complete.\n if(trans._frameWaitingCnt === undefined) {\n trans._frameWaitingCnt = 0;\n }\n\n function getTransitionOpts(i) {\n if(Array.isArray(transitionOpts)) {\n if(i >= transitionOpts.length) {\n return transitionOpts[0];\n } else {\n return transitionOpts[i];\n }\n } else {\n return transitionOpts;\n }\n }\n\n function getFrameOpts(i) {\n if(Array.isArray(frameOpts)) {\n if(i >= frameOpts.length) {\n return frameOpts[0];\n } else {\n return frameOpts[i];\n }\n } else {\n return frameOpts;\n }\n }\n\n // Execute a callback after the wrapper function has been called n times.\n // This is used to defer the resolution until a transition has resovled *and*\n // the frame has completed. If it's not done this way, then we get a race\n // condition in which the animation might resolve before a transition is complete\n // or vice versa.\n function callbackOnNthTime(cb, n) {\n var cnt = 0;\n return function() {\n if(cb && ++cnt === n) {\n return cb();\n }\n };\n }\n\n return new Promise(function(resolve, reject) {\n function discardExistingFrames() {\n if(trans._frameQueue.length === 0) {\n return;\n }\n\n while(trans._frameQueue.length) {\n var next = trans._frameQueue.pop();\n if(next.onInterrupt) {\n next.onInterrupt();\n }\n }\n\n gd.emit('plotly_animationinterrupted', []);\n }\n\n function queueFrames(frameList) {\n if(frameList.length === 0) return;\n\n for(var i = 0; i < frameList.length; i++) {\n var computedFrame;\n\n if(frameList[i].type === 'byname') {\n // If it's a named frame, compute it:\n computedFrame = Plots.computeFrame(gd, frameList[i].name);\n } else {\n // Otherwise we must have been given a simple object, so treat\n // the input itself as the computed frame.\n computedFrame = frameList[i].data;\n }\n\n var frameOpts = getFrameOpts(i);\n var transitionOpts = getTransitionOpts(i);\n\n // It doesn't make much sense for the transition duration to be greater than\n // the frame duration, so limit it:\n transitionOpts.duration = Math.min(transitionOpts.duration, frameOpts.duration);\n\n var nextFrame = {\n frame: computedFrame,\n name: frameList[i].name,\n frameOpts: frameOpts,\n transitionOpts: transitionOpts,\n };\n if(i === frameList.length - 1) {\n // The last frame in this .animate call stores the promise resolve\n // and reject callbacks. This is how we ensure that the animation\n // loop (which may exist as a result of a *different* .animate call)\n // still resolves or rejecdts this .animate call's promise. once it's\n // complete.\n nextFrame.onComplete = callbackOnNthTime(resolve, 2);\n nextFrame.onInterrupt = reject;\n }\n\n trans._frameQueue.push(nextFrame);\n }\n\n // Set it as never having transitioned to a frame. This will cause the animation\n // loop to immediately transition to the next frame (which, for immediate mode,\n // is the first frame in the list since all others would have been discarded\n // below)\n if(animationOpts.mode === 'immediate') {\n trans._lastFrameAt = -Infinity;\n }\n\n // Only it's not already running, start a RAF loop. This could be avoided in the\n // case that there's only one frame, but it significantly complicated the logic\n // and only sped things up by about 5% or so for a lorenz attractor simulation.\n // It would be a fine thing to implement, but the benefit of that optimization\n // doesn't seem worth the extra complexity.\n if(!trans._animationRaf) {\n beginAnimationLoop();\n }\n }\n\n function stopAnimationLoop() {\n gd.emit('plotly_animated');\n\n // Be sure to unset also since it's how we know whether a loop is already running:\n window.cancelAnimationFrame(trans._animationRaf);\n trans._animationRaf = null;\n }\n\n function nextFrame() {\n if(trans._currentFrame && trans._currentFrame.onComplete) {\n // Execute the callback and unset it to ensure it doesn't\n // accidentally get called twice\n trans._currentFrame.onComplete();\n }\n\n var newFrame = trans._currentFrame = trans._frameQueue.shift();\n\n if(newFrame) {\n // Since it's sometimes necessary to do deep digging into frame data,\n // we'll consider it not 100% impossible for nulls or numbers to sneak through,\n // so check when casting the name, just to be absolutely certain:\n var stringName = newFrame.name ? newFrame.name.toString() : null;\n gd._fullLayout._currentFrame = stringName;\n\n trans._lastFrameAt = Date.now();\n trans._timeToNext = newFrame.frameOpts.duration;\n\n // This is simply called and it's left to .transition to decide how to manage\n // interrupting current transitions. That means we don't need to worry about\n // how it resolves or what happens after this:\n Plots.transition(gd,\n newFrame.frame.data,\n newFrame.frame.layout,\n helpers.coerceTraceIndices(gd, newFrame.frame.traces),\n newFrame.frameOpts,\n newFrame.transitionOpts\n ).then(function() {\n if(newFrame.onComplete) {\n newFrame.onComplete();\n }\n });\n\n gd.emit('plotly_animatingframe', {\n name: stringName,\n frame: newFrame.frame,\n animation: {\n frame: newFrame.frameOpts,\n transition: newFrame.transitionOpts,\n }\n });\n } else {\n // If there are no more frames, then stop the RAF loop:\n stopAnimationLoop();\n }\n }\n\n function beginAnimationLoop() {\n gd.emit('plotly_animating');\n\n // If no timer is running, then set last frame = long ago so that the next\n // frame is immediately transitioned:\n trans._lastFrameAt = -Infinity;\n trans._timeToNext = 0;\n trans._runningTransitions = 0;\n trans._currentFrame = null;\n\n var doFrame = function() {\n // This *must* be requested before nextFrame since nextFrame may decide\n // to cancel it if there's nothing more to animated:\n trans._animationRaf = window.requestAnimationFrame(doFrame);\n\n // Check if we're ready for a new frame:\n if(Date.now() - trans._lastFrameAt > trans._timeToNext) {\n nextFrame();\n }\n };\n\n doFrame();\n }\n\n // This is an animate-local counter that helps match up option input list\n // items with the particular frame.\n var configCounter = 0;\n function setTransitionConfig(frame) {\n if(Array.isArray(transitionOpts)) {\n if(configCounter >= transitionOpts.length) {\n frame.transitionOpts = transitionOpts[configCounter];\n } else {\n frame.transitionOpts = transitionOpts[0];\n }\n } else {\n frame.transitionOpts = transitionOpts;\n }\n configCounter++;\n return frame;\n }\n\n // Disambiguate what's sort of frames have been received\n var i, frame;\n var frameList = [];\n var allFrames = frameOrGroupNameOrFrameList === undefined || frameOrGroupNameOrFrameList === null;\n var isFrameArray = Array.isArray(frameOrGroupNameOrFrameList);\n var isSingleFrame = !allFrames && !isFrameArray && Lib.isPlainObject(frameOrGroupNameOrFrameList);\n\n if(isSingleFrame) {\n // In this case, a simple object has been passed to animate.\n frameList.push({\n type: 'object',\n data: setTransitionConfig(Lib.extendFlat({}, frameOrGroupNameOrFrameList))\n });\n } else if(allFrames || ['string', 'number'].indexOf(typeof frameOrGroupNameOrFrameList) !== -1) {\n // In this case, null or undefined has been passed so that we want to\n // animate *all* currently defined frames\n for(i = 0; i < trans._frames.length; i++) {\n frame = trans._frames[i];\n\n if(!frame) continue;\n\n if(allFrames || String(frame.group) === String(frameOrGroupNameOrFrameList)) {\n frameList.push({\n type: 'byname',\n name: String(frame.name),\n data: setTransitionConfig({name: frame.name})\n });\n }\n }\n } else if(isFrameArray) {\n for(i = 0; i < frameOrGroupNameOrFrameList.length; i++) {\n var frameOrName = frameOrGroupNameOrFrameList[i];\n if(['number', 'string'].indexOf(typeof frameOrName) !== -1) {\n frameOrName = String(frameOrName);\n // In this case, there's an array and this frame is a string name:\n frameList.push({\n type: 'byname',\n name: frameOrName,\n data: setTransitionConfig({name: frameOrName})\n });\n } else if(Lib.isPlainObject(frameOrName)) {\n frameList.push({\n type: 'object',\n data: setTransitionConfig(Lib.extendFlat({}, frameOrName))\n });\n }\n }\n }\n\n // Verify that all of these frames actually exist; return and reject if not:\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frame.type === 'byname' && !trans._frameHash[frame.data.name]) {\n Lib.warn('animate failure: frame not found: \"' + frame.data.name + '\"');\n reject();\n return;\n }\n }\n\n // If the mode is either next or immediate, then all currently queued frames must\n // be dumped and the corresponding .animate promises rejected.\n if(['next', 'immediate'].indexOf(animationOpts.mode) !== -1) {\n discardExistingFrames();\n }\n\n if(animationOpts.direction === 'reverse') {\n frameList.reverse();\n }\n\n var currentFrame = gd._fullLayout._currentFrame;\n if(currentFrame && animationOpts.fromcurrent) {\n var idx = -1;\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frame.type === 'byname' && frame.name === currentFrame) {\n idx = i;\n break;\n }\n }\n\n if(idx > 0 && idx < frameList.length - 1) {\n var filteredFrameList = [];\n for(i = 0; i < frameList.length; i++) {\n frame = frameList[i];\n if(frameList[i].type !== 'byname' || i > idx) {\n filteredFrameList.push(frame);\n }\n }\n frameList = filteredFrameList;\n }\n }\n\n if(frameList.length > 0) {\n queueFrames(frameList);\n } else {\n // This is the case where there were simply no frames. It's a little strange\n // since there's not much to do:\n gd.emit('plotly_animated');\n resolve();\n }\n });\n}\n\n/**\n * Register new frames\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {array of objects} frameList\n * list of frame definitions, in which each object includes any of:\n * - name: {string} name of frame to add\n * - data: {array of objects} trace data\n * - layout {object} layout definition\n * - traces {array} trace indices\n * - baseframe {string} name of frame from which this frame gets defaults\n *\n * @param {array of integers} indices\n * an array of integer indices matching the respective frames in `frameList`. If not\n * provided, an index will be provided in serial order. If already used, the frame\n * will be overwritten.\n */\nfunction addFrames(gd, frameList, indices) {\n gd = Lib.getGraphDiv(gd);\n\n if(frameList === null || frameList === undefined) {\n return Promise.resolve();\n }\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error(\n 'This element is not a Plotly plot: ' + gd + '. It\\'s likely that you\\'ve failed ' +\n 'to create a plot before adding frames. For more details, see ' +\n 'https://plotly.com/javascript/animations/'\n );\n }\n\n var i, frame, j, idx;\n var _frames = gd._transitionData._frames;\n var _frameHash = gd._transitionData._frameHash;\n\n\n if(!Array.isArray(frameList)) {\n throw new Error('addFrames failure: frameList must be an Array of frame definitions' + frameList);\n }\n\n // Create a sorted list of insertions since we run into lots of problems if these\n // aren't in ascending order of index:\n //\n // Strictly for sorting. Make sure this is guaranteed to never collide with any\n // already-exisisting indices:\n var bigIndex = _frames.length + frameList.length * 2;\n\n var insertions = [];\n var _frameHashLocal = {};\n for(i = frameList.length - 1; i >= 0; i--) {\n if(!Lib.isPlainObject(frameList[i])) continue;\n\n // The entire logic for checking for this type of name collision can be removed once we migrate to ES6 and\n // use a Map instead of an Object instance, as Map keys aren't converted to strings.\n var lookupName = frameList[i].name;\n var name = (_frameHash[lookupName] || _frameHashLocal[lookupName] || {}).name;\n var newName = frameList[i].name;\n var collisionPresent = _frameHash[name] || _frameHashLocal[name];\n\n if(name && newName && typeof newName === 'number' && collisionPresent && numericNameWarningCount < numericNameWarningCountLimit) {\n numericNameWarningCount++;\n\n Lib.warn('addFrames: overwriting frame \"' + (_frameHash[name] || _frameHashLocal[name]).name +\n '\" with a frame whose name of type \"number\" also equates to \"' +\n name + '\". This is valid but may potentially lead to unexpected ' +\n 'behavior since all plotly.js frame names are stored internally ' +\n 'as strings.');\n\n if(numericNameWarningCount === numericNameWarningCountLimit) {\n Lib.warn('addFrames: This API call has yielded too many of these warnings. ' +\n 'For the rest of this call, further warnings about numeric frame ' +\n 'names will be suppressed.');\n }\n }\n\n _frameHashLocal[lookupName] = {name: lookupName};\n\n insertions.push({\n frame: Plots.supplyFrameDefaults(frameList[i]),\n index: (indices && indices[i] !== undefined && indices[i] !== null) ? indices[i] : bigIndex + i\n });\n }\n\n // Sort this, taking note that undefined insertions end up at the end:\n insertions.sort(function(a, b) {\n if(a.index > b.index) return -1;\n if(a.index < b.index) return 1;\n return 0;\n });\n\n var ops = [];\n var revops = [];\n var frameCount = _frames.length;\n\n for(i = insertions.length - 1; i >= 0; i--) {\n frame = insertions[i].frame;\n\n if(typeof frame.name === 'number') {\n Lib.warn('Warning: addFrames accepts frames with numeric names, but the numbers are' +\n 'implicitly cast to strings');\n }\n\n if(!frame.name) {\n // Repeatedly assign a default name, incrementing the counter each time until\n // we get a name that's not in the hashed lookup table:\n while(_frameHash[(frame.name = 'frame ' + gd._transitionData._counter++)]);\n }\n\n if(_frameHash[frame.name]) {\n // If frame is present, overwrite its definition:\n for(j = 0; j < _frames.length; j++) {\n if((_frames[j] || {}).name === frame.name) break;\n }\n ops.push({type: 'replace', index: j, value: frame});\n revops.unshift({type: 'replace', index: j, value: _frames[j]});\n } else {\n // Otherwise insert it at the end of the list:\n idx = Math.max(0, Math.min(insertions[i].index, frameCount));\n\n ops.push({type: 'insert', index: idx, value: frame});\n revops.unshift({type: 'delete', index: idx});\n frameCount++;\n }\n }\n\n var undoFunc = Plots.modifyFrames;\n var redoFunc = Plots.modifyFrames;\n var undoArgs = [gd, revops];\n var redoArgs = [gd, ops];\n\n if(Queue) Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return Plots.modifyFrames(gd, ops);\n}\n\n/**\n * Delete frame\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n *\n * @param {array of integers} frameList\n * list of integer indices of frames to be deleted\n */\nfunction deleteFrames(gd, frameList) {\n gd = Lib.getGraphDiv(gd);\n\n if(!Lib.isPlotDiv(gd)) {\n throw new Error('This element is not a Plotly plot: ' + gd);\n }\n\n var i, idx;\n var _frames = gd._transitionData._frames;\n var ops = [];\n var revops = [];\n\n if(!frameList) {\n frameList = [];\n for(i = 0; i < _frames.length; i++) {\n frameList.push(i);\n }\n }\n\n frameList = frameList.slice();\n frameList.sort();\n\n for(i = frameList.length - 1; i >= 0; i--) {\n idx = frameList[i];\n ops.push({type: 'delete', index: idx});\n revops.unshift({type: 'insert', index: idx, value: _frames[idx]});\n }\n\n var undoFunc = Plots.modifyFrames;\n var redoFunc = Plots.modifyFrames;\n var undoArgs = [gd, revops];\n var redoArgs = [gd, ops];\n\n if(Queue) Queue.add(gd, undoFunc, undoArgs, redoFunc, redoArgs);\n\n return Plots.modifyFrames(gd, ops);\n}\n\n/**\n * Purge a graph container div back to its initial pre-Plotly.plot state\n *\n * @param {string id or DOM element} gd\n * the id or DOM element of the graph container div\n */\nfunction purge(gd) {\n gd = Lib.getGraphDiv(gd);\n\n var fullLayout = gd._fullLayout || {};\n var fullData = gd._fullData || [];\n\n // remove gl contexts\n Plots.cleanPlot([], {}, fullData, fullLayout);\n\n // purge properties\n Plots.purge(gd);\n\n // purge event emitter methods\n Events.purge(gd);\n\n // remove plot container\n if(fullLayout._container) fullLayout._container.remove();\n\n // in contrast to Plotly.Plots.purge which does NOT clear _context!\n delete gd._context;\n\n return gd;\n}\n\n// -------------------------------------------------------\n// makePlotFramework: Create the plot container and axes\n// -------------------------------------------------------\nfunction makePlotFramework(gd) {\n var gd3 = d3.select(gd);\n var fullLayout = gd._fullLayout;\n\n // Plot container\n fullLayout._container = gd3.selectAll('.plot-container').data([0]);\n fullLayout._container.enter().insert('div', ':first-child')\n .classed('plot-container', true)\n .classed('plotly', true);\n\n // Make the svg container\n fullLayout._paperdiv = fullLayout._container.selectAll('.svg-container').data([0]);\n fullLayout._paperdiv.enter().append('div')\n .classed('svg-container', true)\n .style('position', 'relative');\n\n // Make the graph containers\n // start fresh each time we get here, so we know the order comes out\n // right, rather than enter/exit which can muck up the order\n // TODO: sort out all the ordering so we don't have to\n // explicitly delete anything\n // FIXME: parcoords reuses this object, not the best pattern\n fullLayout._glcontainer = fullLayout._paperdiv.selectAll('.gl-container')\n .data([{}]);\n\n fullLayout._glcontainer.enter().append('div')\n .classed('gl-container', true);\n\n fullLayout._paperdiv.selectAll('.main-svg').remove();\n fullLayout._paperdiv.select('.modebar-container').remove();\n\n fullLayout._paper = fullLayout._paperdiv.insert('svg', ':first-child')\n .classed('main-svg', true);\n\n fullLayout._toppaper = fullLayout._paperdiv.append('svg')\n .classed('main-svg', true);\n\n fullLayout._modebardiv = fullLayout._paperdiv.append('div');\n\n fullLayout._hoverpaper = fullLayout._paperdiv.append('svg')\n .classed('main-svg', true);\n\n if(!fullLayout._uid) {\n var otherUids = {};\n d3.selectAll('defs').each(function() {\n if(this.id) otherUids[this.id.split('-')[1]] = 1;\n });\n fullLayout._uid = Lib.randstr(otherUids);\n }\n\n fullLayout._paperdiv.selectAll('.main-svg')\n .attr(xmlnsNamespaces.svgAttrs);\n\n fullLayout._defs = fullLayout._paper.append('defs')\n .attr('id', 'defs-' + fullLayout._uid);\n\n fullLayout._clips = fullLayout._defs.append('g')\n .classed('clips', true);\n\n fullLayout._topdefs = fullLayout._toppaper.append('defs')\n .attr('id', 'topdefs-' + fullLayout._uid);\n\n fullLayout._topclips = fullLayout._topdefs.append('g')\n .classed('clips', true);\n\n fullLayout._bgLayer = fullLayout._paper.append('g')\n .classed('bglayer', true);\n\n fullLayout._draggers = fullLayout._paper.append('g')\n .classed('draglayer', true);\n\n // lower shape/image layer - note that this is behind\n // all subplots data/grids but above the backgrounds\n // except inset subplots, whose backgrounds are drawn\n // inside their own group so that they appear above\n // the data for the main subplot\n // lower shapes and images which are fully referenced to\n // a subplot still get drawn within the subplot's group\n // so they will work correctly on insets\n var layerBelow = fullLayout._paper.append('g')\n .classed('layer-below', true);\n fullLayout._imageLowerLayer = layerBelow.append('g')\n .classed('imagelayer', true);\n fullLayout._shapeLowerLayer = layerBelow.append('g')\n .classed('shapelayer', true);\n\n // single cartesian layer for the whole plot\n fullLayout._cartesianlayer = fullLayout._paper.append('g').classed('cartesianlayer', true);\n\n // single polar layer for the whole plot\n fullLayout._polarlayer = fullLayout._paper.append('g').classed('polarlayer', true);\n\n // single ternary layer for the whole plot\n fullLayout._ternarylayer = fullLayout._paper.append('g').classed('ternarylayer', true);\n\n // single geo layer for the whole plot\n fullLayout._geolayer = fullLayout._paper.append('g').classed('geolayer', true);\n\n // single funnelarea layer for the whole plot\n fullLayout._funnelarealayer = fullLayout._paper.append('g').classed('funnelarealayer', true);\n\n // single pie layer for the whole plot\n fullLayout._pielayer = fullLayout._paper.append('g').classed('pielayer', true);\n\n // single treemap layer for the whole plot\n fullLayout._treemaplayer = fullLayout._paper.append('g').classed('treemaplayer', true);\n\n // single sunburst layer for the whole plot\n fullLayout._sunburstlayer = fullLayout._paper.append('g').classed('sunburstlayer', true);\n\n // single indicator layer for the whole plot\n fullLayout._indicatorlayer = fullLayout._toppaper.append('g').classed('indicatorlayer', true);\n\n // fill in image server scrape-svg\n fullLayout._glimages = fullLayout._paper.append('g').classed('glimages', true);\n\n // lastly upper shapes, info (legend, annotations) and hover layers go on top\n // these are in a different svg element normally, but get collapsed into a single\n // svg when exporting (after inserting 3D)\n // upper shapes/images are only those drawn above the whole plot, including subplots\n var layerAbove = fullLayout._toppaper.append('g')\n .classed('layer-above', true);\n fullLayout._imageUpperLayer = layerAbove.append('g')\n .classed('imagelayer', true);\n fullLayout._shapeUpperLayer = layerAbove.append('g')\n .classed('shapelayer', true);\n\n fullLayout._infolayer = fullLayout._toppaper.append('g').classed('infolayer', true);\n fullLayout._menulayer = fullLayout._toppaper.append('g').classed('menulayer', true);\n fullLayout._zoomlayer = fullLayout._toppaper.append('g').classed('zoomlayer', true);\n fullLayout._hoverlayer = fullLayout._hoverpaper.append('g').classed('hoverlayer', true);\n\n // Make the modebar container\n fullLayout._modebardiv\n .classed('modebar-container', true)\n .style('position', 'absolute')\n .style('top', '0px')\n .style('right', '0px');\n\n gd.emit('plotly_framework');\n}\n\nexports.animate = animate;\nexports.addFrames = addFrames;\nexports.deleteFrames = deleteFrames;\n\nexports.addTraces = addTraces;\nexports.deleteTraces = deleteTraces;\nexports.extendTraces = extendTraces;\nexports.moveTraces = moveTraces;\nexports.prependTraces = prependTraces;\n\nexports.newPlot = newPlot;\nexports.plot = plot;\nexports.purge = purge;\n\nexports.react = react;\nexports.redraw = redraw;\nexports.relayout = relayout;\nexports.restyle = restyle;\n\nexports.setPlotConfig = setPlotConfig;\n\nexports.update = update;\n\nexports._guiRelayout = guiEdit(relayout);\nexports._guiRestyle = guiEdit(restyle);\nexports._guiUpdate = guiEdit(update);\n\nexports._storeDirectGUIEdit = _storeDirectGUIEdit;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar drawRaw = require('../annotations/draw').drawRaw;\nvar project = require('../../plots/gl3d/project');\nvar axLetters = ['x', 'y', 'z'];\n\nmodule.exports = function draw(scene) {\n var fullSceneLayout = scene.fullSceneLayout;\n var dataScale = scene.dataScale;\n var anns = fullSceneLayout.annotations;\n\n for(var i = 0; i < anns.length; i++) {\n var ann = anns[i];\n var annotationIsOffscreen = false;\n\n for(var j = 0; j < 3; j++) {\n var axLetter = axLetters[j];\n var pos = ann[axLetter];\n var ax = fullSceneLayout[axLetter + 'axis'];\n var posFraction = ax.r2fraction(pos);\n\n if(posFraction < 0 || posFraction > 1) {\n annotationIsOffscreen = true;\n break;\n }\n }\n\n if(annotationIsOffscreen) {\n scene.fullLayout._infolayer\n .select('.annotation-' + scene.id + '[data-index=\"' + i + '\"]')\n .remove();\n } else {\n ann._pdata = project(scene.glplot.cameraParams, [\n fullSceneLayout.xaxis.r2l(ann.x) * dataScale[0],\n fullSceneLayout.yaxis.r2l(ann.y) * dataScale[1],\n fullSceneLayout.zaxis.r2l(ann.z) * dataScale[2]\n ]);\n\n drawRaw(scene.graphDiv, ann, i, scene.id, ann._xa, ann._ya);\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar d3 = require('d3');\nvar tinycolor = require('tinycolor2');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Color = require('../color');\n\nvar isValidScale = require('./scales').isValid;\n\nfunction hasColorscale(trace, containerStr, colorKey) {\n var container = containerStr ?\n Lib.nestedProperty(trace, containerStr).get() || {} :\n trace;\n var color = container[colorKey || 'color'];\n\n var isArrayWithOneNumber = false;\n if(Lib.isArrayOrTypedArray(color)) {\n for(var i = 0; i < color.length; i++) {\n if(isNumeric(color[i])) {\n isArrayWithOneNumber = true;\n break;\n }\n }\n }\n\n return (\n Lib.isPlainObject(container) && (\n isArrayWithOneNumber ||\n container.showscale === true ||\n (isNumeric(container.cmin) && isNumeric(container.cmax)) ||\n isValidScale(container.colorscale) ||\n Lib.isPlainObject(container.colorbar)\n )\n );\n}\n\nvar constantAttrs = ['showscale', 'autocolorscale', 'colorscale', 'reversescale', 'colorbar'];\nvar letterAttrs = ['min', 'max', 'mid', 'auto'];\n\n/**\n * Extract 'c' / 'z', trace / color axis colorscale options\n *\n * Note that it would be nice to replace all z* with c* equivalents in v2\n *\n * @param {object} cont : attribute container\n * @return {object}:\n * - min: cmin or zmin\n * - max: cmax or zmax\n * - mid: cmid or zmid\n * - auto: cauto or zauto\n * - *scale: *scale attrs\n * - colorbar: colorbar\n * - _sync: function syncing attr and underscore dual (useful when calc'ing min/max)\n */\nfunction extractOpts(cont) {\n var colorAx = cont._colorAx;\n var cont2 = colorAx ? colorAx : cont;\n var out = {};\n var cLetter;\n var i, k;\n\n for(i = 0; i < constantAttrs.length; i++) {\n k = constantAttrs[i];\n out[k] = cont2[k];\n }\n\n if(colorAx) {\n cLetter = 'c';\n for(i = 0; i < letterAttrs.length; i++) {\n k = letterAttrs[i];\n out[k] = cont2['c' + k];\n }\n } else {\n var k2;\n for(i = 0; i < letterAttrs.length; i++) {\n k = letterAttrs[i];\n k2 = 'c' + k;\n if(k2 in cont2) {\n out[k] = cont2[k2];\n continue;\n }\n k2 = 'z' + k;\n if(k2 in cont2) {\n out[k] = cont2[k2];\n }\n }\n cLetter = k2.charAt(0);\n }\n\n out._sync = function(k, v) {\n var k2 = letterAttrs.indexOf(k) !== -1 ? cLetter + k : k;\n cont2[k2] = cont2['_' + k2] = v;\n };\n\n return out;\n}\n\n/**\n * Extract colorscale into numeric domain and color range.\n *\n * @param {object} cont colorscale container (e.g. trace, marker)\n * - colorscale {array of arrays}\n * - cmin/zmin {number}\n * - cmax/zmax {number}\n * - reversescale {boolean}\n *\n * @return {object}\n * - domain {array}\n * - range {array}\n */\nfunction extractScale(cont) {\n var cOpts = extractOpts(cont);\n var cmin = cOpts.min;\n var cmax = cOpts.max;\n\n var scl = cOpts.reversescale ?\n flipScale(cOpts.colorscale) :\n cOpts.colorscale;\n\n var N = scl.length;\n var domain = new Array(N);\n var range = new Array(N);\n\n for(var i = 0; i < N; i++) {\n var si = scl[i];\n domain[i] = cmin + si[0] * (cmax - cmin);\n range[i] = si[1];\n }\n\n return {domain: domain, range: range};\n}\n\nfunction flipScale(scl) {\n var N = scl.length;\n var sclNew = new Array(N);\n\n for(var i = N - 1, j = 0; i >= 0; i--, j++) {\n var si = scl[i];\n sclNew[j] = [1 - si[0], si[1]];\n }\n return sclNew;\n}\n\n/**\n * General colorscale function generator.\n *\n * @param {object} specs output of Colorscale.extractScale or precomputed domain, range.\n * - domain {array}\n * - range {array}\n *\n * @param {object} opts\n * - noNumericCheck {boolean} if true, scale func bypasses numeric checks\n * - returnArray {boolean} if true, scale func return 4-item array instead of color strings\n *\n * @return {function}\n */\nfunction makeColorScaleFunc(specs, opts) {\n opts = opts || {};\n\n var domain = specs.domain;\n var range = specs.range;\n var N = range.length;\n var _range = new Array(N);\n\n for(var i = 0; i < N; i++) {\n var rgba = tinycolor(range[i]).toRgb();\n _range[i] = [rgba.r, rgba.g, rgba.b, rgba.a];\n }\n\n var _sclFunc = d3.scale.linear()\n .domain(domain)\n .range(_range)\n .clamp(true);\n\n var noNumericCheck = opts.noNumericCheck;\n var returnArray = opts.returnArray;\n var sclFunc;\n\n if(noNumericCheck && returnArray) {\n sclFunc = _sclFunc;\n } else if(noNumericCheck) {\n sclFunc = function(v) {\n return colorArray2rbga(_sclFunc(v));\n };\n } else if(returnArray) {\n sclFunc = function(v) {\n if(isNumeric(v)) return _sclFunc(v);\n else if(tinycolor(v).isValid()) return v;\n else return Color.defaultLine;\n };\n } else {\n sclFunc = function(v) {\n if(isNumeric(v)) return colorArray2rbga(_sclFunc(v));\n else if(tinycolor(v).isValid()) return v;\n else return Color.defaultLine;\n };\n }\n\n // colorbar draw looks into the d3 scale closure for domain and range\n sclFunc.domain = _sclFunc.domain;\n sclFunc.range = function() { return range; };\n\n return sclFunc;\n}\n\nfunction makeColorScaleFuncFromTrace(trace, opts) {\n return makeColorScaleFunc(extractScale(trace), opts);\n}\n\nfunction colorArray2rbga(colorArray) {\n var colorObj = {\n r: colorArray[0],\n g: colorArray[1],\n b: colorArray[2],\n a: colorArray[3]\n };\n\n return tinycolor(colorObj).toRgbString();\n}\n\nmodule.exports = {\n hasColorscale: hasColorscale,\n extractOpts: extractOpts,\n extractScale: extractScale,\n flipScale: flipScale,\n makeColorScaleFunc: makeColorScaleFunc,\n makeColorScaleFuncFromTrace: makeColorScaleFuncFromTrace\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\n\nvar attributes = require('./attributes');\nvar basePlotLayoutAttributes = require('../../plots/layout_attributes');\nvar helpers = require('./helpers');\n\n\nmodule.exports = function legendDefaults(layoutIn, layoutOut, fullData) {\n var containerIn = layoutIn.legend || {};\n\n var legendTraceCount = 0;\n var legendReallyHasATrace = false;\n var defaultOrder = 'normal';\n\n for(var i = 0; i < fullData.length; i++) {\n var trace = fullData[i];\n\n if(!trace.visible) continue;\n\n // Note that we explicitly count any trace that is either shown or\n // *would* be shown by default, toward the two traces you need to\n // ensure the legend is shown by default, because this can still help\n // disambiguate.\n if(trace.showlegend || (\n trace._dfltShowLegend && !(\n trace._module &&\n trace._module.attributes &&\n trace._module.attributes.showlegend &&\n trace._module.attributes.showlegend.dflt === false\n )\n )) {\n legendTraceCount++;\n if(trace.showlegend) {\n legendReallyHasATrace = true;\n // Always show the legend by default if there's a pie,\n // or if there's only one trace but it's explicitly shown\n if(Registry.traceIs(trace, 'pie-like') ||\n trace._input.showlegend === true\n ) {\n legendTraceCount++;\n }\n }\n }\n\n if((Registry.traceIs(trace, 'bar') && layoutOut.barmode === 'stack') ||\n ['tonextx', 'tonexty'].indexOf(trace.fill) !== -1) {\n defaultOrder = helpers.isGrouped({traceorder: defaultOrder}) ?\n 'grouped+reversed' : 'reversed';\n }\n\n if(trace.legendgroup !== undefined && trace.legendgroup !== '') {\n defaultOrder = helpers.isReversed({traceorder: defaultOrder}) ?\n 'reversed+grouped' : 'grouped';\n }\n }\n\n var showLegend = Lib.coerce(layoutIn, layoutOut,\n basePlotLayoutAttributes, 'showlegend',\n legendReallyHasATrace && legendTraceCount > 1);\n\n if(showLegend === false && !containerIn.uirevision) return;\n\n var containerOut = Template.newContainer(layoutOut, 'legend');\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n coerce('uirevision', layoutOut.uirevision);\n\n if(showLegend === false) return;\n\n coerce('bgcolor', layoutOut.paper_bgcolor);\n coerce('bordercolor');\n coerce('borderwidth');\n Lib.coerceFont(coerce, 'font', layoutOut.font);\n\n var orientation = coerce('orientation');\n var defaultX, defaultY, defaultYAnchor;\n\n if(orientation === 'h') {\n defaultX = 0;\n\n if(Registry.getComponentMethod('rangeslider', 'isVisible')(layoutIn.xaxis)) {\n defaultY = 1.1;\n defaultYAnchor = 'bottom';\n } else {\n // maybe use y=1.1 / yanchor=bottom as above\n // to avoid https://github.com/plotly/plotly.js/issues/1199\n // in v2\n defaultY = -0.1;\n defaultYAnchor = 'top';\n }\n } else {\n defaultX = 1.02;\n defaultY = 1;\n defaultYAnchor = 'auto';\n }\n\n coerce('traceorder', defaultOrder);\n if(helpers.isGrouped(layoutOut.legend)) coerce('tracegroupgap');\n\n coerce('itemsizing');\n\n coerce('itemclick');\n coerce('itemdoubleclick');\n\n coerce('x', defaultX);\n coerce('xanchor');\n coerce('y', defaultY);\n coerce('yanchor', defaultYAnchor);\n coerce('valign');\n Lib.noneOrAll(containerIn, containerOut, ['x', 'y']);\n\n var titleText = coerce('title.text');\n if(titleText) {\n coerce('title.side', orientation === 'h' ? 'left' : 'top');\n Lib.coerceFont(coerce, 'title.font', layoutOut.font);\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'images',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('images'),\n\n draw: require('./draw'),\n\n convertCoords: require('./convert_coords')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n moduleType: 'component',\n name: 'colorbar',\n\n attributes: require('./attributes'),\n supplyDefaults: require('./defaults'),\n\n draw: require('./draw').draw,\n hasColorbar: require('./has_colorbar')\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n\n// used in the drawing step for 'scatter' and 'scattegeo' and\n// in the convert step for 'scatter3d'\nmodule.exports = function makeBubbleSizeFn(trace) {\n var marker = trace.marker;\n var sizeRef = marker.sizeref || 1;\n var sizeMin = marker.sizemin || 0;\n\n // for bubble charts, allow scaling the provided value linearly\n // and by area or diameter.\n // Note this only applies to the array-value sizes\n\n var baseFn = (marker.sizemode === 'area') ?\n function(v) { return Math.sqrt(v / sizeRef); } :\n function(v) { return v / sizeRef; };\n\n // TODO add support for position/negative bubbles?\n // TODO add 'sizeoffset' attribute?\n return function(v) {\n var baseSize = baseFn(v / 2);\n\n // don't show non-numeric and negative sizes\n return (isNumeric(baseSize) && (baseSize > 0)) ?\n Math.max(baseSize, sizeMin) :\n 0;\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar ensureSingle = Lib.ensureSingle;\nvar identity = Lib.identity;\nvar Drawing = require('../../components/drawing');\n\nvar subTypes = require('./subtypes');\nvar linePoints = require('./line_points');\nvar linkTraces = require('./link_traces');\nvar polygonTester = require('../../lib/polygon').tester;\n\nmodule.exports = function plot(gd, plotinfo, cdscatter, scatterLayer, transitionOpts, makeOnCompleteCallback) {\n var join, onComplete;\n\n // If transition config is provided, then it is only a partial replot and traces not\n // updated are removed.\n var isFullReplot = !transitionOpts;\n var hasTransition = !!transitionOpts && transitionOpts.duration > 0;\n\n // Link traces so the z-order of fill layers is correct\n var cdscatterSorted = linkTraces(gd, plotinfo, cdscatter);\n\n join = scatterLayer.selectAll('g.trace')\n .data(cdscatterSorted, function(d) { return d[0].trace.uid; });\n\n // Append new traces:\n join.enter().append('g')\n .attr('class', function(d) {\n return 'trace scatter trace' + d[0].trace.uid;\n })\n .style('stroke-miterlimit', 2);\n join.order();\n\n createFills(gd, join, plotinfo);\n\n if(hasTransition) {\n if(makeOnCompleteCallback) {\n // If it was passed a callback to register completion, make a callback. If\n // this is created, then it must be executed on completion, otherwise the\n // pos-transition redraw will not execute:\n onComplete = makeOnCompleteCallback();\n }\n\n var transition = d3.transition()\n .duration(transitionOpts.duration)\n .ease(transitionOpts.easing)\n .each('end', function() {\n onComplete && onComplete();\n })\n .each('interrupt', function() {\n onComplete && onComplete();\n });\n\n transition.each(function() {\n // Must run the selection again since otherwise enters/updates get grouped together\n // and these get executed out of order. Except we need them in order!\n scatterLayer.selectAll('g.trace').each(function(d, i) {\n plotOne(gd, i, plotinfo, d, cdscatterSorted, this, transitionOpts);\n });\n });\n } else {\n join.each(function(d, i) {\n plotOne(gd, i, plotinfo, d, cdscatterSorted, this, transitionOpts);\n });\n }\n\n if(isFullReplot) {\n join.exit().remove();\n }\n\n // remove paths that didn't get used\n scatterLayer.selectAll('path:not([d])').remove();\n};\n\nfunction createFills(gd, traceJoin, plotinfo) {\n traceJoin.each(function(d) {\n var fills = ensureSingle(d3.select(this), 'g', 'fills');\n Drawing.setClipUrl(fills, plotinfo.layerClipId, gd);\n\n var trace = d[0].trace;\n\n var fillData = [];\n if(trace._ownfill) fillData.push('_ownFill');\n if(trace._nexttrace) fillData.push('_nextFill');\n\n var fillJoin = fills.selectAll('g').data(fillData, identity);\n\n fillJoin.enter().append('g');\n\n fillJoin.exit()\n .each(function(d) { trace[d] = null; })\n .remove();\n\n fillJoin.order().each(function(d) {\n // make a path element inside the fill group, just so\n // we can give it its own data later on and the group can\n // keep its simple '_*Fill' data\n trace[d] = ensureSingle(d3.select(this), 'path', 'js-fill');\n });\n });\n}\n\nfunction plotOne(gd, idx, plotinfo, cdscatter, cdscatterAll, element, transitionOpts) {\n var i;\n\n // Since this has been reorganized and we're executing this on individual traces,\n // we need to pass it the full list of cdscatter as well as this trace's index (idx)\n // since it does an internal n^2 loop over comparisons with other traces:\n selectMarkers(gd, idx, plotinfo, cdscatter, cdscatterAll);\n\n var hasTransition = !!transitionOpts && transitionOpts.duration > 0;\n\n function transition(selection) {\n return hasTransition ? selection.transition() : selection;\n }\n\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n\n var trace = cdscatter[0].trace;\n var line = trace.line;\n var tr = d3.select(element);\n\n var errorBarGroup = ensureSingle(tr, 'g', 'errorbars');\n var lines = ensureSingle(tr, 'g', 'lines');\n var points = ensureSingle(tr, 'g', 'points');\n var text = ensureSingle(tr, 'g', 'text');\n\n // error bars are at the bottom\n Registry.getComponentMethod('errorbars', 'plot')(gd, errorBarGroup, plotinfo, transitionOpts);\n\n if(trace.visible !== true) return;\n\n transition(tr).style('opacity', trace.opacity);\n\n // BUILD LINES AND FILLS\n var ownFillEl3, tonext;\n var ownFillDir = trace.fill.charAt(trace.fill.length - 1);\n if(ownFillDir !== 'x' && ownFillDir !== 'y') ownFillDir = '';\n\n // store node for tweaking by selectPoints\n cdscatter[0][plotinfo.isRangePlot ? 'nodeRangePlot3' : 'node3'] = tr;\n\n var prevRevpath = '';\n var prevPolygons = [];\n var prevtrace = trace._prevtrace;\n\n if(prevtrace) {\n prevRevpath = prevtrace._prevRevpath || '';\n tonext = prevtrace._nextFill;\n prevPolygons = prevtrace._polygons;\n }\n\n var thispath;\n var thisrevpath;\n // fullpath is all paths for this curve, joined together straight\n // across gaps, for filling\n var fullpath = '';\n // revpath is fullpath reversed, for fill-to-next\n var revpath = '';\n // functions for converting a point array to a path\n var pathfn, revpathbase, revpathfn;\n // variables used before and after the data join\n var pt0, lastSegment, pt1, thisPolygons;\n\n // initialize line join data / method\n var segments = [];\n var makeUpdate = Lib.noop;\n\n ownFillEl3 = trace._ownFill;\n\n if(subTypes.hasLines(trace) || trace.fill !== 'none') {\n if(tonext) {\n // This tells .style which trace to use for fill information:\n tonext.datum(cdscatter);\n }\n\n if(['hv', 'vh', 'hvh', 'vhv'].indexOf(line.shape) !== -1) {\n pathfn = Drawing.steps(line.shape);\n revpathbase = Drawing.steps(\n line.shape.split('').reverse().join('')\n );\n } else if(line.shape === 'spline') {\n pathfn = revpathbase = function(pts) {\n var pLast = pts[pts.length - 1];\n if(pts.length > 1 && pts[0][0] === pLast[0] && pts[0][1] === pLast[1]) {\n // identical start and end points: treat it as a\n // closed curve so we don't get a kink\n return Drawing.smoothclosed(pts.slice(1), line.smoothing);\n } else {\n return Drawing.smoothopen(pts, line.smoothing);\n }\n };\n } else {\n pathfn = revpathbase = function(pts) {\n return 'M' + pts.join('L');\n };\n }\n\n revpathfn = function(pts) {\n // note: this is destructive (reverses pts in place) so can't use pts after this\n return revpathbase(pts.reverse());\n };\n\n segments = linePoints(cdscatter, {\n xaxis: xa,\n yaxis: ya,\n connectGaps: trace.connectgaps,\n baseTolerance: Math.max(line.width || 1, 3) / 4,\n shape: line.shape,\n simplify: line.simplify,\n fill: trace.fill\n });\n\n // since we already have the pixel segments here, use them to make\n // polygons for hover on fill\n // TODO: can we skip this if hoveron!=fills? That would mean we\n // need to redraw when you change hoveron...\n thisPolygons = trace._polygons = new Array(segments.length);\n for(i = 0; i < segments.length; i++) {\n trace._polygons[i] = polygonTester(segments[i]);\n }\n\n if(segments.length) {\n pt0 = segments[0][0];\n lastSegment = segments[segments.length - 1];\n pt1 = lastSegment[lastSegment.length - 1];\n }\n\n makeUpdate = function(isEnter) {\n return function(pts) {\n thispath = pathfn(pts);\n thisrevpath = revpathfn(pts);\n if(!fullpath) {\n fullpath = thispath;\n revpath = thisrevpath;\n } else if(ownFillDir) {\n fullpath += 'L' + thispath.substr(1);\n revpath = thisrevpath + ('L' + revpath.substr(1));\n } else {\n fullpath += 'Z' + thispath;\n revpath = thisrevpath + 'Z' + revpath;\n }\n\n if(subTypes.hasLines(trace) && pts.length > 1) {\n var el = d3.select(this);\n\n // This makes the coloring work correctly:\n el.datum(cdscatter);\n\n if(isEnter) {\n transition(el.style('opacity', 0)\n .attr('d', thispath)\n .call(Drawing.lineGroupStyle))\n .style('opacity', 1);\n } else {\n var sel = transition(el);\n sel.attr('d', thispath);\n Drawing.singleLineStyle(cdscatter, sel);\n }\n }\n };\n };\n }\n\n var lineJoin = lines.selectAll('.js-line').data(segments);\n\n transition(lineJoin.exit())\n .style('opacity', 0)\n .remove();\n\n lineJoin.each(makeUpdate(false));\n\n lineJoin.enter().append('path')\n .classed('js-line', true)\n .style('vector-effect', 'non-scaling-stroke')\n .call(Drawing.lineGroupStyle)\n .each(makeUpdate(true));\n\n Drawing.setClipUrl(lineJoin, plotinfo.layerClipId, gd);\n\n function clearFill(selection) {\n transition(selection).attr('d', 'M0,0Z');\n }\n\n if(segments.length) {\n if(ownFillEl3) {\n ownFillEl3.datum(cdscatter);\n if(pt0 && pt1) {\n if(ownFillDir) {\n if(ownFillDir === 'y') {\n pt0[1] = pt1[1] = ya.c2p(0, true);\n } else if(ownFillDir === 'x') {\n pt0[0] = pt1[0] = xa.c2p(0, true);\n }\n\n // fill to zero: full trace path, plus extension of\n // the endpoints to the appropriate axis\n // For the sake of animations, wrap the points around so that\n // the points on the axes are the first two points. Otherwise\n // animations get a little crazy if the number of points changes.\n transition(ownFillEl3).attr('d', 'M' + pt1 + 'L' + pt0 + 'L' + fullpath.substr(1))\n .call(Drawing.singleFillStyle);\n } else {\n // fill to self: just join the path to itself\n transition(ownFillEl3).attr('d', fullpath + 'Z')\n .call(Drawing.singleFillStyle);\n }\n }\n } else if(tonext) {\n if(trace.fill.substr(0, 6) === 'tonext' && fullpath && prevRevpath) {\n // fill to next: full trace path, plus the previous path reversed\n if(trace.fill === 'tonext') {\n // tonext: for use by concentric shapes, like manually constructed\n // contours, we just add the two paths closed on themselves.\n // This makes strange results if one path is *not* entirely\n // inside the other, but then that is a strange usage.\n transition(tonext).attr('d', fullpath + 'Z' + prevRevpath + 'Z')\n .call(Drawing.singleFillStyle);\n } else {\n // tonextx/y: for now just connect endpoints with lines. This is\n // the correct behavior if the endpoints are at the same value of\n // y/x, but if they *aren't*, we should ideally do more complicated\n // things depending on whether the new endpoint projects onto the\n // existing curve or off the end of it\n transition(tonext).attr('d', fullpath + 'L' + prevRevpath.substr(1) + 'Z')\n .call(Drawing.singleFillStyle);\n }\n trace._polygons = trace._polygons.concat(prevPolygons);\n } else {\n clearFill(tonext);\n trace._polygons = null;\n }\n }\n trace._prevRevpath = revpath;\n trace._prevPolygons = thisPolygons;\n } else {\n if(ownFillEl3) clearFill(ownFillEl3);\n else if(tonext) clearFill(tonext);\n trace._polygons = trace._prevRevpath = trace._prevPolygons = null;\n }\n\n\n function visFilter(d) {\n return d.filter(function(v) { return !v.gap && v.vis; });\n }\n\n function visFilterWithGaps(d) {\n return d.filter(function(v) { return v.vis; });\n }\n\n function gapFilter(d) {\n return d.filter(function(v) { return !v.gap; });\n }\n\n function keyFunc(d) {\n return d.id;\n }\n\n // Returns a function if the trace is keyed, otherwise returns undefined\n function getKeyFunc(trace) {\n if(trace.ids) {\n return keyFunc;\n }\n }\n\n function hideFilter() {\n return false;\n }\n\n function makePoints(points, text, cdscatter) {\n var join, selection, hasNode;\n\n var trace = cdscatter[0].trace;\n var showMarkers = subTypes.hasMarkers(trace);\n var showText = subTypes.hasText(trace);\n\n var keyFunc = getKeyFunc(trace);\n var markerFilter = hideFilter;\n var textFilter = hideFilter;\n\n if(showMarkers || showText) {\n var showFilter = identity;\n // if we're stacking, \"infer zero\" gap mode gets markers in the\n // gap points - because we've inferred a zero there - but other\n // modes (currently \"interpolate\", later \"interrupt\" hopefully)\n // we don't draw generated markers\n var stackGroup = trace.stackgroup;\n var isInferZero = stackGroup && (\n gd._fullLayout._scatterStackOpts[xa._id + ya._id][stackGroup].stackgaps === 'infer zero');\n if(trace.marker.maxdisplayed || trace._needsCull) {\n showFilter = isInferZero ? visFilterWithGaps : visFilter;\n } else if(stackGroup && !isInferZero) {\n showFilter = gapFilter;\n }\n\n if(showMarkers) markerFilter = showFilter;\n if(showText) textFilter = showFilter;\n }\n\n // marker points\n\n selection = points.selectAll('path.point');\n\n join = selection.data(markerFilter, keyFunc);\n\n var enter = join.enter().append('path')\n .classed('point', true);\n\n if(hasTransition) {\n enter\n .call(Drawing.pointStyle, trace, gd)\n .call(Drawing.translatePoints, xa, ya)\n .style('opacity', 0)\n .transition()\n .style('opacity', 1);\n }\n\n join.order();\n\n var styleFns;\n if(showMarkers) {\n styleFns = Drawing.makePointStyleFns(trace);\n }\n\n join.each(function(d) {\n var el = d3.select(this);\n var sel = transition(el);\n hasNode = Drawing.translatePoint(d, sel, xa, ya);\n\n if(hasNode) {\n Drawing.singlePointStyle(d, sel, trace, styleFns, gd);\n\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(d, sel, xa, ya, trace.xcalendar, trace.ycalendar);\n }\n\n if(trace.customdata) {\n el.classed('plotly-customdata', d.data !== null && d.data !== undefined);\n }\n } else {\n sel.remove();\n }\n });\n\n if(hasTransition) {\n join.exit().transition()\n .style('opacity', 0)\n .remove();\n } else {\n join.exit().remove();\n }\n\n // text points\n selection = text.selectAll('g');\n join = selection.data(textFilter, keyFunc);\n\n // each text needs to go in its own 'g' in case\n // it gets converted to mathjax\n join.enter().append('g').classed('textpoint', true).append('text');\n\n join.order();\n\n join.each(function(d) {\n var g = d3.select(this);\n var sel = transition(g.select('text'));\n hasNode = Drawing.translatePoint(d, sel, xa, ya);\n\n if(hasNode) {\n if(plotinfo.layerClipId) {\n Drawing.hideOutsideRangePoint(d, g, xa, ya, trace.xcalendar, trace.ycalendar);\n }\n } else {\n g.remove();\n }\n });\n\n join.selectAll('text')\n .call(Drawing.textPointStyle, trace, gd)\n .each(function(d) {\n // This just *has* to be totally custom becuase of SVG text positioning :(\n // It's obviously copied from translatePoint; we just can't use that\n var x = xa.c2p(d.x);\n var y = ya.c2p(d.y);\n\n d3.select(this).selectAll('tspan.line').each(function() {\n transition(d3.select(this)).attr({x: x, y: y});\n });\n });\n\n join.exit().remove();\n }\n\n points.datum(cdscatter);\n text.datum(cdscatter);\n makePoints(points, text, cdscatter);\n\n // lastly, clip points groups of `cliponaxis !== false` traces\n // on `plotinfo._hasClipOnAxisFalse === true` subplots\n var hasClipOnAxisFalse = trace.cliponaxis === false;\n var clipUrl = hasClipOnAxisFalse ? null : plotinfo.layerClipId;\n Drawing.setClipUrl(points, clipUrl, gd);\n Drawing.setClipUrl(text, clipUrl, gd);\n}\n\nfunction selectMarkers(gd, idx, plotinfo, cdscatter, cdscatterAll) {\n var xa = plotinfo.xaxis;\n var ya = plotinfo.yaxis;\n var xr = d3.extent(Lib.simpleMap(xa.range, xa.r2c));\n var yr = d3.extent(Lib.simpleMap(ya.range, ya.r2c));\n\n var trace = cdscatter[0].trace;\n if(!subTypes.hasMarkers(trace)) return;\n // if marker.maxdisplayed is used, select a maximum of\n // mnum markers to show, from the set that are in the viewport\n var mnum = trace.marker.maxdisplayed;\n\n // TODO: remove some as we get away from the viewport?\n if(mnum === 0) return;\n\n var cd = cdscatter.filter(function(v) {\n return v.x >= xr[0] && v.x <= xr[1] && v.y >= yr[0] && v.y <= yr[1];\n });\n var inc = Math.ceil(cd.length / mnum);\n var tnum = 0;\n cdscatterAll.forEach(function(cdj, j) {\n var tracei = cdj[0].trace;\n if(subTypes.hasMarkers(tracei) &&\n tracei.marker.maxdisplayed > 0 && j < idx) {\n tnum++;\n }\n });\n\n // if multiple traces use maxdisplayed, stagger which markers we\n // display this formula offsets successive traces by 1/3 of the\n // increment, adding an extra small amount after each triplet so\n // it's not quite periodic\n var i0 = Math.round(tnum * inc / 3 + Math.floor(tnum / 3) * inc / 7.1);\n\n // for error bars: save in cd which markers to show\n // so we don't have to repeat this\n cdscatter.forEach(function(v) { delete v.vis; });\n cd.forEach(function(v, i) {\n if(Math.round((i + i0) % inc) === 0) v.vis = true;\n });\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\nvar Lib = require('../../lib');\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\nmodule.exports = function clean2dArray(zOld, trace, xa, ya) {\n var rowlen, collen, getCollen, old2new, i, j;\n\n function cleanZvalue(v) {\n if(!isNumeric(v)) return undefined;\n return +v;\n }\n\n if(trace && trace.transpose) {\n rowlen = 0;\n for(i = 0; i < zOld.length; i++) rowlen = Math.max(rowlen, zOld[i].length);\n if(rowlen === 0) return false;\n getCollen = function(zOld) { return zOld.length; };\n old2new = function(zOld, i, j) { return (zOld[j] || [])[i]; };\n } else {\n rowlen = zOld.length;\n getCollen = function(zOld, i) { return zOld[i].length; };\n old2new = function(zOld, i, j) { return (zOld[i] || [])[j]; };\n }\n\n var padOld2new = function(zOld, i, j) {\n if(i === BADNUM || j === BADNUM) return BADNUM;\n return old2new(zOld, i, j);\n };\n\n function axisMapping(ax) {\n if(trace && trace.type !== 'carpet' && trace.type !== 'contourcarpet' &&\n ax && ax.type === 'category' && trace['_' + ax._id.charAt(0)].length) {\n var axLetter = ax._id.charAt(0);\n var axMapping = {};\n var traceCategories = trace['_' + axLetter + 'CategoryMap'] || trace[axLetter];\n for(i = 0; i < traceCategories.length; i++) {\n axMapping[traceCategories[i]] = i;\n }\n return function(i) {\n var ind = axMapping[ax._categories[i]];\n return ind + 1 ? ind : BADNUM;\n };\n } else {\n return Lib.identity;\n }\n }\n\n var xMap = axisMapping(xa);\n var yMap = axisMapping(ya);\n\n if(ya && ya.type === 'category') rowlen = ya._categories.length;\n var zNew = new Array(rowlen);\n\n for(i = 0; i < rowlen; i++) {\n if(xa && xa.type === 'category') {\n collen = xa._categories.length;\n } else {\n collen = getCollen(zOld, i);\n }\n zNew[i] = new Array(collen);\n for(j = 0; j < collen; j++) zNew[i][j] = cleanZvalue(padOld2new(zOld, yMap(i), xMap(j)));\n }\n\n return zNew;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar axisIDs = require('../../plots/cartesian/axis_ids');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar constants = require('./constants');\nvar LINE_SPACING = require('../../constants/alignment').LINE_SPACING;\nvar name = constants.name;\n\nfunction isVisible(ax) {\n var rangeSlider = ax && ax[name];\n return rangeSlider && rangeSlider.visible;\n}\nexports.isVisible = isVisible;\n\nexports.makeData = function(fullLayout) {\n var axes = axisIDs.list({ _fullLayout: fullLayout }, 'x', true);\n var margin = fullLayout.margin;\n var rangeSliderData = [];\n\n if(!fullLayout._has('gl2d')) {\n for(var i = 0; i < axes.length; i++) {\n var ax = axes[i];\n\n if(isVisible(ax)) {\n rangeSliderData.push(ax);\n\n var opts = ax[name];\n opts._id = name + ax._id;\n opts._height = (fullLayout.height - margin.b - margin.t) * opts.thickness;\n opts._offsetShift = Math.floor(opts.borderwidth / 2);\n }\n }\n }\n\n fullLayout._rangeSliderData = rangeSliderData;\n};\n\nexports.autoMarginOpts = function(gd, ax) {\n var fullLayout = gd._fullLayout;\n var opts = ax[name];\n var axLetter = ax._id.charAt(0);\n\n var bottomDepth = 0;\n var titleHeight = 0;\n if(ax.side === 'bottom') {\n bottomDepth = ax._depth;\n if(ax.title.text !== fullLayout._dfltTitle[axLetter]) {\n // as in rangeslider/draw.js\n titleHeight = 1.5 * ax.title.font.size + 10 + opts._offsetShift;\n // multi-line extra bump\n var extraLines = (ax.title.text.match(svgTextUtils.BR_TAG_ALL) || []).length;\n titleHeight += extraLines * ax.title.font.size * LINE_SPACING;\n }\n }\n\n return {\n x: 0,\n y: ax._counterDomainMin,\n l: 0,\n r: 0,\n t: 0,\n b: opts._height + bottomDepth + Math.max(fullLayout.margin.b, titleHeight),\n pad: constants.extraPad + opts._offsetShift * 2\n };\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar drawModule = require('./draw');\n\nmodule.exports = {\n moduleType: 'component',\n name: 'shapes',\n\n layoutAttributes: require('./attributes'),\n supplyLayoutDefaults: require('./defaults'),\n includeBasePlot: require('../../plots/cartesian/include_components')('shapes'),\n\n calcAutorange: require('./calc_autorange'),\n draw: drawModule.draw,\n drawOne: drawModule.drawOne\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n moduleType: 'locale',\n name: 'en',\n dictionary: {\n 'Click to enter Colorscale title': 'Click to enter Colourscale title'\n },\n format: {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n shortDays: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n months: [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December'\n ],\n shortMonths: [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ],\n periods: ['AM', 'PM'],\n dateTime: '%a %b %e %X %Y',\n date: '%d/%m/%Y',\n time: '%H:%M:%S',\n decimal: '.',\n thousands: ',',\n grouping: [3],\n currency: ['$', ''],\n year: '%Y',\n month: '%b %Y',\n dayMonth: '%b %-d',\n dayMonthYear: '%b %-d, %Y'\n }\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = plotComponentFactory;\n\nvar _react = _interopRequireWildcard(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _getRequireWildcardCache() { if (typeof WeakMap !== \"function\") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; if (obj != null) { var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj[\"default\"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n// The naming convention is:\n// - events are attached as `'plotly_' + eventName.toLowerCase()`\n// - react props are `'on' + eventName`\nvar eventNames = ['AfterExport', 'AfterPlot', 'Animated', 'AnimatingFrame', 'AnimationInterrupted', 'AutoSize', 'BeforeExport', 'ButtonClicked', 'Click', 'ClickAnnotation', 'Deselect', 'DoubleClick', 'Framework', 'Hover', 'LegendClick', 'LegendDoubleClick', 'Relayout', 'Restyle', 'Redraw', 'Selected', 'Selecting', 'SliderChange', 'SliderEnd', 'SliderStart', 'Transitioning', 'TransitionInterrupted', 'Unhover'];\nvar updateEvents = ['plotly_restyle', 'plotly_redraw', 'plotly_relayout', 'plotly_doubleclick', 'plotly_animated']; // Check if a window is available since SSR (server-side rendering)\n// breaks unnecessarily if you try to use it server-side.\n\nvar isBrowser = typeof window !== 'undefined';\n\nfunction plotComponentFactory(Plotly) {\n var PlotlyComponent =\n /*#__PURE__*/\n function (_Component) {\n _inherits(PlotlyComponent, _Component);\n\n function PlotlyComponent(props) {\n var _this;\n\n _classCallCheck(this, PlotlyComponent);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(PlotlyComponent).call(this, props));\n _this.p = Promise.resolve();\n _this.resizeHandler = null;\n _this.handlers = {};\n _this.syncWindowResize = _this.syncWindowResize.bind(_assertThisInitialized(_this));\n _this.syncEventHandlers = _this.syncEventHandlers.bind(_assertThisInitialized(_this));\n _this.attachUpdateEvents = _this.attachUpdateEvents.bind(_assertThisInitialized(_this));\n _this.getRef = _this.getRef.bind(_assertThisInitialized(_this));\n _this.handleUpdate = _this.handleUpdate.bind(_assertThisInitialized(_this));\n _this.figureCallback = _this.figureCallback.bind(_assertThisInitialized(_this));\n _this.updatePlotly = _this.updatePlotly.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n _createClass(PlotlyComponent, [{\n key: \"updatePlotly\",\n value: function updatePlotly(shouldInvokeResizeHandler, figureCallbackFunction, shouldAttachUpdateEvents) {\n var _this2 = this;\n\n this.p = this.p.then(function () {\n if (!_this2.el) {\n var error;\n\n if (_this2.unmounting) {\n error = new Error('Component is unmounting');\n error.reason = 'unmounting';\n } else {\n error = new Error('Missing element reference');\n }\n\n throw error;\n }\n\n return Plotly.react(_this2.el, {\n data: _this2.props.data,\n layout: _this2.props.layout,\n config: _this2.props.config,\n frames: _this2.props.frames\n });\n }).then(function () {\n return _this2.syncWindowResize(shouldInvokeResizeHandler);\n }).then(this.syncEventHandlers).then(function () {\n return _this2.figureCallback(figureCallbackFunction);\n }).then(shouldAttachUpdateEvents ? this.attachUpdateEvents : function () {})[\"catch\"](function (err) {\n if (err.reason === 'unmounting') {\n return;\n }\n\n console.error('Error while plotting:', err); // eslint-disable-line no-console\n\n if (_this2.props.onError) {\n _this2.props.onError(err);\n }\n });\n }\n }, {\n key: \"componentDidMount\",\n value: function componentDidMount() {\n this.unmounting = false;\n this.updatePlotly(true, this.props.onInitialized, true);\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(prevProps) {\n this.unmounting = false; // frames *always* changes identity so fall back to check length only :(\n\n var numPrevFrames = prevProps.frames && prevProps.frames.length ? prevProps.frames.length : 0;\n var numNextFrames = this.props.frames && this.props.frames.length ? this.props.frames.length : 0;\n var figureChanged = !(prevProps.layout === this.props.layout && prevProps.data === this.props.data && prevProps.config === this.props.config && numNextFrames === numPrevFrames);\n var revisionDefined = prevProps.revision !== void 0;\n var revisionChanged = prevProps.revision !== this.props.revision;\n\n if (!figureChanged && (!revisionDefined || revisionDefined && !revisionChanged)) {\n return;\n }\n\n this.updatePlotly(false, this.props.onUpdate, false);\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n this.unmounting = true;\n this.figureCallback(this.props.onPurge);\n\n if (this.resizeHandler && isBrowser) {\n window.removeEventListener('resize', this.resizeHandler);\n this.resizeHandler = null;\n }\n\n this.removeUpdateEvents();\n Plotly.purge(this.el);\n }\n }, {\n key: \"attachUpdateEvents\",\n value: function attachUpdateEvents() {\n var _this3 = this;\n\n if (!this.el || !this.el.removeListener) {\n return;\n }\n\n updateEvents.forEach(function (updateEvent) {\n _this3.el.on(updateEvent, _this3.handleUpdate);\n });\n }\n }, {\n key: \"removeUpdateEvents\",\n value: function removeUpdateEvents() {\n var _this4 = this;\n\n if (!this.el || !this.el.removeListener) {\n return;\n }\n\n updateEvents.forEach(function (updateEvent) {\n _this4.el.removeListener(updateEvent, _this4.handleUpdate);\n });\n }\n }, {\n key: \"handleUpdate\",\n value: function handleUpdate() {\n this.figureCallback(this.props.onUpdate);\n }\n }, {\n key: \"figureCallback\",\n value: function figureCallback(callback) {\n if (typeof callback === 'function') {\n var _this$el = this.el,\n data = _this$el.data,\n layout = _this$el.layout;\n var frames = this.el._transitionData ? this.el._transitionData._frames : null;\n var figure = {\n data: data,\n layout: layout,\n frames: frames\n };\n callback(figure, this.el);\n }\n }\n }, {\n key: \"syncWindowResize\",\n value: function syncWindowResize(invoke) {\n var _this5 = this;\n\n if (!isBrowser) {\n return;\n }\n\n if (this.props.useResizeHandler && !this.resizeHandler) {\n this.resizeHandler = function () {\n return Plotly.Plots.resize(_this5.el);\n };\n\n window.addEventListener('resize', this.resizeHandler);\n\n if (invoke) {\n this.resizeHandler();\n }\n } else if (!this.props.useResizeHandler && this.resizeHandler) {\n window.removeEventListener('resize', this.resizeHandler);\n this.resizeHandler = null;\n }\n }\n }, {\n key: \"getRef\",\n value: function getRef(el) {\n this.el = el;\n\n if (this.props.debug && isBrowser) {\n window.gd = this.el;\n }\n } // Attach and remove event handlers as they're added or removed from props:\n\n }, {\n key: \"syncEventHandlers\",\n value: function syncEventHandlers() {\n var _this6 = this;\n\n eventNames.forEach(function (eventName) {\n var prop = _this6.props['on' + eventName];\n var handler = _this6.handlers[eventName];\n var hasHandler = Boolean(handler);\n\n if (prop && !hasHandler) {\n _this6.addEventHandler(eventName, prop);\n } else if (!prop && hasHandler) {\n // Needs to be removed:\n _this6.removeEventHandler(eventName);\n } else if (prop && hasHandler && prop !== handler) {\n // replace the handler\n _this6.removeEventHandler(eventName);\n\n _this6.addEventHandler(eventName, prop);\n }\n });\n }\n }, {\n key: \"addEventHandler\",\n value: function addEventHandler(eventName, prop) {\n this.handlers[eventName] = prop;\n this.el.on(this.getPlotlyEventName(eventName), this.handlers[eventName]);\n }\n }, {\n key: \"removeEventHandler\",\n value: function removeEventHandler(eventName) {\n this.el.removeListener(this.getPlotlyEventName(eventName), this.handlers[eventName]);\n delete this.handlers[eventName];\n }\n }, {\n key: \"getPlotlyEventName\",\n value: function getPlotlyEventName(eventName) {\n return 'plotly_' + eventName.toLowerCase();\n }\n }, {\n key: \"render\",\n value: function render() {\n return _react[\"default\"].createElement(\"div\", {\n id: this.props.divId,\n style: this.props.style,\n ref: this.getRef,\n className: this.props.className\n });\n }\n }]);\n\n return PlotlyComponent;\n }(_react.Component);\n\n PlotlyComponent.propTypes = {\n data: _propTypes[\"default\"].arrayOf(_propTypes[\"default\"].object),\n config: _propTypes[\"default\"].object,\n layout: _propTypes[\"default\"].object,\n frames: _propTypes[\"default\"].arrayOf(_propTypes[\"default\"].object),\n revision: _propTypes[\"default\"].number,\n onInitialized: _propTypes[\"default\"].func,\n onPurge: _propTypes[\"default\"].func,\n onError: _propTypes[\"default\"].func,\n onUpdate: _propTypes[\"default\"].func,\n debug: _propTypes[\"default\"].bool,\n style: _propTypes[\"default\"].object,\n className: _propTypes[\"default\"].string,\n useResizeHandler: _propTypes[\"default\"].bool,\n divId: _propTypes[\"default\"].string\n };\n eventNames.forEach(function (eventName) {\n PlotlyComponent.propTypes['on' + eventName] = _propTypes[\"default\"].func;\n });\n PlotlyComponent.defaultProps = {\n debug: false,\n useResizeHandler: false,\n data: [],\n style: {\n position: 'relative',\n display: 'inline-block'\n }\n };\n return PlotlyComponent;\n}\n//# sourceMappingURL=factory.js.map","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar Lib = require('../../lib');\nvar Template = require('../../plot_api/plot_template');\nvar axisIds = require('../../plots/cartesian/axis_ids');\n\nvar attributes = require('./attributes');\nvar oppAxisAttrs = require('./oppaxis_attributes');\n\nmodule.exports = function handleDefaults(layoutIn, layoutOut, axName) {\n var axIn = layoutIn[axName];\n var axOut = layoutOut[axName];\n\n if(!(axIn.rangeslider || layoutOut._requestRangeslider[axOut._id])) return;\n\n // not super proud of this (maybe store _ in axis object instead\n if(!Lib.isPlainObject(axIn.rangeslider)) {\n axIn.rangeslider = {};\n }\n\n var containerIn = axIn.rangeslider;\n var containerOut = Template.newContainer(axOut, 'rangeslider');\n\n function coerce(attr, dflt) {\n return Lib.coerce(containerIn, containerOut, attributes, attr, dflt);\n }\n\n var rangeContainerIn, rangeContainerOut;\n function coerceRange(attr, dflt) {\n return Lib.coerce(rangeContainerIn, rangeContainerOut, oppAxisAttrs, attr, dflt);\n }\n\n var visible = coerce('visible');\n if(!visible) return;\n\n coerce('bgcolor', layoutOut.plot_bgcolor);\n coerce('bordercolor');\n coerce('borderwidth');\n coerce('thickness');\n\n coerce('autorange', !axOut.isValidRange(containerIn.range));\n coerce('range');\n\n var subplots = layoutOut._subplots;\n if(subplots) {\n var yIds = subplots.cartesian\n .filter(function(subplotId) {\n return subplotId.substr(0, subplotId.indexOf('y')) === axisIds.name2id(axName);\n })\n .map(function(subplotId) {\n return subplotId.substr(subplotId.indexOf('y'), subplotId.length);\n });\n var yNames = Lib.simpleMap(yIds, axisIds.id2name);\n for(var i = 0; i < yNames.length; i++) {\n var yName = yNames[i];\n\n rangeContainerIn = containerIn[yName] || {};\n rangeContainerOut = Template.newContainer(containerOut, yName, 'yaxis');\n\n var yAxOut = layoutOut[yName];\n\n var rangemodeDflt;\n if(rangeContainerIn.range && yAxOut.isValidRange(rangeContainerIn.range)) {\n rangemodeDflt = 'fixed';\n }\n\n var rangeMode = coerceRange('rangemode', rangemodeDflt);\n if(rangeMode !== 'match') {\n coerceRange('range', yAxOut.range.slice());\n }\n }\n }\n\n // to map back range slider (auto) range\n containerOut._input = containerIn;\n};\n","// (c) Copyright 2016, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// simple linked list implementation that allows you to traverse down nodes and save positions\n//\n\nvar LinkedList = {\n\tcreate: function(){\n\t\tvar my = {\n\t\t\troot: { root: true, next: null },\n\t\t\texists: function(node){\n\t\t\t\tif (node === null || node === my.root)\n\t\t\t\t\treturn false;\n\t\t\t\treturn true;\n\t\t\t},\n\t\t\tisEmpty: function(){\n\t\t\t\treturn my.root.next === null;\n\t\t\t},\n\t\t\tgetHead: function(){\n\t\t\t\treturn my.root.next;\n\t\t\t},\n\t\t\tinsertBefore: function(node, check){\n\t\t\t\tvar last = my.root;\n\t\t\t\tvar here = my.root.next;\n\t\t\t\twhile (here !== null){\n\t\t\t\t\tif (check(here)){\n\t\t\t\t\t\tnode.prev = here.prev;\n\t\t\t\t\t\tnode.next = here;\n\t\t\t\t\t\there.prev.next = node;\n\t\t\t\t\t\there.prev = node;\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t\tlast = here;\n\t\t\t\t\there = here.next;\n\t\t\t\t}\n\t\t\t\tlast.next = node;\n\t\t\t\tnode.prev = last;\n\t\t\t\tnode.next = null;\n\t\t\t},\n\t\t\tfindTransition: function(check){\n\t\t\t\tvar prev = my.root;\n\t\t\t\tvar here = my.root.next;\n\t\t\t\twhile (here !== null){\n\t\t\t\t\tif (check(here))\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tprev = here;\n\t\t\t\t\there = here.next;\n\t\t\t\t}\n\t\t\t\treturn {\n\t\t\t\t\tbefore: prev === my.root ? null : prev,\n\t\t\t\t\tafter: here,\n\t\t\t\t\tinsert: function(node){\n\t\t\t\t\t\tnode.prev = prev;\n\t\t\t\t\t\tnode.next = here;\n\t\t\t\t\t\tprev.next = node;\n\t\t\t\t\t\tif (here !== null)\n\t\t\t\t\t\t\there.prev = node;\n\t\t\t\t\t\treturn node;\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t};\n\t\treturn my;\n\t},\n\tnode: function(data){\n\t\tdata.prev = null;\n\t\tdata.next = null;\n\t\tdata.remove = function(){\n\t\t\tdata.prev.next = data.next;\n\t\t\tif (data.next)\n\t\t\t\tdata.next.prev = data.prev;\n\t\t\tdata.prev = null;\n\t\t\tdata.next = null;\n\t\t};\n\t\treturn data;\n\t}\n};\n\nmodule.exports = LinkedList;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n visible: {\n valType: 'boolean',\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not this set of error bars is visible.'\n ].join(' ')\n },\n type: {\n valType: 'enumerated',\n values: ['percent', 'constant', 'sqrt', 'data'],\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines the rule used to generate the error bars.',\n\n 'If *constant`, the bar lengths are of a constant value.',\n 'Set this constant in `value`.',\n\n 'If *percent*, the bar lengths correspond to a percentage of',\n 'underlying data. Set this percentage in `value`.',\n\n 'If *sqrt*, the bar lengths correspond to the sqaure of the',\n 'underlying data.',\n\n 'If *data*, the bar lengths are set with data set `array`.'\n ].join(' ')\n },\n symmetric: {\n valType: 'boolean',\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not the error bars have the same length',\n 'in both direction',\n '(top/bottom for vertical bars, left/right for horizontal bars.'\n ].join(' ')\n },\n array: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the data corresponding the length of each error bar.',\n 'Values are plotted relative to the underlying data.'\n ].join(' ')\n },\n arrayminus: {\n valType: 'data_array',\n editType: 'calc',\n description: [\n 'Sets the data corresponding the length of each error bar in the',\n 'bottom (left) direction for vertical (horizontal) bars',\n 'Values are plotted relative to the underlying data.'\n ].join(' ')\n },\n value: {\n valType: 'number',\n min: 0,\n dflt: 10,\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the value of either the percentage',\n '(if `type` is set to *percent*) or the constant',\n '(if `type` is set to *constant*) corresponding to the lengths of',\n 'the error bars.'\n ].join(' ')\n },\n valueminus: {\n valType: 'number',\n min: 0,\n dflt: 10,\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the value of either the percentage',\n '(if `type` is set to *percent*) or the constant',\n '(if `type` is set to *constant*) corresponding to the lengths of',\n 'the error bars in the',\n 'bottom (left) direction for vertical (horizontal) bars'\n ].join(' ')\n },\n traceref: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n role: 'info',\n editType: 'style'\n },\n tracerefminus: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n role: 'info',\n editType: 'style'\n },\n copy_ystyle: {\n valType: 'boolean',\n role: 'style',\n editType: 'plot'\n },\n copy_zstyle: {\n valType: 'boolean',\n role: 'style',\n editType: 'style'\n },\n color: {\n valType: 'color',\n role: 'style',\n editType: 'style',\n description: 'Sets the stoke color of the error bars.'\n },\n thickness: {\n valType: 'number',\n min: 0,\n dflt: 2,\n role: 'style',\n editType: 'style',\n description: 'Sets the thickness (in px) of the error bars.'\n },\n width: {\n valType: 'number',\n min: 0,\n role: 'style',\n editType: 'plot',\n description: [\n 'Sets the width (in px) of the cross-bar at both ends',\n 'of the error bars.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n opacity: {\n valType: 'number',\n role: 'style',\n editType: 'style',\n description: [\n 'Obsolete.',\n 'Use the alpha channel in error bar `color` to set the opacity.'\n ].join(' ')\n }\n }\n};\n","'use strict'\r\n\r\nvar isBrowser = require('is-browser')\r\n\r\nfunction detect() {\r\n\tvar supported = false\r\n\r\n\ttry {\r\n\t\tvar opts = Object.defineProperty({}, 'passive', {\r\n\t\t\tget: function() {\r\n\t\t\t\tsupported = true\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\twindow.addEventListener('test', null, opts)\r\n\t\twindow.removeEventListener('test', null, opts)\r\n\t} catch(e) {\r\n\t\tsupported = false\r\n\t}\r\n\r\n\treturn supported\r\n}\r\n\r\nmodule.exports = isBrowser && detect()\r\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\n\n// remove opacity for any trace that has a fill or is filled to\nmodule.exports = function crossTraceDefaults(fullData) {\n for(var i = 0; i < fullData.length; i++) {\n var tracei = fullData[i];\n if(tracei.type !== 'scatter') continue;\n\n var filli = tracei.fill;\n if(filli === 'none' || filli === 'toself') continue;\n\n tracei.opacity = undefined;\n\n if(filli === 'tonexty' || filli === 'tonextx') {\n for(var j = i - 1; j >= 0; j--) {\n var tracej = fullData[j];\n\n if((tracej.type === 'scatter') &&\n (tracej.xaxis === tracei.xaxis) &&\n (tracej.yaxis === tracei.yaxis)) {\n tracej.opacity = undefined;\n break;\n }\n }\n }\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = require('../src/traces/heatmap');\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar constants = require('./constants');\n\nvar fontAttrs = require('../../plots/font_attributes')({\n editType: 'none',\n description: 'Sets the default hover label font used by all traces on the graph.'\n});\nfontAttrs.family.dflt = constants.HOVERFONT;\nfontAttrs.size.dflt = constants.HOVERFONTSIZE;\n\nmodule.exports = {\n clickmode: {\n valType: 'flaglist',\n role: 'info',\n flags: ['event', 'select'],\n dflt: 'event',\n editType: 'plot',\n extras: ['none'],\n description: [\n 'Determines the mode of single click interactions.',\n '*event* is the default value and emits the `plotly_click`',\n 'event. In addition this mode emits the `plotly_selected` event',\n 'in drag modes *lasso* and *select*, but with no event data attached',\n '(kept for compatibility reasons).',\n 'The *select* flag enables selecting single',\n 'data points via click. This mode also supports persistent selections,',\n 'meaning that pressing Shift while clicking, adds to / subtracts from an',\n 'existing selection. *select* with `hovermode`: *x* can be confusing, consider',\n 'explicitly setting `hovermode`: *closest* when using this feature.',\n 'Selection events are sent accordingly as long as *event* flag is set as well.',\n 'When the *event* flag is missing, `plotly_click` and `plotly_selected`',\n 'events are not fired.'\n ].join(' ')\n },\n dragmode: {\n valType: 'enumerated',\n role: 'info',\n values: ['zoom', 'pan', 'select', 'lasso', 'orbit', 'turntable', false],\n dflt: 'zoom',\n editType: 'modebar',\n description: [\n 'Determines the mode of drag interactions.',\n '*select* and *lasso* apply only to scatter traces with',\n 'markers or text. *orbit* and *turntable* apply only to',\n '3D scenes.'\n ].join(' ')\n },\n hovermode: {\n valType: 'enumerated',\n role: 'info',\n values: ['x', 'y', 'closest', false, 'x unified', 'y unified'],\n editType: 'modebar',\n description: [\n 'Determines the mode of hover interactions.',\n 'If *closest*, a single hoverlabel will appear',\n 'for the *closest* point within the `hoverdistance`.',\n 'If *x* (or *y*), multiple hoverlabels will appear for multiple points',\n 'at the *closest* x- (or y-) coordinate within the `hoverdistance`,',\n 'with the caveat that no more than one hoverlabel will appear per trace.',\n 'If *x unified* (or *y unified*), a single hoverlabel will appear',\n 'multiple points at the closest x- (or y-) coordinate within the `hoverdistance`',\n 'with the caveat that no more than one hoverlabel will appear per trace.',\n 'In this mode, spikelines are enabled by default perpendicular to the specified axis.',\n 'If false, hover interactions are disabled.',\n 'If `clickmode` includes the *select* flag,',\n '`hovermode` defaults to *closest*.',\n 'If `clickmode` lacks the *select* flag,',\n 'it defaults to *x* or *y* (depending on the trace\\'s',\n '`orientation` value) for plots based on',\n 'cartesian coordinates. For anything else the default',\n 'value is *closest*.',\n ].join(' ')\n },\n hoverdistance: {\n valType: 'integer',\n min: -1,\n dflt: 20,\n role: 'info',\n editType: 'none',\n description: [\n 'Sets the default distance (in pixels) to look for data',\n 'to add hover labels (-1 means no cutoff, 0 means no looking for data).',\n 'This is only a real distance for hovering on point-like objects,',\n 'like scatter points. For area-like objects (bars, scatter fills, etc)',\n 'hovering is on inside the area and off outside, but these objects',\n 'will not supersede hover on point-like objects in case of conflict.'\n ].join(' ')\n },\n spikedistance: {\n valType: 'integer',\n min: -1,\n dflt: 20,\n role: 'info',\n editType: 'none',\n description: [\n 'Sets the default distance (in pixels) to look for data to draw',\n 'spikelines to (-1 means no cutoff, 0 means no looking for data).',\n 'As with hoverdistance, distance does not apply to area-like objects.',\n 'In addition, some objects can be hovered on but will not generate',\n 'spikelines, such as scatter fills.'\n ].join(' ')\n },\n hoverlabel: {\n bgcolor: {\n valType: 'color',\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the background color of all hover labels on graph'\n ].join(' ')\n },\n bordercolor: {\n valType: 'color',\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the border color of all hover labels on graph.'\n ].join(' ')\n },\n font: fontAttrs,\n align: {\n valType: 'enumerated',\n values: ['left', 'right', 'auto'],\n dflt: 'auto',\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the horizontal alignment of the text content within hover label box.',\n 'Has an effect only if the hover label text spans more two or more lines'\n ].join(' ')\n },\n namelength: {\n valType: 'integer',\n min: -1,\n dflt: 15,\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the default length (in number of characters) of the trace name in',\n 'the hover labels for all traces. -1 shows the whole name',\n 'regardless of length. 0-3 shows the first 0-3 characters, and',\n 'an integer >3 will show the whole name if it is less than that',\n 'many characters, but if it is longer, will truncate to',\n '`namelength - 3` characters and add an ellipsis.'\n ].join(' ')\n },\n editType: 'none'\n },\n selectdirection: {\n valType: 'enumerated',\n role: 'info',\n values: ['h', 'v', 'd', 'any'],\n dflt: 'any',\n description: [\n 'When \"dragmode\" is set to \"select\", this limits the selection of the drag to',\n 'horizontal, vertical or diagonal. \"h\" only allows horizontal selection,',\n '\"v\" only vertical, \"d\" only diagonal and \"any\" sets no limit.'\n ].join(' '),\n editType: 'none'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar scatterAttrs = require('../../../traces/scatter/attributes');\nvar scatterMarkerAttrs = scatterAttrs.marker;\nvar extendFlat = require('../../../lib/extend').extendFlat;\n\nvar deprecationWarning = [\n 'Area traces are deprecated!',\n 'Please switch to the *barpolar* trace type.'\n].join(' ');\n\nmodule.exports = {\n r: extendFlat({}, scatterAttrs.r, {\n description: [\n deprecationWarning,\n 'Sets the radial coordinates',\n 'for legacy polar chart only.'\n ].join(' ')\n }),\n t: extendFlat({}, scatterAttrs.t, {\n description: [\n deprecationWarning,\n 'Sets the angular coordinates',\n 'for legacy polar chart only.'\n ].join(' ')\n }),\n marker: {\n color: extendFlat({}, scatterMarkerAttrs.color, {\n description: [\n deprecationWarning,\n scatterMarkerAttrs.color.description\n ].join(' ')\n }),\n size: extendFlat({}, scatterMarkerAttrs.size, {\n description: [\n deprecationWarning,\n scatterMarkerAttrs.size.description\n ].join(' ')\n }),\n symbol: extendFlat({}, scatterMarkerAttrs.symbol, {\n description: [\n deprecationWarning,\n scatterMarkerAttrs.symbol.description\n ].join(' ')\n }),\n opacity: extendFlat({}, scatterMarkerAttrs.opacity, {\n description: [\n deprecationWarning,\n scatterMarkerAttrs.opacity.description\n ].join(' ')\n }),\n editType: 'calc'\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar LINKEDFILLS = {tonextx: 1, tonexty: 1, tonext: 1};\n\nmodule.exports = function linkTraces(gd, plotinfo, cdscatter) {\n var trace, i, group, prevtrace, groupIndex;\n\n // first sort traces to keep stacks & filled-together groups together\n var groupIndices = {};\n var needsSort = false;\n var prevGroupIndex = -1;\n var nextGroupIndex = 0;\n var prevUnstackedGroupIndex = -1;\n for(i = 0; i < cdscatter.length; i++) {\n trace = cdscatter[i][0].trace;\n group = trace.stackgroup || '';\n if(group) {\n if(group in groupIndices) {\n groupIndex = groupIndices[group];\n } else {\n groupIndex = groupIndices[group] = nextGroupIndex;\n nextGroupIndex++;\n }\n } else if(trace.fill in LINKEDFILLS && prevUnstackedGroupIndex >= 0) {\n groupIndex = prevUnstackedGroupIndex;\n } else {\n groupIndex = prevUnstackedGroupIndex = nextGroupIndex;\n nextGroupIndex++;\n }\n\n if(groupIndex < prevGroupIndex) needsSort = true;\n trace._groupIndex = prevGroupIndex = groupIndex;\n }\n\n var cdscatterSorted = cdscatter.slice();\n if(needsSort) {\n cdscatterSorted.sort(function(a, b) {\n var traceA = a[0].trace;\n var traceB = b[0].trace;\n return (traceA._groupIndex - traceB._groupIndex) ||\n (traceA.index - traceB.index);\n });\n }\n\n // now link traces to each other\n var prevtraces = {};\n for(i = 0; i < cdscatterSorted.length; i++) {\n trace = cdscatterSorted[i][0].trace;\n group = trace.stackgroup || '';\n\n // Note: The check which ensures all cdscatter here are for the same axis and\n // are either cartesian or scatterternary has been removed. This code assumes\n // the passed scattertraces have been filtered to the proper plot types and\n // the proper subplots.\n if(trace.visible === true) {\n trace._nexttrace = null;\n\n if(trace.fill in LINKEDFILLS) {\n prevtrace = prevtraces[group];\n trace._prevtrace = prevtrace || null;\n\n if(prevtrace) {\n prevtrace._nexttrace = trace;\n }\n }\n\n trace._ownfill = (trace.fill && (\n trace.fill.substr(0, 6) === 'tozero' ||\n trace.fill === 'toself' ||\n (trace.fill.substr(0, 2) === 'to' && !trace._prevtrace)\n ));\n\n prevtraces[group] = trace;\n } else {\n trace._prevtrace = trace._nexttrace = trace._ownfill = null;\n }\n }\n\n return cdscatterSorted;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\n\nvar handleArrayContainerDefaults = require('../array_container_defaults');\n\nvar layoutAttributes = require('./layout_attributes');\nvar handleTickValueDefaults = require('./tick_value_defaults');\nvar handleTickMarkDefaults = require('./tick_mark_defaults');\nvar handleTickLabelDefaults = require('./tick_label_defaults');\nvar handleCategoryOrderDefaults = require('./category_order_defaults');\nvar handleLineGridDefaults = require('./line_grid_defaults');\nvar setConvert = require('./set_convert');\n\nvar DAY_OF_WEEK = require('./constants').WEEKDAY_PATTERN;\nvar HOUR = require('./constants').HOUR_PATTERN;\n\n/**\n * options: object containing:\n *\n * letter: 'x' or 'y'\n * title: name of the axis (ie 'Colorbar') to go in default title\n * font: the default font to inherit\n * outerTicks: boolean, should ticks default to outside?\n * showGrid: boolean, should gridlines be shown by default?\n * noHover: boolean, this axis doesn't support hover effects?\n * noTickson: boolean, this axis doesn't support 'tickson'\n * data: the plot data, used to manage categories\n * bgColor: the plot background color, to calculate default gridline colors\n * calendar:\n * splomStash:\n * visibleDflt: boolean\n * reverseDflt: boolean\n * automargin: boolean\n */\nmodule.exports = function handleAxisDefaults(containerIn, containerOut, coerce, options, layoutOut) {\n var letter = options.letter;\n var font = options.font || {};\n var splomStash = options.splomStash || {};\n\n var visible = coerce('visible', !options.visibleDflt);\n\n var axTemplate = containerOut._template || {};\n var axType = containerOut.type || axTemplate.type || '-';\n\n if(axType === 'date') {\n var handleCalendarDefaults = Registry.getComponentMethod('calendars', 'handleDefaults');\n handleCalendarDefaults(containerIn, containerOut, 'calendar', options.calendar);\n }\n\n setConvert(containerOut, layoutOut);\n\n var autorangeDflt = !containerOut.isValidRange(containerIn.range);\n if(autorangeDflt && options.reverseDflt) autorangeDflt = 'reversed';\n var autoRange = coerce('autorange', autorangeDflt);\n if(autoRange && (axType === 'linear' || axType === '-')) coerce('rangemode');\n\n coerce('range');\n containerOut.cleanRange();\n\n handleCategoryOrderDefaults(containerIn, containerOut, coerce, options);\n\n if(axType !== 'category' && !options.noHover) coerce('hoverformat');\n\n var dfltColor = coerce('color');\n // if axis.color was provided, use it for fonts too; otherwise,\n // inherit from global font color in case that was provided.\n // Compare to dflt rather than to containerIn, so we can provide color via\n // template too.\n var dfltFontColor = (dfltColor !== layoutAttributes.color.dflt) ? dfltColor : font.color;\n // try to get default title from splom trace, fallback to graph-wide value\n var dfltTitle = splomStash.label || layoutOut._dfltTitle[letter];\n\n handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options, {pass: 1});\n if(!visible) return containerOut;\n\n coerce('title.text', dfltTitle);\n Lib.coerceFont(coerce, 'title.font', {\n family: font.family,\n size: Math.round(font.size * 1.2),\n color: dfltFontColor\n });\n\n handleTickValueDefaults(containerIn, containerOut, coerce, axType);\n handleTickLabelDefaults(containerIn, containerOut, coerce, axType, options, {pass: 2});\n handleTickMarkDefaults(containerIn, containerOut, coerce, options);\n handleLineGridDefaults(containerIn, containerOut, coerce, {\n dfltColor: dfltColor,\n bgColor: options.bgColor,\n showGrid: options.showGrid,\n attributes: layoutAttributes\n });\n\n if(containerOut.showline || containerOut.ticks) coerce('mirror');\n\n if(options.automargin) coerce('automargin');\n\n var isMultiCategory = axType === 'multicategory';\n\n if(!options.noTickson &&\n (axType === 'category' || isMultiCategory) &&\n (containerOut.ticks || containerOut.showgrid)\n ) {\n var ticksonDflt;\n if(isMultiCategory) ticksonDflt = 'boundaries';\n coerce('tickson', ticksonDflt);\n }\n\n if(isMultiCategory) {\n var showDividers = coerce('showdividers');\n if(showDividers) {\n coerce('dividercolor');\n coerce('dividerwidth');\n }\n }\n\n if(axType === 'date') {\n handleArrayContainerDefaults(containerIn, containerOut, {\n name: 'rangebreaks',\n inclusionAttr: 'enabled',\n handleItemDefaults: rangebreaksDefaults\n });\n\n if(!containerOut.rangebreaks.length) {\n delete containerOut.rangebreaks;\n } else {\n for(var k = 0; k < containerOut.rangebreaks.length; k++) {\n if(containerOut.rangebreaks[k].pattern === DAY_OF_WEEK) {\n containerOut._hasDayOfWeekBreaks = true;\n break;\n }\n }\n\n setConvert(containerOut, layoutOut);\n\n if(layoutOut._has('scattergl') || layoutOut._has('splom')) {\n for(var i = 0; i < options.data.length; i++) {\n var trace = options.data[i];\n if(trace.type === 'scattergl' || trace.type === 'splom') {\n trace.visible = false;\n Lib.warn(trace.type +\n ' traces do not work on axes with rangebreaks.' +\n ' Setting trace ' + trace.index + ' to `visible: false`.');\n }\n }\n }\n }\n }\n\n return containerOut;\n};\n\nfunction rangebreaksDefaults(itemIn, itemOut, containerOut) {\n function coerce(attr, dflt) {\n return Lib.coerce(itemIn, itemOut, layoutAttributes.rangebreaks, attr, dflt);\n }\n\n var enabled = coerce('enabled');\n\n if(enabled) {\n var bnds = coerce('bounds');\n if(bnds && bnds.length >= 2) {\n var dfltPattern = '';\n var i, q;\n if(bnds.length === 2) {\n for(i = 0; i < 2; i++) {\n q = indexOfDay(bnds[i]);\n if(q) {\n dfltPattern = DAY_OF_WEEK;\n break;\n }\n }\n }\n var pattern = coerce('pattern', dfltPattern);\n if(pattern === DAY_OF_WEEK) {\n for(i = 0; i < 2; i++) {\n q = indexOfDay(bnds[i]);\n if(q) {\n // convert to integers i.e 'Sunday' --> 0\n itemOut.bounds[i] = bnds[i] = q - 1;\n }\n }\n }\n if(pattern) {\n // ensure types and ranges\n for(i = 0; i < 2; i++) {\n q = bnds[i];\n switch(pattern) {\n case DAY_OF_WEEK :\n if(!isNumeric(q)) {\n itemOut.enabled = false;\n return;\n }\n q = +q;\n\n if(\n q !== Math.floor(q) || // don't accept fractional days for mow\n q < 0 || q >= 7\n ) {\n itemOut.enabled = false;\n return;\n }\n // use number\n itemOut.bounds[i] = bnds[i] = q;\n break;\n\n case HOUR :\n if(!isNumeric(q)) {\n itemOut.enabled = false;\n return;\n }\n q = +q;\n\n if(q < 0 || q > 24) { // accept 24\n itemOut.enabled = false;\n return;\n }\n // use number\n itemOut.bounds[i] = bnds[i] = q;\n break;\n }\n }\n }\n\n if(containerOut.autorange === false) {\n var rng = containerOut.range;\n\n // if bounds are bigger than the (set) range, disable break\n if(rng[0] < rng[1]) {\n if(bnds[0] < rng[0] && bnds[1] > rng[1]) {\n itemOut.enabled = false;\n return;\n }\n } else if(bnds[0] > rng[0] && bnds[1] < rng[1]) {\n itemOut.enabled = false;\n return;\n }\n }\n } else {\n var values = coerce('values');\n\n if(values && values.length) {\n coerce('dvalue');\n } else {\n itemOut.enabled = false;\n return;\n }\n }\n }\n}\n\n// these numbers are one more than what bounds would be mapped to\nvar dayStrToNum = {\n sun: 1,\n mon: 2,\n tue: 3,\n wed: 4,\n thu: 5,\n fri: 6,\n sat: 7\n};\n\nfunction indexOfDay(v) {\n if(typeof v !== 'string') return;\n return dayStrToNum[\n v.substr(0, 3).toLowerCase()\n ];\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = {\n min: 'zmin',\n max: 'zmax'\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\nvar plotApi = require('./plot_api');\nvar plots = require('../plots/plots');\nvar Lib = require('../lib');\n\nvar helpers = require('../snapshot/helpers');\nvar toSVG = require('../snapshot/tosvg');\nvar svgToImg = require('../snapshot/svgtoimg');\nvar version = require('../version').version;\n\nvar attrs = {\n format: {\n valType: 'enumerated',\n values: ['png', 'jpeg', 'webp', 'svg', 'full-json'],\n dflt: 'png',\n description: 'Sets the format of exported image.'\n },\n width: {\n valType: 'number',\n min: 1,\n description: [\n 'Sets the exported image width.',\n 'Defaults to the value found in `layout.width`',\n 'If set to *null*, the exported image width will match the current graph width.'\n ].join(' ')\n },\n height: {\n valType: 'number',\n min: 1,\n description: [\n 'Sets the exported image height.',\n 'Defaults to the value found in `layout.height`',\n 'If set to *null*, the exported image height will match the current graph height.'\n ].join(' ')\n },\n scale: {\n valType: 'number',\n min: 0,\n dflt: 1,\n description: [\n 'Sets a scaling for the generated image.',\n 'If set, all features of a graphs (e.g. text, line width)',\n 'are scaled, unlike simply setting',\n 'a bigger *width* and *height*.'\n ].join(' ')\n },\n setBackground: {\n valType: 'any',\n dflt: false,\n description: [\n 'Sets the image background mode.',\n 'By default, the image background is determined by `layout.paper_bgcolor`,',\n 'the *transparent* mode.',\n 'One might consider setting `setBackground` to *opaque*',\n 'when exporting a *jpeg* image as JPEGs do not support opacity.'\n ].join(' ')\n },\n imageDataOnly: {\n valType: 'boolean',\n dflt: false,\n description: [\n 'Determines whether or not the return value is prefixed by',\n 'the image format\\'s corresponding \\'data:image;\\' spec.'\n ].join(' ')\n }\n};\n\n/** Plotly.toImage\n *\n * @param {object | string | HTML div} gd\n * can either be a data/layout/config object\n * or an existing graph
\n * or an id to an existing graph
\n * @param {object} opts (see above)\n * @return {promise}\n */\nfunction toImage(gd, opts) {\n opts = opts || {};\n\n var data;\n var layout;\n var config;\n var fullLayout;\n\n if(Lib.isPlainObject(gd)) {\n data = gd.data || [];\n layout = gd.layout || {};\n config = gd.config || {};\n fullLayout = {};\n } else {\n gd = Lib.getGraphDiv(gd);\n data = Lib.extendDeep([], gd.data);\n layout = Lib.extendDeep({}, gd.layout);\n config = gd._context;\n fullLayout = gd._fullLayout || {};\n }\n\n function isImpliedOrValid(attr) {\n return !(attr in opts) || Lib.validate(opts[attr], attrs[attr]);\n }\n\n if((!isImpliedOrValid('width') && opts.width !== null) ||\n (!isImpliedOrValid('height') && opts.height !== null)) {\n throw new Error('Height and width should be pixel values.');\n }\n\n if(!isImpliedOrValid('format')) {\n throw new Error('Image format is not jpeg, png, svg or webp.');\n }\n\n var fullOpts = {};\n\n function coerce(attr, dflt) {\n return Lib.coerce(opts, fullOpts, attrs, attr, dflt);\n }\n\n var format = coerce('format');\n var width = coerce('width');\n var height = coerce('height');\n var scale = coerce('scale');\n var setBackground = coerce('setBackground');\n var imageDataOnly = coerce('imageDataOnly');\n\n // put the cloned div somewhere off screen before attaching to DOM\n var clonedGd = document.createElement('div');\n clonedGd.style.position = 'absolute';\n clonedGd.style.left = '-5000px';\n document.body.appendChild(clonedGd);\n\n // extend layout with image options\n var layoutImage = Lib.extendFlat({}, layout);\n if(width) {\n layoutImage.width = width;\n } else if(opts.width === null && isNumeric(fullLayout.width)) {\n layoutImage.width = fullLayout.width;\n }\n if(height) {\n layoutImage.height = height;\n } else if(opts.height === null && isNumeric(fullLayout.height)) {\n layoutImage.height = fullLayout.height;\n }\n\n // extend config for static plot\n var configImage = Lib.extendFlat({}, config, {\n _exportedPlot: true,\n staticPlot: true,\n setBackground: setBackground\n });\n\n var redrawFunc = helpers.getRedrawFunc(clonedGd);\n\n function wait() {\n return new Promise(function(resolve) {\n setTimeout(resolve, helpers.getDelay(clonedGd._fullLayout));\n });\n }\n\n function convert() {\n return new Promise(function(resolve, reject) {\n var svg = toSVG(clonedGd, format, scale);\n var width = clonedGd._fullLayout.width;\n var height = clonedGd._fullLayout.height;\n\n function cleanup() {\n plotApi.purge(clonedGd);\n document.body.removeChild(clonedGd);\n }\n\n if(format === 'full-json') {\n var json = plots.graphJson(clonedGd, false, 'keepdata', 'object', true, true);\n json.version = version;\n json = JSON.stringify(json);\n cleanup();\n if(imageDataOnly) {\n return resolve(json);\n } else {\n return resolve(helpers.encodeJSON(json));\n }\n }\n\n cleanup();\n\n if(format === 'svg') {\n if(imageDataOnly) {\n return resolve(svg);\n } else {\n return resolve(helpers.encodeSVG(svg));\n }\n }\n\n var canvas = document.createElement('canvas');\n canvas.id = Lib.randstr();\n\n svgToImg({\n format: format,\n width: width,\n height: height,\n scale: scale,\n canvas: canvas,\n svg: svg,\n // ask svgToImg to return a Promise\n // rather than EventEmitter\n // leave EventEmitter for backward\n // compatibility\n promise: true\n })\n .then(resolve)\n .catch(reject);\n });\n }\n\n function urlToImageData(url) {\n if(imageDataOnly) {\n return url.replace(helpers.IMAGE_URL_PREFIX, '');\n } else {\n return url;\n }\n }\n\n return new Promise(function(resolve, reject) {\n plotApi.plot(clonedGd, data, layoutImage, configImage)\n .then(redrawFunc)\n .then(wait)\n .then(convert)\n .then(function(url) { resolve(urlToImageData(url)); })\n .catch(function(err) { reject(err); });\n });\n}\n\nmodule.exports = toImage;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n/**\n * convert a linear value into a logged value, folding negative numbers into\n * the given range\n */\nmodule.exports = function toLogRange(val, range) {\n if(val > 0) return Math.log(val) / Math.LN10;\n\n // move a negative value reference to a log axis - just put the\n // result at the lowest range value on the plot (or if the range also went negative,\n // one millionth of the top of the range)\n var newVal = Math.log(Math.min(range[0], range[1])) / Math.LN10;\n if(!isNumeric(newVal)) newVal = Math.log(Math.max(range[0], range[1])) / Math.LN10 - 6;\n return newVal;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar annAttrs = require('../annotations/attributes');\nvar scatterLineAttrs = require('../../traces/scatter/attributes').line;\nvar dash = require('../drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nmodule.exports = templatedArray('shape', {\n visible: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'calc+arraydraw',\n description: [\n 'Determines whether or not this shape is visible.'\n ].join(' ')\n },\n\n type: {\n valType: 'enumerated',\n values: ['circle', 'rect', 'path', 'line'],\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Specifies the shape type to be drawn.',\n\n 'If *line*, a line is drawn from (`x0`,`y0`) to (`x1`,`y1`)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *circle*, a circle is drawn from',\n '((`x0`+`x1`)/2, (`y0`+`y1`)/2))',\n 'with radius',\n '(|(`x0`+`x1`)/2 - `x0`|, |(`y0`+`y1`)/2 -`y0`)|)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *rect*, a rectangle is drawn linking',\n '(`x0`,`y0`), (`x1`,`y0`), (`x1`,`y1`), (`x0`,`y1`), (`x0`,`y0`)',\n 'with respect to the axes\\' sizing mode.',\n\n 'If *path*, draw a custom SVG path using `path`.',\n 'with respect to the axes\\' sizing mode.'\n ].join(' ')\n },\n\n layer: {\n valType: 'enumerated',\n values: ['below', 'above'],\n dflt: 'above',\n role: 'info',\n editType: 'arraydraw',\n description: 'Specifies whether shapes are drawn below or above traces.'\n },\n\n xref: extendFlat({}, annAttrs.xref, {\n description: [\n 'Sets the shape\\'s x coordinate axis.',\n 'If set to an x axis id (e.g. *x* or *x2*), the `x` position',\n 'refers to an x coordinate.',\n 'If set to *paper*, the `x` position refers to the distance from',\n 'the left side of the plotting area in normalized coordinates',\n 'where *0* (*1*) corresponds to the left (right) side.',\n 'If the axis `type` is *log*, then you must take the',\n 'log of your desired range.',\n 'If the axis `type` is *date*, then you must convert',\n 'the date to unix time in milliseconds.'\n ].join(' ')\n }),\n xsizemode: {\n valType: 'enumerated',\n values: ['scaled', 'pixel'],\n dflt: 'scaled',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shapes\\'s sizing mode along the x axis.',\n 'If set to *scaled*, `x0`, `x1` and x coordinates within `path` refer to',\n 'data values on the x axis or a fraction of the plot area\\'s width',\n '(`xref` set to *paper*).',\n 'If set to *pixel*, `xanchor` specifies the x position in terms',\n 'of data or plot fraction but `x0`, `x1` and x coordinates within `path`',\n 'are pixels relative to `xanchor`. This way, the shape can have',\n 'a fixed width while maintaining a position relative to data or',\n 'plot fraction.'\n ].join(' ')\n },\n xanchor: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Only relevant in conjunction with `xsizemode` set to *pixel*.',\n 'Specifies the anchor point on the x axis to which `x0`, `x1`',\n 'and x coordinates within `path` are relative to.',\n 'E.g. useful to attach a pixel sized shape to a certain data value.',\n 'No effect when `xsizemode` not set to *pixel*.'\n ].join(' ')\n },\n x0: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s starting x position.',\n 'See `type` and `xsizemode` for more info.'\n ].join(' ')\n },\n x1: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s end x position.',\n 'See `type` and `xsizemode` for more info.'\n ].join(' ')\n },\n\n yref: extendFlat({}, annAttrs.yref, {\n description: [\n 'Sets the annotation\\'s y coordinate axis.',\n 'If set to an y axis id (e.g. *y* or *y2*), the `y` position',\n 'refers to an y coordinate',\n 'If set to *paper*, the `y` position refers to the distance from',\n 'the bottom of the plotting area in normalized coordinates',\n 'where *0* (*1*) corresponds to the bottom (top).'\n ].join(' ')\n }),\n ysizemode: {\n valType: 'enumerated',\n values: ['scaled', 'pixel'],\n dflt: 'scaled',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shapes\\'s sizing mode along the y axis.',\n 'If set to *scaled*, `y0`, `y1` and y coordinates within `path` refer to',\n 'data values on the y axis or a fraction of the plot area\\'s height',\n '(`yref` set to *paper*).',\n 'If set to *pixel*, `yanchor` specifies the y position in terms',\n 'of data or plot fraction but `y0`, `y1` and y coordinates within `path`',\n 'are pixels relative to `yanchor`. This way, the shape can have',\n 'a fixed height while maintaining a position relative to data or',\n 'plot fraction.'\n ].join(' ')\n },\n yanchor: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Only relevant in conjunction with `ysizemode` set to *pixel*.',\n 'Specifies the anchor point on the y axis to which `y0`, `y1`',\n 'and y coordinates within `path` are relative to.',\n 'E.g. useful to attach a pixel sized shape to a certain data value.',\n 'No effect when `ysizemode` not set to *pixel*.'\n ].join(' ')\n },\n y0: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s starting y position.',\n 'See `type` and `ysizemode` for more info.'\n ].join(' ')\n },\n y1: {\n valType: 'any',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'Sets the shape\\'s end y position.',\n 'See `type` and `ysizemode` for more info.'\n ].join(' ')\n },\n\n path: {\n valType: 'string',\n role: 'info',\n editType: 'calc+arraydraw',\n description: [\n 'For `type` *path* - a valid SVG path with the pixel values',\n 'replaced by data values in `xsizemode`/`ysizemode` being *scaled*',\n 'and taken unmodified as pixels relative to `xanchor` and `yanchor`',\n 'in case of *pixel* size mode.',\n 'There are a few restrictions / quirks',\n 'only absolute instructions, not relative. So the allowed segments',\n 'are: M, L, H, V, Q, C, T, S, and Z',\n 'arcs (A) are not allowed because radius rx and ry are relative.',\n\n 'In the future we could consider supporting relative commands,',\n 'but we would have to decide on how to handle date and log axes.',\n 'Note that even as is, Q and C Bezier paths that are smooth on',\n 'linear axes may not be smooth on log, and vice versa.',\n 'no chained \"polybezier\" commands - specify the segment type for',\n 'each one.',\n\n 'On category axes, values are numbers scaled to the serial numbers',\n 'of categories because using the categories themselves there would',\n 'be no way to describe fractional positions',\n 'On data axes: because space and T are both normal components of path',\n 'strings, we can\\'t use either to separate date from time parts.',\n 'Therefore we\\'ll use underscore for this purpose:',\n '2015-02-21_13:45:56.789'\n ].join(' ')\n },\n\n opacity: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 1,\n role: 'info',\n editType: 'arraydraw',\n description: 'Sets the opacity of the shape.'\n },\n line: {\n color: extendFlat({}, scatterLineAttrs.color, {editType: 'arraydraw'}),\n width: extendFlat({}, scatterLineAttrs.width, {editType: 'calc+arraydraw'}),\n dash: extendFlat({}, dash, {editType: 'arraydraw'}),\n role: 'info',\n editType: 'calc+arraydraw'\n },\n fillcolor: {\n valType: 'color',\n dflt: 'rgba(0,0,0,0)',\n role: 'info',\n editType: 'arraydraw',\n description: [\n 'Sets the color filling the shape\\'s interior.'\n ].join(' ')\n },\n editType: 'arraydraw'\n});\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isPlainObject = require('./is_plain_object.js');\nvar isArray = Array.isArray;\n\nfunction primitivesLoopSplice(source, target) {\n var i, value;\n for(i = 0; i < source.length; i++) {\n value = source[i];\n if(value !== null && typeof(value) === 'object') {\n return false;\n }\n if(value !== void(0)) {\n target[i] = value;\n }\n }\n return true;\n}\n\nexports.extendFlat = function() {\n return _extend(arguments, false, false, false);\n};\n\nexports.extendDeep = function() {\n return _extend(arguments, true, false, false);\n};\n\nexports.extendDeepAll = function() {\n return _extend(arguments, true, true, false);\n};\n\nexports.extendDeepNoArrays = function() {\n return _extend(arguments, true, false, true);\n};\n\n/*\n * Inspired by https://github.com/justmoon/node-extend/blob/master/index.js\n * All credit to the jQuery authors for perfecting this amazing utility.\n *\n * API difference with jQuery version:\n * - No optional boolean (true -> deep extend) first argument,\n * use `extendFlat` for first-level only extend and\n * use `extendDeep` for a deep extend.\n *\n * Other differences with jQuery version:\n * - Uses a modern (and faster) isPlainObject routine.\n * - Expected to work with object {} and array [] arguments only.\n * - Does not check for circular structure.\n * FYI: jQuery only does a check across one level.\n * Warning: this might result in infinite loops.\n *\n */\nfunction _extend(inputs, isDeep, keepAllKeys, noArrayCopies) {\n var target = inputs[0];\n var length = inputs.length;\n\n var input, key, src, copy, copyIsArray, clone, allPrimitives;\n\n // TODO does this do the right thing for typed arrays?\n\n if(length === 2 && isArray(target) && isArray(inputs[1]) && target.length === 0) {\n allPrimitives = primitivesLoopSplice(inputs[1], target);\n\n if(allPrimitives) {\n return target;\n } else {\n target.splice(0, target.length); // reset target and continue to next block\n }\n }\n\n for(var i = 1; i < length; i++) {\n input = inputs[i];\n\n for(key in input) {\n src = target[key];\n copy = input[key];\n\n if(noArrayCopies && isArray(copy)) {\n // Stop early and just transfer the array if array copies are disallowed:\n\n target[key] = copy;\n } else if(isDeep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n // recurse if we're merging plain objects or arrays\n\n if(copyIsArray) {\n copyIsArray = false;\n clone = src && isArray(src) ? src : [];\n } else {\n clone = src && isPlainObject(src) ? src : {};\n }\n\n // never move original objects, clone them\n target[key] = _extend([clone, copy], isDeep, keepAllKeys, noArrayCopies);\n } else if(typeof copy !== 'undefined' || keepAllKeys) {\n // don't bring in undefined values, except for extendDeepAll\n\n target[key] = copy;\n }\n }\n }\n\n return target;\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Plots = require('../../plots/plots');\nvar Registry = require('../../registry');\nvar Lib = require('../../lib');\nvar Drawing = require('../drawing');\nvar Color = require('../color');\nvar svgTextUtils = require('../../lib/svg_text_utils');\nvar interactConstants = require('../../constants/interactions');\n\nvar OPPOSITE_SIDE = require('../../constants/alignment').OPPOSITE_SIDE;\nvar numStripRE = / [XY][0-9]* /;\n\n/**\n * Titles - (re)draw titles on the axes and plot:\n * @param {DOM element} gd - the graphDiv\n * @param {string} titleClass - the css class of this title\n * @param {object} options - how and what to draw\n * propContainer - the layout object containing `title` and `titlefont`\n * attributes that apply to this title\n * propName - the full name of the title property (for Plotly.relayout)\n * [traceIndex] - include only if this property applies to one trace\n * (such as a colorbar title) - then editing pipes to Plotly.restyle\n * instead of Plotly.relayout\n * placeholder - placeholder text for an empty editable title\n * [avoid] {object} - include if this title should move to avoid other elements\n * selection - d3 selection of elements to avoid\n * side - which direction to move if there is a conflict\n * [offsetLeft] - if these elements are subject to a translation\n * wrt the title element\n * [offsetTop]\n * attributes {object} - position and alignment attributes\n * x - pixels\n * y - pixels\n * text-anchor - start|middle|end\n * transform {object} - how to transform the title after positioning\n * rotate - degrees\n * offset - shift up/down in the rotated frame (unused?)\n * containerGroup - if an svg element already exists to hold this\n * title, include here. Otherwise it will go in fullLayout._infolayer\n * _meta {object (optional} - meta key-value to for title with\n * Lib.templateString, default to fullLayout._meta, if not provided\n *\n * @return {selection} d3 selection of title container group\n */\nfunction draw(gd, titleClass, options) {\n var cont = options.propContainer;\n var prop = options.propName;\n var placeholder = options.placeholder;\n var traceIndex = options.traceIndex;\n var avoid = options.avoid || {};\n var attributes = options.attributes;\n var transform = options.transform;\n var group = options.containerGroup;\n\n var fullLayout = gd._fullLayout;\n\n var opacity = 1;\n var isplaceholder = false;\n var title = cont.title;\n var txt = (title && title.text ? title.text : '').trim();\n\n var font = title && title.font ? title.font : {};\n var fontFamily = font.family;\n var fontSize = font.size;\n var fontColor = font.color;\n\n // only make this title editable if we positively identify its property\n // as one that has editing enabled.\n var editAttr;\n if(prop === 'title.text') editAttr = 'titleText';\n else if(prop.indexOf('axis') !== -1) editAttr = 'axisTitleText';\n else if(prop.indexOf('colorbar' !== -1)) editAttr = 'colorbarTitleText';\n var editable = gd._context.edits[editAttr];\n\n if(txt === '') opacity = 0;\n // look for placeholder text while stripping out numbers from eg X2, Y3\n // this is just for backward compatibility with the old version that had\n // \"Click to enter X2 title\" and may have gotten saved in some old plots,\n // we don't want this to show up when these are displayed.\n else if(txt.replace(numStripRE, ' % ') === placeholder.replace(numStripRE, ' % ')) {\n opacity = 0.2;\n isplaceholder = true;\n if(!editable) txt = '';\n }\n\n if(options._meta) {\n txt = Lib.templateString(txt, options._meta);\n } else if(fullLayout._meta) {\n txt = Lib.templateString(txt, fullLayout._meta);\n }\n\n var elShouldExist = txt || editable;\n\n if(!group) {\n group = Lib.ensureSingle(fullLayout._infolayer, 'g', 'g-' + titleClass);\n }\n\n var el = group.selectAll('text')\n .data(elShouldExist ? [0] : []);\n el.enter().append('text');\n el.text(txt)\n // this is hacky, but convertToTspans uses the class\n // to determine whether to rotate mathJax...\n // so we need to clear out any old class and put the\n // correct one (only relevant for colorbars, at least\n // for now) - ie don't use .classed\n .attr('class', titleClass);\n el.exit().remove();\n\n if(!elShouldExist) return group;\n\n function titleLayout(titleEl) {\n Lib.syncOrAsync([drawTitle, scootTitle], titleEl);\n }\n\n function drawTitle(titleEl) {\n var transformVal;\n\n if(transform) {\n transformVal = '';\n if(transform.rotate) {\n transformVal += 'rotate(' + [transform.rotate, attributes.x, attributes.y] + ')';\n }\n if(transform.offset) {\n transformVal += 'translate(0, ' + transform.offset + ')';\n }\n } else {\n transformVal = null;\n }\n\n titleEl.attr('transform', transformVal);\n\n titleEl.style({\n 'font-family': fontFamily,\n 'font-size': d3.round(fontSize, 2) + 'px',\n fill: Color.rgb(fontColor),\n opacity: opacity * Color.opacity(fontColor),\n 'font-weight': Plots.fontWeight\n })\n .attr(attributes)\n .call(svgTextUtils.convertToTspans, gd);\n\n return Plots.previousPromises(gd);\n }\n\n function scootTitle(titleElIn) {\n var titleGroup = d3.select(titleElIn.node().parentNode);\n\n if(avoid && avoid.selection && avoid.side && txt) {\n titleGroup.attr('transform', null);\n\n // move toward avoid.side (= left, right, top, bottom) if needed\n // can include pad (pixels, default 2)\n var backside = OPPOSITE_SIDE[avoid.side];\n var shiftSign = (avoid.side === 'left' || avoid.side === 'top') ? -1 : 1;\n var pad = isNumeric(avoid.pad) ? avoid.pad : 2;\n\n var titlebb = Drawing.bBox(titleGroup.node());\n var paperbb = {\n left: 0,\n top: 0,\n right: fullLayout.width,\n bottom: fullLayout.height\n };\n\n var maxshift = avoid.maxShift ||\n shiftSign * (paperbb[avoid.side] - titlebb[avoid.side]);\n var shift = 0;\n\n // Prevent the title going off the paper\n if(maxshift < 0) {\n shift = maxshift;\n } else {\n // so we don't have to offset each avoided element,\n // give the title the opposite offset\n var offsetLeft = avoid.offsetLeft || 0;\n var offsetTop = avoid.offsetTop || 0;\n titlebb.left -= offsetLeft;\n titlebb.right -= offsetLeft;\n titlebb.top -= offsetTop;\n titlebb.bottom -= offsetTop;\n\n // iterate over a set of elements (avoid.selection)\n // to avoid collisions with\n avoid.selection.each(function() {\n var avoidbb = Drawing.bBox(this);\n\n if(Lib.bBoxIntersect(titlebb, avoidbb, pad)) {\n shift = Math.max(shift, shiftSign * (\n avoidbb[avoid.side] - titlebb[backside]) + pad);\n }\n });\n shift = Math.min(maxshift, shift);\n }\n\n if(shift > 0 || maxshift < 0) {\n var shiftTemplate = {\n left: [-shift, 0],\n right: [shift, 0],\n top: [0, -shift],\n bottom: [0, shift]\n }[avoid.side];\n titleGroup.attr('transform', 'translate(' + shiftTemplate + ')');\n }\n }\n }\n\n el.call(titleLayout);\n\n function setPlaceholder() {\n opacity = 0;\n isplaceholder = true;\n el.text(placeholder)\n .on('mouseover.opacity', function() {\n d3.select(this).transition()\n .duration(interactConstants.SHOW_PLACEHOLDER).style('opacity', 1);\n })\n .on('mouseout.opacity', function() {\n d3.select(this).transition()\n .duration(interactConstants.HIDE_PLACEHOLDER).style('opacity', 0);\n });\n }\n\n if(editable) {\n if(!txt) setPlaceholder();\n else el.on('.opacity', null);\n\n el.call(svgTextUtils.makeEditable, {gd: gd})\n .on('edit', function(text) {\n if(traceIndex !== undefined) {\n Registry.call('_guiRestyle', gd, prop, text, traceIndex);\n } else {\n Registry.call('_guiRelayout', gd, prop, text);\n }\n })\n .on('cancel', function() {\n this.text(this.attr('data-unformatted'))\n .call(titleLayout);\n })\n .on('input', function(d) {\n this.text(d || ' ')\n .call(svgTextUtils.positionText, attributes.x, attributes.y);\n });\n }\n el.classed('js-placeholder', isplaceholder);\n\n return group;\n}\n\nmodule.exports = {\n draw: draw\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar d3 = require('d3');\nvar isNumeric = require('fast-isnumeric');\n\nvar Lib = require('../../lib');\nvar Icons = require('../../fonts/ploticon');\nvar Parser = new DOMParser();\n\n/**\n * UI controller for interactive plots\n * @Class\n * @Param {object} opts\n * @Param {object} opts.buttons nested arrays of grouped buttons config objects\n * @Param {object} opts.container container div to append modeBar\n * @Param {object} opts.graphInfo primary plot object containing data and layout\n */\nfunction ModeBar(opts) {\n this.container = opts.container;\n this.element = document.createElement('div');\n\n this.update(opts.graphInfo, opts.buttons);\n\n this.container.appendChild(this.element);\n}\n\nvar proto = ModeBar.prototype;\n\n/**\n * Update modeBar (buttons and logo)\n *\n * @param {object} graphInfo primary plot object containing data and layout\n * @param {array of arrays} buttons nested arrays of grouped buttons to initialize\n *\n */\nproto.update = function(graphInfo, buttons) {\n this.graphInfo = graphInfo;\n\n var context = this.graphInfo._context;\n var fullLayout = this.graphInfo._fullLayout;\n var modeBarId = 'modebar-' + fullLayout._uid;\n\n this.element.setAttribute('id', modeBarId);\n this._uid = modeBarId;\n\n this.element.className = 'modebar';\n if(context.displayModeBar === 'hover') this.element.className += ' modebar--hover ease-bg';\n\n if(fullLayout.modebar.orientation === 'v') {\n this.element.className += ' vertical';\n buttons = buttons.reverse();\n }\n\n var style = fullLayout.modebar;\n var bgSelector = context.displayModeBar === 'hover' ? '.js-plotly-plot .plotly:hover ' : '';\n\n Lib.deleteRelatedStyleRule(modeBarId);\n Lib.addRelatedStyleRule(modeBarId, bgSelector + '#' + modeBarId + ' .modebar-group', 'background-color: ' + style.bgcolor);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn .icon path', 'fill: ' + style.color);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn:hover .icon path', 'fill: ' + style.activecolor);\n Lib.addRelatedStyleRule(modeBarId, '#' + modeBarId + ' .modebar-btn.active .icon path', 'fill: ' + style.activecolor);\n\n // if buttons or logo have changed, redraw modebar interior\n var needsNewButtons = !this.hasButtons(buttons);\n var needsNewLogo = (this.hasLogo !== context.displaylogo);\n var needsNewLocale = (this.locale !== context.locale);\n\n this.locale = context.locale;\n\n if(needsNewButtons || needsNewLogo || needsNewLocale) {\n this.removeAllButtons();\n\n this.updateButtons(buttons);\n\n if(context.watermark || context.displaylogo) {\n var logoGroup = this.getLogo();\n if(context.watermark) {\n logoGroup.className = logoGroup.className + ' watermark';\n }\n\n if(fullLayout.modebar.orientation === 'v') {\n this.element.insertBefore(logoGroup, this.element.childNodes[0]);\n } else {\n this.element.appendChild(logoGroup);\n }\n\n this.hasLogo = true;\n }\n }\n\n this.updateActiveButton();\n};\n\nproto.updateButtons = function(buttons) {\n var _this = this;\n\n this.buttons = buttons;\n this.buttonElements = [];\n this.buttonsNames = [];\n\n this.buttons.forEach(function(buttonGroup) {\n var group = _this.createGroup();\n\n buttonGroup.forEach(function(buttonConfig) {\n var buttonName = buttonConfig.name;\n if(!buttonName) {\n throw new Error('must provide button \\'name\\' in button config');\n }\n if(_this.buttonsNames.indexOf(buttonName) !== -1) {\n throw new Error('button name \\'' + buttonName + '\\' is taken');\n }\n _this.buttonsNames.push(buttonName);\n\n var button = _this.createButton(buttonConfig);\n _this.buttonElements.push(button);\n group.appendChild(button);\n });\n\n _this.element.appendChild(group);\n });\n};\n\n/**\n * Empty div for containing a group of buttons\n * @Return {HTMLelement}\n */\nproto.createGroup = function() {\n var group = document.createElement('div');\n group.className = 'modebar-group';\n return group;\n};\n\n/**\n * Create a new button div and set constant and configurable attributes\n * @Param {object} config (see ./buttons.js for more info)\n * @Return {HTMLelement}\n */\nproto.createButton = function(config) {\n var _this = this;\n var button = document.createElement('a');\n\n button.setAttribute('rel', 'tooltip');\n button.className = 'modebar-btn';\n\n var title = config.title;\n if(title === undefined) title = config.name;\n // for localization: allow title to be a callable that takes gd as arg\n else if(typeof title === 'function') title = title(this.graphInfo);\n\n if(title || title === 0) button.setAttribute('data-title', title);\n\n if(config.attr !== undefined) button.setAttribute('data-attr', config.attr);\n\n var val = config.val;\n if(val !== undefined) {\n if(typeof val === 'function') val = val(this.graphInfo);\n button.setAttribute('data-val', val);\n }\n\n var click = config.click;\n if(typeof click !== 'function') {\n throw new Error('must provide button \\'click\\' function in button config');\n } else {\n button.addEventListener('click', function(ev) {\n config.click(_this.graphInfo, ev);\n\n // only needed for 'hoverClosestGeo' which does not call relayout\n _this.updateActiveButton(ev.currentTarget);\n });\n }\n\n button.setAttribute('data-toggle', config.toggle || false);\n if(config.toggle) d3.select(button).classed('active', true);\n\n var icon = config.icon;\n if(typeof icon === 'function') {\n button.appendChild(icon());\n } else {\n button.appendChild(this.createIcon(icon || Icons.question));\n }\n button.setAttribute('data-gravity', config.gravity || 'n');\n\n return button;\n};\n\n/**\n * Add an icon to a button\n * @Param {object} thisIcon\n * @Param {number} thisIcon.width\n * @Param {string} thisIcon.path\n * @Param {string} thisIcon.color\n * @Return {HTMLelement}\n */\nproto.createIcon = function(thisIcon) {\n var iconHeight = isNumeric(thisIcon.height) ?\n Number(thisIcon.height) :\n thisIcon.ascent - thisIcon.descent;\n var svgNS = 'http://www.w3.org/2000/svg';\n var icon;\n\n if(thisIcon.path) {\n icon = document.createElementNS(svgNS, 'svg');\n icon.setAttribute('viewBox', [0, 0, thisIcon.width, iconHeight].join(' '));\n icon.setAttribute('class', 'icon');\n\n var path = document.createElementNS(svgNS, 'path');\n path.setAttribute('d', thisIcon.path);\n\n if(thisIcon.transform) {\n path.setAttribute('transform', thisIcon.transform);\n } else if(thisIcon.ascent !== undefined) {\n // Legacy icon transform calculation\n path.setAttribute('transform', 'matrix(1 0 0 -1 0 ' + thisIcon.ascent + ')');\n }\n\n icon.appendChild(path);\n }\n\n if(thisIcon.svg) {\n var svgDoc = Parser.parseFromString(thisIcon.svg, 'application/xml');\n icon = svgDoc.childNodes[0];\n }\n\n icon.setAttribute('height', '1em');\n icon.setAttribute('width', '1em');\n\n return icon;\n};\n\n/**\n * Updates active button with attribute specified in layout\n * @Param {object} graphInfo plot object containing data and layout\n * @Return {HTMLelement}\n */\nproto.updateActiveButton = function(buttonClicked) {\n var fullLayout = this.graphInfo._fullLayout;\n var dataAttrClicked = (buttonClicked !== undefined) ?\n buttonClicked.getAttribute('data-attr') :\n null;\n\n this.buttonElements.forEach(function(button) {\n var thisval = button.getAttribute('data-val') || true;\n var dataAttr = button.getAttribute('data-attr');\n var isToggleButton = (button.getAttribute('data-toggle') === 'true');\n var button3 = d3.select(button);\n\n // Use 'data-toggle' and 'buttonClicked' to toggle buttons\n // that have no one-to-one equivalent in fullLayout\n if(isToggleButton) {\n if(dataAttr === dataAttrClicked) {\n button3.classed('active', !button3.classed('active'));\n }\n } else {\n var val = (dataAttr === null) ?\n dataAttr :\n Lib.nestedProperty(fullLayout, dataAttr).get();\n\n button3.classed('active', val === thisval);\n }\n });\n};\n\n/**\n * Check if modeBar is configured as button configuration argument\n *\n * @Param {object} buttons 2d array of grouped button config objects\n * @Return {boolean}\n */\nproto.hasButtons = function(buttons) {\n var currentButtons = this.buttons;\n\n if(!currentButtons) return false;\n\n if(buttons.length !== currentButtons.length) return false;\n\n for(var i = 0; i < buttons.length; ++i) {\n if(buttons[i].length !== currentButtons[i].length) return false;\n for(var j = 0; j < buttons[i].length; j++) {\n if(buttons[i][j].name !== currentButtons[i][j].name) return false;\n }\n }\n\n return true;\n};\n\n/**\n * @return {HTMLDivElement} The logo image wrapped in a group\n */\nproto.getLogo = function() {\n var group = this.createGroup();\n var a = document.createElement('a');\n\n a.href = 'https://plotly.com/';\n a.target = '_blank';\n a.setAttribute('data-title', Lib._(this.graphInfo, 'Produced with Plotly'));\n a.className = 'modebar-btn plotlyjsicon modebar-btn--logo';\n\n a.appendChild(this.createIcon(Icons.newplotlylogo));\n\n group.appendChild(a);\n return group;\n};\n\nproto.removeAllButtons = function() {\n while(this.element.firstChild) {\n this.element.removeChild(this.element.firstChild);\n }\n\n this.hasLogo = false;\n};\n\nproto.destroy = function() {\n Lib.removeElement(this.container.querySelector('.modebar'));\n Lib.deleteRelatedStyleRule(this._uid);\n};\n\nfunction createModeBar(gd, buttons) {\n var fullLayout = gd._fullLayout;\n\n var modeBar = new ModeBar({\n graphInfo: gd,\n container: fullLayout._modebardiv.node(),\n buttons: buttons\n });\n\n if(fullLayout._privateplot) {\n d3.select(modeBar.element).append('span')\n .classed('badge-private float--left', true)\n .text('PRIVATE');\n }\n\n return modeBar;\n}\n\nmodule.exports = createModeBar;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar traceIs = require('../../registry').traceIs;\nvar autoType = require('./axis_autotype');\n\n/*\n * data: the plot data to use in choosing auto type\n * name: axis object name (ie 'xaxis') if one should be stored\n */\nmodule.exports = function handleTypeDefaults(containerIn, containerOut, coerce, options) {\n var axType = coerce('type', (options.splomStash || {}).type);\n\n if(axType === '-') {\n setAutoType(containerOut, options.data);\n\n if(containerOut.type === '-') {\n containerOut.type = 'linear';\n } else {\n // copy autoType back to input axis\n // note that if this object didn't exist\n // in the input layout, we have to put it in\n // this happens in the main supplyDefaults function\n containerIn.type = containerOut.type;\n }\n }\n};\n\nfunction setAutoType(ax, data) {\n // new logic: let people specify any type they want,\n // only autotype if type is '-'\n if(ax.type !== '-') return;\n\n var id = ax._id;\n var axLetter = id.charAt(0);\n var i;\n\n // support 3d\n if(id.indexOf('scene') !== -1) id = axLetter;\n\n var d0 = getFirstNonEmptyTrace(data, id, axLetter);\n if(!d0) return;\n\n // first check for histograms, as the count direction\n // should always default to a linear axis\n if(d0.type === 'histogram' &&\n axLetter === {v: 'y', h: 'x'}[d0.orientation || 'v']\n ) {\n ax.type = 'linear';\n return;\n }\n\n var calAttr = axLetter + 'calendar';\n var calendar = d0[calAttr];\n var opts = {noMultiCategory: !traceIs(d0, 'cartesian') || traceIs(d0, 'noMultiCategory')};\n\n // To not confuse 2D x/y used for per-box sample points for multicategory coordinates\n if(d0.type === 'box' && d0._hasPreCompStats &&\n axLetter === {h: 'x', v: 'y'}[d0.orientation || 'v']\n ) {\n opts.noMultiCategory = true;\n }\n\n // check all boxes on this x axis to see\n // if they're dates, numbers, or categories\n if(isBoxWithoutPositionCoords(d0, axLetter)) {\n var posLetter = getBoxPosLetter(d0);\n var boxPositions = [];\n\n for(i = 0; i < data.length; i++) {\n var trace = data[i];\n if(!traceIs(trace, 'box-violin') || (trace[axLetter + 'axis'] || axLetter) !== id) continue;\n\n if(trace[posLetter] !== undefined) boxPositions.push(trace[posLetter][0]);\n else if(trace.name !== undefined) boxPositions.push(trace.name);\n else boxPositions.push('text');\n\n if(trace[calAttr] !== calendar) calendar = undefined;\n }\n\n ax.type = autoType(boxPositions, calendar, opts);\n } else if(d0.type === 'splom') {\n var dimensions = d0.dimensions;\n var dim = dimensions[d0._axesDim[id]];\n if(dim.visible) ax.type = autoType(dim.values, calendar, opts);\n } else {\n ax.type = autoType(d0[axLetter] || [d0[axLetter + '0']], calendar, opts);\n }\n}\n\nfunction getFirstNonEmptyTrace(data, id, axLetter) {\n for(var i = 0; i < data.length; i++) {\n var trace = data[i];\n\n if(trace.type === 'splom' &&\n trace._length > 0 &&\n (trace['_' + axLetter + 'axes'] || {})[id]\n ) {\n return trace;\n }\n\n if((trace[axLetter + 'axis'] || axLetter) === id) {\n if(isBoxWithoutPositionCoords(trace, axLetter)) {\n return trace;\n } else if((trace[axLetter] || []).length || trace[axLetter + '0']) {\n return trace;\n }\n }\n }\n}\n\nfunction getBoxPosLetter(trace) {\n return {v: 'x', h: 'y'}[trace.orientation || 'v'];\n}\n\nfunction isBoxWithoutPositionCoords(trace, axLetter) {\n var posLetter = getBoxPosLetter(trace);\n var isBox = traceIs(trace, 'box-violin');\n var isCandlestick = traceIs(trace._fullInput || {}, 'candlestick');\n\n return (\n isBox &&\n !isCandlestick &&\n axLetter === posLetter &&\n trace[posLetter] === undefined &&\n trace[posLetter + '0'] === undefined\n );\n}\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = function selectPoints(searchInfo, selectionTester) {\n var cd = searchInfo.cd;\n var xa = searchInfo.xaxis;\n var ya = searchInfo.yaxis;\n var trace = cd[0].trace;\n var isFunnel = (trace.type === 'funnel');\n var isHorizontal = (trace.orientation === 'h');\n var selection = [];\n var i;\n\n if(selectionTester === false) {\n // clear selection\n for(i = 0; i < cd.length; i++) {\n cd[i].selected = 0;\n }\n } else {\n for(i = 0; i < cd.length; i++) {\n var di = cd[i];\n var ct = 'ct' in di ? di.ct : getCentroid(di, xa, ya, isHorizontal, isFunnel);\n\n if(selectionTester.contains(ct, false, i, searchInfo)) {\n selection.push({\n pointNumber: i,\n x: xa.c2d(di.x),\n y: ya.c2d(di.y)\n });\n di.selected = 1;\n } else {\n di.selected = 0;\n }\n }\n }\n\n return selection;\n};\n\nfunction getCentroid(d, xa, ya, isHorizontal, isFunnel) {\n var x0 = xa.c2p(isHorizontal ? d.s0 : d.p0, true);\n var x1 = xa.c2p(isHorizontal ? d.s1 : d.p1, true);\n var y0 = ya.c2p(isHorizontal ? d.p0 : d.s0, true);\n var y1 = ya.c2p(isHorizontal ? d.p1 : d.s1, true);\n\n if(isFunnel) {\n return [(x0 + x1) / 2, (y0 + y1) / 2];\n } else {\n if(isHorizontal) {\n return [x1, (y0 + y1) / 2];\n } else {\n return [(x0 + x1) / 2, y1];\n }\n }\n}\n","/**\n * inspired by is-number \n * but significantly simplified and sped up by ignoring number and string constructors\n * ie these return false:\n * new Number(1)\n * new String('1')\n */\n\n'use strict';\n\nvar allBlankCharCodes = require('is-string-blank');\n\nmodule.exports = function(n) {\n var type = typeof n;\n if(type === 'string') {\n var original = n;\n n = +n;\n // whitespace strings cast to zero - filter them out\n if(n===0 && allBlankCharCodes(original)) return false;\n }\n else if(type !== 'number') return false;\n\n return n - n < 1;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar helpers = require('./helpers');\n\nvar Snapshot = {\n getDelay: helpers.getDelay,\n getRedrawFunc: helpers.getRedrawFunc,\n clone: require('./cloneplot'),\n toSVG: require('./tosvg'),\n svgToImg: require('./svgtoimg'),\n toImage: require('./toimage'),\n downloadImage: require('./download')\n};\n\nmodule.exports = Snapshot;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar isNumeric = require('fast-isnumeric');\n\n\nmodule.exports = {\n count: function(n, i, size) {\n size[n]++;\n return 1;\n },\n\n sum: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n size[n] += v;\n return v;\n }\n return 0;\n },\n\n avg: function(n, i, size, counterData, counts) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n size[n] += v;\n counts[n]++;\n }\n return 0;\n },\n\n min: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n if(!isNumeric(size[n])) {\n size[n] = v;\n return v;\n } else if(size[n] > v) {\n var delta = v - size[n];\n size[n] = v;\n return delta;\n }\n }\n return 0;\n },\n\n max: function(n, i, size, counterData) {\n var v = counterData[i];\n if(isNumeric(v)) {\n v = Number(v);\n if(!isNumeric(size[n])) {\n size[n] = v;\n return v;\n } else if(size[n] < v) {\n var delta = v - size[n];\n size[n] = v;\n return delta;\n }\n }\n return 0;\n }\n};\n","// (c) Copyright 2017, Sean Connelly (@voidqk), http://syntheti.cc\n// MIT License\n// Project Home: https://github.com/voidqk/polybooljs\n\n//\n// convert between PolyBool polygon format and GeoJSON formats (Polygon and MultiPolygon)\n//\n\nvar GeoJSON = {\n\t// convert a GeoJSON object to a PolyBool polygon\n\ttoPolygon: function(PolyBool, geojson){\n\n\t\t// converts list of LineString's to segments\n\t\tfunction GeoPoly(coords){\n\t\t\t// check for empty coords\n\t\t\tif (coords.length <= 0)\n\t\t\t\treturn PolyBool.segments({ inverted: false, regions: [] });\n\n\t\t\t// convert LineString to segments\n\t\t\tfunction LineString(ls){\n\t\t\t\t// remove tail which should be the same as head\n\t\t\t\tvar reg = ls.slice(0, ls.length - 1);\n\t\t\t\treturn PolyBool.segments({ inverted: false, regions: [reg] });\n\t\t\t}\n\n\t\t\t// the first LineString is considered the outside\n\t\t\tvar out = LineString(coords[0]);\n\n\t\t\t// the rest of the LineStrings are considered interior holes, so subtract them from the\n\t\t\t// current result\n\t\t\tfor (var i = 1; i < coords.length; i++)\n\t\t\t\tout = PolyBool.selectDifference(PolyBool.combine(out, LineString(coords[i])));\n\n\t\t\treturn out;\n\t\t}\n\n\t\tif (geojson.type === 'Polygon'){\n\t\t\t// single polygon, so just convert it and we're done\n\t\t\treturn PolyBool.polygon(GeoPoly(geojson.coordinates));\n\t\t}\n\t\telse if (geojson.type === 'MultiPolygon'){\n\t\t\t// multiple polygons, so union all the polygons together\n\t\t\tvar out = PolyBool.segments({ inverted: false, regions: [] });\n\t\t\tfor (var i = 0; i < geojson.coordinates.length; i++)\n\t\t\t\tout = PolyBool.selectUnion(PolyBool.combine(out, GeoPoly(geojson.coordinates[i])));\n\t\t\treturn PolyBool.polygon(out);\n\t\t}\n\t\tthrow new Error('PolyBool: Cannot convert GeoJSON object to PolyBool polygon');\n\t},\n\n\t// convert a PolyBool polygon to a GeoJSON object\n\tfromPolygon: function(PolyBool, eps, poly){\n\t\t// make sure out polygon is clean\n\t\tpoly = PolyBool.polygon(PolyBool.segments(poly));\n\n\t\t// test if r1 is inside r2\n\t\tfunction regionInsideRegion(r1, r2){\n\t\t\t// we're guaranteed no lines intersect (because the polygon is clean), but a vertex\n\t\t\t// could be on the edge -- so we just average pt[0] and pt[1] to produce a point on the\n\t\t\t// edge of the first line, which cannot be on an edge\n\t\t\treturn eps.pointInsideRegion([\n\t\t\t\t(r1[0][0] + r1[1][0]) * 0.5,\n\t\t\t\t(r1[0][1] + r1[1][1]) * 0.5\n\t\t\t], r2);\n\t\t}\n\n\t\t// calculate inside heirarchy\n\t\t//\n\t\t// _____________________ _______ roots -> A -> F\n\t\t// | A | | F | | |\n\t\t// | _______ _______ | | ___ | +-- B +-- G\n\t\t// | | B | | C | | | | | | | |\n\t\t// | | ___ | | ___ | | | | | | | +-- D\n\t\t// | | | D | | | | E | | | | | G | | |\n\t\t// | | |___| | | |___| | | | | | | +-- C\n\t\t// | |_______| |_______| | | |___| | |\n\t\t// |_____________________| |_______| +-- E\n\n\t\tfunction newNode(region){\n\t\t\treturn {\n\t\t\t\tregion: region,\n\t\t\t\tchildren: []\n\t\t\t};\n\t\t}\n\n\t\tvar roots = newNode(null);\n\n\t\tfunction addChild(root, region){\n\t\t\t// first check if we're inside any children\n\t\t\tfor (var i = 0; i < root.children.length; i++){\n\t\t\t\tvar child = root.children[i];\n\t\t\t\tif (regionInsideRegion(region, child.region)){\n\t\t\t\t\t// we are, so insert inside them instead\n\t\t\t\t\taddChild(child, region);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// not inside any children, so check to see if any children are inside us\n\t\t\tvar node = newNode(region);\n\t\t\tfor (var i = 0; i < root.children.length; i++){\n\t\t\t\tvar child = root.children[i];\n\t\t\t\tif (regionInsideRegion(child.region, region)){\n\t\t\t\t\t// oops... move the child beneath us, and remove them from root\n\t\t\t\t\tnode.children.push(child);\n\t\t\t\t\troot.children.splice(i, 1);\n\t\t\t\t\ti--;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// now we can add ourselves\n\t\t\troot.children.push(node);\n\t\t}\n\n\t\t// add all regions to the root\n\t\tfor (var i = 0; i < poly.regions.length; i++){\n\t\t\tvar region = poly.regions[i];\n\t\t\tif (region.length < 3) // regions must have at least 3 points (sanity check)\n\t\t\t\tcontinue;\n\t\t\taddChild(roots, region);\n\t\t}\n\n\t\t// with our heirarchy, we can distinguish between exterior borders, and interior holes\n\t\t// the root nodes are exterior, children are interior, children's children are exterior,\n\t\t// children's children's children are interior, etc\n\n\t\t// while we're at it, exteriors are counter-clockwise, and interiors are clockwise\n\n\t\tfunction forceWinding(region, clockwise){\n\t\t\t// first, see if we're clockwise or counter-clockwise\n\t\t\t// https://en.wikipedia.org/wiki/Shoelace_formula\n\t\t\tvar winding = 0;\n\t\t\tvar last_x = region[region.length - 1][0];\n\t\t\tvar last_y = region[region.length - 1][1];\n\t\t\tvar copy = [];\n\t\t\tfor (var i = 0; i < region.length; i++){\n\t\t\t\tvar curr_x = region[i][0];\n\t\t\t\tvar curr_y = region[i][1];\n\t\t\t\tcopy.push([curr_x, curr_y]); // create a copy while we're at it\n\t\t\t\twinding += curr_y * last_x - curr_x * last_y;\n\t\t\t\tlast_x = curr_x;\n\t\t\t\tlast_y = curr_y;\n\t\t\t}\n\t\t\t// this assumes Cartesian coordinates (Y is positive going up)\n\t\t\tvar isclockwise = winding < 0;\n\t\t\tif (isclockwise !== clockwise)\n\t\t\t\tcopy.reverse();\n\t\t\t// while we're here, the last point must be the first point...\n\t\t\tcopy.push([copy[0][0], copy[0][1]]);\n\t\t\treturn copy;\n\t\t}\n\n\t\tvar geopolys = [];\n\n\t\tfunction addExterior(node){\n\t\t\tvar poly = [forceWinding(node.region, false)];\n\t\t\tgeopolys.push(poly);\n\t\t\t// children of exteriors are interior\n\t\t\tfor (var i = 0; i < node.children.length; i++)\n\t\t\t\tpoly.push(getInterior(node.children[i]));\n\t\t}\n\n\t\tfunction getInterior(node){\n\t\t\t// children of interiors are exterior\n\t\t\tfor (var i = 0; i < node.children.length; i++)\n\t\t\t\taddExterior(node.children[i]);\n\t\t\t// return the clockwise interior\n\t\t\treturn forceWinding(node.region, true);\n\t\t}\n\n\t\t// root nodes are exterior\n\t\tfor (var i = 0; i < roots.children.length; i++)\n\t\t\taddExterior(roots.children[i]);\n\n\t\t// lastly, construct the approrpriate GeoJSON object\n\n\t\tif (geopolys.length <= 0) // empty GeoJSON Polygon\n\t\t\treturn { type: 'Polygon', coordinates: [] };\n\t\tif (geopolys.length == 1) // use a GeoJSON Polygon\n\t\t\treturn { type: 'Polygon', coordinates: geopolys[0] };\n\t\treturn { // otherwise, use a GeoJSON MultiPolygon\n\t\t\ttype: 'MultiPolygon',\n\t\t\tcoordinates: geopolys\n\t\t};\n\t}\n};\n\nmodule.exports = GeoJSON;\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nmodule.exports = Sieve;\n\nvar distinctVals = require('../../lib').distinctVals;\nvar BADNUM = require('../../constants/numerical').BADNUM;\n\n/**\n * Helper class to sieve data from traces into bins\n *\n * @class\n *\n * @param {Array} traces\n* Array of calculated traces\n * @param {object} opts\n * - @param {boolean} [sepNegVal]\n * If true, then split data at the same position into a bar\n * for positive values and another for negative values\n * - @param {boolean} [overlapNoMerge]\n * If true, then don't merge overlapping bars into a single bar\n */\nfunction Sieve(traces, opts) {\n this.traces = traces;\n this.sepNegVal = opts.sepNegVal;\n this.overlapNoMerge = opts.overlapNoMerge;\n\n // for single-bin histograms - see histogram/calc\n var width1 = Infinity;\n\n var positions = [];\n for(var i = 0; i < traces.length; i++) {\n var trace = traces[i];\n for(var j = 0; j < trace.length; j++) {\n var bar = trace[j];\n if(bar.p !== BADNUM) positions.push(bar.p);\n }\n if(trace[0] && trace[0].width1) {\n width1 = Math.min(trace[0].width1, width1);\n }\n }\n this.positions = positions;\n\n var dv = distinctVals(positions);\n this.distinctPositions = dv.vals;\n if(dv.vals.length === 1 && width1 !== Infinity) this.minDiff = width1;\n else this.minDiff = Math.min(dv.minDiff, width1);\n\n this.binWidth = this.minDiff;\n\n this.bins = {};\n}\n\n/**\n * Sieve datum\n *\n * @method\n * @param {number} position\n * @param {number} value\n * @returns {number} Previous bin value\n */\nSieve.prototype.put = function put(position, value) {\n var label = this.getLabel(position, value);\n var oldValue = this.bins[label] || 0;\n\n this.bins[label] = oldValue + value;\n\n return oldValue;\n};\n\n/**\n * Get current bin value for a given datum\n *\n * @method\n * @param {number} position Position of datum\n * @param {number} [value] Value of datum\n * (required if this.sepNegVal is true)\n * @returns {number} Current bin value\n */\nSieve.prototype.get = function get(position, value) {\n var label = this.getLabel(position, value);\n return this.bins[label] || 0;\n};\n\n/**\n * Get bin label for a given datum\n *\n * @method\n * @param {number} position Position of datum\n * @param {number} [value] Value of datum\n * (required if this.sepNegVal is true)\n * @returns {string} Bin label\n * (prefixed with a 'v' if value is negative and this.sepNegVal is\n * true; otherwise prefixed with '^')\n */\nSieve.prototype.getLabel = function getLabel(position, value) {\n var prefix = (value < 0 && this.sepNegVal) ? 'v' : '^';\n var label = (this.overlapNoMerge) ?\n position :\n Math.round(position / this.binWidth);\n return prefix + label;\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\nvar fontAttrs = require('../font_attributes');\nvar colorAttrs = require('../../components/color/attributes');\nvar dash = require('../../components/drawing/attributes').dash;\nvar extendFlat = require('../../lib/extend').extendFlat;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nvar FORMAT_LINK = require('../../constants/docs').FORMAT_LINK;\nvar DATE_FORMAT_LINK = require('../../constants/docs').DATE_FORMAT_LINK;\nvar ONEDAY = require('../../constants/numerical').ONEDAY;\nvar constants = require('./constants');\nvar HOUR = constants.HOUR_PATTERN;\nvar DAY_OF_WEEK = constants.WEEKDAY_PATTERN;\n\nmodule.exports = {\n visible: {\n valType: 'boolean',\n role: 'info',\n editType: 'plot',\n description: [\n 'A single toggle to hide the axis while preserving interaction like dragging.',\n 'Default is true when a cheater plot is present on the axis, otherwise',\n 'false'\n ].join(' ')\n },\n color: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Sets default for all colors associated with this axis',\n 'all at once: line, font, tick, and grid colors.',\n 'Grid color is lightened by blending this with the plot background',\n 'Individual pieces can override this.'\n ].join(' ')\n },\n title: {\n text: {\n valType: 'string',\n role: 'info',\n editType: 'ticks',\n description: [\n 'Sets the title of this axis.',\n 'Note that before the existence of `title.text`, the title\\'s',\n 'contents used to be defined as the `title` attribute itself.',\n 'This behavior has been deprecated.'\n ].join(' ')\n },\n font: fontAttrs({\n editType: 'ticks',\n description: [\n 'Sets this axis\\' title font.',\n 'Note that the title\\'s font used to be customized',\n 'by the now deprecated `titlefont` attribute.'\n ].join(' ')\n }),\n standoff: {\n valType: 'number',\n role: 'info',\n min: 0,\n editType: 'ticks',\n description: [\n 'Sets the standoff distance (in px) between the axis labels and the title text',\n 'The default value is a function of the axis tick labels, the title `font.size`',\n 'and the axis `linewidth`.',\n 'Note that the axis title position is always constrained within the margins,',\n 'so the actual standoff distance is always less than the set or default value.',\n 'By setting `standoff` and turning on `automargin`, plotly.js will push the',\n 'margins to fit the axis title at given standoff distance.'\n ].join(' ')\n },\n editType: 'ticks'\n },\n type: {\n valType: 'enumerated',\n // '-' means we haven't yet run autotype or couldn't find any data\n // it gets turned into linear in gd._fullLayout but not copied back\n // to gd.data like the others are.\n values: ['-', 'linear', 'log', 'date', 'category', 'multicategory'],\n dflt: '-',\n role: 'info',\n editType: 'calc',\n // we forget when an axis has been autotyped, just writing the auto\n // value back to the input - so it doesn't make sense to template this.\n // Note: we do NOT prohibit this in `coerce`, so if someone enters a\n // type in the template explicitly it will be honored as the default.\n _noTemplating: true,\n description: [\n 'Sets the axis type.',\n 'By default, plotly attempts to determined the axis type',\n 'by looking into the data of the traces that referenced',\n 'the axis in question.'\n ].join(' ')\n },\n autorange: {\n valType: 'enumerated',\n values: [true, false, 'reversed'],\n dflt: true,\n role: 'info',\n editType: 'axrange',\n impliedEdits: {'range[0]': undefined, 'range[1]': undefined},\n description: [\n 'Determines whether or not the range of this axis is',\n 'computed in relation to the input data.',\n 'See `rangemode` for more info.',\n 'If `range` is provided, then `autorange` is set to *false*.'\n ].join(' ')\n },\n rangemode: {\n valType: 'enumerated',\n values: ['normal', 'tozero', 'nonnegative'],\n dflt: 'normal',\n role: 'info',\n editType: 'plot',\n description: [\n 'If *normal*, the range is computed in relation to the extrema',\n 'of the input data.',\n 'If *tozero*`, the range extends to 0,',\n 'regardless of the input data',\n 'If *nonnegative*, the range is non-negative,',\n 'regardless of the input data.',\n 'Applies only to linear axes.'\n ].join(' ')\n },\n range: {\n valType: 'info_array',\n role: 'info',\n items: [\n {valType: 'any', editType: 'axrange', impliedEdits: {'^autorange': false}, anim: true},\n {valType: 'any', editType: 'axrange', impliedEdits: {'^autorange': false}, anim: true}\n ],\n editType: 'axrange',\n impliedEdits: {'autorange': false},\n anim: true,\n description: [\n 'Sets the range of this axis.',\n 'If the axis `type` is *log*, then you must take the log of your',\n 'desired range (e.g. to set the range from 1 to 100,',\n 'set the range from 0 to 2).',\n 'If the axis `type` is *date*, it should be date strings,',\n 'like date data, though Date objects and unix milliseconds',\n 'will be accepted and converted to strings.',\n 'If the axis `type` is *category*, it should be numbers,',\n 'using the scale where each category is assigned a serial',\n 'number from zero in the order it appears.'\n ].join(' ')\n },\n fixedrange: {\n valType: 'boolean',\n dflt: false,\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines whether or not this axis is zoom-able.',\n 'If true, then zoom is disabled.'\n ].join(' ')\n },\n // scaleanchor: not used directly, just put here for reference\n // values are any opposite-letter axis id\n scaleanchor: {\n valType: 'enumerated',\n values: [\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'plot',\n description: [\n 'If set to another axis id (e.g. `x2`, `y`), the range of this axis',\n 'changes together with the range of the corresponding axis',\n 'such that the scale of pixels per unit is in a constant ratio.',\n 'Both axes are still zoomable, but when you zoom one, the other will',\n 'zoom the same amount, keeping a fixed midpoint.',\n '`constrain` and `constraintoward` determine how we enforce the constraint.',\n 'You can chain these, ie `yaxis: {scaleanchor: *x*}, xaxis2: {scaleanchor: *y*}`',\n 'but you can only link axes of the same `type`.',\n 'The linked axis can have the opposite letter (to constrain the aspect ratio)',\n 'or the same letter (to match scales across subplots).',\n 'Loops (`yaxis: {scaleanchor: *x*}, xaxis: {scaleanchor: *y*}` or longer) are redundant',\n 'and the last constraint encountered will be ignored to avoid possible',\n 'inconsistent constraints via `scaleratio`.',\n 'Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint',\n 'is currently forbidden.'\n ].join(' ')\n },\n scaleratio: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'info',\n editType: 'plot',\n description: [\n 'If this axis is linked to another by `scaleanchor`, this determines the pixel',\n 'to unit scale ratio. For example, if this value is 10, then every unit on',\n 'this axis spans 10 times the number of pixels as a unit on the linked axis.',\n 'Use this for example to create an elevation profile where the vertical scale',\n 'is exaggerated a fixed amount with respect to the horizontal.'\n ].join(' ')\n },\n constrain: {\n valType: 'enumerated',\n values: ['range', 'domain'],\n dflt: 'range',\n role: 'info',\n editType: 'plot',\n description: [\n 'If this axis needs to be compressed (either due to its own `scaleanchor` and',\n '`scaleratio` or those of the other axis), determines how that happens:',\n 'by increasing the *range* (default), or by decreasing the *domain*.'\n ].join(' ')\n },\n // constraintoward: not used directly, just put here for reference\n constraintoward: {\n valType: 'enumerated',\n values: ['left', 'center', 'right', 'top', 'middle', 'bottom'],\n role: 'info',\n editType: 'plot',\n description: [\n 'If this axis needs to be compressed (either due to its own `scaleanchor` and',\n '`scaleratio` or those of the other axis), determines which direction we push',\n 'the originally specified plot area. Options are *left*, *center* (default),',\n 'and *right* for x axes, and *top*, *middle* (default), and *bottom* for y axes.'\n ].join(' ')\n },\n matches: {\n valType: 'enumerated',\n values: [\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'calc',\n description: [\n 'If set to another axis id (e.g. `x2`, `y`), the range of this axis',\n 'will match the range of the corresponding axis in data-coordinates space.',\n 'Moreover, matching axes share auto-range values, category lists and',\n 'histogram auto-bins.',\n 'Note that setting axes simultaneously in both a `scaleanchor` and a `matches` constraint',\n 'is currently forbidden.',\n 'Moreover, note that matching axes must have the same `type`.'\n ].join(' ')\n },\n\n rangebreaks: templatedArray('rangebreak', {\n enabled: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'calc',\n description: [\n 'Determines whether this axis rangebreak is enabled or disabled.',\n 'Please note that `rangebreaks` only work for *date* axis type.'\n ].join(' ')\n },\n\n bounds: {\n valType: 'info_array',\n role: 'info',\n items: [\n {valType: 'any', editType: 'calc'},\n {valType: 'any', editType: 'calc'}\n ],\n editType: 'calc',\n description: [\n 'Sets the lower and upper bounds of this axis rangebreak.',\n 'Can be used with `pattern`.'\n ].join(' ')\n },\n\n pattern: {\n valType: 'enumerated',\n values: [DAY_OF_WEEK, HOUR, ''],\n role: 'info',\n editType: 'calc',\n description: [\n 'Determines a pattern on the time line that generates breaks.',\n 'If *' + DAY_OF_WEEK + '* - days of the week in English e.g. \\'Sunday\\' or `\\sun\\`',\n '(matching is case-insensitive and considers only the first three characters),',\n 'as well as Sunday-based integers between 0 and 6.',\n 'If *' + HOUR + '* - hour (24-hour clock) as decimal numbers between 0 and 24.',\n 'for more info.',\n 'Examples:',\n '- { pattern: \\'' + DAY_OF_WEEK + '\\', bounds: [6, 1] }',\n ' or simply { bounds: [\\'sat\\', \\'mon\\'] }',\n ' breaks from Saturday to Monday (i.e. skips the weekends).',\n '- { pattern: \\'' + HOUR + '\\', bounds: [17, 8] }',\n ' breaks from 5pm to 8am (i.e. skips non-work hours).'\n ].join(' ')\n },\n\n values: {\n valType: 'info_array',\n freeLength: true,\n role: 'info',\n editType: 'calc',\n items: {\n valType: 'any',\n editType: 'calc'\n },\n description: [\n 'Sets the coordinate values corresponding to the rangebreaks.',\n 'An alternative to `bounds`.',\n 'Use `dvalue` to set the size of the values along the axis.'\n ].join(' ')\n },\n dvalue: {\n // TODO could become 'any' to add support for 'months', 'years'\n valType: 'number',\n role: 'info',\n editType: 'calc',\n min: 0,\n dflt: ONEDAY,\n description: [\n 'Sets the size of each `values` item.',\n 'The default is one day in milliseconds.'\n ].join(' ')\n },\n\n /*\n gap: {\n valType: 'number',\n min: 0,\n dflt: 0, // for *date* axes, maybe something else for *linear*\n editType: 'calc',\n role: 'info',\n description: [\n 'Sets the gap distance between the start and the end of this rangebreak.',\n 'Use with `gapmode` to set the unit of measurement.'\n ].join(' ')\n },\n gapmode: {\n valType: 'enumerated',\n values: ['pixels', 'fraction'],\n dflt: 'pixels',\n editType: 'calc',\n role: 'info',\n description: [\n 'Determines if the `gap` value corresponds to a pixel length',\n 'or a fraction of the plot area.'\n ].join(' ')\n },\n */\n\n // To complete https://github.com/plotly/plotly.js/issues/4210\n // we additionally need `gap` and make this work on *linear*, and\n // possibly all other cartesian axis types. We possibly would also need\n // some style attributes controlling the zig-zag on the corresponding\n // axis.\n\n editType: 'calc'\n }),\n\n // ticks\n tickmode: {\n valType: 'enumerated',\n values: ['auto', 'linear', 'array'],\n role: 'info',\n editType: 'ticks',\n impliedEdits: {tick0: undefined, dtick: undefined},\n description: [\n 'Sets the tick mode for this axis.',\n 'If *auto*, the number of ticks is set via `nticks`.',\n 'If *linear*, the placement of the ticks is determined by',\n 'a starting position `tick0` and a tick step `dtick`',\n '(*linear* is the default value if `tick0` and `dtick` are provided).',\n 'If *array*, the placement of the ticks is set via `tickvals`',\n 'and the tick text is `ticktext`.',\n '(*array* is the default value if `tickvals` is provided).'\n ].join(' ')\n },\n nticks: {\n valType: 'integer',\n min: 0,\n dflt: 0,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Specifies the maximum number of ticks for the particular axis.',\n 'The actual number of ticks will be chosen automatically to be',\n 'less than or equal to `nticks`.',\n 'Has an effect only if `tickmode` is set to *auto*.'\n ].join(' ')\n },\n tick0: {\n valType: 'any',\n role: 'style',\n editType: 'ticks',\n impliedEdits: {tickmode: 'linear'},\n description: [\n 'Sets the placement of the first tick on this axis.',\n 'Use with `dtick`.',\n 'If the axis `type` is *log*, then you must take the log of your starting tick',\n '(e.g. to set the starting tick to 100, set the `tick0` to 2)',\n 'except when `dtick`=*L* (see `dtick` for more info).',\n 'If the axis `type` is *date*, it should be a date string, like date data.',\n 'If the axis `type` is *category*, it should be a number, using the scale where',\n 'each category is assigned a serial number from zero in the order it appears.'\n ].join(' ')\n },\n dtick: {\n valType: 'any',\n role: 'style',\n editType: 'ticks',\n impliedEdits: {tickmode: 'linear'},\n description: [\n 'Sets the step in-between ticks on this axis. Use with `tick0`.',\n 'Must be a positive number, or special strings available to *log* and *date* axes.',\n 'If the axis `type` is *log*, then ticks are set every 10^(n*dtick) where n',\n 'is the tick number. For example,',\n 'to set a tick mark at 1, 10, 100, 1000, ... set dtick to 1.',\n 'To set tick marks at 1, 100, 10000, ... set dtick to 2.',\n 'To set tick marks at 1, 5, 25, 125, 625, 3125, ... set dtick to log_10(5), or 0.69897000433.',\n '*log* has several special values; *L*, where `f` is a positive number,',\n 'gives ticks linearly spaced in value (but not position).',\n 'For example `tick0` = 0.1, `dtick` = *L0.5* will put ticks at 0.1, 0.6, 1.1, 1.6 etc.',\n 'To show powers of 10 plus small digits between, use *D1* (all digits) or *D2* (only 2 and 5).',\n '`tick0` is ignored for *D1* and *D2*.',\n 'If the axis `type` is *date*, then you must convert the time to milliseconds.',\n 'For example, to set the interval between ticks to one day,',\n 'set `dtick` to 86400000.0.',\n '*date* also has special values *M* gives ticks spaced by a number of months.',\n '`n` must be a positive integer.',\n 'To set ticks on the 15th of every third month, set `tick0` to *2000-01-15* and `dtick` to *M3*.',\n 'To set ticks every 4 years, set `dtick` to *M48*'\n ].join(' ')\n },\n tickvals: {\n valType: 'data_array',\n editType: 'ticks',\n description: [\n 'Sets the values at which ticks on this axis appear.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `ticktext`.'\n ].join(' ')\n },\n ticktext: {\n valType: 'data_array',\n editType: 'ticks',\n description: [\n 'Sets the text displayed at the ticks position via `tickvals`.',\n 'Only has an effect if `tickmode` is set to *array*.',\n 'Used with `tickvals`.'\n ].join(' ')\n },\n ticks: {\n valType: 'enumerated',\n values: ['outside', 'inside', ''],\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines whether ticks are drawn or not.',\n 'If **, this axis\\' ticks are not drawn.',\n 'If *outside* (*inside*), this axis\\' are drawn outside (inside)',\n 'the axis lines.'\n ].join(' ')\n },\n tickson: {\n valType: 'enumerated',\n values: ['labels', 'boundaries'],\n role: 'info',\n dflt: 'labels',\n editType: 'ticks',\n description: [\n 'Determines where ticks and grid lines are drawn with respect to their',\n 'corresponding tick labels.',\n 'Only has an effect for axes of `type` *category* or *multicategory*.',\n 'When set to *boundaries*, ticks and grid lines are drawn half a category',\n 'to the left/bottom of labels.'\n ].join(' ')\n },\n mirror: {\n valType: 'enumerated',\n values: [true, 'ticks', false, 'all', 'allticks'],\n dflt: false,\n role: 'style',\n editType: 'ticks+layoutstyle',\n description: [\n 'Determines if the axis lines or/and ticks are mirrored to',\n 'the opposite side of the plotting area.',\n 'If *true*, the axis lines are mirrored.',\n 'If *ticks*, the axis lines and ticks are mirrored.',\n 'If *false*, mirroring is disable.',\n 'If *all*, axis lines are mirrored on all shared-axes subplots.',\n 'If *allticks*, axis lines and ticks are mirrored',\n 'on all shared-axes subplots.'\n ].join(' ')\n },\n ticklen: {\n valType: 'number',\n min: 0,\n dflt: 5,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the tick length (in px).'\n },\n tickwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the tick width (in px).'\n },\n tickcolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the tick color.'\n },\n showticklabels: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'ticks',\n description: 'Determines whether or not the tick labels are drawn.'\n },\n automargin: {\n valType: 'boolean',\n dflt: false,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines whether long tick labels automatically grow the figure',\n 'margins.'\n ].join(' ')\n },\n showspikes: {\n valType: 'boolean',\n dflt: false,\n role: 'style',\n editType: 'modebar',\n description: [\n 'Determines whether or not spikes (aka droplines) are drawn for this axis.',\n 'Note: This only takes affect when hovermode = closest'\n ].join(' ')\n },\n spikecolor: {\n valType: 'color',\n dflt: null,\n role: 'style',\n editType: 'none',\n description: 'Sets the spike color. If undefined, will use the series color'\n },\n spikethickness: {\n valType: 'number',\n dflt: 3,\n role: 'style',\n editType: 'none',\n description: 'Sets the width (in px) of the zero line.'\n },\n spikedash: extendFlat({}, dash, {dflt: 'dash', editType: 'none'}),\n spikemode: {\n valType: 'flaglist',\n flags: ['toaxis', 'across', 'marker'],\n role: 'style',\n dflt: 'toaxis',\n editType: 'none',\n description: [\n 'Determines the drawing mode for the spike line',\n 'If *toaxis*, the line is drawn from the data point to the axis the ',\n 'series is plotted on.',\n\n 'If *across*, the line is drawn across the entire plot area, and',\n 'supercedes *toaxis*.',\n\n 'If *marker*, then a marker dot is drawn on the axis the series is',\n 'plotted on'\n ].join(' ')\n },\n spikesnap: {\n valType: 'enumerated',\n values: ['data', 'cursor', 'hovered data'],\n dflt: 'data',\n role: 'style',\n editType: 'none',\n description: 'Determines whether spikelines are stuck to the cursor or to the closest datapoints.'\n },\n tickfont: fontAttrs({\n editType: 'ticks',\n description: 'Sets the tick font.'\n }),\n tickangle: {\n valType: 'angle',\n dflt: 'auto',\n role: 'style',\n editType: 'ticks',\n description: [\n 'Sets the angle of the tick labels with respect to the horizontal.',\n 'For example, a `tickangle` of -90 draws the tick labels',\n 'vertically.'\n ].join(' ')\n },\n tickprefix: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'ticks',\n description: 'Sets a tick label prefix.'\n },\n showtickprefix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n role: 'style',\n editType: 'ticks',\n description: [\n 'If *all*, all tick labels are displayed with a prefix.',\n 'If *first*, only the first tick is displayed with a prefix.',\n 'If *last*, only the last tick is displayed with a suffix.',\n 'If *none*, tick prefixes are hidden.'\n ].join(' ')\n },\n ticksuffix: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'ticks',\n description: 'Sets a tick label suffix.'\n },\n showticksuffix: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n role: 'style',\n editType: 'ticks',\n description: 'Same as `showtickprefix` but for tick suffixes.'\n },\n showexponent: {\n valType: 'enumerated',\n values: ['all', 'first', 'last', 'none'],\n dflt: 'all',\n role: 'style',\n editType: 'ticks',\n description: [\n 'If *all*, all exponents are shown besides their significands.',\n 'If *first*, only the exponent of the first tick is shown.',\n 'If *last*, only the exponent of the last tick is shown.',\n 'If *none*, no exponents appear.'\n ].join(' ')\n },\n exponentformat: {\n valType: 'enumerated',\n values: ['none', 'e', 'E', 'power', 'SI', 'B'],\n dflt: 'B',\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines a formatting rule for the tick exponents.',\n 'For example, consider the number 1,000,000,000.',\n 'If *none*, it appears as 1,000,000,000.',\n 'If *e*, 1e+9.',\n 'If *E*, 1E+9.',\n 'If *power*, 1x10^9 (with 9 in a super script).',\n 'If *SI*, 1G.',\n 'If *B*, 1B.'\n ].join(' ')\n },\n separatethousands: {\n valType: 'boolean',\n dflt: false,\n role: 'style',\n editType: 'ticks',\n description: [\n 'If \"true\", even 4-digit integers are separated'\n ].join(' ')\n },\n tickformat: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'ticks',\n description: [\n 'Sets the tick label formatting rule using d3 formatting mini-languages',\n 'which are very similar to those in Python. For numbers, see:',\n FORMAT_LINK,\n 'And for dates see:',\n DATE_FORMAT_LINK,\n 'We add one item to d3\\'s date formatter: *%{n}f* for fractional seconds',\n 'with n digits. For example, *2016-10-13 09:15:23.456* with tickformat',\n '*%H~%M~%S.%2f* would display *09~15~23.46*'\n ].join(' ')\n },\n tickformatstops: templatedArray('tickformatstop', {\n enabled: {\n valType: 'boolean',\n role: 'info',\n dflt: true,\n editType: 'ticks',\n description: [\n 'Determines whether or not this stop is used.',\n 'If `false`, this stop is ignored even within its `dtickrange`.'\n ].join(' ')\n },\n dtickrange: {\n valType: 'info_array',\n role: 'info',\n items: [\n {valType: 'any', editType: 'ticks'},\n {valType: 'any', editType: 'ticks'}\n ],\n editType: 'ticks',\n description: [\n 'range [*min*, *max*], where *min*, *max* - dtick values',\n 'which describe some zoom level, it is possible to omit *min*',\n 'or *max* value by passing *null*'\n ].join(' ')\n },\n value: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'ticks',\n description: [\n 'string - dtickformat for described zoom level, the same as *tickformat*'\n ].join(' ')\n },\n editType: 'ticks'\n }),\n hoverformat: {\n valType: 'string',\n dflt: '',\n role: 'style',\n editType: 'none',\n description: [\n 'Sets the hover text formatting rule using d3 formatting mini-languages',\n 'which are very similar to those in Python. For numbers, see:',\n FORMAT_LINK,\n 'And for dates see:',\n DATE_FORMAT_LINK,\n 'We add one item to d3\\'s date formatter: *%{n}f* for fractional seconds',\n 'with n digits. For example, *2016-10-13 09:15:23.456* with tickformat',\n '*%H~%M~%S.%2f* would display *09~15~23.46*'\n ].join(' ')\n },\n // lines and grids\n showline: {\n valType: 'boolean',\n dflt: false,\n role: 'style',\n editType: 'ticks+layoutstyle',\n description: [\n 'Determines whether or not a line bounding this axis is drawn.'\n ].join(' ')\n },\n linecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'layoutstyle',\n description: 'Sets the axis line color.'\n },\n linewidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n editType: 'ticks+layoutstyle',\n description: 'Sets the width (in px) of the axis line.'\n },\n showgrid: {\n valType: 'boolean',\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines whether or not grid lines are drawn.',\n 'If *true*, the grid lines are drawn at every tick mark.'\n ].join(' ')\n },\n gridcolor: {\n valType: 'color',\n dflt: colorAttrs.lightLine,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the color of the grid lines.'\n },\n gridwidth: {\n valType: 'number',\n min: 0,\n dflt: 1,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the width (in px) of the grid lines.'\n },\n zeroline: {\n valType: 'boolean',\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines whether or not a line is drawn at along the 0 value',\n 'of this axis.',\n 'If *true*, the zero line is drawn on top of the grid lines.'\n ].join(' ')\n },\n zerolinecolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the line color of the zero line.'\n },\n zerolinewidth: {\n valType: 'number',\n dflt: 1,\n role: 'style',\n editType: 'ticks',\n description: 'Sets the width (in px) of the zero line.'\n },\n\n showdividers: {\n valType: 'boolean',\n dflt: true,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Determines whether or not a dividers are drawn',\n 'between the category levels of this axis.',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n dividercolor: {\n valType: 'color',\n dflt: colorAttrs.defaultLine,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Sets the color of the dividers',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n dividerwidth: {\n valType: 'number',\n dflt: 1,\n role: 'style',\n editType: 'ticks',\n description: [\n 'Sets the width (in px) of the dividers',\n 'Only has an effect on *multicategory* axes.'\n ].join(' ')\n },\n // TODO dividerlen: that would override \"to label base\" length?\n\n // positioning attributes\n // anchor: not used directly, just put here for reference\n // values are any opposite-letter axis id\n anchor: {\n valType: 'enumerated',\n values: [\n 'free',\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'plot',\n description: [\n 'If set to an opposite-letter axis id (e.g. `x2`, `y`), this axis is bound to',\n 'the corresponding opposite-letter axis.',\n 'If set to *free*, this axis\\' position is determined by `position`.'\n ].join(' ')\n },\n // side: not used directly, as values depend on direction\n // values are top, bottom for x axes, and left, right for y\n side: {\n valType: 'enumerated',\n values: ['top', 'bottom', 'left', 'right'],\n role: 'info',\n editType: 'plot',\n description: [\n 'Determines whether a x (y) axis is positioned',\n 'at the *bottom* (*left*) or *top* (*right*)',\n 'of the plotting area.'\n ].join(' ')\n },\n // overlaying: not used directly, just put here for reference\n // values are false and any other same-letter axis id that's not\n // itself overlaying anything\n overlaying: {\n valType: 'enumerated',\n values: [\n 'free',\n constants.idRegex.x.toString(),\n constants.idRegex.y.toString()\n ],\n role: 'info',\n editType: 'plot',\n description: [\n 'If set a same-letter axis id, this axis is overlaid on top of',\n 'the corresponding same-letter axis, with traces and axes visible for both',\n 'axes.',\n 'If *false*, this axis does not overlay any same-letter axes.',\n 'In this case, for axes with overlapping domains only the highest-numbered',\n 'axis will be visible.'\n ].join(' ')\n },\n layer: {\n valType: 'enumerated',\n values: ['above traces', 'below traces'],\n dflt: 'above traces',\n role: 'info',\n editType: 'plot',\n description: [\n 'Sets the layer on which this axis is displayed.',\n 'If *above traces*, this axis is displayed above all the subplot\\'s traces',\n 'If *below traces*, this axis is displayed below all the subplot\\'s traces,',\n 'but above the grid lines.',\n 'Useful when used together with scatter-like traces with `cliponaxis`',\n 'set to *false* to show markers and/or text nodes above this axis.'\n ].join(' ')\n },\n domain: {\n valType: 'info_array',\n role: 'info',\n items: [\n {valType: 'number', min: 0, max: 1, editType: 'plot'},\n {valType: 'number', min: 0, max: 1, editType: 'plot'}\n ],\n dflt: [0, 1],\n editType: 'plot',\n description: [\n 'Sets the domain of this axis (in plot fraction).'\n ].join(' ')\n },\n position: {\n valType: 'number',\n min: 0,\n max: 1,\n dflt: 0,\n role: 'style',\n editType: 'plot',\n description: [\n 'Sets the position of this axis in the plotting space',\n '(in normalized coordinates).',\n 'Only has an effect if `anchor` is set to *free*.'\n ].join(' ')\n },\n categoryorder: {\n valType: 'enumerated',\n values: [\n 'trace', 'category ascending', 'category descending', 'array',\n 'total ascending', 'total descending',\n 'min ascending', 'min descending',\n 'max ascending', 'max descending',\n 'sum ascending', 'sum descending',\n 'mean ascending', 'mean descending',\n 'median ascending', 'median descending'\n ],\n dflt: 'trace',\n role: 'info',\n editType: 'calc',\n description: [\n 'Specifies the ordering logic for the case of categorical variables.',\n 'By default, plotly uses *trace*, which specifies the order that is present in the data supplied.',\n 'Set `categoryorder` to *category ascending* or *category descending* if order should be determined by',\n 'the alphanumerical order of the category names.',\n 'Set `categoryorder` to *array* to derive the ordering from the attribute `categoryarray`. If a category',\n 'is not found in the `categoryarray` array, the sorting behavior for that attribute will be identical to',\n 'the *trace* mode. The unspecified categories will follow the categories in `categoryarray`.',\n 'Set `categoryorder` to *total ascending* or *total descending* if order should be determined by the',\n 'numerical order of the values.',\n 'Similarly, the order can be determined by the min, max, sum, mean or median of all the values.'\n ].join(' ')\n },\n categoryarray: {\n valType: 'data_array',\n role: 'info',\n editType: 'calc',\n description: [\n 'Sets the order in which categories on this axis appear.',\n 'Only has an effect if `categoryorder` is set to *array*.',\n 'Used with `categoryorder`.'\n ].join(' ')\n },\n uirevision: {\n valType: 'any',\n role: 'info',\n editType: 'none',\n description: [\n 'Controls persistence of user-driven changes in axis `range`,',\n '`autorange`, and `title` if in `editable: true` configuration.',\n 'Defaults to `layout.uirevision`.'\n ].join(' ')\n },\n editType: 'calc',\n\n _deprecated: {\n autotick: {\n valType: 'boolean',\n role: 'info',\n editType: 'ticks',\n description: [\n 'Obsolete.',\n 'Set `tickmode` to *auto* for old `autotick` *true* behavior.',\n 'Set `tickmode` to *linear* for `autotick` *false*.'\n ].join(' ')\n },\n title: {\n valType: 'string',\n role: 'info',\n editType: 'ticks',\n description: [\n 'Value of `title` is no longer a simple *string* but a set of sub-attributes.',\n 'To set the axis\\' title, please use `title.text` now.'\n ].join(' ')\n },\n titlefont: fontAttrs({\n editType: 'ticks',\n description: [\n 'Former `titlefont` is now the sub-attribute `font` of `title`.',\n 'To customize title font properties, please use `title.font` now.'\n ].join(' ')\n })\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n'use strict';\n\n\nmodule.exports = {\n xaxis: {\n valType: 'subplotid',\n role: 'info',\n dflt: 'x',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets a reference between this trace\\'s x coordinates and',\n 'a 2D cartesian x axis.',\n 'If *x* (the default value), the x coordinates refer to',\n '`layout.xaxis`.',\n 'If *x2*, the x coordinates refer to `layout.xaxis2`, and so on.'\n ].join(' ')\n },\n yaxis: {\n valType: 'subplotid',\n role: 'info',\n dflt: 'y',\n editType: 'calc+clearAxisTypes',\n description: [\n 'Sets a reference between this trace\\'s y coordinates and',\n 'a 2D cartesian y axis.',\n 'If *y* (the default value), the y coordinates refer to',\n '`layout.yaxis`.',\n 'If *y2*, the y coordinates refer to `layout.yaxis2`, and so on.'\n ].join(' ')\n }\n};\n","/**\n* Copyright 2012-2020, Plotly, Inc.\n* All rights reserved.\n*\n* This source code is licensed under the MIT license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\n\n'use strict';\n\nvar annAttrs = require('../annotations/attributes');\nvar overrideAll = require('../../plot_api/edit_types').overrideAll;\nvar templatedArray = require('../../plot_api/plot_template').templatedArray;\n\nmodule.exports = overrideAll(templatedArray('annotation', {\n visible: annAttrs.visible,\n x: {\n valType: 'any',\n role: 'info',\n description: [\n 'Sets the annotation\\'s x position.'\n ].join(' ')\n },\n y: {\n valType: 'any',\n role: 'info',\n description: [\n 'Sets the annotation\\'s y position.'\n ].join(' ')\n },\n z: {\n valType: 'any',\n role: 'info',\n description: [\n 'Sets the annotation\\'s z position.'\n ].join(' ')\n },\n ax: {\n valType: 'number',\n role: 'info',\n description: [\n 'Sets the x component of the arrow tail about the arrow head (in pixels).'\n ].join(' ')\n },\n ay: {\n valType: 'number',\n role: 'info',\n description: [\n 'Sets the y component of the arrow tail about the arrow head (in pixels).'\n ].join(' ')\n },\n\n xanchor: annAttrs.xanchor,\n xshift: annAttrs.xshift,\n yanchor: annAttrs.yanchor,\n yshift: annAttrs.yshift,\n\n text: annAttrs.text,\n textangle: annAttrs.textangle,\n font: annAttrs.font,\n width: annAttrs.width,\n height: annAttrs.height,\n opacity: annAttrs.opacity,\n align: annAttrs.align,\n valign: annAttrs.valign,\n bgcolor: annAttrs.bgcolor,\n bordercolor: annAttrs.bordercolor,\n borderpad: annAttrs.borderpad,\n borderwidth: annAttrs.borderwidth,\n showarrow: annAttrs.showarrow,\n arrowcolor: annAttrs.arrowcolor,\n arrowhead: annAttrs.arrowhead,\n startarrowhead: annAttrs.startarrowhead,\n arrowside: annAttrs.arrowside,\n arrowsize: annAttrs.arrowsize,\n startarrowsize: annAttrs.startarrowsize,\n arrowwidth: annAttrs.arrowwidth,\n standoff: annAttrs.standoff,\n startstandoff: annAttrs.startstandoff,\n hovertext: annAttrs.hovertext,\n hoverlabel: annAttrs.hoverlabel,\n captureevents: annAttrs.captureevents,\n\n // maybes later?\n // clicktoshow: annAttrs.clicktoshow,\n // xclick: annAttrs.xclick,\n // yclick: annAttrs.yclick,\n\n // not needed!\n // axref: 'pixel'\n // ayref: 'pixel'\n // xref: 'x'\n // yref: 'y\n // zref: 'z'\n}), 'calc', 'from-root');\n"],"sourceRoot":""}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy