@decidables/discountable-elements 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"discountableElements.esm.min.js","sources":["../../../node_modules/@lit/reactive-element/css-tag.js","../../../node_modules/@lit/reactive-element/reactive-element.js","../../../node_modules/lit-html/lit-html.js","../../../node_modules/lit-element/lit-element.js","../../../node_modules/d3-array/src/ascending.js","../../../node_modules/d3-array/src/descending.js","../../../node_modules/d3-array/src/bisector.js","../../../node_modules/d3-array/src/number.js","../../../node_modules/d3-array/src/bisect.js","../../../node_modules/d3-array/src/count.js","../../../node_modules/d3-array/src/cross.js","../../../node_modules/d3-array/src/cumsum.js","../../../node_modules/d3-array/src/variance.js","../../../node_modules/d3-array/src/deviation.js","../../../node_modules/d3-array/src/extent.js","../../../node_modules/d3-array/src/fsum.js","../../../node_modules/internmap/src/index.js","../../../node_modules/d3-array/src/identity.js","../../../node_modules/d3-array/src/group.js","../../../node_modules/d3-array/src/sort.js","../../../node_modules/d3-array/src/permute.js","../../../node_modules/d3-array/src/groupSort.js","../../../node_modules/d3-array/src/ticks.js","../../../node_modules/d3-array/src/threshold/sturges.js","../../../node_modules/d3-array/src/max.js","../../../node_modules/d3-array/src/maxIndex.js","../../../node_modules/d3-array/src/min.js","../../../node_modules/d3-array/src/minIndex.js","../../../node_modules/d3-array/src/quickselect.js","../../../node_modules/d3-array/src/greatest.js","../../../node_modules/d3-array/src/quantile.js","../../../node_modules/d3-array/src/threshold/freedmanDiaconis.js","../../../node_modules/d3-array/src/threshold/scott.js","../../../node_modules/d3-array/src/mean.js","../../../node_modules/d3-array/src/median.js","../../../node_modules/d3-array/src/merge.js","../../../node_modules/d3-array/src/mode.js","../../../node_modules/d3-array/src/pairs.js","../../../node_modules/d3-array/src/range.js","../../../node_modules/d3-array/src/sum.js","../../../node_modules/d3-array/src/reverse.js","../../../node_modules/d3-axis/src/identity.js","../../../node_modules/d3-axis/src/axis.js","../../../node_modules/d3-dispatch/src/dispatch.js","../../../node_modules/d3-selection/src/namespaces.js","../../../node_modules/d3-selection/src/namespace.js","../../../node_modules/d3-selection/src/creator.js","../../../node_modules/d3-selection/src/selector.js","../../../node_modules/d3-selection/src/selectorAll.js","../../../node_modules/d3-selection/src/selection/selectAll.js","../../../node_modules/d3-selection/src/array.js","../../../node_modules/d3-selection/src/matcher.js","../../../node_modules/d3-selection/src/selection/selectChild.js","../../../node_modules/d3-selection/src/selection/selectChildren.js","../../../node_modules/d3-selection/src/selection/sparse.js","../../../node_modules/d3-selection/src/selection/enter.js","../../../node_modules/d3-selection/src/selection/data.js","../../../node_modules/d3-selection/src/selection/sort.js","../../../node_modules/d3-selection/src/selection/attr.js","../../../node_modules/d3-selection/src/window.js","../../../node_modules/d3-selection/src/selection/style.js","../../../node_modules/d3-selection/src/selection/property.js","../../../node_modules/d3-selection/src/selection/classed.js","../../../node_modules/d3-selection/src/selection/text.js","../../../node_modules/d3-selection/src/selection/html.js","../../../node_modules/d3-selection/src/selection/raise.js","../../../node_modules/d3-selection/src/selection/lower.js","../../../node_modules/d3-selection/src/selection/insert.js","../../../node_modules/d3-selection/src/selection/remove.js","../../../node_modules/d3-selection/src/selection/clone.js","../../../node_modules/d3-selection/src/selection/on.js","../../../node_modules/d3-selection/src/selection/dispatch.js","../../../node_modules/d3-selection/src/selection/index.js","../../../node_modules/d3-selection/src/select.js","../../../node_modules/d3-selection/src/pointer.js","../../../node_modules/d3-selection/src/sourceEvent.js","../../../node_modules/d3-selection/src/selection/select.js","../../../node_modules/d3-selection/src/selection/filter.js","../../../node_modules/d3-selection/src/constant.js","../../../node_modules/d3-selection/src/selection/exit.js","../../../node_modules/d3-selection/src/selection/join.js","../../../node_modules/d3-selection/src/selection/merge.js","../../../node_modules/d3-selection/src/selection/order.js","../../../node_modules/d3-selection/src/selection/call.js","../../../node_modules/d3-selection/src/selection/nodes.js","../../../node_modules/d3-selection/src/selection/node.js","../../../node_modules/d3-selection/src/selection/size.js","../../../node_modules/d3-selection/src/selection/empty.js","../../../node_modules/d3-selection/src/selection/each.js","../../../node_modules/d3-selection/src/selection/append.js","../../../node_modules/d3-selection/src/selection/datum.js","../../../node_modules/d3-selection/src/selection/iterator.js","../../../node_modules/d3-drag/src/noevent.js","../../../node_modules/d3-drag/src/constant.js","../../../node_modules/d3-drag/src/event.js","../../../node_modules/d3-drag/src/drag.js","../../../node_modules/d3-drag/src/nodrag.js","../../../node_modules/d3-color/src/define.js","../../../node_modules/d3-color/src/color.js","../../../node_modules/d3-color/src/math.js","../../../node_modules/d3-color/src/lab.js","../../../node_modules/d3-color/src/cubehelix.js","../../../node_modules/d3-interpolate/src/constant.js","../../../node_modules/d3-interpolate/src/color.js","../../../node_modules/d3-interpolate/src/rgb.js","../../../node_modules/d3-interpolate/src/basis.js","../../../node_modules/d3-interpolate/src/numberArray.js","../../../node_modules/d3-interpolate/src/array.js","../../../node_modules/d3-interpolate/src/date.js","../../../node_modules/d3-interpolate/src/number.js","../../../node_modules/d3-interpolate/src/object.js","../../../node_modules/d3-interpolate/src/string.js","../../../node_modules/d3-interpolate/src/value.js","../../../node_modules/d3-interpolate/src/round.js","../../../node_modules/d3-interpolate/src/transform/decompose.js","../../../node_modules/d3-interpolate/src/transform/parse.js","../../../node_modules/d3-interpolate/src/transform/index.js","../../../node_modules/d3-interpolate/src/hsl.js","../../../node_modules/d3-interpolate/src/hcl.js","../../../node_modules/d3-interpolate/src/cubehelix.js","../../../node_modules/d3-interpolate/src/piecewise.js","../../../node_modules/d3-interpolate/src/quantize.js","../../../node_modules/d3-timer/src/timer.js","../../../node_modules/d3-timer/src/timeout.js","../../../node_modules/d3-transition/src/transition/schedule.js","../../../node_modules/d3-transition/src/transition/tween.js","../../../node_modules/d3-transition/src/transition/interpolate.js","../../../node_modules/d3-transition/src/transition/attr.js","../../../node_modules/d3-transition/src/transition/attrTween.js","../../../node_modules/d3-transition/src/transition/delay.js","../../../node_modules/d3-transition/src/transition/duration.js","../../../node_modules/d3-transition/src/transition/selection.js","../../../node_modules/d3-transition/src/transition/style.js","../../../node_modules/d3-transition/src/transition/index.js","../../../node_modules/d3-transition/src/transition/select.js","../../../node_modules/d3-transition/src/transition/selectAll.js","../../../node_modules/d3-transition/src/transition/filter.js","../../../node_modules/d3-transition/src/transition/merge.js","../../../node_modules/d3-transition/src/transition/transition.js","../../../node_modules/d3-transition/src/transition/on.js","../../../node_modules/d3-transition/src/transition/styleTween.js","../../../node_modules/d3-transition/src/transition/text.js","../../../node_modules/d3-transition/src/transition/textTween.js","../../../node_modules/d3-transition/src/transition/remove.js","../../../node_modules/d3-transition/src/transition/ease.js","../../../node_modules/d3-transition/src/transition/easeVarying.js","../../../node_modules/d3-transition/src/transition/end.js","../../../node_modules/d3-ease/src/linear.js","../../../node_modules/d3-ease/src/cubic.js","../../../node_modules/d3-transition/src/selection/transition.js","../../../node_modules/d3-transition/src/selection/index.js","../../../node_modules/d3-transition/src/selection/interrupt.js","../../../node_modules/d3-transition/src/interrupt.js","../../../node_modules/d3-path/src/path.js","../../../node_modules/d3-format/src/formatDecimal.js","../../../node_modules/d3-format/src/exponent.js","../../../node_modules/d3-format/src/formatSpecifier.js","../../../node_modules/d3-format/src/formatPrefixAuto.js","../../../node_modules/d3-format/src/formatRounded.js","../../../node_modules/d3-format/src/formatTypes.js","../../../node_modules/d3-format/src/identity.js","../../../node_modules/d3-format/src/locale.js","../../../node_modules/d3-format/src/defaultLocale.js","../../../node_modules/d3-format/src/formatGroup.js","../../../node_modules/d3-format/src/formatNumerals.js","../../../node_modules/d3-format/src/formatTrim.js","../../../node_modules/d3/node_modules/d3-geo/src/math.js","../../../node_modules/d3/node_modules/d3-geo/src/noop.js","../../../node_modules/d3/node_modules/d3-geo/src/stream.js","../../../node_modules/d3/node_modules/d3-geo/src/cartesian.js","../../../node_modules/d3/node_modules/d3-geo/src/compose.js","../../../node_modules/d3/node_modules/d3-geo/src/rotation.js","../../../node_modules/d3/node_modules/d3-geo/src/circle.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/buffer.js","../../../node_modules/d3/node_modules/d3-geo/src/pointEqual.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/rejoin.js","../../../node_modules/d3/node_modules/d3-geo/src/polygonContains.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/index.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/antimeridian.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/circle.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/rectangle.js","../../../node_modules/d3/node_modules/d3-geo/src/clip/line.js","../../../node_modules/d3/node_modules/d3-geo/src/identity.js","../../../node_modules/d3/node_modules/d3-geo/src/path/area.js","../../../node_modules/d3/node_modules/d3-geo/src/path/bounds.js","../../../node_modules/d3/node_modules/d3-geo/src/path/centroid.js","../../../node_modules/d3/node_modules/d3-geo/src/path/context.js","../../../node_modules/d3/node_modules/d3-geo/src/path/measure.js","../../../node_modules/d3/node_modules/d3-geo/src/path/string.js","../../../node_modules/d3/node_modules/d3-geo/src/path/index.js","../../../node_modules/d3/node_modules/d3-geo/src/transform.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/fit.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/resample.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/index.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/conic.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/conicEqualArea.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/cylindricalEqualArea.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/albers.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/albersUsa.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/azimuthal.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/azimuthalEqualArea.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/azimuthalEquidistant.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/mercator.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/conicConformal.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/equirectangular.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/conicEquidistant.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/equalEarth.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/gnomonic.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/orthographic.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/stereographic.js","../../../node_modules/d3/node_modules/d3-geo/src/projection/transverseMercator.js","../../../node_modules/d3-scale/src/init.js","../../../node_modules/d3-scale/src/ordinal.js","../../../node_modules/d3-scale/src/band.js","../../../node_modules/d3-scale/src/number.js","../../../node_modules/d3-scale/src/continuous.js","../../../node_modules/d3-scale/src/constant.js","../../../node_modules/d3-scale/src/tickFormat.js","../../../node_modules/d3-format/src/precisionPrefix.js","../../../node_modules/d3-format/src/precisionRound.js","../../../node_modules/d3-format/src/precisionFixed.js","../../../node_modules/d3-scale/src/linear.js","../../../node_modules/d3-scale/src/identity.js","../../../node_modules/d3-scale/src/nice.js","../../../node_modules/d3-scale/src/log.js","../../../node_modules/d3-scale/src/symlog.js","../../../node_modules/d3-scale/src/pow.js","../../../node_modules/d3-scale/src/quantile.js","../../../node_modules/d3-scale/src/threshold.js","../../../node_modules/d3-time/src/interval.js","../../../node_modules/d3-time/src/millisecond.js","../../../node_modules/d3-time/src/duration.js","../../../node_modules/d3-time/src/second.js","../../../node_modules/d3-time/src/minute.js","../../../node_modules/d3-time/src/hour.js","../../../node_modules/d3-time/src/day.js","../../../node_modules/d3-time/src/week.js","../../../node_modules/d3-time/src/month.js","../../../node_modules/d3-time/src/year.js","../../../node_modules/d3-time/src/ticks.js","../../../node_modules/d3-time-format/src/locale.js","../../../node_modules/d3-time-format/src/defaultLocale.js","../../../node_modules/d3-scale/src/time.js","../../../node_modules/d3-scale/src/sequential.js","../../../node_modules/d3-scale/src/diverging.js","../../../node_modules/d3-scale-chromatic/src/colors.js","../../../node_modules/d3-scale-chromatic/src/categorical/category10.js","../../../node_modules/d3-scale-chromatic/src/categorical/Accent.js","../../../node_modules/d3-scale-chromatic/src/categorical/Dark2.js","../../../node_modules/d3-scale-chromatic/src/categorical/Paired.js","../../../node_modules/d3-scale-chromatic/src/categorical/Pastel1.js","../../../node_modules/d3-scale-chromatic/src/categorical/Pastel2.js","../../../node_modules/d3-scale-chromatic/src/categorical/Set1.js","../../../node_modules/d3-scale-chromatic/src/categorical/Set2.js","../../../node_modules/d3-scale-chromatic/src/categorical/Set3.js","../../../node_modules/d3-scale-chromatic/src/categorical/Tableau10.js","../../../node_modules/d3-scale-chromatic/src/ramp.js","../../../node_modules/d3-scale-chromatic/src/diverging/BrBG.js","../../../node_modules/d3-scale-chromatic/src/diverging/PRGn.js","../../../node_modules/d3-scale-chromatic/src/diverging/PiYG.js","../../../node_modules/d3-scale-chromatic/src/diverging/PuOr.js","../../../node_modules/d3-scale-chromatic/src/diverging/RdBu.js","../../../node_modules/d3-scale-chromatic/src/diverging/RdGy.js","../../../node_modules/d3-scale-chromatic/src/diverging/RdYlBu.js","../../../node_modules/d3-scale-chromatic/src/diverging/RdYlGn.js","../../../node_modules/d3-scale-chromatic/src/diverging/Spectral.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/BuGn.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/BuPu.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/GnBu.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/OrRd.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/PuBuGn.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/PuBu.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/PuRd.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/RdPu.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/YlGnBu.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/YlGn.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/YlOrBr.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/YlOrRd.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Blues.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Greens.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Greys.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Purples.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Reds.js","../../../node_modules/d3-scale-chromatic/src/sequential-single/Oranges.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/cividis.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/cubehelix.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/rainbow.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/sinebow.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/turbo.js","../../../node_modules/d3-scale-chromatic/src/sequential-multi/viridis.js","../../../node_modules/d3/node_modules/d3-shape/src/constant.js","../../../node_modules/d3/node_modules/d3-shape/src/math.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/linear.js","../../../node_modules/d3/node_modules/d3-shape/src/point.js","../../../node_modules/d3/node_modules/d3-shape/src/line.js","../../../node_modules/d3/node_modules/d3-shape/src/path.js","../../../node_modules/d3/node_modules/d3-shape/src/array.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/bump.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/asterisk.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/circle.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/cross.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/diamond.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/diamond2.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/plus.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/square.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/square2.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/star.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/triangle.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/triangle2.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/wye.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol/times.js","../../../node_modules/d3/node_modules/d3-shape/src/symbol.js","../../../node_modules/d3/node_modules/d3-shape/src/noop.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/basis.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/basisClosed.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/basisOpen.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/bundle.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/cardinal.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/cardinalClosed.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/cardinalOpen.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/catmullRom.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/catmullRomClosed.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/catmullRomOpen.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/linearClosed.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/monotone.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/natural.js","../../../node_modules/d3/node_modules/d3-shape/src/curve/step.js","../../../node_modules/d3-zoom/src/transform.js","../../decidables-elements/src/decidables-element.js","../../decidables-elements/src/button.js","../../../node_modules/lit-html/directives/if-defined.js","../../decidables-elements/src/slider.js","../../decidables-elements/src/spinner.js","../../decidables-elements/src/switch.js","../../decidables-elements/src/toggle.js","../../decidables-elements/src/toggle-option.js","../src/discountable-element.js","../src/components/discountable-control.js","../src/components/discountable-response.js","../../../node_modules/lit-html/directive.js","../../../node_modules/lit-html/directive-helpers.js","../../../node_modules/lit-html/async-directive.js","../../../node_modules/@lit-labs/motion/animate-controller.js","../../../node_modules/@lit-labs/motion/animate.js","../../discountable-math/src/htd-math.js","../src/equations/htd-equation.js","../src/components/htd-calculation.js","../src/components/htd-curves.js","../../decidables-elements/src/mixin-resizeable.js","../../../node_modules/@observablehq/plot/src/defined.js","../../../node_modules/isoformat/src/format.js","../../../node_modules/isoformat/src/parse.js","../../../node_modules/@observablehq/plot/src/time.js","../../../node_modules/@observablehq/plot/src/options.js","../../../node_modules/@observablehq/plot/src/scales/index.js","../../../node_modules/@observablehq/plot/src/symbol.js","../../../node_modules/@observablehq/plot/src/transforms/basic.js","../../../node_modules/@observablehq/plot/src/transforms/group.js","../../../node_modules/@observablehq/plot/src/channel.js","../../../node_modules/@observablehq/plot/src/format.js","../../../node_modules/@observablehq/plot/src/memoize.js","../../../node_modules/@observablehq/plot/src/warnings.js","../../../node_modules/@observablehq/plot/src/style.js","../../../node_modules/@observablehq/plot/src/context.js","../../../node_modules/@observablehq/plot/src/projection.js","../../../node_modules/@observablehq/plot/src/scales/schemes.js","../../../node_modules/@observablehq/plot/src/scales/quantitative.js","../../../node_modules/d3-interpolate/src/lab.js","../../../node_modules/@observablehq/plot/src/scales/diverging.js","../../../node_modules/@observablehq/plot/src/scales/temporal.js","../../../node_modules/d3-scale/src/utcTime.js","../../../node_modules/@observablehq/plot/src/scales/ordinal.js","../../../node_modules/@observablehq/plot/src/scales.js","../../../node_modules/@observablehq/plot/src/dimensions.js","../../../node_modules/@observablehq/plot/src/facet.js","../../../node_modules/@observablehq/plot/src/mark.js","../../../node_modules/@observablehq/plot/src/interactions/pointer.js","../../../node_modules/@observablehq/plot/src/axes.js","../../../node_modules/@observablehq/plot/src/math.js","../../../node_modules/@observablehq/plot/src/marker.js","../../../node_modules/@observablehq/plot/src/transforms/inset.js","../../../node_modules/@observablehq/plot/src/transforms/interval.js","../../../node_modules/@observablehq/plot/src/marks/rule.js","../../../node_modules/@observablehq/plot/src/template.js","../../../node_modules/@observablehq/plot/src/marks/text.js","../../../node_modules/@observablehq/plot/src/marks/vector.js","../../../node_modules/@observablehq/plot/src/marks/axis.js","../../../node_modules/@observablehq/plot/src/legends/swatches.js","../../../node_modules/@observablehq/plot/src/legends.js","../../../node_modules/@observablehq/plot/src/legends/ramp.js","../../../node_modules/@observablehq/plot/src/marks/frame.js","../../../node_modules/@observablehq/plot/src/marks/tip.js","../../../node_modules/@observablehq/plot/src/plot.js","../../../node_modules/@observablehq/plot/src/curve.js","../../../node_modules/@observablehq/plot/src/transforms/bin.js","../../../node_modules/@observablehq/plot/src/transforms/stack.js","../../../node_modules/@observablehq/plot/src/transforms/exclusiveFacets.js","../../../node_modules/@observablehq/plot/src/marks/line.js","../../../node_modules/@observablehq/plot/src/marks/rect.js","../../../node_modules/@observablehq/plot/src/transforms/identity.js","../src/components/htd-fit.js","../src/components/itc-option.js","../src/components/itc-choice.js","../src/components/itc-task.js","../../../node_modules/d3-timer/src/interval.js","../src/equations/adk2v.js","../src/examples/htd-example.js","../src/examples/human.js","../src/examples/interactive.js","../src/examples/model.js"],"sourcesContent":["/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t=window,e=t.ShadowRoot&&(void 0===t.ShadyCSS||t.ShadyCSS.nativeShadow)&&\"adoptedStyleSheets\"in Document.prototype&&\"replace\"in CSSStyleSheet.prototype,s=Symbol(),n=new WeakMap;class o{constructor(t,e,n){if(this._$cssResult$=!0,n!==s)throw Error(\"CSSResult is not constructable. Use `unsafeCSS` or `css` instead.\");this.cssText=t,this.t=e}get styleSheet(){let t=this.o;const s=this.t;if(e&&void 0===t){const e=void 0!==s&&1===s.length;e&&(t=n.get(s)),void 0===t&&((this.o=t=new CSSStyleSheet).replaceSync(this.cssText),e&&n.set(s,t))}return t}toString(){return this.cssText}}const r=t=>new o(\"string\"==typeof t?t:t+\"\",void 0,s),i=(t,...e)=>{const n=1===t.length?t[0]:e.reduce(((e,s,n)=>e+(t=>{if(!0===t._$cssResult$)return t.cssText;if(\"number\"==typeof t)return t;throw Error(\"Value passed to 'css' function must be a 'css' function result: \"+t+\". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.\")})(s)+t[n+1]),t[0]);return new o(n,t,s)},S=(s,n)=>{e?s.adoptedStyleSheets=n.map((t=>t instanceof CSSStyleSheet?t:t.styleSheet)):n.forEach((e=>{const n=document.createElement(\"style\"),o=t.litNonce;void 0!==o&&n.setAttribute(\"nonce\",o),n.textContent=e.cssText,s.appendChild(n)}))},c=e?t=>t:t=>t instanceof CSSStyleSheet?(t=>{let e=\"\";for(const s of t.cssRules)e+=s.cssText;return r(e)})(t):t;export{o as CSSResult,S as adoptStyles,i as css,c as getCompatibleStyle,e as supportsAdoptingStyleSheets,r as unsafeCSS};\n//# sourceMappingURL=css-tag.js.map\n","import{getCompatibleStyle as t,adoptStyles as i}from\"./css-tag.js\";export{CSSResult,adoptStyles,css,getCompatibleStyle,supportsAdoptingStyleSheets,unsafeCSS}from\"./css-tag.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */var s;const e=window,r=e.trustedTypes,h=r?r.emptyScript:\"\",o=e.reactiveElementPolyfillSupport,n={toAttribute(t,i){switch(i){case Boolean:t=t?h:null;break;case Object:case Array:t=null==t?t:JSON.stringify(t)}return t},fromAttribute(t,i){let s=t;switch(i){case Boolean:s=null!==t;break;case Number:s=null===t?null:Number(t);break;case Object:case Array:try{s=JSON.parse(t)}catch(t){s=null}}return s}},a=(t,i)=>i!==t&&(i==i||t==t),l={attribute:!0,type:String,converter:n,reflect:!1,hasChanged:a},d=\"finalized\";class u extends HTMLElement{constructor(){super(),this._$Ei=new Map,this.isUpdatePending=!1,this.hasUpdated=!1,this._$El=null,this._$Eu()}static addInitializer(t){var i;this.finalize(),(null!==(i=this.h)&&void 0!==i?i:this.h=[]).push(t)}static get observedAttributes(){this.finalize();const t=[];return this.elementProperties.forEach(((i,s)=>{const e=this._$Ep(s,i);void 0!==e&&(this._$Ev.set(e,s),t.push(e))})),t}static createProperty(t,i=l){if(i.state&&(i.attribute=!1),this.finalize(),this.elementProperties.set(t,i),!i.noAccessor&&!this.prototype.hasOwnProperty(t)){const s=\"symbol\"==typeof t?Symbol():\"__\"+t,e=this.getPropertyDescriptor(t,s,i);void 0!==e&&Object.defineProperty(this.prototype,t,e)}}static getPropertyDescriptor(t,i,s){return{get(){return this[i]},set(e){const r=this[t];this[i]=e,this.requestUpdate(t,r,s)},configurable:!0,enumerable:!0}}static getPropertyOptions(t){return this.elementProperties.get(t)||l}static finalize(){if(this.hasOwnProperty(d))return!1;this[d]=!0;const t=Object.getPrototypeOf(this);if(t.finalize(),void 0!==t.h&&(this.h=[...t.h]),this.elementProperties=new Map(t.elementProperties),this._$Ev=new Map,this.hasOwnProperty(\"properties\")){const t=this.properties,i=[...Object.getOwnPropertyNames(t),...Object.getOwnPropertySymbols(t)];for(const s of i)this.createProperty(s,t[s])}return this.elementStyles=this.finalizeStyles(this.styles),!0}static finalizeStyles(i){const s=[];if(Array.isArray(i)){const e=new Set(i.flat(1/0).reverse());for(const i of e)s.unshift(t(i))}else void 0!==i&&s.push(t(i));return s}static _$Ep(t,i){const s=i.attribute;return!1===s?void 0:\"string\"==typeof s?s:\"string\"==typeof t?t.toLowerCase():void 0}_$Eu(){var t;this._$E_=new Promise((t=>this.enableUpdating=t)),this._$AL=new Map,this._$Eg(),this.requestUpdate(),null===(t=this.constructor.h)||void 0===t||t.forEach((t=>t(this)))}addController(t){var i,s;(null!==(i=this._$ES)&&void 0!==i?i:this._$ES=[]).push(t),void 0!==this.renderRoot&&this.isConnected&&(null===(s=t.hostConnected)||void 0===s||s.call(t))}removeController(t){var i;null===(i=this._$ES)||void 0===i||i.splice(this._$ES.indexOf(t)>>>0,1)}_$Eg(){this.constructor.elementProperties.forEach(((t,i)=>{this.hasOwnProperty(i)&&(this._$Ei.set(i,this[i]),delete this[i])}))}createRenderRoot(){var t;const s=null!==(t=this.shadowRoot)&&void 0!==t?t:this.attachShadow(this.constructor.shadowRootOptions);return i(s,this.constructor.elementStyles),s}connectedCallback(){var t;void 0===this.renderRoot&&(this.renderRoot=this.createRenderRoot()),this.enableUpdating(!0),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostConnected)||void 0===i?void 0:i.call(t)}))}enableUpdating(t){}disconnectedCallback(){var t;null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostDisconnected)||void 0===i?void 0:i.call(t)}))}attributeChangedCallback(t,i,s){this._$AK(t,s)}_$EO(t,i,s=l){var e;const r=this.constructor._$Ep(t,s);if(void 0!==r&&!0===s.reflect){const h=(void 0!==(null===(e=s.converter)||void 0===e?void 0:e.toAttribute)?s.converter:n).toAttribute(i,s.type);this._$El=t,null==h?this.removeAttribute(r):this.setAttribute(r,h),this._$El=null}}_$AK(t,i){var s;const e=this.constructor,r=e._$Ev.get(t);if(void 0!==r&&this._$El!==r){const t=e.getPropertyOptions(r),h=\"function\"==typeof t.converter?{fromAttribute:t.converter}:void 0!==(null===(s=t.converter)||void 0===s?void 0:s.fromAttribute)?t.converter:n;this._$El=r,this[r]=h.fromAttribute(i,t.type),this._$El=null}}requestUpdate(t,i,s){let e=!0;void 0!==t&&(((s=s||this.constructor.getPropertyOptions(t)).hasChanged||a)(this[t],i)?(this._$AL.has(t)||this._$AL.set(t,i),!0===s.reflect&&this._$El!==t&&(void 0===this._$EC&&(this._$EC=new Map),this._$EC.set(t,s))):e=!1),!this.isUpdatePending&&e&&(this._$E_=this._$Ej())}async _$Ej(){this.isUpdatePending=!0;try{await this._$E_}catch(t){Promise.reject(t)}const t=this.scheduleUpdate();return null!=t&&await t,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){var t;if(!this.isUpdatePending)return;this.hasUpdated,this._$Ei&&(this._$Ei.forEach(((t,i)=>this[i]=t)),this._$Ei=void 0);let i=!1;const s=this._$AL;try{i=this.shouldUpdate(s),i?(this.willUpdate(s),null===(t=this._$ES)||void 0===t||t.forEach((t=>{var i;return null===(i=t.hostUpdate)||void 0===i?void 0:i.call(t)})),this.update(s)):this._$Ek()}catch(t){throw i=!1,this._$Ek(),t}i&&this._$AE(s)}willUpdate(t){}_$AE(t){var i;null===(i=this._$ES)||void 0===i||i.forEach((t=>{var i;return null===(i=t.hostUpdated)||void 0===i?void 0:i.call(t)})),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(t)),this.updated(t)}_$Ek(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$E_}shouldUpdate(t){return!0}update(t){void 0!==this._$EC&&(this._$EC.forEach(((t,i)=>this._$EO(i,this[i],t))),this._$EC=void 0),this._$Ek()}updated(t){}firstUpdated(t){}}u[d]=!0,u.elementProperties=new Map,u.elementStyles=[],u.shadowRootOptions={mode:\"open\"},null==o||o({ReactiveElement:u}),(null!==(s=e.reactiveElementVersions)&&void 0!==s?s:e.reactiveElementVersions=[]).push(\"1.6.3\");export{u as ReactiveElement,n as defaultConverter,a as notEqual};\n//# sourceMappingURL=reactive-element.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nvar t;const i=window,s=i.trustedTypes,e=s?s.createPolicy(\"lit-html\",{createHTML:t=>t}):void 0,o=\"$lit$\",n=`lit$${(Math.random()+\"\").slice(9)}$`,l=\"?\"+n,h=`<${l}>`,r=document,u=()=>r.createComment(\"\"),d=t=>null===t||\"object\"!=typeof t&&\"function\"!=typeof t,c=Array.isArray,v=t=>c(t)||\"function\"==typeof(null==t?void 0:t[Symbol.iterator]),a=\"[ \\t\\n\\f\\r]\",f=/<(?:(!--|\\/[^a-zA-Z])|(\\/?[a-zA-Z][^>\\s]*)|(\\/?$))/g,_=/-->/g,m=/>/g,p=RegExp(`>|${a}(?:([^\\\\s\"'>=/]+)(${a}*=${a}*(?:[^ \\t\\n\\f\\r\"'\\`<>=]|(\"|')|))|$)`,\"g\"),g=/'/g,$=/\"/g,y=/^(?:script|style|textarea|title)$/i,w=t=>(i,...s)=>({_$litType$:t,strings:i,values:s}),x=w(1),b=w(2),T=Symbol.for(\"lit-noChange\"),A=Symbol.for(\"lit-nothing\"),E=new WeakMap,C=r.createTreeWalker(r,129,null,!1);function P(t,i){if(!Array.isArray(t)||!t.hasOwnProperty(\"raw\"))throw Error(\"invalid template strings array\");return void 0!==e?e.createHTML(i):i}const V=(t,i)=>{const s=t.length-1,e=[];let l,r=2===i?\"<svg>\":\"\",u=f;for(let i=0;i<s;i++){const s=t[i];let d,c,v=-1,a=0;for(;a<s.length&&(u.lastIndex=a,c=u.exec(s),null!==c);)a=u.lastIndex,u===f?\"!--\"===c[1]?u=_:void 0!==c[1]?u=m:void 0!==c[2]?(y.test(c[2])&&(l=RegExp(\"</\"+c[2],\"g\")),u=p):void 0!==c[3]&&(u=p):u===p?\">\"===c[0]?(u=null!=l?l:f,v=-1):void 0===c[1]?v=-2:(v=u.lastIndex-c[2].length,d=c[1],u=void 0===c[3]?p:'\"'===c[3]?$:g):u===$||u===g?u=p:u===_||u===m?u=f:(u=p,l=void 0);const w=u===p&&t[i+1].startsWith(\"/>\")?\" \":\"\";r+=u===f?s+h:v>=0?(e.push(d),s.slice(0,v)+o+s.slice(v)+n+w):s+n+(-2===v?(e.push(void 0),i):w)}return[P(t,r+(t[s]||\"<?>\")+(2===i?\"</svg>\":\"\")),e]};class N{constructor({strings:t,_$litType$:i},e){let h;this.parts=[];let r=0,d=0;const c=t.length-1,v=this.parts,[a,f]=V(t,i);if(this.el=N.createElement(a,e),C.currentNode=this.el.content,2===i){const t=this.el.content,i=t.firstChild;i.remove(),t.append(...i.childNodes)}for(;null!==(h=C.nextNode())&&v.length<c;){if(1===h.nodeType){if(h.hasAttributes()){const t=[];for(const i of h.getAttributeNames())if(i.endsWith(o)||i.startsWith(n)){const s=f[d++];if(t.push(i),void 0!==s){const t=h.getAttribute(s.toLowerCase()+o).split(n),i=/([.?@])?(.*)/.exec(s);v.push({type:1,index:r,name:i[2],strings:t,ctor:\".\"===i[1]?H:\"?\"===i[1]?L:\"@\"===i[1]?z:k})}else v.push({type:6,index:r})}for(const i of t)h.removeAttribute(i)}if(y.test(h.tagName)){const t=h.textContent.split(n),i=t.length-1;if(i>0){h.textContent=s?s.emptyScript:\"\";for(let s=0;s<i;s++)h.append(t[s],u()),C.nextNode(),v.push({type:2,index:++r});h.append(t[i],u())}}}else if(8===h.nodeType)if(h.data===l)v.push({type:2,index:r});else{let t=-1;for(;-1!==(t=h.data.indexOf(n,t+1));)v.push({type:7,index:r}),t+=n.length-1}r++}}static createElement(t,i){const s=r.createElement(\"template\");return s.innerHTML=t,s}}function S(t,i,s=t,e){var o,n,l,h;if(i===T)return i;let r=void 0!==e?null===(o=s._$Co)||void 0===o?void 0:o[e]:s._$Cl;const u=d(i)?void 0:i._$litDirective$;return(null==r?void 0:r.constructor)!==u&&(null===(n=null==r?void 0:r._$AO)||void 0===n||n.call(r,!1),void 0===u?r=void 0:(r=new u(t),r._$AT(t,s,e)),void 0!==e?(null!==(l=(h=s)._$Co)&&void 0!==l?l:h._$Co=[])[e]=r:s._$Cl=r),void 0!==r&&(i=S(t,r._$AS(t,i.values),r,e)),i}class M{constructor(t,i){this._$AV=[],this._$AN=void 0,this._$AD=t,this._$AM=i}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(t){var i;const{el:{content:s},parts:e}=this._$AD,o=(null!==(i=null==t?void 0:t.creationScope)&&void 0!==i?i:r).importNode(s,!0);C.currentNode=o;let n=C.nextNode(),l=0,h=0,u=e[0];for(;void 0!==u;){if(l===u.index){let i;2===u.type?i=new R(n,n.nextSibling,this,t):1===u.type?i=new u.ctor(n,u.name,u.strings,this,t):6===u.type&&(i=new Z(n,this,t)),this._$AV.push(i),u=e[++h]}l!==(null==u?void 0:u.index)&&(n=C.nextNode(),l++)}return C.currentNode=r,o}v(t){let i=0;for(const s of this._$AV)void 0!==s&&(void 0!==s.strings?(s._$AI(t,s,i),i+=s.strings.length-2):s._$AI(t[i])),i++}}class R{constructor(t,i,s,e){var o;this.type=2,this._$AH=A,this._$AN=void 0,this._$AA=t,this._$AB=i,this._$AM=s,this.options=e,this._$Cp=null===(o=null==e?void 0:e.isConnected)||void 0===o||o}get _$AU(){var t,i;return null!==(i=null===(t=this._$AM)||void 0===t?void 0:t._$AU)&&void 0!==i?i:this._$Cp}get parentNode(){let t=this._$AA.parentNode;const i=this._$AM;return void 0!==i&&11===(null==t?void 0:t.nodeType)&&(t=i.parentNode),t}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(t,i=this){t=S(this,t,i),d(t)?t===A||null==t||\"\"===t?(this._$AH!==A&&this._$AR(),this._$AH=A):t!==this._$AH&&t!==T&&this._(t):void 0!==t._$litType$?this.g(t):void 0!==t.nodeType?this.$(t):v(t)?this.T(t):this._(t)}k(t){return this._$AA.parentNode.insertBefore(t,this._$AB)}$(t){this._$AH!==t&&(this._$AR(),this._$AH=this.k(t))}_(t){this._$AH!==A&&d(this._$AH)?this._$AA.nextSibling.data=t:this.$(r.createTextNode(t)),this._$AH=t}g(t){var i;const{values:s,_$litType$:e}=t,o=\"number\"==typeof e?this._$AC(t):(void 0===e.el&&(e.el=N.createElement(P(e.h,e.h[0]),this.options)),e);if((null===(i=this._$AH)||void 0===i?void 0:i._$AD)===o)this._$AH.v(s);else{const t=new M(o,this),i=t.u(this.options);t.v(s),this.$(i),this._$AH=t}}_$AC(t){let i=E.get(t.strings);return void 0===i&&E.set(t.strings,i=new N(t)),i}T(t){c(this._$AH)||(this._$AH=[],this._$AR());const i=this._$AH;let s,e=0;for(const o of t)e===i.length?i.push(s=new R(this.k(u()),this.k(u()),this,this.options)):s=i[e],s._$AI(o),e++;e<i.length&&(this._$AR(s&&s._$AB.nextSibling,e),i.length=e)}_$AR(t=this._$AA.nextSibling,i){var s;for(null===(s=this._$AP)||void 0===s||s.call(this,!1,!0,i);t&&t!==this._$AB;){const i=t.nextSibling;t.remove(),t=i}}setConnected(t){var i;void 0===this._$AM&&(this._$Cp=t,null===(i=this._$AP)||void 0===i||i.call(this,t))}}class k{constructor(t,i,s,e,o){this.type=1,this._$AH=A,this._$AN=void 0,this.element=t,this.name=i,this._$AM=e,this.options=o,s.length>2||\"\"!==s[0]||\"\"!==s[1]?(this._$AH=Array(s.length-1).fill(new String),this.strings=s):this._$AH=A}get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}_$AI(t,i=this,s,e){const o=this.strings;let n=!1;if(void 0===o)t=S(this,t,i,0),n=!d(t)||t!==this._$AH&&t!==T,n&&(this._$AH=t);else{const e=t;let l,h;for(t=o[0],l=0;l<o.length-1;l++)h=S(this,e[s+l],i,l),h===T&&(h=this._$AH[l]),n||(n=!d(h)||h!==this._$AH[l]),h===A?t=A:t!==A&&(t+=(null!=h?h:\"\")+o[l+1]),this._$AH[l]=h}n&&!e&&this.j(t)}j(t){t===A?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,null!=t?t:\"\")}}class H extends k{constructor(){super(...arguments),this.type=3}j(t){this.element[this.name]=t===A?void 0:t}}const I=s?s.emptyScript:\"\";class L extends k{constructor(){super(...arguments),this.type=4}j(t){t&&t!==A?this.element.setAttribute(this.name,I):this.element.removeAttribute(this.name)}}class z extends k{constructor(t,i,s,e,o){super(t,i,s,e,o),this.type=5}_$AI(t,i=this){var s;if((t=null!==(s=S(this,t,i,0))&&void 0!==s?s:A)===T)return;const e=this._$AH,o=t===A&&e!==A||t.capture!==e.capture||t.once!==e.once||t.passive!==e.passive,n=t!==A&&(e===A||o);o&&this.element.removeEventListener(this.name,this,e),n&&this.element.addEventListener(this.name,this,t),this._$AH=t}handleEvent(t){var i,s;\"function\"==typeof this._$AH?this._$AH.call(null!==(s=null===(i=this.options)||void 0===i?void 0:i.host)&&void 0!==s?s:this.element,t):this._$AH.handleEvent(t)}}class Z{constructor(t,i,s){this.element=t,this.type=6,this._$AN=void 0,this._$AM=i,this.options=s}get _$AU(){return this._$AM._$AU}_$AI(t){S(this,t)}}const j={O:o,P:n,A:l,C:1,M:V,L:M,R:v,D:S,I:R,V:k,H:L,N:z,U:H,F:Z},B=i.litHtmlPolyfillSupport;null==B||B(N,R),(null!==(t=i.litHtmlVersions)&&void 0!==t?t:i.litHtmlVersions=[]).push(\"2.8.0\");const D=(t,i,s)=>{var e,o;const n=null!==(e=null==s?void 0:s.renderBefore)&&void 0!==e?e:i;let l=n._$litPart$;if(void 0===l){const t=null!==(o=null==s?void 0:s.renderBefore)&&void 0!==o?o:null;n._$litPart$=l=new R(i.insertBefore(u(),t),t,void 0,null!=s?s:{})}return l._$AI(t),l};export{j as _$LH,x as html,T as noChange,A as nothing,D as render,b as svg};\n//# sourceMappingURL=lit-html.js.map\n","import{ReactiveElement as t}from\"@lit/reactive-element\";export*from\"@lit/reactive-element\";import{render as e,noChange as i}from\"lit-html\";export*from\"lit-html\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */var l,o;const r=t;class s extends t{constructor(){super(...arguments),this.renderOptions={host:this},this._$Do=void 0}createRenderRoot(){var t,e;const i=super.createRenderRoot();return null!==(t=(e=this.renderOptions).renderBefore)&&void 0!==t||(e.renderBefore=i.firstChild),i}update(t){const i=this.render();this.hasUpdated||(this.renderOptions.isConnected=this.isConnected),super.update(t),this._$Do=e(i,this.renderRoot,this.renderOptions)}connectedCallback(){var t;super.connectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!0)}disconnectedCallback(){var t;super.disconnectedCallback(),null===(t=this._$Do)||void 0===t||t.setConnected(!1)}render(){return i}}s.finalized=!0,s._$litElement$=!0,null===(l=globalThis.litElementHydrateSupport)||void 0===l||l.call(globalThis,{LitElement:s});const n=globalThis.litElementPolyfillSupport;null==n||n({LitElement:s});const h={_$AK:(t,e,i)=>{t._$AK(e,i)},_$AL:t=>t._$AL};(null!==(o=globalThis.litElementVersions)&&void 0!==o?o:globalThis.litElementVersions=[]).push(\"3.3.3\");export{s as LitElement,r as UpdatingElement,h as _$LE};\n//# sourceMappingURL=lit-element.js.map\n","export default function ascending(a, b) {\n return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","export default function descending(a, b) {\n return a == null || b == null ? NaN\n : b < a ? -1\n : b > a ? 1\n : b >= a ? 0\n : NaN;\n}\n","import ascending from \"./ascending.js\";\nimport descending from \"./descending.js\";\n\nexport default function bisector(f) {\n let compare1, compare2, delta;\n\n // If an accessor is specified, promote it to a comparator. In this case we\n // can test whether the search value is (self-) comparable. We can’t do this\n // for a comparator (except for specific, known comparators) because we can’t\n // tell if the comparator is symmetric, and an asymmetric comparator can’t be\n // used to test whether a single value is comparable.\n if (f.length !== 2) {\n compare1 = ascending;\n compare2 = (d, x) => ascending(f(d), x);\n delta = (d, x) => f(d) - x;\n } else {\n compare1 = f === ascending || f === descending ? f : zero;\n compare2 = f;\n delta = f;\n }\n\n function left(a, x, lo = 0, hi = a.length) {\n if (lo < hi) {\n if (compare1(x, x) !== 0) return hi;\n do {\n const mid = (lo + hi) >>> 1;\n if (compare2(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n } while (lo < hi);\n }\n return lo;\n }\n\n function right(a, x, lo = 0, hi = a.length) {\n if (lo < hi) {\n if (compare1(x, x) !== 0) return hi;\n do {\n const mid = (lo + hi) >>> 1;\n if (compare2(a[mid], x) <= 0) lo = mid + 1;\n else hi = mid;\n } while (lo < hi);\n }\n return lo;\n }\n\n function center(a, x, lo = 0, hi = a.length) {\n const i = left(a, x, lo, hi - 1);\n return i > lo && delta(a[i - 1], x) > -delta(a[i], x) ? i - 1 : i;\n }\n\n return {left, center, right};\n}\n\nfunction zero() {\n return 0;\n}\n","export default function number(x) {\n return x === null ? NaN : +x;\n}\n\nexport function* numbers(values, valueof) {\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && (value = +value) >= value) {\n yield value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n yield value;\n }\n }\n }\n}\n","import ascending from \"./ascending.js\";\nimport bisector from \"./bisector.js\";\nimport number from \"./number.js\";\n\nconst ascendingBisect = bisector(ascending);\nexport const bisectRight = ascendingBisect.right;\nexport const bisectLeft = ascendingBisect.left;\nexport const bisectCenter = bisector(number).center;\nexport default bisectRight;\n","export default function count(values, valueof) {\n let count = 0;\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && (value = +value) >= value) {\n ++count;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n ++count;\n }\n }\n }\n return count;\n}\n","function length(array) {\n return array.length | 0;\n}\n\nfunction empty(length) {\n return !(length > 0);\n}\n\nfunction arrayify(values) {\n return typeof values !== \"object\" || \"length\" in values ? values : Array.from(values);\n}\n\nfunction reducer(reduce) {\n return values => reduce(...values);\n}\n\nexport default function cross(...values) {\n const reduce = typeof values[values.length - 1] === \"function\" && reducer(values.pop());\n values = values.map(arrayify);\n const lengths = values.map(length);\n const j = values.length - 1;\n const index = new Array(j + 1).fill(0);\n const product = [];\n if (j < 0 || lengths.some(empty)) return product;\n while (true) {\n product.push(index.map((j, i) => values[i][j]));\n let i = j;\n while (++index[i] === lengths[i]) {\n if (i === 0) return reduce ? product.map(reduce) : product;\n index[i--] = 0;\n }\n }\n}\n","export default function cumsum(values, valueof) {\n var sum = 0, index = 0;\n return Float64Array.from(values, valueof === undefined\n ? v => (sum += +v || 0)\n : v => (sum += +valueof(v, index++, values) || 0));\n}","export default function variance(values, valueof) {\n let count = 0;\n let delta;\n let mean = 0;\n let sum = 0;\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && (value = +value) >= value) {\n delta = value - mean;\n mean += delta / ++count;\n sum += delta * (value - mean);\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n delta = value - mean;\n mean += delta / ++count;\n sum += delta * (value - mean);\n }\n }\n }\n if (count > 1) return sum / (count - 1);\n}\n","import variance from \"./variance.js\";\n\nexport default function deviation(values, valueof) {\n const v = variance(values, valueof);\n return v ? Math.sqrt(v) : v;\n}\n","export default function extent(values, valueof) {\n let min;\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null) {\n if (min === undefined) {\n if (value >= value) min = max = value;\n } else {\n if (min > value) min = value;\n if (max < value) max = value;\n }\n }\n }\n }\n return [min, max];\n}\n","// https://github.com/python/cpython/blob/a74eea238f5baba15797e2e8b570d153bc8690a7/Modules/mathmodule.c#L1423\nexport class Adder {\n constructor() {\n this._partials = new Float64Array(32);\n this._n = 0;\n }\n add(x) {\n const p = this._partials;\n let i = 0;\n for (let j = 0; j < this._n && j < 32; j++) {\n const y = p[j],\n hi = x + y,\n lo = Math.abs(x) < Math.abs(y) ? x - (hi - y) : y - (hi - x);\n if (lo) p[i++] = lo;\n x = hi;\n }\n p[i] = x;\n this._n = i + 1;\n return this;\n }\n valueOf() {\n const p = this._partials;\n let n = this._n, x, y, lo, hi = 0;\n if (n > 0) {\n hi = p[--n];\n while (n > 0) {\n x = hi;\n y = p[--n];\n hi = x + y;\n lo = y - (hi - x);\n if (lo) break;\n }\n if (n > 0 && ((lo < 0 && p[n - 1] < 0) || (lo > 0 && p[n - 1] > 0))) {\n y = lo * 2;\n x = hi + y;\n if (y == x - hi) hi = x;\n }\n }\n return hi;\n }\n}\n\nexport function fsum(values, valueof) {\n const adder = new Adder();\n if (valueof === undefined) {\n for (let value of values) {\n if (value = +value) {\n adder.add(value);\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if (value = +valueof(value, ++index, values)) {\n adder.add(value);\n }\n }\n }\n return +adder;\n}\n\nexport function fcumsum(values, valueof) {\n const adder = new Adder();\n let index = -1;\n return Float64Array.from(values, valueof === undefined\n ? v => adder.add(+v || 0)\n : v => adder.add(+valueof(v, ++index, values) || 0)\n );\n}\n","export class InternMap extends Map {\n constructor(entries, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (entries != null) for (const [key, value] of entries) this.set(key, value);\n }\n get(key) {\n return super.get(intern_get(this, key));\n }\n has(key) {\n return super.has(intern_get(this, key));\n }\n set(key, value) {\n return super.set(intern_set(this, key), value);\n }\n delete(key) {\n return super.delete(intern_delete(this, key));\n }\n}\n\nexport class InternSet extends Set {\n constructor(values, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (values != null) for (const value of values) this.add(value);\n }\n has(value) {\n return super.has(intern_get(this, value));\n }\n add(value) {\n return super.add(intern_set(this, value));\n }\n delete(value) {\n return super.delete(intern_delete(this, value));\n }\n}\n\nfunction intern_get({_intern, _key}, value) {\n const key = _key(value);\n return _intern.has(key) ? _intern.get(key) : value;\n}\n\nfunction intern_set({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) return _intern.get(key);\n _intern.set(key, value);\n return value;\n}\n\nfunction intern_delete({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) {\n value = _intern.get(key);\n _intern.delete(key);\n }\n return value;\n}\n\nfunction keyof(value) {\n return value !== null && typeof value === \"object\" ? value.valueOf() : value;\n}\n","export default function identity(x) {\n return x;\n}\n","import {InternMap} from \"internmap\";\nimport identity from \"./identity.js\";\n\nexport default function group(values, ...keys) {\n return nest(values, identity, identity, keys);\n}\n\nexport function groups(values, ...keys) {\n return nest(values, Array.from, identity, keys);\n}\n\nfunction flatten(groups, keys) {\n for (let i = 1, n = keys.length; i < n; ++i) {\n groups = groups.flatMap(g => g.pop().map(([key, value]) => [...g, key, value]));\n }\n return groups;\n}\n\nexport function flatGroup(values, ...keys) {\n return flatten(groups(values, ...keys), keys);\n}\n\nexport function flatRollup(values, reduce, ...keys) {\n return flatten(rollups(values, reduce, ...keys), keys);\n}\n\nexport function rollup(values, reduce, ...keys) {\n return nest(values, identity, reduce, keys);\n}\n\nexport function rollups(values, reduce, ...keys) {\n return nest(values, Array.from, reduce, keys);\n}\n\nexport function index(values, ...keys) {\n return nest(values, identity, unique, keys);\n}\n\nexport function indexes(values, ...keys) {\n return nest(values, Array.from, unique, keys);\n}\n\nfunction unique(values) {\n if (values.length !== 1) throw new Error(\"duplicate key\");\n return values[0];\n}\n\nfunction nest(values, map, reduce, keys) {\n return (function regroup(values, i) {\n if (i >= keys.length) return reduce(values);\n const groups = new InternMap();\n const keyof = keys[i++];\n let index = -1;\n for (const value of values) {\n const key = keyof(value, ++index, values);\n const group = groups.get(key);\n if (group) group.push(value);\n else groups.set(key, [value]);\n }\n for (const [key, values] of groups) {\n groups.set(key, regroup(values, i));\n }\n return map(groups);\n })(values, 0);\n}\n","import ascending from \"./ascending.js\";\nimport permute from \"./permute.js\";\n\nexport default function sort(values, ...F) {\n if (typeof values[Symbol.iterator] !== \"function\") throw new TypeError(\"values is not iterable\");\n values = Array.from(values);\n let [f] = F;\n if ((f && f.length !== 2) || F.length > 1) {\n const index = Uint32Array.from(values, (d, i) => i);\n if (F.length > 1) {\n F = F.map(f => values.map(f));\n index.sort((i, j) => {\n for (const f of F) {\n const c = ascendingDefined(f[i], f[j]);\n if (c) return c;\n }\n });\n } else {\n f = values.map(f);\n index.sort((i, j) => ascendingDefined(f[i], f[j]));\n }\n return permute(values, index);\n }\n return values.sort(compareDefined(f));\n}\n\nexport function compareDefined(compare = ascending) {\n if (compare === ascending) return ascendingDefined;\n if (typeof compare !== \"function\") throw new TypeError(\"compare is not a function\");\n return (a, b) => {\n const x = compare(a, b);\n if (x || x === 0) return x;\n return (compare(b, b) === 0) - (compare(a, a) === 0);\n };\n}\n\nexport function ascendingDefined(a, b) {\n return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);\n}\n","export default function permute(source, keys) {\n return Array.from(keys, key => source[key]);\n}\n","import ascending from \"./ascending.js\";\nimport group, {rollup} from \"./group.js\";\nimport sort from \"./sort.js\";\n\nexport default function groupSort(values, reduce, key) {\n return (reduce.length !== 2\n ? sort(rollup(values, reduce, key), (([ak, av], [bk, bv]) => ascending(av, bv) || ascending(ak, bk)))\n : sort(group(values, key), (([ak, av], [bk, bv]) => reduce(av, bv) || ascending(ak, bk))))\n .map(([key]) => key);\n}\n","const e10 = Math.sqrt(50),\n e5 = Math.sqrt(10),\n e2 = Math.sqrt(2);\n\nfunction tickSpec(start, stop, count) {\n const step = (stop - start) / Math.max(0, count),\n power = Math.floor(Math.log10(step)),\n error = step / Math.pow(10, power),\n factor = error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1;\n let i1, i2, inc;\n if (power < 0) {\n inc = Math.pow(10, -power) / factor;\n i1 = Math.round(start * inc);\n i2 = Math.round(stop * inc);\n if (i1 / inc < start) ++i1;\n if (i2 / inc > stop) --i2;\n inc = -inc;\n } else {\n inc = Math.pow(10, power) * factor;\n i1 = Math.round(start / inc);\n i2 = Math.round(stop / inc);\n if (i1 * inc < start) ++i1;\n if (i2 * inc > stop) --i2;\n }\n if (i2 < i1 && 0.5 <= count && count < 2) return tickSpec(start, stop, count * 2);\n return [i1, i2, inc];\n}\n\nexport default function ticks(start, stop, count) {\n stop = +stop, start = +start, count = +count;\n if (!(count > 0)) return [];\n if (start === stop) return [start];\n const reverse = stop < start, [i1, i2, inc] = reverse ? tickSpec(stop, start, count) : tickSpec(start, stop, count);\n if (!(i2 >= i1)) return [];\n const n = i2 - i1 + 1, ticks = new Array(n);\n if (reverse) {\n if (inc < 0) for (let i = 0; i < n; ++i) ticks[i] = (i2 - i) / -inc;\n else for (let i = 0; i < n; ++i) ticks[i] = (i2 - i) * inc;\n } else {\n if (inc < 0) for (let i = 0; i < n; ++i) ticks[i] = (i1 + i) / -inc;\n else for (let i = 0; i < n; ++i) ticks[i] = (i1 + i) * inc;\n }\n return ticks;\n}\n\nexport function tickIncrement(start, stop, count) {\n stop = +stop, start = +start, count = +count;\n return tickSpec(start, stop, count)[2];\n}\n\nexport function tickStep(start, stop, count) {\n stop = +stop, start = +start, count = +count;\n const reverse = stop < start, inc = reverse ? tickIncrement(stop, start, count) : tickIncrement(start, stop, count);\n return (reverse ? -1 : 1) * (inc < 0 ? 1 / -inc : inc);\n}\n","import count from \"../count.js\";\n\nexport default function thresholdSturges(values) {\n return Math.max(1, Math.ceil(Math.log(count(values)) / Math.LN2) + 1);\n}\n","export default function max(values, valueof) {\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null\n && (max < value || (max === undefined && value >= value))) {\n max = value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (max < value || (max === undefined && value >= value))) {\n max = value;\n }\n }\n }\n return max;\n}\n","export default function maxIndex(values, valueof) {\n let max;\n let maxIndex = -1;\n let index = -1;\n if (valueof === undefined) {\n for (const value of values) {\n ++index;\n if (value != null\n && (max < value || (max === undefined && value >= value))) {\n max = value, maxIndex = index;\n }\n }\n } else {\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (max < value || (max === undefined && value >= value))) {\n max = value, maxIndex = index;\n }\n }\n }\n return maxIndex;\n}\n","export default function min(values, valueof) {\n let min;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null\n && (min > value || (min === undefined && value >= value))) {\n min = value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (min > value || (min === undefined && value >= value))) {\n min = value;\n }\n }\n }\n return min;\n}\n","export default function minIndex(values, valueof) {\n let min;\n let minIndex = -1;\n let index = -1;\n if (valueof === undefined) {\n for (const value of values) {\n ++index;\n if (value != null\n && (min > value || (min === undefined && value >= value))) {\n min = value, minIndex = index;\n }\n }\n } else {\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (min > value || (min === undefined && value >= value))) {\n min = value, minIndex = index;\n }\n }\n }\n return minIndex;\n}\n","import {ascendingDefined, compareDefined} from \"./sort.js\";\n\n// Based on https://github.com/mourner/quickselect\n// ISC license, Copyright 2018 Vladimir Agafonkin.\nexport default function quickselect(array, k, left = 0, right = Infinity, compare) {\n k = Math.floor(k);\n left = Math.floor(Math.max(0, left));\n right = Math.floor(Math.min(array.length - 1, right));\n\n if (!(left <= k && k <= right)) return array;\n\n compare = compare === undefined ? ascendingDefined : compareDefined(compare);\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselect(array, k, newLeft, newRight, compare);\n }\n\n const t = array[k];\n let i = left;\n let j = right;\n\n swap(array, left, k);\n if (compare(array[right], t) > 0) swap(array, left, right);\n\n while (i < j) {\n swap(array, i, j), ++i, --j;\n while (compare(array[i], t) < 0) ++i;\n while (compare(array[j], t) > 0) --j;\n }\n\n if (compare(array[left], t) === 0) swap(array, left, j);\n else ++j, swap(array, j, right);\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n\n return array;\n}\n\nfunction swap(array, i, j) {\n const t = array[i];\n array[i] = array[j];\n array[j] = t;\n}\n","import ascending from \"./ascending.js\";\n\nexport default function greatest(values, compare = ascending) {\n let max;\n let defined = false;\n if (compare.length === 1) {\n let maxValue;\n for (const element of values) {\n const value = compare(element);\n if (defined\n ? ascending(value, maxValue) > 0\n : ascending(value, value) === 0) {\n max = element;\n maxValue = value;\n defined = true;\n }\n }\n } else {\n for (const value of values) {\n if (defined\n ? compare(value, max) > 0\n : compare(value, value) === 0) {\n max = value;\n defined = true;\n }\n }\n }\n return max;\n}\n","import max from \"./max.js\";\nimport maxIndex from \"./maxIndex.js\";\nimport min from \"./min.js\";\nimport minIndex from \"./minIndex.js\";\nimport quickselect from \"./quickselect.js\";\nimport number, {numbers} from \"./number.js\";\nimport {ascendingDefined} from \"./sort.js\";\nimport greatest from \"./greatest.js\";\n\nexport default function quantile(values, p, valueof) {\n values = Float64Array.from(numbers(values, valueof));\n if (!(n = values.length) || isNaN(p = +p)) return;\n if (p <= 0 || n < 2) return min(values);\n if (p >= 1) return max(values);\n var n,\n i = (n - 1) * p,\n i0 = Math.floor(i),\n value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),\n value1 = min(values.subarray(i0 + 1));\n return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileSorted(values, p, valueof = number) {\n if (!(n = values.length) || isNaN(p = +p)) return;\n if (p <= 0 || n < 2) return +valueof(values[0], 0, values);\n if (p >= 1) return +valueof(values[n - 1], n - 1, values);\n var n,\n i = (n - 1) * p,\n i0 = Math.floor(i),\n value0 = +valueof(values[i0], i0, values),\n value1 = +valueof(values[i0 + 1], i0 + 1, values);\n return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileIndex(values, p, valueof = number) {\n if (isNaN(p = +p)) return;\n numbers = Float64Array.from(values, (_, i) => number(valueof(values[i], i, values)));\n if (p <= 0) return minIndex(numbers);\n if (p >= 1) return maxIndex(numbers);\n var numbers,\n index = Uint32Array.from(values, (_, i) => i),\n j = numbers.length - 1,\n i = Math.floor(j * p);\n quickselect(index, i, 0, j, (i, j) => ascendingDefined(numbers[i], numbers[j]));\n i = greatest(index.subarray(0, i + 1), (i) => numbers[i]);\n return i >= 0 ? i : -1;\n}\n","import count from \"../count.js\";\nimport quantile from \"../quantile.js\";\n\nexport default function thresholdFreedmanDiaconis(values, min, max) {\n const c = count(values), d = quantile(values, 0.75) - quantile(values, 0.25);\n return c && d ? Math.ceil((max - min) / (2 * d * Math.pow(c, -1 / 3))) : 1;\n}\n","import count from \"../count.js\";\nimport deviation from \"../deviation.js\";\n\nexport default function thresholdScott(values, min, max) {\n const c = count(values), d = deviation(values);\n return c && d ? Math.ceil((max - min) * Math.cbrt(c) / (3.49 * d)) : 1;\n}\n","export default function mean(values, valueof) {\n let count = 0;\n let sum = 0;\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && (value = +value) >= value) {\n ++count, sum += value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n ++count, sum += value;\n }\n }\n }\n if (count) return sum / count;\n}\n","import quantile, {quantileIndex} from \"./quantile.js\";\n\nexport default function median(values, valueof) {\n return quantile(values, 0.5, valueof);\n}\n\nexport function medianIndex(values, valueof) {\n return quantileIndex(values, 0.5, valueof);\n}\n","function* flatten(arrays) {\n for (const array of arrays) {\n yield* array;\n }\n}\n\nexport default function merge(arrays) {\n return Array.from(flatten(arrays));\n}\n","import {InternMap} from \"internmap\";\n\nexport default function mode(values, valueof) {\n const counts = new InternMap();\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && value >= value) {\n counts.set(value, (counts.get(value) || 0) + 1);\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && value >= value) {\n counts.set(value, (counts.get(value) || 0) + 1);\n }\n }\n }\n let modeValue;\n let modeCount = 0;\n for (const [value, count] of counts) {\n if (count > modeCount) {\n modeCount = count;\n modeValue = value;\n }\n }\n return modeValue;\n}\n","export default function pairs(values, pairof = pair) {\n const pairs = [];\n let previous;\n let first = false;\n for (const value of values) {\n if (first) pairs.push(pairof(previous, value));\n previous = value;\n first = true;\n }\n return pairs;\n}\n\nexport function pair(a, b) {\n return [a, b];\n}\n","export default function range(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n}\n","export default function sum(values, valueof) {\n let sum = 0;\n if (valueof === undefined) {\n for (let value of values) {\n if (value = +value) {\n sum += value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if (value = +valueof(value, ++index, values)) {\n sum += value;\n }\n }\n }\n return sum;\n}\n","export default function reverse(values) {\n if (typeof values[Symbol.iterator] !== \"function\") throw new TypeError(\"values is not iterable\");\n return Array.from(values).reverse();\n}\n","export default function(x) {\n return x;\n}\n","import identity from \"./identity.js\";\n\nvar top = 1,\n right = 2,\n bottom = 3,\n left = 4,\n epsilon = 1e-6;\n\nfunction translateX(x) {\n return \"translate(\" + x + \",0)\";\n}\n\nfunction translateY(y) {\n return \"translate(0,\" + y + \")\";\n}\n\nfunction number(scale) {\n return d => +scale(d);\n}\n\nfunction center(scale, offset) {\n offset = Math.max(0, scale.bandwidth() - offset * 2) / 2;\n if (scale.round()) offset = Math.round(offset);\n return d => +scale(d) + offset;\n}\n\nfunction entering() {\n return !this.__axis;\n}\n\nfunction axis(orient, scale) {\n var tickArguments = [],\n tickValues = null,\n tickFormat = null,\n tickSizeInner = 6,\n tickSizeOuter = 6,\n tickPadding = 3,\n offset = typeof window !== \"undefined\" && window.devicePixelRatio > 1 ? 0 : 0.5,\n k = orient === top || orient === left ? -1 : 1,\n x = orient === left || orient === right ? \"x\" : \"y\",\n transform = orient === top || orient === bottom ? translateX : translateY;\n\n function axis(context) {\n var values = tickValues == null ? (scale.ticks ? scale.ticks.apply(scale, tickArguments) : scale.domain()) : tickValues,\n format = tickFormat == null ? (scale.tickFormat ? scale.tickFormat.apply(scale, tickArguments) : identity) : tickFormat,\n spacing = Math.max(tickSizeInner, 0) + tickPadding,\n range = scale.range(),\n range0 = +range[0] + offset,\n range1 = +range[range.length - 1] + offset,\n position = (scale.bandwidth ? center : number)(scale.copy(), offset),\n selection = context.selection ? context.selection() : context,\n path = selection.selectAll(\".domain\").data([null]),\n tick = selection.selectAll(\".tick\").data(values, scale).order(),\n tickExit = tick.exit(),\n tickEnter = tick.enter().append(\"g\").attr(\"class\", \"tick\"),\n line = tick.select(\"line\"),\n text = tick.select(\"text\");\n\n path = path.merge(path.enter().insert(\"path\", \".tick\")\n .attr(\"class\", \"domain\")\n .attr(\"stroke\", \"currentColor\"));\n\n tick = tick.merge(tickEnter);\n\n line = line.merge(tickEnter.append(\"line\")\n .attr(\"stroke\", \"currentColor\")\n .attr(x + \"2\", k * tickSizeInner));\n\n text = text.merge(tickEnter.append(\"text\")\n .attr(\"fill\", \"currentColor\")\n .attr(x, k * spacing)\n .attr(\"dy\", orient === top ? \"0em\" : orient === bottom ? \"0.71em\" : \"0.32em\"));\n\n if (context !== selection) {\n path = path.transition(context);\n tick = tick.transition(context);\n line = line.transition(context);\n text = text.transition(context);\n\n tickExit = tickExit.transition(context)\n .attr(\"opacity\", epsilon)\n .attr(\"transform\", function(d) { return isFinite(d = position(d)) ? transform(d + offset) : this.getAttribute(\"transform\"); });\n\n tickEnter\n .attr(\"opacity\", epsilon)\n .attr(\"transform\", function(d) { var p = this.parentNode.__axis; return transform((p && isFinite(p = p(d)) ? p : position(d)) + offset); });\n }\n\n tickExit.remove();\n\n path\n .attr(\"d\", orient === left || orient === right\n ? (tickSizeOuter ? \"M\" + k * tickSizeOuter + \",\" + range0 + \"H\" + offset + \"V\" + range1 + \"H\" + k * tickSizeOuter : \"M\" + offset + \",\" + range0 + \"V\" + range1)\n : (tickSizeOuter ? \"M\" + range0 + \",\" + k * tickSizeOuter + \"V\" + offset + \"H\" + range1 + \"V\" + k * tickSizeOuter : \"M\" + range0 + \",\" + offset + \"H\" + range1));\n\n tick\n .attr(\"opacity\", 1)\n .attr(\"transform\", function(d) { return transform(position(d) + offset); });\n\n line\n .attr(x + \"2\", k * tickSizeInner);\n\n text\n .attr(x, k * spacing)\n .text(format);\n\n selection.filter(entering)\n .attr(\"fill\", \"none\")\n .attr(\"font-size\", 10)\n .attr(\"font-family\", \"sans-serif\")\n .attr(\"text-anchor\", orient === right ? \"start\" : orient === left ? \"end\" : \"middle\");\n\n selection\n .each(function() { this.__axis = position; });\n }\n\n axis.scale = function(_) {\n return arguments.length ? (scale = _, axis) : scale;\n };\n\n axis.ticks = function() {\n return tickArguments = Array.from(arguments), axis;\n };\n\n axis.tickArguments = function(_) {\n return arguments.length ? (tickArguments = _ == null ? [] : Array.from(_), axis) : tickArguments.slice();\n };\n\n axis.tickValues = function(_) {\n return arguments.length ? (tickValues = _ == null ? null : Array.from(_), axis) : tickValues && tickValues.slice();\n };\n\n axis.tickFormat = function(_) {\n return arguments.length ? (tickFormat = _, axis) : tickFormat;\n };\n\n axis.tickSize = function(_) {\n return arguments.length ? (tickSizeInner = tickSizeOuter = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeInner = function(_) {\n return arguments.length ? (tickSizeInner = +_, axis) : tickSizeInner;\n };\n\n axis.tickSizeOuter = function(_) {\n return arguments.length ? (tickSizeOuter = +_, axis) : tickSizeOuter;\n };\n\n axis.tickPadding = function(_) {\n return arguments.length ? (tickPadding = +_, axis) : tickPadding;\n };\n\n axis.offset = function(_) {\n return arguments.length ? (offset = +_, axis) : offset;\n };\n\n return axis;\n}\n\nexport function axisTop(scale) {\n return axis(top, scale);\n}\n\nexport function axisRight(scale) {\n return axis(right, scale);\n}\n\nexport function axisBottom(scale) {\n return axis(bottom, scale);\n}\n\nexport function axisLeft(scale) {\n return axis(left, scale);\n}\n","var noop = {value: () => {}};\n\nfunction dispatch() {\n for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {\n if (!(t = arguments[i] + \"\") || (t in _) || /[\\s.]/.test(t)) throw new Error(\"illegal type: \" + t);\n _[t] = [];\n }\n return new Dispatch(_);\n}\n\nfunction Dispatch(_) {\n this._ = _;\n}\n\nfunction parseTypenames(typenames, types) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n if (t && !types.hasOwnProperty(t)) throw new Error(\"unknown type: \" + t);\n return {type: t, name: name};\n });\n}\n\nDispatch.prototype = dispatch.prototype = {\n constructor: Dispatch,\n on: function(typename, callback) {\n var _ = this._,\n T = parseTypenames(typename + \"\", _),\n t,\n i = -1,\n n = T.length;\n\n // If no callback was specified, return the callback of the given type and name.\n if (arguments.length < 2) {\n while (++i < n) if ((t = (typename = T[i]).type) && (t = get(_[t], typename.name))) return t;\n return;\n }\n\n // If a type was specified, set the callback for the given type and name.\n // Otherwise, if a null callback was specified, remove callbacks of the given name.\n if (callback != null && typeof callback !== \"function\") throw new Error(\"invalid callback: \" + callback);\n while (++i < n) {\n if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);\n else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);\n }\n\n return this;\n },\n copy: function() {\n var copy = {}, _ = this._;\n for (var t in _) copy[t] = _[t].slice();\n return new Dispatch(copy);\n },\n call: function(type, that) {\n if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n },\n apply: function(type, that, args) {\n if (!this._.hasOwnProperty(type)) throw new Error(\"unknown type: \" + type);\n for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);\n }\n};\n\nfunction get(type, name) {\n for (var i = 0, n = type.length, c; i < n; ++i) {\n if ((c = type[i]).name === name) {\n return c.value;\n }\n }\n}\n\nfunction set(type, name, callback) {\n for (var i = 0, n = type.length; i < n; ++i) {\n if (type[i].name === name) {\n type[i] = noop, type = type.slice(0, i).concat(type.slice(i + 1));\n break;\n }\n }\n if (callback != null) type.push({name: name, value: callback});\n return type;\n}\n\nexport default dispatch;\n","export var xhtml = \"http://www.w3.org/1999/xhtml\";\n\nexport default {\n svg: \"http://www.w3.org/2000/svg\",\n xhtml: xhtml,\n xlink: \"http://www.w3.org/1999/xlink\",\n xml: \"http://www.w3.org/XML/1998/namespace\",\n xmlns: \"http://www.w3.org/2000/xmlns/\"\n};\n","import namespaces from \"./namespaces.js\";\n\nexport default function(name) {\n var prefix = name += \"\", i = prefix.indexOf(\":\");\n if (i >= 0 && (prefix = name.slice(0, i)) !== \"xmlns\") name = name.slice(i + 1);\n return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name; // eslint-disable-line no-prototype-builtins\n}\n","import namespace from \"./namespace.js\";\nimport {xhtml} from \"./namespaces.js\";\n\nfunction creatorInherit(name) {\n return function() {\n var document = this.ownerDocument,\n uri = this.namespaceURI;\n return uri === xhtml && document.documentElement.namespaceURI === xhtml\n ? document.createElement(name)\n : document.createElementNS(uri, name);\n };\n}\n\nfunction creatorFixed(fullname) {\n return function() {\n return this.ownerDocument.createElementNS(fullname.space, fullname.local);\n };\n}\n\nexport default function(name) {\n var fullname = namespace(name);\n return (fullname.local\n ? creatorFixed\n : creatorInherit)(fullname);\n}\n","function none() {}\n\nexport default function(selector) {\n return selector == null ? none : function() {\n return this.querySelector(selector);\n };\n}\n","function empty() {\n return [];\n}\n\nexport default function(selector) {\n return selector == null ? empty : function() {\n return this.querySelectorAll(selector);\n };\n}\n","import {Selection} from \"./index.js\";\nimport array from \"../array.js\";\nimport selectorAll from \"../selectorAll.js\";\n\nfunction arrayAll(select) {\n return function() {\n return array(select.apply(this, arguments));\n };\n}\n\nexport default function(select) {\n if (typeof select === \"function\") select = arrayAll(select);\n else select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n subgroups.push(select.call(node, node.__data__, i, group));\n parents.push(node);\n }\n }\n }\n\n return new Selection(subgroups, parents);\n}\n","// Given something array like (or null), returns something that is strictly an\n// array. This is used to ensure that array-like objects passed to d3.selectAll\n// or selection.selectAll are converted into proper arrays when creating a\n// selection; we don’t ever want to create a selection backed by a live\n// HTMLCollection or NodeList. However, note that selection.selectAll will use a\n// static NodeList as a group, since it safely derived from querySelectorAll.\nexport default function array(x) {\n return x == null ? [] : Array.isArray(x) ? x : Array.from(x);\n}\n","export default function(selector) {\n return function() {\n return this.matches(selector);\n };\n}\n\nexport function childMatcher(selector) {\n return function(node) {\n return node.matches(selector);\n };\n}\n\n","import {childMatcher} from \"../matcher.js\";\n\nvar find = Array.prototype.find;\n\nfunction childFind(match) {\n return function() {\n return find.call(this.children, match);\n };\n}\n\nfunction childFirst() {\n return this.firstElementChild;\n}\n\nexport default function(match) {\n return this.select(match == null ? childFirst\n : childFind(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","import {childMatcher} from \"../matcher.js\";\n\nvar filter = Array.prototype.filter;\n\nfunction children() {\n return Array.from(this.children);\n}\n\nfunction childrenFilter(match) {\n return function() {\n return filter.call(this.children, match);\n };\n}\n\nexport default function(match) {\n return this.selectAll(match == null ? children\n : childrenFilter(typeof match === \"function\" ? match : childMatcher(match)));\n}\n","export default function(update) {\n return new Array(update.length);\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n return new Selection(this._enter || this._groups.map(sparse), this._parents);\n}\n\nexport function EnterNode(parent, datum) {\n this.ownerDocument = parent.ownerDocument;\n this.namespaceURI = parent.namespaceURI;\n this._next = null;\n this._parent = parent;\n this.__data__ = datum;\n}\n\nEnterNode.prototype = {\n constructor: EnterNode,\n appendChild: function(child) { return this._parent.insertBefore(child, this._next); },\n insertBefore: function(child, next) { return this._parent.insertBefore(child, next); },\n querySelector: function(selector) { return this._parent.querySelector(selector); },\n querySelectorAll: function(selector) { return this._parent.querySelectorAll(selector); }\n};\n","import {Selection} from \"./index.js\";\nimport {EnterNode} from \"./enter.js\";\nimport constant from \"../constant.js\";\n\nfunction bindIndex(parent, group, enter, update, exit, data) {\n var i = 0,\n node,\n groupLength = group.length,\n dataLength = data.length;\n\n // Put any non-null nodes that fit into update.\n // Put any null nodes into enter.\n // Put any remaining data into enter.\n for (; i < dataLength; ++i) {\n if (node = group[i]) {\n node.__data__ = data[i];\n update[i] = node;\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Put any non-null nodes that don’t fit into exit.\n for (; i < groupLength; ++i) {\n if (node = group[i]) {\n exit[i] = node;\n }\n }\n}\n\nfunction bindKey(parent, group, enter, update, exit, data, key) {\n var i,\n node,\n nodeByKeyValue = new Map,\n groupLength = group.length,\n dataLength = data.length,\n keyValues = new Array(groupLength),\n keyValue;\n\n // Compute the key for each node.\n // If multiple nodes have the same key, the duplicates are added to exit.\n for (i = 0; i < groupLength; ++i) {\n if (node = group[i]) {\n keyValues[i] = keyValue = key.call(node, node.__data__, i, group) + \"\";\n if (nodeByKeyValue.has(keyValue)) {\n exit[i] = node;\n } else {\n nodeByKeyValue.set(keyValue, node);\n }\n }\n }\n\n // Compute the key for each datum.\n // If there a node associated with this key, join and add it to update.\n // If there is not (or the key is a duplicate), add it to enter.\n for (i = 0; i < dataLength; ++i) {\n keyValue = key.call(parent, data[i], i, data) + \"\";\n if (node = nodeByKeyValue.get(keyValue)) {\n update[i] = node;\n node.__data__ = data[i];\n nodeByKeyValue.delete(keyValue);\n } else {\n enter[i] = new EnterNode(parent, data[i]);\n }\n }\n\n // Add any remaining nodes that were not bound to data to exit.\n for (i = 0; i < groupLength; ++i) {\n if ((node = group[i]) && (nodeByKeyValue.get(keyValues[i]) === node)) {\n exit[i] = node;\n }\n }\n}\n\nfunction datum(node) {\n return node.__data__;\n}\n\nexport default function(value, key) {\n if (!arguments.length) return Array.from(this, datum);\n\n var bind = key ? bindKey : bindIndex,\n parents = this._parents,\n groups = this._groups;\n\n if (typeof value !== \"function\") value = constant(value);\n\n for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {\n var parent = parents[j],\n group = groups[j],\n groupLength = group.length,\n data = arraylike(value.call(parent, parent && parent.__data__, j, parents)),\n dataLength = data.length,\n enterGroup = enter[j] = new Array(dataLength),\n updateGroup = update[j] = new Array(dataLength),\n exitGroup = exit[j] = new Array(groupLength);\n\n bind(parent, group, enterGroup, updateGroup, exitGroup, data, key);\n\n // Now connect the enter nodes to their following update node, such that\n // appendChild can insert the materialized enter node before this node,\n // rather than at the end of the parent node.\n for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {\n if (previous = enterGroup[i0]) {\n if (i0 >= i1) i1 = i0 + 1;\n while (!(next = updateGroup[i1]) && ++i1 < dataLength);\n previous._next = next || null;\n }\n }\n }\n\n update = new Selection(update, parents);\n update._enter = enter;\n update._exit = exit;\n return update;\n}\n\n// Given some data, this returns an array-like view of it: an object that\n// exposes a length property and allows numeric indexing. Note that unlike\n// selectAll, this isn’t worried about “live” collections because the resulting\n// array will only be used briefly while data is being bound. (It is possible to\n// cause the data to change while iterating by using a key function, but please\n// don’t; we’d rather avoid a gratuitous copy.)\nfunction arraylike(data) {\n return typeof data === \"object\" && \"length\" in data\n ? data // Array, TypedArray, NodeList, array-like\n : Array.from(data); // Map, Set, iterable, string, or anything else\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(compare) {\n if (!compare) compare = ascending;\n\n function compareNode(a, b) {\n return a && b ? compare(a.__data__, b.__data__) : !a - !b;\n }\n\n for (var groups = this._groups, m = groups.length, sortgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, sortgroup = sortgroups[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n sortgroup[i] = node;\n }\n }\n sortgroup.sort(compareNode);\n }\n\n return new Selection(sortgroups, this._parents).order();\n}\n\nfunction ascending(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","import namespace from \"../namespace.js\";\n\nfunction attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n}\n\nfunction attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n}\n\nfunction attrConstant(name, value) {\n return function() {\n this.setAttribute(name, value);\n };\n}\n\nfunction attrConstantNS(fullname, value) {\n return function() {\n this.setAttributeNS(fullname.space, fullname.local, value);\n };\n}\n\nfunction attrFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttribute(name);\n else this.setAttribute(name, v);\n };\n}\n\nfunction attrFunctionNS(fullname, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.removeAttributeNS(fullname.space, fullname.local);\n else this.setAttributeNS(fullname.space, fullname.local, v);\n };\n}\n\nexport default function(name, value) {\n var fullname = namespace(name);\n\n if (arguments.length < 2) {\n var node = this.node();\n return fullname.local\n ? node.getAttributeNS(fullname.space, fullname.local)\n : node.getAttribute(fullname);\n }\n\n return this.each((value == null\n ? (fullname.local ? attrRemoveNS : attrRemove) : (typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)\n : (fullname.local ? attrConstantNS : attrConstant)))(fullname, value));\n}\n","export default function(node) {\n return (node.ownerDocument && node.ownerDocument.defaultView) // node is a Node\n || (node.document && node) // node is a Window\n || node.defaultView; // node is a Document\n}\n","import defaultView from \"../window.js\";\n\nfunction styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n}\n\nfunction styleConstant(name, value, priority) {\n return function() {\n this.style.setProperty(name, value, priority);\n };\n}\n\nfunction styleFunction(name, value, priority) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) this.style.removeProperty(name);\n else this.style.setProperty(name, v, priority);\n };\n}\n\nexport default function(name, value, priority) {\n return arguments.length > 1\n ? this.each((value == null\n ? styleRemove : typeof value === \"function\"\n ? styleFunction\n : styleConstant)(name, value, priority == null ? \"\" : priority))\n : styleValue(this.node(), name);\n}\n\nexport function styleValue(node, name) {\n return node.style.getPropertyValue(name)\n || defaultView(node).getComputedStyle(node, null).getPropertyValue(name);\n}\n","function propertyRemove(name) {\n return function() {\n delete this[name];\n };\n}\n\nfunction propertyConstant(name, value) {\n return function() {\n this[name] = value;\n };\n}\n\nfunction propertyFunction(name, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (v == null) delete this[name];\n else this[name] = v;\n };\n}\n\nexport default function(name, value) {\n return arguments.length > 1\n ? this.each((value == null\n ? propertyRemove : typeof value === \"function\"\n ? propertyFunction\n : propertyConstant)(name, value))\n : this.node()[name];\n}\n","function classArray(string) {\n return string.trim().split(/^|\\s+/);\n}\n\nfunction classList(node) {\n return node.classList || new ClassList(node);\n}\n\nfunction ClassList(node) {\n this._node = node;\n this._names = classArray(node.getAttribute(\"class\") || \"\");\n}\n\nClassList.prototype = {\n add: function(name) {\n var i = this._names.indexOf(name);\n if (i < 0) {\n this._names.push(name);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n remove: function(name) {\n var i = this._names.indexOf(name);\n if (i >= 0) {\n this._names.splice(i, 1);\n this._node.setAttribute(\"class\", this._names.join(\" \"));\n }\n },\n contains: function(name) {\n return this._names.indexOf(name) >= 0;\n }\n};\n\nfunction classedAdd(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.add(names[i]);\n}\n\nfunction classedRemove(node, names) {\n var list = classList(node), i = -1, n = names.length;\n while (++i < n) list.remove(names[i]);\n}\n\nfunction classedTrue(names) {\n return function() {\n classedAdd(this, names);\n };\n}\n\nfunction classedFalse(names) {\n return function() {\n classedRemove(this, names);\n };\n}\n\nfunction classedFunction(names, value) {\n return function() {\n (value.apply(this, arguments) ? classedAdd : classedRemove)(this, names);\n };\n}\n\nexport default function(name, value) {\n var names = classArray(name + \"\");\n\n if (arguments.length < 2) {\n var list = classList(this.node()), i = -1, n = names.length;\n while (++i < n) if (!list.contains(names[i])) return false;\n return true;\n }\n\n return this.each((typeof value === \"function\"\n ? classedFunction : value\n ? classedTrue\n : classedFalse)(names, value));\n}\n","function textRemove() {\n this.textContent = \"\";\n}\n\nfunction textConstant(value) {\n return function() {\n this.textContent = value;\n };\n}\n\nfunction textFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.textContent = v == null ? \"\" : v;\n };\n}\n\nexport default function(value) {\n return arguments.length\n ? this.each(value == null\n ? textRemove : (typeof value === \"function\"\n ? textFunction\n : textConstant)(value))\n : this.node().textContent;\n}\n","function htmlRemove() {\n this.innerHTML = \"\";\n}\n\nfunction htmlConstant(value) {\n return function() {\n this.innerHTML = value;\n };\n}\n\nfunction htmlFunction(value) {\n return function() {\n var v = value.apply(this, arguments);\n this.innerHTML = v == null ? \"\" : v;\n };\n}\n\nexport default function(value) {\n return arguments.length\n ? this.each(value == null\n ? htmlRemove : (typeof value === \"function\"\n ? htmlFunction\n : htmlConstant)(value))\n : this.node().innerHTML;\n}\n","function raise() {\n if (this.nextSibling) this.parentNode.appendChild(this);\n}\n\nexport default function() {\n return this.each(raise);\n}\n","function lower() {\n if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);\n}\n\nexport default function() {\n return this.each(lower);\n}\n","import creator from \"../creator.js\";\nimport selector from \"../selector.js\";\n\nfunction constantNull() {\n return null;\n}\n\nexport default function(name, before) {\n var create = typeof name === \"function\" ? name : creator(name),\n select = before == null ? constantNull : typeof before === \"function\" ? before : selector(before);\n return this.select(function() {\n return this.insertBefore(create.apply(this, arguments), select.apply(this, arguments) || null);\n });\n}\n","function remove() {\n var parent = this.parentNode;\n if (parent) parent.removeChild(this);\n}\n\nexport default function() {\n return this.each(remove);\n}\n","function selection_cloneShallow() {\n var clone = this.cloneNode(false), parent = this.parentNode;\n return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nfunction selection_cloneDeep() {\n var clone = this.cloneNode(true), parent = this.parentNode;\n return parent ? parent.insertBefore(clone, this.nextSibling) : clone;\n}\n\nexport default function(deep) {\n return this.select(deep ? selection_cloneDeep : selection_cloneShallow);\n}\n","function contextListener(listener) {\n return function(event) {\n listener.call(this, event, this.__data__);\n };\n}\n\nfunction parseTypenames(typenames) {\n return typenames.trim().split(/^|\\s+/).map(function(t) {\n var name = \"\", i = t.indexOf(\".\");\n if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);\n return {type: t, name: name};\n });\n}\n\nfunction onRemove(typename) {\n return function() {\n var on = this.__on;\n if (!on) return;\n for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {\n if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.options);\n } else {\n on[++i] = o;\n }\n }\n if (++i) on.length = i;\n else delete this.__on;\n };\n}\n\nfunction onAdd(typename, value, options) {\n return function() {\n var on = this.__on, o, listener = contextListener(value);\n if (on) for (var j = 0, m = on.length; j < m; ++j) {\n if ((o = on[j]).type === typename.type && o.name === typename.name) {\n this.removeEventListener(o.type, o.listener, o.options);\n this.addEventListener(o.type, o.listener = listener, o.options = options);\n o.value = value;\n return;\n }\n }\n this.addEventListener(typename.type, listener, options);\n o = {type: typename.type, name: typename.name, value: value, listener: listener, options: options};\n if (!on) this.__on = [o];\n else on.push(o);\n };\n}\n\nexport default function(typename, value, options) {\n var typenames = parseTypenames(typename + \"\"), i, n = typenames.length, t;\n\n if (arguments.length < 2) {\n var on = this.node().__on;\n if (on) for (var j = 0, m = on.length, o; j < m; ++j) {\n for (i = 0, o = on[j]; i < n; ++i) {\n if ((t = typenames[i]).type === o.type && t.name === o.name) {\n return o.value;\n }\n }\n }\n return;\n }\n\n on = value ? onAdd : onRemove;\n for (i = 0; i < n; ++i) this.each(on(typenames[i], value, options));\n return this;\n}\n","import defaultView from \"../window.js\";\n\nfunction dispatchEvent(node, type, params) {\n var window = defaultView(node),\n event = window.CustomEvent;\n\n if (typeof event === \"function\") {\n event = new event(type, params);\n } else {\n event = window.document.createEvent(\"Event\");\n if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;\n else event.initEvent(type, false, false);\n }\n\n node.dispatchEvent(event);\n}\n\nfunction dispatchConstant(type, params) {\n return function() {\n return dispatchEvent(this, type, params);\n };\n}\n\nfunction dispatchFunction(type, params) {\n return function() {\n return dispatchEvent(this, type, params.apply(this, arguments));\n };\n}\n\nexport default function(type, params) {\n return this.each((typeof params === \"function\"\n ? dispatchFunction\n : dispatchConstant)(type, params));\n}\n","import selection_select from \"./select.js\";\nimport selection_selectAll from \"./selectAll.js\";\nimport selection_selectChild from \"./selectChild.js\";\nimport selection_selectChildren from \"./selectChildren.js\";\nimport selection_filter from \"./filter.js\";\nimport selection_data from \"./data.js\";\nimport selection_enter from \"./enter.js\";\nimport selection_exit from \"./exit.js\";\nimport selection_join from \"./join.js\";\nimport selection_merge from \"./merge.js\";\nimport selection_order from \"./order.js\";\nimport selection_sort from \"./sort.js\";\nimport selection_call from \"./call.js\";\nimport selection_nodes from \"./nodes.js\";\nimport selection_node from \"./node.js\";\nimport selection_size from \"./size.js\";\nimport selection_empty from \"./empty.js\";\nimport selection_each from \"./each.js\";\nimport selection_attr from \"./attr.js\";\nimport selection_style from \"./style.js\";\nimport selection_property from \"./property.js\";\nimport selection_classed from \"./classed.js\";\nimport selection_text from \"./text.js\";\nimport selection_html from \"./html.js\";\nimport selection_raise from \"./raise.js\";\nimport selection_lower from \"./lower.js\";\nimport selection_append from \"./append.js\";\nimport selection_insert from \"./insert.js\";\nimport selection_remove from \"./remove.js\";\nimport selection_clone from \"./clone.js\";\nimport selection_datum from \"./datum.js\";\nimport selection_on from \"./on.js\";\nimport selection_dispatch from \"./dispatch.js\";\nimport selection_iterator from \"./iterator.js\";\n\nexport var root = [null];\n\nexport function Selection(groups, parents) {\n this._groups = groups;\n this._parents = parents;\n}\n\nfunction selection() {\n return new Selection([[document.documentElement]], root);\n}\n\nfunction selection_selection() {\n return this;\n}\n\nSelection.prototype = selection.prototype = {\n constructor: Selection,\n select: selection_select,\n selectAll: selection_selectAll,\n selectChild: selection_selectChild,\n selectChildren: selection_selectChildren,\n filter: selection_filter,\n data: selection_data,\n enter: selection_enter,\n exit: selection_exit,\n join: selection_join,\n merge: selection_merge,\n selection: selection_selection,\n order: selection_order,\n sort: selection_sort,\n call: selection_call,\n nodes: selection_nodes,\n node: selection_node,\n size: selection_size,\n empty: selection_empty,\n each: selection_each,\n attr: selection_attr,\n style: selection_style,\n property: selection_property,\n classed: selection_classed,\n text: selection_text,\n html: selection_html,\n raise: selection_raise,\n lower: selection_lower,\n append: selection_append,\n insert: selection_insert,\n remove: selection_remove,\n clone: selection_clone,\n datum: selection_datum,\n on: selection_on,\n dispatch: selection_dispatch,\n [Symbol.iterator]: selection_iterator\n};\n\nexport default selection;\n","import {Selection, root} from \"./selection/index.js\";\n\nexport default function(selector) {\n return typeof selector === \"string\"\n ? new Selection([[document.querySelector(selector)]], [document.documentElement])\n : new Selection([[selector]], root);\n}\n","import sourceEvent from \"./sourceEvent.js\";\n\nexport default function(event, node) {\n event = sourceEvent(event);\n if (node === undefined) node = event.currentTarget;\n if (node) {\n var svg = node.ownerSVGElement || node;\n if (svg.createSVGPoint) {\n var point = svg.createSVGPoint();\n point.x = event.clientX, point.y = event.clientY;\n point = point.matrixTransform(node.getScreenCTM().inverse());\n return [point.x, point.y];\n }\n if (node.getBoundingClientRect) {\n var rect = node.getBoundingClientRect();\n return [event.clientX - rect.left - node.clientLeft, event.clientY - rect.top - node.clientTop];\n }\n }\n return [event.pageX, event.pageY];\n}\n","export default function(event) {\n let sourceEvent;\n while (sourceEvent = event.sourceEvent) event = sourceEvent;\n return event;\n}\n","import {Selection} from \"./index.js\";\nimport selector from \"../selector.js\";\n\nexport default function(select) {\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n}\n","import {Selection} from \"./index.js\";\nimport matcher from \"../matcher.js\";\n\nexport default function(match) {\n if (typeof match !== \"function\") match = matcher(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Selection(subgroups, this._parents);\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\n","import sparse from \"./sparse.js\";\nimport {Selection} from \"./index.js\";\n\nexport default function() {\n return new Selection(this._exit || this._groups.map(sparse), this._parents);\n}\n","export default function(onenter, onupdate, onexit) {\n var enter = this.enter(), update = this, exit = this.exit();\n if (typeof onenter === \"function\") {\n enter = onenter(enter);\n if (enter) enter = enter.selection();\n } else {\n enter = enter.append(onenter + \"\");\n }\n if (onupdate != null) {\n update = onupdate(update);\n if (update) update = update.selection();\n }\n if (onexit == null) exit.remove(); else onexit(exit);\n return enter && update ? enter.merge(update).order() : update;\n}\n","import {Selection} from \"./index.js\";\n\nexport default function(context) {\n var selection = context.selection ? context.selection() : context;\n\n for (var groups0 = this._groups, groups1 = selection._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Selection(merges, this._parents);\n}\n","export default function() {\n\n for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {\n for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {\n if (node = group[i]) {\n if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);\n next = node;\n }\n }\n }\n\n return this;\n}\n","export default function() {\n var callback = arguments[0];\n arguments[0] = this;\n callback.apply(null, arguments);\n return this;\n}\n","export default function() {\n return Array.from(this);\n}\n","export default function() {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {\n var node = group[i];\n if (node) return node;\n }\n }\n\n return null;\n}\n","export default function() {\n let size = 0;\n for (const node of this) ++size; // eslint-disable-line no-unused-vars\n return size;\n}\n","export default function() {\n return !this.node();\n}\n","export default function(callback) {\n\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) callback.call(node, node.__data__, i, group);\n }\n }\n\n return this;\n}\n","import creator from \"../creator.js\";\n\nexport default function(name) {\n var create = typeof name === \"function\" ? name : creator(name);\n return this.select(function() {\n return this.appendChild(create.apply(this, arguments));\n });\n}\n","export default function(value) {\n return arguments.length\n ? this.property(\"__data__\", value)\n : this.node().__data__;\n}\n","export default function*() {\n for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {\n for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {\n if (node = group[i]) yield node;\n }\n }\n}\n","// These are typically used in conjunction with noevent to ensure that we can\n// preventDefault on the event.\nexport const nonpassive = {passive: false};\nexport const nonpassivecapture = {capture: true, passive: false};\n\nexport function nopropagation(event) {\n event.stopImmediatePropagation();\n}\n\nexport default function(event) {\n event.preventDefault();\n event.stopImmediatePropagation();\n}\n","export default x => () => x;\n","export default function DragEvent(type, {\n sourceEvent,\n subject,\n target,\n identifier,\n active,\n x, y, dx, dy,\n dispatch\n}) {\n Object.defineProperties(this, {\n type: {value: type, enumerable: true, configurable: true},\n sourceEvent: {value: sourceEvent, enumerable: true, configurable: true},\n subject: {value: subject, enumerable: true, configurable: true},\n target: {value: target, enumerable: true, configurable: true},\n identifier: {value: identifier, enumerable: true, configurable: true},\n active: {value: active, enumerable: true, configurable: true},\n x: {value: x, enumerable: true, configurable: true},\n y: {value: y, enumerable: true, configurable: true},\n dx: {value: dx, enumerable: true, configurable: true},\n dy: {value: dy, enumerable: true, configurable: true},\n _: {value: dispatch}\n });\n}\n\nDragEvent.prototype.on = function() {\n var value = this._.on.apply(this._, arguments);\n return value === this._ ? this : value;\n};\n","import {dispatch} from \"d3-dispatch\";\nimport {select, pointer} from \"d3-selection\";\nimport nodrag, {yesdrag} from \"./nodrag.js\";\nimport noevent, {nonpassive, nonpassivecapture, nopropagation} from \"./noevent.js\";\nimport constant from \"./constant.js\";\nimport DragEvent from \"./event.js\";\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter(event) {\n return !event.ctrlKey && !event.button;\n}\n\nfunction defaultContainer() {\n return this.parentNode;\n}\n\nfunction defaultSubject(event, d) {\n return d == null ? {x: event.x, y: event.y} : d;\n}\n\nfunction defaultTouchable() {\n return navigator.maxTouchPoints || (\"ontouchstart\" in this);\n}\n\nexport default function() {\n var filter = defaultFilter,\n container = defaultContainer,\n subject = defaultSubject,\n touchable = defaultTouchable,\n gestures = {},\n listeners = dispatch(\"start\", \"drag\", \"end\"),\n active = 0,\n mousedownx,\n mousedowny,\n mousemoving,\n touchending,\n clickDistance2 = 0;\n\n function drag(selection) {\n selection\n .on(\"mousedown.drag\", mousedowned)\n .filter(touchable)\n .on(\"touchstart.drag\", touchstarted)\n .on(\"touchmove.drag\", touchmoved, nonpassive)\n .on(\"touchend.drag touchcancel.drag\", touchended)\n .style(\"touch-action\", \"none\")\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n function mousedowned(event, d) {\n if (touchending || !filter.call(this, event, d)) return;\n var gesture = beforestart(this, container.call(this, event, d), event, d, \"mouse\");\n if (!gesture) return;\n select(event.view)\n .on(\"mousemove.drag\", mousemoved, nonpassivecapture)\n .on(\"mouseup.drag\", mouseupped, nonpassivecapture);\n nodrag(event.view);\n nopropagation(event);\n mousemoving = false;\n mousedownx = event.clientX;\n mousedowny = event.clientY;\n gesture(\"start\", event);\n }\n\n function mousemoved(event) {\n noevent(event);\n if (!mousemoving) {\n var dx = event.clientX - mousedownx, dy = event.clientY - mousedowny;\n mousemoving = dx * dx + dy * dy > clickDistance2;\n }\n gestures.mouse(\"drag\", event);\n }\n\n function mouseupped(event) {\n select(event.view).on(\"mousemove.drag mouseup.drag\", null);\n yesdrag(event.view, mousemoving);\n noevent(event);\n gestures.mouse(\"end\", event);\n }\n\n function touchstarted(event, d) {\n if (!filter.call(this, event, d)) return;\n var touches = event.changedTouches,\n c = container.call(this, event, d),\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = beforestart(this, c, event, d, touches[i].identifier, touches[i])) {\n nopropagation(event);\n gesture(\"start\", event, touches[i]);\n }\n }\n }\n\n function touchmoved(event) {\n var touches = event.changedTouches,\n n = touches.length, i, gesture;\n\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n noevent(event);\n gesture(\"drag\", event, touches[i]);\n }\n }\n }\n\n function touchended(event) {\n var touches = event.changedTouches,\n n = touches.length, i, gesture;\n\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n for (i = 0; i < n; ++i) {\n if (gesture = gestures[touches[i].identifier]) {\n nopropagation(event);\n gesture(\"end\", event, touches[i]);\n }\n }\n }\n\n function beforestart(that, container, event, d, identifier, touch) {\n var dispatch = listeners.copy(),\n p = pointer(touch || event, container), dx, dy,\n s;\n\n if ((s = subject.call(that, new DragEvent(\"beforestart\", {\n sourceEvent: event,\n target: drag,\n identifier,\n active,\n x: p[0],\n y: p[1],\n dx: 0,\n dy: 0,\n dispatch\n }), d)) == null) return;\n\n dx = s.x - p[0] || 0;\n dy = s.y - p[1] || 0;\n\n return function gesture(type, event, touch) {\n var p0 = p, n;\n switch (type) {\n case \"start\": gestures[identifier] = gesture, n = active++; break;\n case \"end\": delete gestures[identifier], --active; // falls through\n case \"drag\": p = pointer(touch || event, container), n = active; break;\n }\n dispatch.call(\n type,\n that,\n new DragEvent(type, {\n sourceEvent: event,\n subject: s,\n target: drag,\n identifier,\n active: n,\n x: p[0] + dx,\n y: p[1] + dy,\n dx: p[0] - p0[0],\n dy: p[1] - p0[1],\n dispatch\n }),\n d\n );\n };\n }\n\n drag.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant(!!_), drag) : filter;\n };\n\n drag.container = function(_) {\n return arguments.length ? (container = typeof _ === \"function\" ? _ : constant(_), drag) : container;\n };\n\n drag.subject = function(_) {\n return arguments.length ? (subject = typeof _ === \"function\" ? _ : constant(_), drag) : subject;\n };\n\n drag.touchable = function(_) {\n return arguments.length ? (touchable = typeof _ === \"function\" ? _ : constant(!!_), drag) : touchable;\n };\n\n drag.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? drag : value;\n };\n\n drag.clickDistance = function(_) {\n return arguments.length ? (clickDistance2 = (_ = +_) * _, drag) : Math.sqrt(clickDistance2);\n };\n\n return drag;\n}\n","import {select} from \"d3-selection\";\nimport noevent, {nonpassivecapture} from \"./noevent.js\";\n\nexport default function(view) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", noevent, nonpassivecapture);\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", noevent, nonpassivecapture);\n } else {\n root.__noselect = root.style.MozUserSelect;\n root.style.MozUserSelect = \"none\";\n }\n}\n\nexport function yesdrag(view, noclick) {\n var root = view.document.documentElement,\n selection = select(view).on(\"dragstart.drag\", null);\n if (noclick) {\n selection.on(\"click.drag\", noevent, nonpassivecapture);\n setTimeout(function() { selection.on(\"click.drag\", null); }, 0);\n }\n if (\"onselectstart\" in root) {\n selection.on(\"selectstart.drag\", null);\n } else {\n root.style.MozUserSelect = root.__noselect;\n delete root.__noselect;\n }\n}\n","export default function(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n}\n","import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n reN = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n reP = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n reHex = /^#([0-9a-f]{3,8})$/,\n reRgbInteger = new RegExp(`^rgb\\\\(${reI},${reI},${reI}\\\\)$`),\n reRgbPercent = new RegExp(`^rgb\\\\(${reP},${reP},${reP}\\\\)$`),\n reRgbaInteger = new RegExp(`^rgba\\\\(${reI},${reI},${reI},${reN}\\\\)$`),\n reRgbaPercent = new RegExp(`^rgba\\\\(${reP},${reP},${reP},${reN}\\\\)$`),\n reHslPercent = new RegExp(`^hsl\\\\(${reN},${reP},${reP}\\\\)$`),\n reHslaPercent = new RegExp(`^hsla\\\\(${reN},${reP},${reP},${reN}\\\\)$`);\n\nvar named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n copy(channels) {\n return Object.assign(new this.constructor, this, channels);\n },\n displayable() {\n return this.rgb().displayable();\n },\n hex: color_formatHex, // Deprecated! Use color.formatHex.\n formatHex: color_formatHex,\n formatHex8: color_formatHex8,\n formatHsl: color_formatHsl,\n formatRgb: color_formatRgb,\n toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n return this.rgb().formatHex();\n}\n\nfunction color_formatHex8() {\n return this.rgb().formatHex8();\n}\n\nfunction color_formatHsl() {\n return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n var m, l;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n : null) // invalid hex\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n}\n\nfunction rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb() {\n return this;\n },\n clamp() {\n return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n },\n displayable() {\n return (-0.5 <= this.r && this.r < 255.5)\n && (-0.5 <= this.g && this.g < 255.5)\n && (-0.5 <= this.b && this.b < 255.5)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n formatHex: rgb_formatHex,\n formatHex8: rgb_formatHex8,\n formatRgb: rgb_formatRgb,\n toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n value = clampi(value);\n return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n clamp() {\n return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n },\n displayable() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n formatHsl() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n }\n}));\n\nfunction clamph(value) {\n value = (value || 0) % 360;\n return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n}\n","export const radians = Math.PI / 180;\nexport const degrees = 180 / Math.PI;\n","import define, {extend} from \"./define.js\";\nimport {Color, rgbConvert, Rgb} from \"./color.js\";\nimport {degrees, radians} from \"./math.js\";\n\n// https://observablehq.com/@mbostock/lab-and-rgb\nconst K = 18,\n Xn = 0.96422,\n Yn = 1,\n Zn = 0.82521,\n t0 = 4 / 29,\n t1 = 6 / 29,\n t2 = 3 * t1 * t1,\n t3 = t1 * t1 * t1;\n\nfunction labConvert(o) {\n if (o instanceof Lab) return new Lab(o.l, o.a, o.b, o.opacity);\n if (o instanceof Hcl) return hcl2lab(o);\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var r = rgb2lrgb(o.r),\n g = rgb2lrgb(o.g),\n b = rgb2lrgb(o.b),\n y = xyz2lab((0.2225045 * r + 0.7168786 * g + 0.0606169 * b) / Yn), x, z;\n if (r === g && g === b) x = z = y; else {\n x = xyz2lab((0.4360747 * r + 0.3850649 * g + 0.1430804 * b) / Xn);\n z = xyz2lab((0.0139322 * r + 0.0971045 * g + 0.7141733 * b) / Zn);\n }\n return new Lab(116 * y - 16, 500 * (x - y), 200 * (y - z), o.opacity);\n}\n\nexport function gray(l, opacity) {\n return new Lab(l, 0, 0, opacity == null ? 1 : opacity);\n}\n\nexport default function lab(l, a, b, opacity) {\n return arguments.length === 1 ? labConvert(l) : new Lab(l, a, b, opacity == null ? 1 : opacity);\n}\n\nexport function Lab(l, a, b, opacity) {\n this.l = +l;\n this.a = +a;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Lab, lab, extend(Color, {\n brighter(k) {\n return new Lab(this.l + K * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n darker(k) {\n return new Lab(this.l - K * (k == null ? 1 : k), this.a, this.b, this.opacity);\n },\n rgb() {\n var y = (this.l + 16) / 116,\n x = isNaN(this.a) ? y : y + this.a / 500,\n z = isNaN(this.b) ? y : y - this.b / 200;\n x = Xn * lab2xyz(x);\n y = Yn * lab2xyz(y);\n z = Zn * lab2xyz(z);\n return new Rgb(\n lrgb2rgb( 3.1338561 * x - 1.6168667 * y - 0.4906146 * z),\n lrgb2rgb(-0.9787684 * x + 1.9161415 * y + 0.0334540 * z),\n lrgb2rgb( 0.0719453 * x - 0.2289914 * y + 1.4052427 * z),\n this.opacity\n );\n }\n}));\n\nfunction xyz2lab(t) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\n\nfunction lab2xyz(t) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n}\n\nfunction lrgb2rgb(x) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\n\nfunction rgb2lrgb(x) {\n return (x /= 255) <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\n\nfunction hclConvert(o) {\n if (o instanceof Hcl) return new Hcl(o.h, o.c, o.l, o.opacity);\n if (!(o instanceof Lab)) o = labConvert(o);\n if (o.a === 0 && o.b === 0) return new Hcl(NaN, 0 < o.l && o.l < 100 ? 0 : NaN, o.l, o.opacity);\n var h = Math.atan2(o.b, o.a) * degrees;\n return new Hcl(h < 0 ? h + 360 : h, Math.sqrt(o.a * o.a + o.b * o.b), o.l, o.opacity);\n}\n\nexport function lch(l, c, h, opacity) {\n return arguments.length === 1 ? hclConvert(l) : new Hcl(h, c, l, opacity == null ? 1 : opacity);\n}\n\nexport function hcl(h, c, l, opacity) {\n return arguments.length === 1 ? hclConvert(h) : new Hcl(h, c, l, opacity == null ? 1 : opacity);\n}\n\nexport function Hcl(h, c, l, opacity) {\n this.h = +h;\n this.c = +c;\n this.l = +l;\n this.opacity = +opacity;\n}\n\nfunction hcl2lab(o) {\n if (isNaN(o.h)) return new Lab(o.l, 0, 0, o.opacity);\n var h = o.h * radians;\n return new Lab(o.l, Math.cos(h) * o.c, Math.sin(h) * o.c, o.opacity);\n}\n\ndefine(Hcl, hcl, extend(Color, {\n brighter(k) {\n return new Hcl(this.h, this.c, this.l + K * (k == null ? 1 : k), this.opacity);\n },\n darker(k) {\n return new Hcl(this.h, this.c, this.l - K * (k == null ? 1 : k), this.opacity);\n },\n rgb() {\n return hcl2lab(this).rgb();\n }\n}));\n","import define, {extend} from \"./define.js\";\nimport {Color, rgbConvert, Rgb, darker, brighter} from \"./color.js\";\nimport {degrees, radians} from \"./math.js\";\n\nvar A = -0.14861,\n B = +1.78277,\n C = -0.29227,\n D = -0.90649,\n E = +1.97294,\n ED = E * D,\n EB = E * B,\n BC_DA = B * C - D * A;\n\nfunction cubehelixConvert(o) {\n if (o instanceof Cubehelix) return new Cubehelix(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Rgb)) o = rgbConvert(o);\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n l = (BC_DA * b + ED * r - EB * g) / (BC_DA + ED - EB),\n bl = b - l,\n k = (E * (g - l) - C * bl) / D,\n s = Math.sqrt(k * k + bl * bl) / (E * l * (1 - l)), // NaN if l=0 or l=1\n h = s ? Math.atan2(k, bl) * degrees - 120 : NaN;\n return new Cubehelix(h < 0 ? h + 360 : h, s, l, o.opacity);\n}\n\nexport default function cubehelix(h, s, l, opacity) {\n return arguments.length === 1 ? cubehelixConvert(h) : new Cubehelix(h, s, l, opacity == null ? 1 : opacity);\n}\n\nexport function Cubehelix(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Cubehelix, cubehelix, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Cubehelix(this.h, this.s, this.l * k, this.opacity);\n },\n rgb() {\n var h = isNaN(this.h) ? 0 : (this.h + 120) * radians,\n l = +this.l,\n a = isNaN(this.s) ? 0 : this.s * l * (1 - l),\n cosh = Math.cos(h),\n sinh = Math.sin(h);\n return new Rgb(\n 255 * (l + a * (A * cosh + B * sinh)),\n 255 * (l + a * (C * cosh + D * sinh)),\n 255 * (l + a * (E * cosh)),\n this.opacity\n );\n }\n}));\n","export default x => () => x;\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n return function(t) {\n return a + t * d;\n };\n}\n\nfunction exponential(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n}\n\nexport function hue(a, b) {\n var d = b - a;\n return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n };\n}\n\nexport default function nogamma(a, b) {\n var d = b - a;\n return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","export function basis(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n}\n\nexport default function(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","export default function(a, b) {\n if (!b) b = [];\n var n = a ? Math.min(b.length, a.length) : 0,\n c = b.slice(),\n i;\n return function(t) {\n for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;\n return c;\n };\n}\n\nexport function isNumberArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n","import value from \"./value.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n return (isNumberArray(b) ? numberArray : genericArray)(a, b);\n}\n\nexport function genericArray(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(na),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = value(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n}\n","export default function(a, b) {\n var d = new Date;\n return a = +a, b = +b, function(t) {\n return d.setTime(a * (1 - t) + b * t), d;\n };\n}\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return a * (1 - t) + b * t;\n };\n}\n","import value from \"./value.js\";\n\nexport default function(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = value(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n return function() {\n return b;\n };\n}\n\nfunction one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n}\n\nexport default function(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: number(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n}\n","import {color} from \"d3-color\";\nimport rgb from \"./rgb.js\";\nimport {genericArray} from \"./array.js\";\nimport date from \"./date.js\";\nimport number from \"./number.js\";\nimport object from \"./object.js\";\nimport string from \"./string.js\";\nimport constant from \"./constant.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant(b)\n : (t === \"number\" ? number\n : t === \"string\" ? ((c = color(b)) ? (b = c, rgb) : string)\n : b instanceof color ? rgb\n : b instanceof Date ? date\n : isNumberArray(b) ? numberArray\n : Array.isArray(b) ? genericArray\n : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n : number)(a, b);\n}\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return Math.round(a * (1 - t) + b * t);\n };\n}\n","var degrees = 180 / Math.PI;\n\nexport var identity = {\n translateX: 0,\n translateY: 0,\n rotate: 0,\n skewX: 0,\n scaleX: 1,\n scaleY: 1\n};\n\nexport default function(a, b, c, d, e, f) {\n var scaleX, scaleY, skewX;\n if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;\n if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;\n if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;\n if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;\n return {\n translateX: e,\n translateY: f,\n rotate: Math.atan2(b, a) * degrees,\n skewX: Math.atan(skewX) * degrees,\n scaleX: scaleX,\n scaleY: scaleY\n };\n}\n","import decompose, {identity} from \"./decompose.js\";\n\nvar svgNode;\n\n/* eslint-disable no-undef */\nexport function parseCss(value) {\n const m = new (typeof DOMMatrix === \"function\" ? DOMMatrix : WebKitCSSMatrix)(value + \"\");\n return m.isIdentity ? identity : decompose(m.a, m.b, m.c, m.d, m.e, m.f);\n}\n\nexport function parseSvg(value) {\n if (value == null) return identity;\n if (!svgNode) svgNode = document.createElementNS(\"http://www.w3.org/2000/svg\", \"g\");\n svgNode.setAttribute(\"transform\", value);\n if (!(value = svgNode.transform.baseVal.consolidate())) return identity;\n value = value.matrix;\n return decompose(value.a, value.b, value.c, value.d, value.e, value.f);\n}\n","import number from \"../number.js\";\nimport {parseCss, parseSvg} from \"./parse.js\";\n\nfunction interpolateTransform(parse, pxComma, pxParen, degParen) {\n\n function pop(s) {\n return s.length ? s.pop() + \" \" : \"\";\n }\n\n function translate(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(\"translate(\", null, pxComma, null, pxParen);\n q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n } else if (xb || yb) {\n s.push(\"translate(\" + xb + pxComma + yb + pxParen);\n }\n }\n\n function rotate(a, b, s, q) {\n if (a !== b) {\n if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path\n q.push({i: s.push(pop(s) + \"rotate(\", null, degParen) - 2, x: number(a, b)});\n } else if (b) {\n s.push(pop(s) + \"rotate(\" + b + degParen);\n }\n }\n\n function skewX(a, b, s, q) {\n if (a !== b) {\n q.push({i: s.push(pop(s) + \"skewX(\", null, degParen) - 2, x: number(a, b)});\n } else if (b) {\n s.push(pop(s) + \"skewX(\" + b + degParen);\n }\n }\n\n function scale(xa, ya, xb, yb, s, q) {\n if (xa !== xb || ya !== yb) {\n var i = s.push(pop(s) + \"scale(\", null, \",\", null, \")\");\n q.push({i: i - 4, x: number(xa, xb)}, {i: i - 2, x: number(ya, yb)});\n } else if (xb !== 1 || yb !== 1) {\n s.push(pop(s) + \"scale(\" + xb + \",\" + yb + \")\");\n }\n }\n\n return function(a, b) {\n var s = [], // string constants and placeholders\n q = []; // number interpolators\n a = parse(a), b = parse(b);\n translate(a.translateX, a.translateY, b.translateX, b.translateY, s, q);\n rotate(a.rotate, b.rotate, s, q);\n skewX(a.skewX, b.skewX, s, q);\n scale(a.scaleX, a.scaleY, b.scaleX, b.scaleY, s, q);\n a = b = null; // gc\n return function(t) {\n var i = -1, n = q.length, o;\n while (++i < n) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n };\n };\n}\n\nexport var interpolateTransformCss = interpolateTransform(parseCss, \"px, \", \"px)\", \"deg)\");\nexport var interpolateTransformSvg = interpolateTransform(parseSvg, \", \", \")\", \")\");\n","import {hsl as colorHsl} from \"d3-color\";\nimport color, {hue} from \"./color.js\";\n\nfunction hsl(hue) {\n return function(start, end) {\n var h = hue((start = colorHsl(start)).h, (end = colorHsl(end)).h),\n s = color(start.s, end.s),\n l = color(start.l, end.l),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n}\n\nexport default hsl(hue);\nexport var hslLong = hsl(color);\n","import {hcl as colorHcl} from \"d3-color\";\nimport color, {hue} from \"./color.js\";\n\nfunction hcl(hue) {\n return function(start, end) {\n var h = hue((start = colorHcl(start)).h, (end = colorHcl(end)).h),\n c = color(start.c, end.c),\n l = color(start.l, end.l),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.c = c(t);\n start.l = l(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n}\n\nexport default hcl(hue);\nexport var hclLong = hcl(color);\n","import {cubehelix as colorCubehelix} from \"d3-color\";\nimport color, {hue} from \"./color.js\";\n\nfunction cubehelix(hue) {\n return (function cubehelixGamma(y) {\n y = +y;\n\n function cubehelix(start, end) {\n var h = hue((start = colorCubehelix(start)).h, (end = colorCubehelix(end)).h),\n s = color(start.s, end.s),\n l = color(start.l, end.l),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.h = h(t);\n start.s = s(t);\n start.l = l(Math.pow(t, y));\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n cubehelix.gamma = cubehelixGamma;\n\n return cubehelix;\n })(1);\n}\n\nexport default cubehelix(hue);\nexport var cubehelixLong = cubehelix(color);\n","import {default as value} from \"./value.js\";\n\nexport default function piecewise(interpolate, values) {\n if (values === undefined) values = interpolate, interpolate = value;\n var i = 0, n = values.length - 1, v = values[0], I = new Array(n < 0 ? 0 : n);\n while (i < n) I[i] = interpolate(v, v = values[++i]);\n return function(t) {\n var i = Math.max(0, Math.min(n - 1, Math.floor(t *= n)));\n return I[i](t - i);\n };\n}\n","export default function(interpolator, n) {\n var samples = new Array(n);\n for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));\n return samples;\n}\n","var frame = 0, // is an animation frame pending?\n timeout = 0, // is a timeout pending?\n interval = 0, // are any timers active?\n pokeDelay = 1000, // how frequently we check for clock skew\n taskHead,\n taskTail,\n clockLast = 0,\n clockNow = 0,\n clockSkew = 0,\n clock = typeof performance === \"object\" && performance.now ? performance : Date,\n setFrame = typeof window === \"object\" && window.requestAnimationFrame ? window.requestAnimationFrame.bind(window) : function(f) { setTimeout(f, 17); };\n\nexport function now() {\n return clockNow || (setFrame(clearNow), clockNow = clock.now() + clockSkew);\n}\n\nfunction clearNow() {\n clockNow = 0;\n}\n\nexport function Timer() {\n this._call =\n this._time =\n this._next = null;\n}\n\nTimer.prototype = timer.prototype = {\n constructor: Timer,\n restart: function(callback, delay, time) {\n if (typeof callback !== \"function\") throw new TypeError(\"callback is not a function\");\n time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);\n if (!this._next && taskTail !== this) {\n if (taskTail) taskTail._next = this;\n else taskHead = this;\n taskTail = this;\n }\n this._call = callback;\n this._time = time;\n sleep();\n },\n stop: function() {\n if (this._call) {\n this._call = null;\n this._time = Infinity;\n sleep();\n }\n }\n};\n\nexport function timer(callback, delay, time) {\n var t = new Timer;\n t.restart(callback, delay, time);\n return t;\n}\n\nexport function timerFlush() {\n now(); // Get the current time, if not already set.\n ++frame; // Pretend we’ve set an alarm, if we haven’t already.\n var t = taskHead, e;\n while (t) {\n if ((e = clockNow - t._time) >= 0) t._call.call(undefined, e);\n t = t._next;\n }\n --frame;\n}\n\nfunction wake() {\n clockNow = (clockLast = clock.now()) + clockSkew;\n frame = timeout = 0;\n try {\n timerFlush();\n } finally {\n frame = 0;\n nap();\n clockNow = 0;\n }\n}\n\nfunction poke() {\n var now = clock.now(), delay = now - clockLast;\n if (delay > pokeDelay) clockSkew -= delay, clockLast = now;\n}\n\nfunction nap() {\n var t0, t1 = taskHead, t2, time = Infinity;\n while (t1) {\n if (t1._call) {\n if (time > t1._time) time = t1._time;\n t0 = t1, t1 = t1._next;\n } else {\n t2 = t1._next, t1._next = null;\n t1 = t0 ? t0._next = t2 : taskHead = t2;\n }\n }\n taskTail = t0;\n sleep(time);\n}\n\nfunction sleep(time) {\n if (frame) return; // Soonest alarm already set, or will be.\n if (timeout) timeout = clearTimeout(timeout);\n var delay = time - clockNow; // Strictly less than if we recomputed clockNow.\n if (delay > 24) {\n if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);\n if (interval) interval = clearInterval(interval);\n } else {\n if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);\n frame = 1, setFrame(wake);\n }\n}\n","import {Timer} from \"./timer.js\";\n\nexport default function(callback, delay, time) {\n var t = new Timer;\n delay = delay == null ? 0 : +delay;\n t.restart(elapsed => {\n t.stop();\n callback(elapsed + delay);\n }, delay, time);\n return t;\n}\n","import {dispatch} from \"d3-dispatch\";\nimport {timer, timeout} from \"d3-timer\";\n\nvar emptyOn = dispatch(\"start\", \"end\", \"cancel\", \"interrupt\");\nvar emptyTween = [];\n\nexport var CREATED = 0;\nexport var SCHEDULED = 1;\nexport var STARTING = 2;\nexport var STARTED = 3;\nexport var RUNNING = 4;\nexport var ENDING = 5;\nexport var ENDED = 6;\n\nexport default function(node, name, id, index, group, timing) {\n var schedules = node.__transition;\n if (!schedules) node.__transition = {};\n else if (id in schedules) return;\n create(node, id, {\n name: name,\n index: index, // For context during callback.\n group: group, // For context during callback.\n on: emptyOn,\n tween: emptyTween,\n time: timing.time,\n delay: timing.delay,\n duration: timing.duration,\n ease: timing.ease,\n timer: null,\n state: CREATED\n });\n}\n\nexport function init(node, id) {\n var schedule = get(node, id);\n if (schedule.state > CREATED) throw new Error(\"too late; already scheduled\");\n return schedule;\n}\n\nexport function set(node, id) {\n var schedule = get(node, id);\n if (schedule.state > STARTED) throw new Error(\"too late; already running\");\n return schedule;\n}\n\nexport function get(node, id) {\n var schedule = node.__transition;\n if (!schedule || !(schedule = schedule[id])) throw new Error(\"transition not found\");\n return schedule;\n}\n\nfunction create(node, id, self) {\n var schedules = node.__transition,\n tween;\n\n // Initialize the self timer when the transition is created.\n // Note the actual delay is not known until the first callback!\n schedules[id] = self;\n self.timer = timer(schedule, 0, self.time);\n\n function schedule(elapsed) {\n self.state = SCHEDULED;\n self.timer.restart(start, self.delay, self.time);\n\n // If the elapsed delay is less than our first sleep, start immediately.\n if (self.delay <= elapsed) start(elapsed - self.delay);\n }\n\n function start(elapsed) {\n var i, j, n, o;\n\n // If the state is not SCHEDULED, then we previously errored on start.\n if (self.state !== SCHEDULED) return stop();\n\n for (i in schedules) {\n o = schedules[i];\n if (o.name !== self.name) continue;\n\n // While this element already has a starting transition during this frame,\n // defer starting an interrupting transition until that transition has a\n // chance to tick (and possibly end); see d3/d3-transition#54!\n if (o.state === STARTED) return timeout(start);\n\n // Interrupt the active transition, if any.\n if (o.state === RUNNING) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"interrupt\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n\n // Cancel any pre-empted transitions.\n else if (+i < id) {\n o.state = ENDED;\n o.timer.stop();\n o.on.call(\"cancel\", node, node.__data__, o.index, o.group);\n delete schedules[i];\n }\n }\n\n // Defer the first tick to end of the current frame; see d3/d3#1576.\n // Note the transition may be canceled after start and before the first tick!\n // Note this must be scheduled before the start event; see d3/d3-transition#16!\n // Assuming this is successful, subsequent callbacks go straight to tick.\n timeout(function() {\n if (self.state === STARTED) {\n self.state = RUNNING;\n self.timer.restart(tick, self.delay, self.time);\n tick(elapsed);\n }\n });\n\n // Dispatch the start event.\n // Note this must be done before the tween are initialized.\n self.state = STARTING;\n self.on.call(\"start\", node, node.__data__, self.index, self.group);\n if (self.state !== STARTING) return; // interrupted\n self.state = STARTED;\n\n // Initialize the tween, deleting null tween.\n tween = new Array(n = self.tween.length);\n for (i = 0, j = -1; i < n; ++i) {\n if (o = self.tween[i].value.call(node, node.__data__, self.index, self.group)) {\n tween[++j] = o;\n }\n }\n tween.length = j + 1;\n }\n\n function tick(elapsed) {\n var t = elapsed < self.duration ? self.ease.call(null, elapsed / self.duration) : (self.timer.restart(stop), self.state = ENDING, 1),\n i = -1,\n n = tween.length;\n\n while (++i < n) {\n tween[i].call(node, t);\n }\n\n // Dispatch the end event.\n if (self.state === ENDING) {\n self.on.call(\"end\", node, node.__data__, self.index, self.group);\n stop();\n }\n }\n\n function stop() {\n self.state = ENDED;\n self.timer.stop();\n delete schedules[id];\n for (var i in schedules) return; // eslint-disable-line no-unused-vars\n delete node.__transition;\n }\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction tweenRemove(id, name) {\n var tween0, tween1;\n return function() {\n var schedule = set(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = tween0 = tween;\n for (var i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1 = tween1.slice();\n tween1.splice(i, 1);\n break;\n }\n }\n }\n\n schedule.tween = tween1;\n };\n}\n\nfunction tweenFunction(id, name, value) {\n var tween0, tween1;\n if (typeof value !== \"function\") throw new Error;\n return function() {\n var schedule = set(this, id),\n tween = schedule.tween;\n\n // If this node shared tween with the previous node,\n // just assign the updated shared tween and we’re done!\n // Otherwise, copy-on-write.\n if (tween !== tween0) {\n tween1 = (tween0 = tween).slice();\n for (var t = {name: name, value: value}, i = 0, n = tween1.length; i < n; ++i) {\n if (tween1[i].name === name) {\n tween1[i] = t;\n break;\n }\n }\n if (i === n) tween1.push(t);\n }\n\n schedule.tween = tween1;\n };\n}\n\nexport default function(name, value) {\n var id = this._id;\n\n name += \"\";\n\n if (arguments.length < 2) {\n var tween = get(this.node(), id).tween;\n for (var i = 0, n = tween.length, t; i < n; ++i) {\n if ((t = tween[i]).name === name) {\n return t.value;\n }\n }\n return null;\n }\n\n return this.each((value == null ? tweenRemove : tweenFunction)(id, name, value));\n}\n\nexport function tweenValue(transition, name, value) {\n var id = transition._id;\n\n transition.each(function() {\n var schedule = set(this, id);\n (schedule.value || (schedule.value = {}))[name] = value.apply(this, arguments);\n });\n\n return function(node) {\n return get(node, id).value[name];\n };\n}\n","import {color} from \"d3-color\";\nimport {interpolateNumber, interpolateRgb, interpolateString} from \"d3-interpolate\";\n\nexport default function(a, b) {\n var c;\n return (typeof b === \"number\" ? interpolateNumber\n : b instanceof color ? interpolateRgb\n : (c = color(b)) ? (b = c, interpolateRgb)\n : interpolateString)(a, b);\n}\n","import {interpolateTransformSvg as interpolateTransform} from \"d3-interpolate\";\nimport {namespace} from \"d3-selection\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction attrRemove(name) {\n return function() {\n this.removeAttribute(name);\n };\n}\n\nfunction attrRemoveNS(fullname) {\n return function() {\n this.removeAttributeNS(fullname.space, fullname.local);\n };\n}\n\nfunction attrConstant(name, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = this.getAttribute(name);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction attrConstantNS(fullname, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = this.getAttributeNS(fullname.space, fullname.local);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction attrFunction(name, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0, value1 = value(this), string1;\n if (value1 == null) return void this.removeAttribute(name);\n string0 = this.getAttribute(name);\n string1 = value1 + \"\";\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nfunction attrFunctionNS(fullname, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0, value1 = value(this), string1;\n if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);\n string0 = this.getAttributeNS(fullname.space, fullname.local);\n string1 = value1 + \"\";\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nexport default function(name, value) {\n var fullname = namespace(name), i = fullname === \"transform\" ? interpolateTransform : interpolate;\n return this.attrTween(name, typeof value === \"function\"\n ? (fullname.local ? attrFunctionNS : attrFunction)(fullname, i, tweenValue(this, \"attr.\" + name, value))\n : value == null ? (fullname.local ? attrRemoveNS : attrRemove)(fullname)\n : (fullname.local ? attrConstantNS : attrConstant)(fullname, i, value));\n}\n","import {namespace} from \"d3-selection\";\n\nfunction attrInterpolate(name, i) {\n return function(t) {\n this.setAttribute(name, i.call(this, t));\n };\n}\n\nfunction attrInterpolateNS(fullname, i) {\n return function(t) {\n this.setAttributeNS(fullname.space, fullname.local, i.call(this, t));\n };\n}\n\nfunction attrTweenNS(fullname, value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nfunction attrTween(name, value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(name, value) {\n var key = \"attr.\" + name;\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n var fullname = namespace(name);\n return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));\n}\n","import {get, init} from \"./schedule.js\";\n\nfunction delayFunction(id, value) {\n return function() {\n init(this, id).delay = +value.apply(this, arguments);\n };\n}\n\nfunction delayConstant(id, value) {\n return value = +value, function() {\n init(this, id).delay = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? delayFunction\n : delayConstant)(id, value))\n : get(this.node(), id).delay;\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction durationFunction(id, value) {\n return function() {\n set(this, id).duration = +value.apply(this, arguments);\n };\n}\n\nfunction durationConstant(id, value) {\n return value = +value, function() {\n set(this, id).duration = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each((typeof value === \"function\"\n ? durationFunction\n : durationConstant)(id, value))\n : get(this.node(), id).duration;\n}\n","import {selection} from \"d3-selection\";\n\nvar Selection = selection.prototype.constructor;\n\nexport default function() {\n return new Selection(this._groups, this._parents);\n}\n","import {interpolateTransformCss as interpolateTransform} from \"d3-interpolate\";\nimport {style} from \"d3-selection\";\nimport {set} from \"./schedule.js\";\nimport {tweenValue} from \"./tween.js\";\nimport interpolate from \"./interpolate.js\";\n\nfunction styleNull(name, interpolate) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0 = style(this, name),\n string1 = (this.style.removeProperty(name), style(this, name));\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, string10 = string1);\n };\n}\n\nfunction styleRemove(name) {\n return function() {\n this.style.removeProperty(name);\n };\n}\n\nfunction styleConstant(name, interpolate, value1) {\n var string00,\n string1 = value1 + \"\",\n interpolate0;\n return function() {\n var string0 = style(this, name);\n return string0 === string1 ? null\n : string0 === string00 ? interpolate0\n : interpolate0 = interpolate(string00 = string0, value1);\n };\n}\n\nfunction styleFunction(name, interpolate, value) {\n var string00,\n string10,\n interpolate0;\n return function() {\n var string0 = style(this, name),\n value1 = value(this),\n string1 = value1 + \"\";\n if (value1 == null) string1 = value1 = (this.style.removeProperty(name), style(this, name));\n return string0 === string1 ? null\n : string0 === string00 && string1 === string10 ? interpolate0\n : (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));\n };\n}\n\nfunction styleMaybeRemove(id, name) {\n var on0, on1, listener0, key = \"style.\" + name, event = \"end.\" + key, remove;\n return function() {\n var schedule = set(this, id),\n on = schedule.on,\n listener = schedule.value[key] == null ? remove || (remove = styleRemove(name)) : undefined;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we’re done!\n // Otherwise, copy-on-write.\n if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);\n\n schedule.on = on1;\n };\n}\n\nexport default function(name, value, priority) {\n var i = (name += \"\") === \"transform\" ? interpolateTransform : interpolate;\n return value == null ? this\n .styleTween(name, styleNull(name, i))\n .on(\"end.style.\" + name, styleRemove(name))\n : typeof value === \"function\" ? this\n .styleTween(name, styleFunction(name, i, tweenValue(this, \"style.\" + name, value)))\n .each(styleMaybeRemove(this._id, name))\n : this\n .styleTween(name, styleConstant(name, i, value), priority)\n .on(\"end.style.\" + name, null);\n}\n","import {selection} from \"d3-selection\";\nimport transition_attr from \"./attr.js\";\nimport transition_attrTween from \"./attrTween.js\";\nimport transition_delay from \"./delay.js\";\nimport transition_duration from \"./duration.js\";\nimport transition_ease from \"./ease.js\";\nimport transition_easeVarying from \"./easeVarying.js\";\nimport transition_filter from \"./filter.js\";\nimport transition_merge from \"./merge.js\";\nimport transition_on from \"./on.js\";\nimport transition_remove from \"./remove.js\";\nimport transition_select from \"./select.js\";\nimport transition_selectAll from \"./selectAll.js\";\nimport transition_selection from \"./selection.js\";\nimport transition_style from \"./style.js\";\nimport transition_styleTween from \"./styleTween.js\";\nimport transition_text from \"./text.js\";\nimport transition_textTween from \"./textTween.js\";\nimport transition_transition from \"./transition.js\";\nimport transition_tween from \"./tween.js\";\nimport transition_end from \"./end.js\";\n\nvar id = 0;\n\nexport function Transition(groups, parents, name, id) {\n this._groups = groups;\n this._parents = parents;\n this._name = name;\n this._id = id;\n}\n\nexport default function transition(name) {\n return selection().transition(name);\n}\n\nexport function newId() {\n return ++id;\n}\n\nvar selection_prototype = selection.prototype;\n\nTransition.prototype = transition.prototype = {\n constructor: Transition,\n select: transition_select,\n selectAll: transition_selectAll,\n selectChild: selection_prototype.selectChild,\n selectChildren: selection_prototype.selectChildren,\n filter: transition_filter,\n merge: transition_merge,\n selection: transition_selection,\n transition: transition_transition,\n call: selection_prototype.call,\n nodes: selection_prototype.nodes,\n node: selection_prototype.node,\n size: selection_prototype.size,\n empty: selection_prototype.empty,\n each: selection_prototype.each,\n on: transition_on,\n attr: transition_attr,\n attrTween: transition_attrTween,\n style: transition_style,\n styleTween: transition_styleTween,\n text: transition_text,\n textTween: transition_textTween,\n remove: transition_remove,\n tween: transition_tween,\n delay: transition_delay,\n duration: transition_duration,\n ease: transition_ease,\n easeVarying: transition_easeVarying,\n end: transition_end,\n [Symbol.iterator]: selection_prototype[Symbol.iterator]\n};\n","import {selector} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selector(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {\n if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {\n if (\"__data__\" in node) subnode.__data__ = node.__data__;\n subgroup[i] = subnode;\n schedule(subgroup[i], name, id, i, subgroup, get(node, id));\n }\n }\n }\n\n return new Transition(subgroups, this._parents, name, id);\n}\n","import {selectorAll} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function(select) {\n var name = this._name,\n id = this._id;\n\n if (typeof select !== \"function\") select = selectorAll(select);\n\n for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n for (var children = select.call(node, node.__data__, i, group), child, inherit = get(node, id), k = 0, l = children.length; k < l; ++k) {\n if (child = children[k]) {\n schedule(child, name, id, k, children, inherit);\n }\n }\n subgroups.push(children);\n parents.push(node);\n }\n }\n }\n\n return new Transition(subgroups, parents, name, id);\n}\n","import {matcher} from \"d3-selection\";\nimport {Transition} from \"./index.js\";\n\nexport default function(match) {\n if (typeof match !== \"function\") match = matcher(match);\n\n for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {\n if ((node = group[i]) && match.call(node, node.__data__, i, group)) {\n subgroup.push(node);\n }\n }\n }\n\n return new Transition(subgroups, this._parents, this._name, this._id);\n}\n","import {Transition} from \"./index.js\";\n\nexport default function(transition) {\n if (transition._id !== this._id) throw new Error;\n\n for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {\n for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {\n if (node = group0[i] || group1[i]) {\n merge[i] = node;\n }\n }\n }\n\n for (; j < m0; ++j) {\n merges[j] = groups0[j];\n }\n\n return new Transition(merges, this._parents, this._name, this._id);\n}\n","import {Transition, newId} from \"./index.js\";\nimport schedule, {get} from \"./schedule.js\";\n\nexport default function() {\n var name = this._name,\n id0 = this._id,\n id1 = newId();\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n var inherit = get(node, id0);\n schedule(node, name, id1, i, group, {\n time: inherit.time + inherit.delay + inherit.duration,\n delay: 0,\n duration: inherit.duration,\n ease: inherit.ease\n });\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id1);\n}\n","import {get, set, init} from \"./schedule.js\";\n\nfunction start(name) {\n return (name + \"\").trim().split(/^|\\s+/).every(function(t) {\n var i = t.indexOf(\".\");\n if (i >= 0) t = t.slice(0, i);\n return !t || t === \"start\";\n });\n}\n\nfunction onFunction(id, name, listener) {\n var on0, on1, sit = start(name) ? init : set;\n return function() {\n var schedule = sit(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we’re done!\n // Otherwise, copy-on-write.\n if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);\n\n schedule.on = on1;\n };\n}\n\nexport default function(name, listener) {\n var id = this._id;\n\n return arguments.length < 2\n ? get(this.node(), id).on.on(name)\n : this.each(onFunction(id, name, listener));\n}\n","function styleInterpolate(name, i, priority) {\n return function(t) {\n this.style.setProperty(name, i.call(this, t), priority);\n };\n}\n\nfunction styleTween(name, value, priority) {\n var t, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);\n return t;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(name, value, priority) {\n var key = \"style.\" + (name += \"\");\n if (arguments.length < 2) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, styleTween(name, value, priority == null ? \"\" : priority));\n}\n","import {tweenValue} from \"./tween.js\";\n\nfunction textConstant(value) {\n return function() {\n this.textContent = value;\n };\n}\n\nfunction textFunction(value) {\n return function() {\n var value1 = value(this);\n this.textContent = value1 == null ? \"\" : value1;\n };\n}\n\nexport default function(value) {\n return this.tween(\"text\", typeof value === \"function\"\n ? textFunction(tweenValue(this, \"text\", value))\n : textConstant(value == null ? \"\" : value + \"\"));\n}\n","function textInterpolate(i) {\n return function(t) {\n this.textContent = i.call(this, t);\n };\n}\n\nfunction textTween(value) {\n var t0, i0;\n function tween() {\n var i = value.apply(this, arguments);\n if (i !== i0) t0 = (i0 = i) && textInterpolate(i);\n return t0;\n }\n tween._value = value;\n return tween;\n}\n\nexport default function(value) {\n var key = \"text\";\n if (arguments.length < 1) return (key = this.tween(key)) && key._value;\n if (value == null) return this.tween(key, null);\n if (typeof value !== \"function\") throw new Error;\n return this.tween(key, textTween(value));\n}\n","function removeFunction(id) {\n return function() {\n var parent = this.parentNode;\n for (var i in this.__transition) if (+i !== id) return;\n if (parent) parent.removeChild(this);\n };\n}\n\nexport default function() {\n return this.on(\"end.remove\", removeFunction(this._id));\n}\n","import {get, set} from \"./schedule.js\";\n\nfunction easeConstant(id, value) {\n if (typeof value !== \"function\") throw new Error;\n return function() {\n set(this, id).ease = value;\n };\n}\n\nexport default function(value) {\n var id = this._id;\n\n return arguments.length\n ? this.each(easeConstant(id, value))\n : get(this.node(), id).ease;\n}\n","import {set} from \"./schedule.js\";\n\nfunction easeVarying(id, value) {\n return function() {\n var v = value.apply(this, arguments);\n if (typeof v !== \"function\") throw new Error;\n set(this, id).ease = v;\n };\n}\n\nexport default function(value) {\n if (typeof value !== \"function\") throw new Error;\n return this.each(easeVarying(this._id, value));\n}\n","import {set} from \"./schedule.js\";\n\nexport default function() {\n var on0, on1, that = this, id = that._id, size = that.size();\n return new Promise(function(resolve, reject) {\n var cancel = {value: reject},\n end = {value: function() { if (--size === 0) resolve(); }};\n\n that.each(function() {\n var schedule = set(this, id),\n on = schedule.on;\n\n // If this node shared a dispatch with the previous node,\n // just assign the updated shared dispatch and we’re done!\n // Otherwise, copy-on-write.\n if (on !== on0) {\n on1 = (on0 = on).copy();\n on1._.cancel.push(cancel);\n on1._.interrupt.push(cancel);\n on1._.end.push(end);\n }\n\n schedule.on = on1;\n });\n\n // The selection was empty, resolve end immediately\n if (size === 0) resolve();\n });\n}\n","export const linear = t => +t;\n","export function cubicIn(t) {\n return t * t * t;\n}\n\nexport function cubicOut(t) {\n return --t * t * t + 1;\n}\n\nexport function cubicInOut(t) {\n return ((t *= 2) <= 1 ? t * t * t : (t -= 2) * t * t + 2) / 2;\n}\n","import {Transition, newId} from \"../transition/index.js\";\nimport schedule from \"../transition/schedule.js\";\nimport {easeCubicInOut} from \"d3-ease\";\nimport {now} from \"d3-timer\";\n\nvar defaultTiming = {\n time: null, // Set on use.\n delay: 0,\n duration: 250,\n ease: easeCubicInOut\n};\n\nfunction inherit(node, id) {\n var timing;\n while (!(timing = node.__transition) || !(timing = timing[id])) {\n if (!(node = node.parentNode)) {\n throw new Error(`transition ${id} not found`);\n }\n }\n return timing;\n}\n\nexport default function(name) {\n var id,\n timing;\n\n if (name instanceof Transition) {\n id = name._id, name = name._name;\n } else {\n id = newId(), (timing = defaultTiming).time = now(), name = name == null ? null : name + \"\";\n }\n\n for (var groups = this._groups, m = groups.length, j = 0; j < m; ++j) {\n for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {\n if (node = group[i]) {\n schedule(node, name, id, i, group, timing || inherit(node, id));\n }\n }\n }\n\n return new Transition(groups, this._parents, name, id);\n}\n","import {selection} from \"d3-selection\";\nimport selection_interrupt from \"./interrupt.js\";\nimport selection_transition from \"./transition.js\";\n\nselection.prototype.interrupt = selection_interrupt;\nselection.prototype.transition = selection_transition;\n","import interrupt from \"../interrupt.js\";\n\nexport default function(name) {\n return this.each(function() {\n interrupt(this, name);\n });\n}\n","import {STARTING, ENDING, ENDED} from \"./transition/schedule.js\";\n\nexport default function(node, name) {\n var schedules = node.__transition,\n schedule,\n active,\n empty = true,\n i;\n\n if (!schedules) return;\n\n name = name == null ? null : name + \"\";\n\n for (i in schedules) {\n if ((schedule = schedules[i]).name !== name) { empty = false; continue; }\n active = schedule.state > STARTING && schedule.state < ENDING;\n schedule.state = ENDED;\n schedule.timer.stop();\n schedule.on.call(active ? \"interrupt\" : \"cancel\", node, node.__data__, schedule.index, schedule.group);\n delete schedules[i];\n }\n\n if (empty) delete node.__transition;\n}\n","const pi = Math.PI,\n tau = 2 * pi,\n epsilon = 1e-6,\n tauEpsilon = tau - epsilon;\n\nfunction append(strings) {\n this._ += strings[0];\n for (let i = 1, n = strings.length; i < n; ++i) {\n this._ += arguments[i] + strings[i];\n }\n}\n\nfunction appendRound(digits) {\n let d = Math.floor(digits);\n if (!(d >= 0)) throw new Error(`invalid digits: ${digits}`);\n if (d > 15) return append;\n const k = 10 ** d;\n return function(strings) {\n this._ += strings[0];\n for (let i = 1, n = strings.length; i < n; ++i) {\n this._ += Math.round(arguments[i] * k) / k + strings[i];\n }\n };\n}\n\nexport class Path {\n constructor(digits) {\n this._x0 = this._y0 = // start of current subpath\n this._x1 = this._y1 = null; // end of current subpath\n this._ = \"\";\n this._append = digits == null ? append : appendRound(digits);\n }\n moveTo(x, y) {\n this._append`M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}`;\n }\n closePath() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._append`Z`;\n }\n }\n lineTo(x, y) {\n this._append`L${this._x1 = +x},${this._y1 = +y}`;\n }\n quadraticCurveTo(x1, y1, x, y) {\n this._append`Q${+x1},${+y1},${this._x1 = +x},${this._y1 = +y}`;\n }\n bezierCurveTo(x1, y1, x2, y2, x, y) {\n this._append`C${+x1},${+y1},${+x2},${+y2},${this._x1 = +x},${this._y1 = +y}`;\n }\n arcTo(x1, y1, x2, y2, r) {\n x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(`negative radius: ${r}`);\n\n let x0 = this._x1,\n y0 = this._y1,\n x21 = x2 - x1,\n y21 = y2 - y1,\n x01 = x0 - x1,\n y01 = y0 - y1,\n l01_2 = x01 * x01 + y01 * y01;\n\n // Is this path empty? Move to (x1,y1).\n if (this._x1 === null) {\n this._append`M${this._x1 = x1},${this._y1 = y1}`;\n }\n\n // Or, is (x1,y1) coincident with (x0,y0)? Do nothing.\n else if (!(l01_2 > epsilon));\n\n // Or, are (x0,y0), (x1,y1) and (x2,y2) collinear?\n // Equivalently, is (x1,y1) coincident with (x2,y2)?\n // Or, is the radius zero? Line to (x1,y1).\n else if (!(Math.abs(y01 * x21 - y21 * x01) > epsilon) || !r) {\n this._append`L${this._x1 = x1},${this._y1 = y1}`;\n }\n\n // Otherwise, draw an arc!\n else {\n let x20 = x2 - x0,\n y20 = y2 - y0,\n l21_2 = x21 * x21 + y21 * y21,\n l20_2 = x20 * x20 + y20 * y20,\n l21 = Math.sqrt(l21_2),\n l01 = Math.sqrt(l01_2),\n l = r * Math.tan((pi - Math.acos((l21_2 + l01_2 - l20_2) / (2 * l21 * l01))) / 2),\n t01 = l / l01,\n t21 = l / l21;\n\n // If the start tangent is not coincident with (x0,y0), line to.\n if (Math.abs(t01 - 1) > epsilon) {\n this._append`L${x1 + t01 * x01},${y1 + t01 * y01}`;\n }\n\n this._append`A${r},${r},0,0,${+(y01 * x20 > x01 * y20)},${this._x1 = x1 + t21 * x21},${this._y1 = y1 + t21 * y21}`;\n }\n }\n arc(x, y, r, a0, a1, ccw) {\n x = +x, y = +y, r = +r, ccw = !!ccw;\n\n // Is the radius negative? Error.\n if (r < 0) throw new Error(`negative radius: ${r}`);\n\n let dx = r * Math.cos(a0),\n dy = r * Math.sin(a0),\n x0 = x + dx,\n y0 = y + dy,\n cw = 1 ^ ccw,\n da = ccw ? a0 - a1 : a1 - a0;\n\n // Is this path empty? Move to (x0,y0).\n if (this._x1 === null) {\n this._append`M${x0},${y0}`;\n }\n\n // Or, is (x0,y0) not coincident with the previous point? Line to (x0,y0).\n else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) {\n this._append`L${x0},${y0}`;\n }\n\n // Is this arc empty? We’re done.\n if (!r) return;\n\n // Does the angle go the wrong way? Flip the direction.\n if (da < 0) da = da % tau + tau;\n\n // Is this a complete circle? Draw two arcs to complete the circle.\n if (da > tauEpsilon) {\n this._append`A${r},${r},0,1,${cw},${x - dx},${y - dy}A${r},${r},0,1,${cw},${this._x1 = x0},${this._y1 = y0}`;\n }\n\n // Is this arc non-empty? Draw an arc!\n else if (da > epsilon) {\n this._append`A${r},${r},0,${+(da >= pi)},${cw},${this._x1 = x + r * Math.cos(a1)},${this._y1 = y + r * Math.sin(a1)}`;\n }\n }\n rect(x, y, w, h) {\n this._append`M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}h${w = +w}v${+h}h${-w}Z`;\n }\n toString() {\n return this._;\n }\n}\n\nexport function path() {\n return new Path;\n}\n\n// Allow instanceof d3.path\npath.prototype = Path.prototype;\n\nexport function pathRound(digits = 3) {\n return new Path(+digits);\n}\n","export default function(x) {\n return Math.abs(x = Math.round(x)) >= 1e21\n ? x.toLocaleString(\"en\").replace(/,/g, \"\")\n : x.toString(10);\n}\n\n// Computes the decimal coefficient and exponent of the specified number x with\n// significant digits p, where x is positive and p is in [1, 21] or undefined.\n// For example, formatDecimalParts(1.23) returns [\"123\", 0].\nexport function formatDecimalParts(x, p) {\n if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n var i, coefficient = x.slice(0, i);\n\n // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n return [\n coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n +x.slice(i + 1)\n ];\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x) {\n return x = formatDecimalParts(Math.abs(x)), x ? x[1] : NaN;\n}\n","// [[fill]align][sign][symbol][0][width][,][.precision][~][type]\nvar re = /^(?:(.)?([<>=^]))?([+\\-( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?(~)?([a-z%])?$/i;\n\nexport default function formatSpecifier(specifier) {\n if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n var match;\n return new FormatSpecifier({\n fill: match[1],\n align: match[2],\n sign: match[3],\n symbol: match[4],\n zero: match[5],\n width: match[6],\n comma: match[7],\n precision: match[8] && match[8].slice(1),\n trim: match[9],\n type: match[10]\n });\n}\n\nformatSpecifier.prototype = FormatSpecifier.prototype; // instanceof\n\nexport function FormatSpecifier(specifier) {\n this.fill = specifier.fill === undefined ? \" \" : specifier.fill + \"\";\n this.align = specifier.align === undefined ? \">\" : specifier.align + \"\";\n this.sign = specifier.sign === undefined ? \"-\" : specifier.sign + \"\";\n this.symbol = specifier.symbol === undefined ? \"\" : specifier.symbol + \"\";\n this.zero = !!specifier.zero;\n this.width = specifier.width === undefined ? undefined : +specifier.width;\n this.comma = !!specifier.comma;\n this.precision = specifier.precision === undefined ? undefined : +specifier.precision;\n this.trim = !!specifier.trim;\n this.type = specifier.type === undefined ? \"\" : specifier.type + \"\";\n}\n\nFormatSpecifier.prototype.toString = function() {\n return this.fill\n + this.align\n + this.sign\n + this.symbol\n + (this.zero ? \"0\" : \"\")\n + (this.width === undefined ? \"\" : Math.max(1, this.width | 0))\n + (this.comma ? \",\" : \"\")\n + (this.precision === undefined ? \"\" : \".\" + Math.max(0, this.precision | 0))\n + (this.trim ? \"~\" : \"\")\n + this.type;\n};\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport var prefixExponent;\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1],\n i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n n = coefficient.length;\n return i === n ? coefficient\n : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimalParts(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1];\n return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n}\n","import formatDecimal from \"./formatDecimal.js\";\nimport formatPrefixAuto from \"./formatPrefixAuto.js\";\nimport formatRounded from \"./formatRounded.js\";\n\nexport default {\n \"%\": (x, p) => (x * 100).toFixed(p),\n \"b\": (x) => Math.round(x).toString(2),\n \"c\": (x) => x + \"\",\n \"d\": formatDecimal,\n \"e\": (x, p) => x.toExponential(p),\n \"f\": (x, p) => x.toFixed(p),\n \"g\": (x, p) => x.toPrecision(p),\n \"o\": (x) => Math.round(x).toString(8),\n \"p\": (x, p) => formatRounded(x * 100, p),\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": (x) => Math.round(x).toString(16).toUpperCase(),\n \"x\": (x) => Math.round(x).toString(16)\n};\n","export default function(x) {\n return x;\n}\n","import exponent from \"./exponent.js\";\nimport formatGroup from \"./formatGroup.js\";\nimport formatNumerals from \"./formatNumerals.js\";\nimport formatSpecifier from \"./formatSpecifier.js\";\nimport formatTrim from \"./formatTrim.js\";\nimport formatTypes from \"./formatTypes.js\";\nimport {prefixExponent} from \"./formatPrefixAuto.js\";\nimport identity from \"./identity.js\";\n\nvar map = Array.prototype.map,\n prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"µ\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\nexport default function(locale) {\n var group = locale.grouping === undefined || locale.thousands === undefined ? identity : formatGroup(map.call(locale.grouping, Number), locale.thousands + \"\"),\n currencyPrefix = locale.currency === undefined ? \"\" : locale.currency[0] + \"\",\n currencySuffix = locale.currency === undefined ? \"\" : locale.currency[1] + \"\",\n decimal = locale.decimal === undefined ? \".\" : locale.decimal + \"\",\n numerals = locale.numerals === undefined ? identity : formatNumerals(map.call(locale.numerals, String)),\n percent = locale.percent === undefined ? \"%\" : locale.percent + \"\",\n minus = locale.minus === undefined ? \"−\" : locale.minus + \"\",\n nan = locale.nan === undefined ? \"NaN\" : locale.nan + \"\";\n\n function newFormat(specifier) {\n specifier = formatSpecifier(specifier);\n\n var fill = specifier.fill,\n align = specifier.align,\n sign = specifier.sign,\n symbol = specifier.symbol,\n zero = specifier.zero,\n width = specifier.width,\n comma = specifier.comma,\n precision = specifier.precision,\n trim = specifier.trim,\n type = specifier.type;\n\n // The \"n\" type is an alias for \",g\".\n if (type === \"n\") comma = true, type = \"g\";\n\n // The \"\" type, and any invalid type, is an alias for \".12~g\".\n else if (!formatTypes[type]) precision === undefined && (precision = 12), trim = true, type = \"g\";\n\n // If zero fill is specified, padding goes after sign and before digits.\n if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n // Compute the prefix and suffix.\n // For SI-prefix, the suffix is lazily computed.\n var prefix = symbol === \"$\" ? currencyPrefix : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n suffix = symbol === \"$\" ? currencySuffix : /[%p]/.test(type) ? percent : \"\";\n\n // What format function should we use?\n // Is this an integer type?\n // Can this type generate exponential notation?\n var formatType = formatTypes[type],\n maybeSuffix = /[defgprs%]/.test(type);\n\n // Set the default precision if not specified,\n // or clamp the specified precision to the supported range.\n // For significant precision, it must be in [1, 21].\n // For fixed precision, it must be in [0, 20].\n precision = precision === undefined ? 6\n : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n : Math.max(0, Math.min(20, precision));\n\n function format(value) {\n var valuePrefix = prefix,\n valueSuffix = suffix,\n i, n, c;\n\n if (type === \"c\") {\n valueSuffix = formatType(value) + valueSuffix;\n value = \"\";\n } else {\n value = +value;\n\n // Determine the sign. -0 is not less than 0, but 1 / -0 is!\n var valueNegative = value < 0 || 1 / value < 0;\n\n // Perform the initial formatting.\n value = isNaN(value) ? nan : formatType(Math.abs(value), precision);\n\n // Trim insignificant zeros.\n if (trim) value = formatTrim(value);\n\n // If a negative value rounds to zero after formatting, and no explicit positive sign is requested, hide the sign.\n if (valueNegative && +value === 0 && sign !== \"+\") valueNegative = false;\n\n // Compute the prefix and suffix.\n valuePrefix = (valueNegative ? (sign === \"(\" ? sign : minus) : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n valueSuffix = (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + valueSuffix + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n // Break the formatted value into the integer “value” part that can be\n // grouped, and fractional or exponential “suffix” part that is not.\n if (maybeSuffix) {\n i = -1, n = value.length;\n while (++i < n) {\n if (c = value.charCodeAt(i), 48 > c || c > 57) {\n valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n value = value.slice(0, i);\n break;\n }\n }\n }\n }\n\n // If the fill character is not \"0\", grouping is applied before padding.\n if (comma && !zero) value = group(value, Infinity);\n\n // Compute the padding.\n var length = valuePrefix.length + value.length + valueSuffix.length,\n padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n // If the fill character is \"0\", grouping is applied after padding.\n if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n // Reconstruct the final output based on the desired alignment.\n switch (align) {\n case \"<\": value = valuePrefix + value + valueSuffix + padding; break;\n case \"=\": value = valuePrefix + padding + value + valueSuffix; break;\n case \"^\": value = padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length); break;\n default: value = padding + valuePrefix + value + valueSuffix; break;\n }\n\n return numerals(value);\n }\n\n format.toString = function() {\n return specifier + \"\";\n };\n\n return format;\n }\n\n function formatPrefix(specifier, value) {\n var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n e = Math.max(-8, Math.min(8, Math.floor(exponent(value) / 3))) * 3,\n k = Math.pow(10, -e),\n prefix = prefixes[8 + e / 3];\n return function(value) {\n return f(k * value) + prefix;\n };\n }\n\n return {\n format: newFormat,\n formatPrefix: formatPrefix\n };\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var format;\nexport var formatPrefix;\n\ndefaultLocale({\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"]\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n format = locale.format;\n formatPrefix = locale.formatPrefix;\n return locale;\n}\n","export default function(grouping, thousands) {\n return function(value, width) {\n var i = value.length,\n t = [],\n j = 0,\n g = grouping[0],\n length = 0;\n\n while (i > 0 && g > 0) {\n if (length + g + 1 > width) g = Math.max(1, width - length);\n t.push(value.substring(i -= g, i + g));\n if ((length += g + 1) > width) break;\n g = grouping[j = (j + 1) % grouping.length];\n }\n\n return t.reverse().join(thousands);\n };\n}\n","export default function(numerals) {\n return function(value) {\n return value.replace(/[0-9]/g, function(i) {\n return numerals[+i];\n });\n };\n}\n","// Trims insignificant zeros, e.g., replaces 1.2000k with 1.2k.\nexport default function(s) {\n out: for (var n = s.length, i = 1, i0 = -1, i1; i < n; ++i) {\n switch (s[i]) {\n case \".\": i0 = i1 = i; break;\n case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n default: if (!+s[i]) break out; if (i0 > 0) i0 = 0; break;\n }\n }\n return i0 > 0 ? s.slice(0, i0) + s.slice(i1 + 1) : s;\n}\n","export var epsilon = 1e-6;\nexport var epsilon2 = 1e-12;\nexport var pi = Math.PI;\nexport var halfPi = pi / 2;\nexport var quarterPi = pi / 4;\nexport var tau = pi * 2;\n\nexport var degrees = 180 / pi;\nexport var radians = pi / 180;\n\nexport var abs = Math.abs;\nexport var atan = Math.atan;\nexport var atan2 = Math.atan2;\nexport var cos = Math.cos;\nexport var ceil = Math.ceil;\nexport var exp = Math.exp;\nexport var floor = Math.floor;\nexport var hypot = Math.hypot;\nexport var log = Math.log;\nexport var pow = Math.pow;\nexport var sin = Math.sin;\nexport var sign = Math.sign || function(x) { return x > 0 ? 1 : x < 0 ? -1 : 0; };\nexport var sqrt = Math.sqrt;\nexport var tan = Math.tan;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x > 1 ? halfPi : x < -1 ? -halfPi : Math.asin(x);\n}\n\nexport function haversin(x) {\n return (x = sin(x / 2)) * x;\n}\n","export default function noop() {}\n","function streamGeometry(geometry, stream) {\n if (geometry && streamGeometryType.hasOwnProperty(geometry.type)) {\n streamGeometryType[geometry.type](geometry, stream);\n }\n}\n\nvar streamObjectType = {\n Feature: function(object, stream) {\n streamGeometry(object.geometry, stream);\n },\n FeatureCollection: function(object, stream) {\n var features = object.features, i = -1, n = features.length;\n while (++i < n) streamGeometry(features[i].geometry, stream);\n }\n};\n\nvar streamGeometryType = {\n Sphere: function(object, stream) {\n stream.sphere();\n },\n Point: function(object, stream) {\n object = object.coordinates;\n stream.point(object[0], object[1], object[2]);\n },\n MultiPoint: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);\n },\n LineString: function(object, stream) {\n streamLine(object.coordinates, stream, 0);\n },\n MultiLineString: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamLine(coordinates[i], stream, 0);\n },\n Polygon: function(object, stream) {\n streamPolygon(object.coordinates, stream);\n },\n MultiPolygon: function(object, stream) {\n var coordinates = object.coordinates, i = -1, n = coordinates.length;\n while (++i < n) streamPolygon(coordinates[i], stream);\n },\n GeometryCollection: function(object, stream) {\n var geometries = object.geometries, i = -1, n = geometries.length;\n while (++i < n) streamGeometry(geometries[i], stream);\n }\n};\n\nfunction streamLine(coordinates, stream, closed) {\n var i = -1, n = coordinates.length - closed, coordinate;\n stream.lineStart();\n while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);\n stream.lineEnd();\n}\n\nfunction streamPolygon(coordinates, stream) {\n var i = -1, n = coordinates.length;\n stream.polygonStart();\n while (++i < n) streamLine(coordinates[i], stream, 1);\n stream.polygonEnd();\n}\n\nexport default function(object, stream) {\n if (object && streamObjectType.hasOwnProperty(object.type)) {\n streamObjectType[object.type](object, stream);\n } else {\n streamGeometry(object, stream);\n }\n}\n","import {asin, atan2, cos, sin, sqrt} from \"./math.js\";\n\nexport function spherical(cartesian) {\n return [atan2(cartesian[1], cartesian[0]), asin(cartesian[2])];\n}\n\nexport function cartesian(spherical) {\n var lambda = spherical[0], phi = spherical[1], cosPhi = cos(phi);\n return [cosPhi * cos(lambda), cosPhi * sin(lambda), sin(phi)];\n}\n\nexport function cartesianDot(a, b) {\n return a[0] * b[0] + a[1] * b[1] + a[2] * b[2];\n}\n\nexport function cartesianCross(a, b) {\n return [a[1] * b[2] - a[2] * b[1], a[2] * b[0] - a[0] * b[2], a[0] * b[1] - a[1] * b[0]];\n}\n\n// TODO return a\nexport function cartesianAddInPlace(a, b) {\n a[0] += b[0], a[1] += b[1], a[2] += b[2];\n}\n\nexport function cartesianScale(vector, k) {\n return [vector[0] * k, vector[1] * k, vector[2] * k];\n}\n\n// TODO return d\nexport function cartesianNormalizeInPlace(d) {\n var l = sqrt(d[0] * d[0] + d[1] * d[1] + d[2] * d[2]);\n d[0] /= l, d[1] /= l, d[2] /= l;\n}\n","export default function(a, b) {\n\n function compose(x, y) {\n return x = a(x, y), b(x[0], x[1]);\n }\n\n if (a.invert && b.invert) compose.invert = function(x, y) {\n return x = b.invert(x, y), x && a.invert(x[0], x[1]);\n };\n\n return compose;\n}\n","import compose from \"./compose.js\";\nimport {abs, asin, atan2, cos, degrees, pi, radians, sin, tau} from \"./math.js\";\n\nfunction rotationIdentity(lambda, phi) {\n if (abs(lambda) > pi) lambda -= Math.round(lambda / tau) * tau;\n return [lambda, phi];\n}\n\nrotationIdentity.invert = rotationIdentity;\n\nexport function rotateRadians(deltaLambda, deltaPhi, deltaGamma) {\n return (deltaLambda %= tau) ? (deltaPhi || deltaGamma ? compose(rotationLambda(deltaLambda), rotationPhiGamma(deltaPhi, deltaGamma))\n : rotationLambda(deltaLambda))\n : (deltaPhi || deltaGamma ? rotationPhiGamma(deltaPhi, deltaGamma)\n : rotationIdentity);\n}\n\nfunction forwardRotationLambda(deltaLambda) {\n return function(lambda, phi) {\n lambda += deltaLambda;\n if (abs(lambda) > pi) lambda -= Math.round(lambda / tau) * tau;\n return [lambda, phi];\n };\n}\n\nfunction rotationLambda(deltaLambda) {\n var rotation = forwardRotationLambda(deltaLambda);\n rotation.invert = forwardRotationLambda(-deltaLambda);\n return rotation;\n}\n\nfunction rotationPhiGamma(deltaPhi, deltaGamma) {\n var cosDeltaPhi = cos(deltaPhi),\n sinDeltaPhi = sin(deltaPhi),\n cosDeltaGamma = cos(deltaGamma),\n sinDeltaGamma = sin(deltaGamma);\n\n function rotation(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaPhi + x * sinDeltaPhi;\n return [\n atan2(y * cosDeltaGamma - k * sinDeltaGamma, x * cosDeltaPhi - z * sinDeltaPhi),\n asin(k * cosDeltaGamma + y * sinDeltaGamma)\n ];\n }\n\n rotation.invert = function(lambda, phi) {\n var cosPhi = cos(phi),\n x = cos(lambda) * cosPhi,\n y = sin(lambda) * cosPhi,\n z = sin(phi),\n k = z * cosDeltaGamma - y * sinDeltaGamma;\n return [\n atan2(y * cosDeltaGamma + z * sinDeltaGamma, x * cosDeltaPhi + k * sinDeltaPhi),\n asin(k * cosDeltaPhi - x * sinDeltaPhi)\n ];\n };\n\n return rotation;\n}\n\nexport default function(rotate) {\n rotate = rotateRadians(rotate[0] * radians, rotate[1] * radians, rotate.length > 2 ? rotate[2] * radians : 0);\n\n function forward(coordinates) {\n coordinates = rotate(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n }\n\n forward.invert = function(coordinates) {\n coordinates = rotate.invert(coordinates[0] * radians, coordinates[1] * radians);\n return coordinates[0] *= degrees, coordinates[1] *= degrees, coordinates;\n };\n\n return forward;\n}\n","import {cartesian, cartesianNormalizeInPlace, spherical} from \"./cartesian.js\";\nimport constant from \"./constant.js\";\nimport {acos, cos, degrees, epsilon, radians, sin, tau} from \"./math.js\";\nimport {rotateRadians} from \"./rotation.js\";\n\n// Generates a circle centered at [0°, 0°], with a given radius and precision.\nexport function circleStream(stream, radius, delta, direction, t0, t1) {\n if (!delta) return;\n var cosRadius = cos(radius),\n sinRadius = sin(radius),\n step = direction * delta;\n if (t0 == null) {\n t0 = radius + direction * tau;\n t1 = radius - step / 2;\n } else {\n t0 = circleRadius(cosRadius, t0);\n t1 = circleRadius(cosRadius, t1);\n if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau;\n }\n for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {\n point = spherical([cosRadius, -sinRadius * cos(t), -sinRadius * sin(t)]);\n stream.point(point[0], point[1]);\n }\n}\n\n// Returns the signed angle of a cartesian point relative to [cosRadius, 0, 0].\nfunction circleRadius(cosRadius, point) {\n point = cartesian(point), point[0] -= cosRadius;\n cartesianNormalizeInPlace(point);\n var radius = acos(-point[1]);\n return ((-point[2] < 0 ? -radius : radius) + tau - epsilon) % tau;\n}\n\nexport default function() {\n var center = constant([0, 0]),\n radius = constant(90),\n precision = constant(6),\n ring,\n rotate,\n stream = {point: point};\n\n function point(x, y) {\n ring.push(x = rotate(x, y));\n x[0] *= degrees, x[1] *= degrees;\n }\n\n function circle() {\n var c = center.apply(this, arguments),\n r = radius.apply(this, arguments) * radians,\n p = precision.apply(this, arguments) * radians;\n ring = [];\n rotate = rotateRadians(-c[0] * radians, -c[1] * radians, 0).invert;\n circleStream(stream, r, p, 1);\n c = {type: \"Polygon\", coordinates: [ring]};\n ring = rotate = null;\n return c;\n }\n\n circle.center = function(_) {\n return arguments.length ? (center = typeof _ === \"function\" ? _ : constant([+_[0], +_[1]]), circle) : center;\n };\n\n circle.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), circle) : radius;\n };\n\n circle.precision = function(_) {\n return arguments.length ? (precision = typeof _ === \"function\" ? _ : constant(+_), circle) : precision;\n };\n\n return circle;\n}\n","import noop from \"../noop.js\";\n\nexport default function() {\n var lines = [],\n line;\n return {\n point: function(x, y, m) {\n line.push([x, y, m]);\n },\n lineStart: function() {\n lines.push(line = []);\n },\n lineEnd: noop,\n rejoin: function() {\n if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));\n },\n result: function() {\n var result = lines;\n lines = [];\n line = null;\n return result;\n }\n };\n}\n","import {abs, epsilon} from \"./math.js\";\n\nexport default function(a, b) {\n return abs(a[0] - b[0]) < epsilon && abs(a[1] - b[1]) < epsilon;\n}\n","import pointEqual from \"../pointEqual.js\";\nimport {epsilon} from \"../math.js\";\n\nfunction Intersection(point, points, other, entry) {\n this.x = point;\n this.z = points;\n this.o = other; // another intersection\n this.e = entry; // is an entry?\n this.v = false; // visited\n this.n = this.p = null; // next & previous\n}\n\n// A generalized polygon clipping algorithm: given a polygon that has been cut\n// into its visible line segments, and rejoins the segments by interpolating\n// along the clip edge.\nexport default function(segments, compareIntersection, startInside, interpolate, stream) {\n var subject = [],\n clip = [],\n i,\n n;\n\n segments.forEach(function(segment) {\n if ((n = segment.length - 1) <= 0) return;\n var n, p0 = segment[0], p1 = segment[n], x;\n\n if (pointEqual(p0, p1)) {\n if (!p0[2] && !p1[2]) {\n stream.lineStart();\n for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);\n stream.lineEnd();\n return;\n }\n // handle degenerate cases by moving the point\n p1[0] += 2 * epsilon;\n }\n\n subject.push(x = new Intersection(p0, segment, null, true));\n clip.push(x.o = new Intersection(p0, null, x, false));\n subject.push(x = new Intersection(p1, segment, null, false));\n clip.push(x.o = new Intersection(p1, null, x, true));\n });\n\n if (!subject.length) return;\n\n clip.sort(compareIntersection);\n link(subject);\n link(clip);\n\n for (i = 0, n = clip.length; i < n; ++i) {\n clip[i].e = startInside = !startInside;\n }\n\n var start = subject[0],\n points,\n point;\n\n while (1) {\n // Find first unvisited intersection.\n var current = start,\n isSubject = true;\n while (current.v) if ((current = current.n) === start) return;\n points = current.z;\n stream.lineStart();\n do {\n current.v = current.o.v = true;\n if (current.e) {\n if (isSubject) {\n for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.n.x, 1, stream);\n }\n current = current.n;\n } else {\n if (isSubject) {\n points = current.p.z;\n for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);\n } else {\n interpolate(current.x, current.p.x, -1, stream);\n }\n current = current.p;\n }\n current = current.o;\n points = current.z;\n isSubject = !isSubject;\n } while (!current.v);\n stream.lineEnd();\n }\n}\n\nfunction link(array) {\n if (!(n = array.length)) return;\n var n,\n i = 0,\n a = array[0],\n b;\n while (++i < n) {\n a.n = b = array[i];\n b.p = a;\n a = b;\n }\n a.n = b = array[0];\n b.p = a;\n}\n","import {Adder} from \"d3-array\";\nimport {cartesian, cartesianCross, cartesianNormalizeInPlace} from \"./cartesian.js\";\nimport {abs, asin, atan2, cos, epsilon, epsilon2, halfPi, pi, quarterPi, sign, sin, tau} from \"./math.js\";\n\nfunction longitude(point) {\n return abs(point[0]) <= pi ? point[0] : sign(point[0]) * ((abs(point[0]) + pi) % tau - pi);\n}\n\nexport default function(polygon, point) {\n var lambda = longitude(point),\n phi = point[1],\n sinPhi = sin(phi),\n normal = [sin(lambda), -cos(lambda), 0],\n angle = 0,\n winding = 0;\n\n var sum = new Adder();\n\n if (sinPhi === 1) phi = halfPi + epsilon;\n else if (sinPhi === -1) phi = -halfPi - epsilon;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n if (!(m = (ring = polygon[i]).length)) continue;\n var ring,\n m,\n point0 = ring[m - 1],\n lambda0 = longitude(point0),\n phi0 = point0[1] / 2 + quarterPi,\n sinPhi0 = sin(phi0),\n cosPhi0 = cos(phi0);\n\n for (var j = 0; j < m; ++j, lambda0 = lambda1, sinPhi0 = sinPhi1, cosPhi0 = cosPhi1, point0 = point1) {\n var point1 = ring[j],\n lambda1 = longitude(point1),\n phi1 = point1[1] / 2 + quarterPi,\n sinPhi1 = sin(phi1),\n cosPhi1 = cos(phi1),\n delta = lambda1 - lambda0,\n sign = delta >= 0 ? 1 : -1,\n absDelta = sign * delta,\n antimeridian = absDelta > pi,\n k = sinPhi0 * sinPhi1;\n\n sum.add(atan2(k * sign * sin(absDelta), cosPhi0 * cosPhi1 + k * cos(absDelta)));\n angle += antimeridian ? delta + sign * tau : delta;\n\n // Are the longitudes either side of the point’s meridian (lambda),\n // and are the latitudes smaller than the parallel (phi)?\n if (antimeridian ^ lambda0 >= lambda ^ lambda1 >= lambda) {\n var arc = cartesianCross(cartesian(point0), cartesian(point1));\n cartesianNormalizeInPlace(arc);\n var intersection = cartesianCross(normal, arc);\n cartesianNormalizeInPlace(intersection);\n var phiArc = (antimeridian ^ delta >= 0 ? -1 : 1) * asin(intersection[2]);\n if (phi > phiArc || phi === phiArc && (arc[0] || arc[1])) {\n winding += antimeridian ^ delta >= 0 ? 1 : -1;\n }\n }\n }\n }\n\n // First, determine whether the South pole is inside or outside:\n //\n // It is inside if:\n // * the polygon winds around it in a clockwise direction.\n // * the polygon does not (cumulatively) wind around it, but has a negative\n // (counter-clockwise) area.\n //\n // Second, count the (signed) number of times a segment crosses a lambda\n // from the point to the South pole. If it is zero, then the point is the\n // same side as the South pole.\n\n return (angle < -epsilon || angle < epsilon && sum < -epsilon2) ^ (winding & 1);\n}\n","import clipBuffer from \"./buffer.js\";\nimport clipRejoin from \"./rejoin.js\";\nimport {epsilon, halfPi} from \"../math.js\";\nimport polygonContains from \"../polygonContains.js\";\nimport {merge} from \"d3-array\";\n\nexport default function(pointVisible, clipLine, interpolate, start) {\n return function(sink) {\n var line = clipLine(sink),\n ringBuffer = clipBuffer(),\n ringSink = clipLine(ringBuffer),\n polygonStarted = false,\n polygon,\n segments,\n ring;\n\n var clip = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() {\n clip.point = pointRing;\n clip.lineStart = ringStart;\n clip.lineEnd = ringEnd;\n segments = [];\n polygon = [];\n },\n polygonEnd: function() {\n clip.point = point;\n clip.lineStart = lineStart;\n clip.lineEnd = lineEnd;\n segments = merge(segments);\n var startInside = polygonContains(polygon, start);\n if (segments.length) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n clipRejoin(segments, compareIntersection, startInside, interpolate, sink);\n } else if (startInside) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n }\n if (polygonStarted) sink.polygonEnd(), polygonStarted = false;\n segments = polygon = null;\n },\n sphere: function() {\n sink.polygonStart();\n sink.lineStart();\n interpolate(null, null, 1, sink);\n sink.lineEnd();\n sink.polygonEnd();\n }\n };\n\n function point(lambda, phi) {\n if (pointVisible(lambda, phi)) sink.point(lambda, phi);\n }\n\n function pointLine(lambda, phi) {\n line.point(lambda, phi);\n }\n\n function lineStart() {\n clip.point = pointLine;\n line.lineStart();\n }\n\n function lineEnd() {\n clip.point = point;\n line.lineEnd();\n }\n\n function pointRing(lambda, phi) {\n ring.push([lambda, phi]);\n ringSink.point(lambda, phi);\n }\n\n function ringStart() {\n ringSink.lineStart();\n ring = [];\n }\n\n function ringEnd() {\n pointRing(ring[0][0], ring[0][1]);\n ringSink.lineEnd();\n\n var clean = ringSink.clean(),\n ringSegments = ringBuffer.result(),\n i, n = ringSegments.length, m,\n segment,\n point;\n\n ring.pop();\n polygon.push(ring);\n ring = null;\n\n if (!n) return;\n\n // No intersections.\n if (clean & 1) {\n segment = ringSegments[0];\n if ((m = segment.length - 1) > 0) {\n if (!polygonStarted) sink.polygonStart(), polygonStarted = true;\n sink.lineStart();\n for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);\n sink.lineEnd();\n }\n return;\n }\n\n // Rejoin connected segments.\n // TODO reuse ringBuffer.rejoin()?\n if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));\n\n segments.push(ringSegments.filter(validSegment));\n }\n\n return clip;\n };\n}\n\nfunction validSegment(segment) {\n return segment.length > 1;\n}\n\n// Intersections are sorted along the clip edge. For both antimeridian cutting\n// and circle clipping, the same comparison is used.\nfunction compareIntersection(a, b) {\n return ((a = a.x)[0] < 0 ? a[1] - halfPi - epsilon : halfPi - a[1])\n - ((b = b.x)[0] < 0 ? b[1] - halfPi - epsilon : halfPi - b[1]);\n}\n","import clip from \"./index.js\";\nimport {abs, atan, cos, epsilon, halfPi, pi, sin} from \"../math.js\";\n\nexport default clip(\n function() { return true; },\n clipAntimeridianLine,\n clipAntimeridianInterpolate,\n [-pi, -halfPi]\n);\n\n// Takes a line and cuts into visible segments. Return values: 0 - there were\n// intersections or the line was empty; 1 - no intersections; 2 - there were\n// intersections, and the first and last segments should be rejoined.\nfunction clipAntimeridianLine(stream) {\n var lambda0 = NaN,\n phi0 = NaN,\n sign0 = NaN,\n clean; // no intersections\n\n return {\n lineStart: function() {\n stream.lineStart();\n clean = 1;\n },\n point: function(lambda1, phi1) {\n var sign1 = lambda1 > 0 ? pi : -pi,\n delta = abs(lambda1 - lambda0);\n if (abs(delta - pi) < epsilon) { // line crosses a pole\n stream.point(lambda0, phi0 = (phi0 + phi1) / 2 > 0 ? halfPi : -halfPi);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n stream.point(lambda1, phi0);\n clean = 0;\n } else if (sign0 !== sign1 && delta >= pi) { // line crosses antimeridian\n if (abs(lambda0 - sign0) < epsilon) lambda0 -= sign0 * epsilon; // handle degeneracies\n if (abs(lambda1 - sign1) < epsilon) lambda1 -= sign1 * epsilon;\n phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);\n stream.point(sign0, phi0);\n stream.lineEnd();\n stream.lineStart();\n stream.point(sign1, phi0);\n clean = 0;\n }\n stream.point(lambda0 = lambda1, phi0 = phi1);\n sign0 = sign1;\n },\n lineEnd: function() {\n stream.lineEnd();\n lambda0 = phi0 = NaN;\n },\n clean: function() {\n return 2 - clean; // if intersections, rejoin first and last segments\n }\n };\n}\n\nfunction clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1) {\n var cosPhi0,\n cosPhi1,\n sinLambda0Lambda1 = sin(lambda0 - lambda1);\n return abs(sinLambda0Lambda1) > epsilon\n ? atan((sin(phi0) * (cosPhi1 = cos(phi1)) * sin(lambda1)\n - sin(phi1) * (cosPhi0 = cos(phi0)) * sin(lambda0))\n / (cosPhi0 * cosPhi1 * sinLambda0Lambda1))\n : (phi0 + phi1) / 2;\n}\n\nfunction clipAntimeridianInterpolate(from, to, direction, stream) {\n var phi;\n if (from == null) {\n phi = direction * halfPi;\n stream.point(-pi, phi);\n stream.point(0, phi);\n stream.point(pi, phi);\n stream.point(pi, 0);\n stream.point(pi, -phi);\n stream.point(0, -phi);\n stream.point(-pi, -phi);\n stream.point(-pi, 0);\n stream.point(-pi, phi);\n } else if (abs(from[0] - to[0]) > epsilon) {\n var lambda = from[0] < to[0] ? pi : -pi;\n phi = direction * lambda / 2;\n stream.point(-lambda, phi);\n stream.point(0, phi);\n stream.point(lambda, phi);\n } else {\n stream.point(to[0], to[1]);\n }\n}\n","import {cartesian, cartesianAddInPlace, cartesianCross, cartesianDot, cartesianScale, spherical} from \"../cartesian.js\";\nimport {circleStream} from \"../circle.js\";\nimport {abs, cos, epsilon, pi, radians, sqrt} from \"../math.js\";\nimport pointEqual from \"../pointEqual.js\";\nimport clip from \"./index.js\";\n\nexport default function(radius) {\n var cr = cos(radius),\n delta = 6 * radians,\n smallRadius = cr > 0,\n notHemisphere = abs(cr) > epsilon; // TODO optimise for this common case\n\n function interpolate(from, to, direction, stream) {\n circleStream(stream, radius, delta, direction, from, to);\n }\n\n function visible(lambda, phi) {\n return cos(lambda) * cos(phi) > cr;\n }\n\n // Takes a line and cuts into visible segments. Return values used for polygon\n // clipping: 0 - there were intersections or the line was empty; 1 - no\n // intersections 2 - there were intersections, and the first and last segments\n // should be rejoined.\n function clipLine(stream) {\n var point0, // previous point\n c0, // code for previous point\n v0, // visibility of previous point\n v00, // visibility of first point\n clean; // no intersections\n return {\n lineStart: function() {\n v00 = v0 = false;\n clean = 1;\n },\n point: function(lambda, phi) {\n var point1 = [lambda, phi],\n point2,\n v = visible(lambda, phi),\n c = smallRadius\n ? v ? 0 : code(lambda, phi)\n : v ? code(lambda + (lambda < 0 ? pi : -pi), phi) : 0;\n if (!point0 && (v00 = v0 = v)) stream.lineStart();\n if (v !== v0) {\n point2 = intersect(point0, point1);\n if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2))\n point1[2] = 1;\n }\n if (v !== v0) {\n clean = 0;\n if (v) {\n // outside going in\n stream.lineStart();\n point2 = intersect(point1, point0);\n stream.point(point2[0], point2[1]);\n } else {\n // inside going out\n point2 = intersect(point0, point1);\n stream.point(point2[0], point2[1], 2);\n stream.lineEnd();\n }\n point0 = point2;\n } else if (notHemisphere && point0 && smallRadius ^ v) {\n var t;\n // If the codes for two points are different, or are both zero,\n // and there this segment intersects with the small circle.\n if (!(c & c0) && (t = intersect(point1, point0, true))) {\n clean = 0;\n if (smallRadius) {\n stream.lineStart();\n stream.point(t[0][0], t[0][1]);\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n } else {\n stream.point(t[1][0], t[1][1]);\n stream.lineEnd();\n stream.lineStart();\n stream.point(t[0][0], t[0][1], 3);\n }\n }\n }\n if (v && (!point0 || !pointEqual(point0, point1))) {\n stream.point(point1[0], point1[1]);\n }\n point0 = point1, v0 = v, c0 = c;\n },\n lineEnd: function() {\n if (v0) stream.lineEnd();\n point0 = null;\n },\n // Rejoin first and last segments if there were intersections and the first\n // and last points were visible.\n clean: function() {\n return clean | ((v00 && v0) << 1);\n }\n };\n }\n\n // Intersects the great circle between a and b with the clip circle.\n function intersect(a, b, two) {\n var pa = cartesian(a),\n pb = cartesian(b);\n\n // We have two planes, n1.p = d1 and n2.p = d2.\n // Find intersection line p(t) = c1 n1 + c2 n2 + t (n1 ⨯ n2).\n var n1 = [1, 0, 0], // normal\n n2 = cartesianCross(pa, pb),\n n2n2 = cartesianDot(n2, n2),\n n1n2 = n2[0], // cartesianDot(n1, n2),\n determinant = n2n2 - n1n2 * n1n2;\n\n // Two polar points.\n if (!determinant) return !two && a;\n\n var c1 = cr * n2n2 / determinant,\n c2 = -cr * n1n2 / determinant,\n n1xn2 = cartesianCross(n1, n2),\n A = cartesianScale(n1, c1),\n B = cartesianScale(n2, c2);\n cartesianAddInPlace(A, B);\n\n // Solve |p(t)|^2 = 1.\n var u = n1xn2,\n w = cartesianDot(A, u),\n uu = cartesianDot(u, u),\n t2 = w * w - uu * (cartesianDot(A, A) - 1);\n\n if (t2 < 0) return;\n\n var t = sqrt(t2),\n q = cartesianScale(u, (-w - t) / uu);\n cartesianAddInPlace(q, A);\n q = spherical(q);\n\n if (!two) return q;\n\n // Two intersection points.\n var lambda0 = a[0],\n lambda1 = b[0],\n phi0 = a[1],\n phi1 = b[1],\n z;\n\n if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;\n\n var delta = lambda1 - lambda0,\n polar = abs(delta - pi) < epsilon,\n meridian = polar || delta < epsilon;\n\n if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;\n\n // Check that the first point is between a and b.\n if (meridian\n ? polar\n ? phi0 + phi1 > 0 ^ q[1] < (abs(q[0] - lambda0) < epsilon ? phi0 : phi1)\n : phi0 <= q[1] && q[1] <= phi1\n : delta > pi ^ (lambda0 <= q[0] && q[0] <= lambda1)) {\n var q1 = cartesianScale(u, (-w + t) / uu);\n cartesianAddInPlace(q1, A);\n return [q, spherical(q1)];\n }\n }\n\n // Generates a 4-bit vector representing the location of a point relative to\n // the small circle's bounding box.\n function code(lambda, phi) {\n var r = smallRadius ? radius : pi - radius,\n code = 0;\n if (lambda < -r) code |= 1; // left\n else if (lambda > r) code |= 2; // right\n if (phi < -r) code |= 4; // below\n else if (phi > r) code |= 8; // above\n return code;\n }\n\n return clip(visible, clipLine, interpolate, smallRadius ? [0, -radius] : [-pi, radius - pi]);\n}\n","import {abs, epsilon} from \"../math.js\";\nimport clipBuffer from \"./buffer.js\";\nimport clipLine from \"./line.js\";\nimport clipRejoin from \"./rejoin.js\";\nimport {merge} from \"d3-array\";\n\nvar clipMax = 1e9, clipMin = -clipMax;\n\n// TODO Use d3-polygon’s polygonContains here for the ring check?\n// TODO Eliminate duplicate buffering in clipBuffer and polygon.push?\n\nexport default function clipRectangle(x0, y0, x1, y1) {\n\n function visible(x, y) {\n return x0 <= x && x <= x1 && y0 <= y && y <= y1;\n }\n\n function interpolate(from, to, direction, stream) {\n var a = 0, a1 = 0;\n if (from == null\n || (a = corner(from, direction)) !== (a1 = corner(to, direction))\n || comparePoint(from, to) < 0 ^ direction > 0) {\n do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);\n while ((a = (a + direction + 4) % 4) !== a1);\n } else {\n stream.point(to[0], to[1]);\n }\n }\n\n function corner(p, direction) {\n return abs(p[0] - x0) < epsilon ? direction > 0 ? 0 : 3\n : abs(p[0] - x1) < epsilon ? direction > 0 ? 2 : 1\n : abs(p[1] - y0) < epsilon ? direction > 0 ? 1 : 0\n : direction > 0 ? 3 : 2; // abs(p[1] - y1) < epsilon\n }\n\n function compareIntersection(a, b) {\n return comparePoint(a.x, b.x);\n }\n\n function comparePoint(a, b) {\n var ca = corner(a, 1),\n cb = corner(b, 1);\n return ca !== cb ? ca - cb\n : ca === 0 ? b[1] - a[1]\n : ca === 1 ? a[0] - b[0]\n : ca === 2 ? a[1] - b[1]\n : b[0] - a[0];\n }\n\n return function(stream) {\n var activeStream = stream,\n bufferStream = clipBuffer(),\n segments,\n polygon,\n ring,\n x__, y__, v__, // first point\n x_, y_, v_, // previous point\n first,\n clean;\n\n var clipStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: polygonStart,\n polygonEnd: polygonEnd\n };\n\n function point(x, y) {\n if (visible(x, y)) activeStream.point(x, y);\n }\n\n function polygonInside() {\n var winding = 0;\n\n for (var i = 0, n = polygon.length; i < n; ++i) {\n for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {\n a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];\n if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }\n else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }\n }\n }\n\n return winding;\n }\n\n // Buffer geometry within a polygon and then clip it en masse.\n function polygonStart() {\n activeStream = bufferStream, segments = [], polygon = [], clean = true;\n }\n\n function polygonEnd() {\n var startInside = polygonInside(),\n cleanInside = clean && startInside,\n visible = (segments = merge(segments)).length;\n if (cleanInside || visible) {\n stream.polygonStart();\n if (cleanInside) {\n stream.lineStart();\n interpolate(null, null, 1, stream);\n stream.lineEnd();\n }\n if (visible) {\n clipRejoin(segments, compareIntersection, startInside, interpolate, stream);\n }\n stream.polygonEnd();\n }\n activeStream = stream, segments = polygon = ring = null;\n }\n\n function lineStart() {\n clipStream.point = linePoint;\n if (polygon) polygon.push(ring = []);\n first = true;\n v_ = false;\n x_ = y_ = NaN;\n }\n\n // TODO rather than special-case polygons, simply handle them separately.\n // Ideally, coincident intersection points should be jittered to avoid\n // clipping issues.\n function lineEnd() {\n if (segments) {\n linePoint(x__, y__);\n if (v__ && v_) bufferStream.rejoin();\n segments.push(bufferStream.result());\n }\n clipStream.point = point;\n if (v_) activeStream.lineEnd();\n }\n\n function linePoint(x, y) {\n var v = visible(x, y);\n if (polygon) ring.push([x, y]);\n if (first) {\n x__ = x, y__ = y, v__ = v;\n first = false;\n if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n }\n } else {\n if (v && v_) activeStream.point(x, y);\n else {\n var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],\n b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];\n if (clipLine(a, b, x0, y0, x1, y1)) {\n if (!v_) {\n activeStream.lineStart();\n activeStream.point(a[0], a[1]);\n }\n activeStream.point(b[0], b[1]);\n if (!v) activeStream.lineEnd();\n clean = false;\n } else if (v) {\n activeStream.lineStart();\n activeStream.point(x, y);\n clean = false;\n }\n }\n }\n x_ = x, y_ = y, v_ = v;\n }\n\n return clipStream;\n };\n}\n","export default function(a, b, x0, y0, x1, y1) {\n var ax = a[0],\n ay = a[1],\n bx = b[0],\n by = b[1],\n t0 = 0,\n t1 = 1,\n dx = bx - ax,\n dy = by - ay,\n r;\n\n r = x0 - ax;\n if (!dx && r > 0) return;\n r /= dx;\n if (dx < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dx > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = x1 - ax;\n if (!dx && r < 0) return;\n r /= dx;\n if (dx < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dx > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n r = y0 - ay;\n if (!dy && r > 0) return;\n r /= dy;\n if (dy < 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n } else if (dy > 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n }\n\n r = y1 - ay;\n if (!dy && r < 0) return;\n r /= dy;\n if (dy < 0) {\n if (r > t1) return;\n if (r > t0) t0 = r;\n } else if (dy > 0) {\n if (r < t0) return;\n if (r < t1) t1 = r;\n }\n\n if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;\n if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;\n return true;\n}\n","export default x => x;\n","import {Adder} from \"d3-array\";\nimport {abs} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nvar areaSum = new Adder(),\n areaRingSum = new Adder(),\n x00,\n y00,\n x0,\n y0;\n\nvar areaStream = {\n point: noop,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: function() {\n areaStream.lineStart = areaRingStart;\n areaStream.lineEnd = areaRingEnd;\n },\n polygonEnd: function() {\n areaStream.lineStart = areaStream.lineEnd = areaStream.point = noop;\n areaSum.add(abs(areaRingSum));\n areaRingSum = new Adder();\n },\n result: function() {\n var area = areaSum / 2;\n areaSum = new Adder();\n return area;\n }\n};\n\nfunction areaRingStart() {\n areaStream.point = areaPointFirst;\n}\n\nfunction areaPointFirst(x, y) {\n areaStream.point = areaPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction areaPoint(x, y) {\n areaRingSum.add(y0 * x - x0 * y);\n x0 = x, y0 = y;\n}\n\nfunction areaRingEnd() {\n areaPoint(x00, y00);\n}\n\nexport default areaStream;\n","import noop from \"../noop.js\";\n\nvar x0 = Infinity,\n y0 = x0,\n x1 = -x0,\n y1 = x1;\n\nvar boundsStream = {\n point: boundsPoint,\n lineStart: noop,\n lineEnd: noop,\n polygonStart: noop,\n polygonEnd: noop,\n result: function() {\n var bounds = [[x0, y0], [x1, y1]];\n x1 = y1 = -(y0 = x0 = Infinity);\n return bounds;\n }\n};\n\nfunction boundsPoint(x, y) {\n if (x < x0) x0 = x;\n if (x > x1) x1 = x;\n if (y < y0) y0 = y;\n if (y > y1) y1 = y;\n}\n\nexport default boundsStream;\n","import {sqrt} from \"../math.js\";\n\n// TODO Enforce positive area for exterior, negative area for interior?\n\nvar X0 = 0,\n Y0 = 0,\n Z0 = 0,\n X1 = 0,\n Y1 = 0,\n Z1 = 0,\n X2 = 0,\n Y2 = 0,\n Z2 = 0,\n x00,\n y00,\n x0,\n y0;\n\nvar centroidStream = {\n point: centroidPoint,\n lineStart: centroidLineStart,\n lineEnd: centroidLineEnd,\n polygonStart: function() {\n centroidStream.lineStart = centroidRingStart;\n centroidStream.lineEnd = centroidRingEnd;\n },\n polygonEnd: function() {\n centroidStream.point = centroidPoint;\n centroidStream.lineStart = centroidLineStart;\n centroidStream.lineEnd = centroidLineEnd;\n },\n result: function() {\n var centroid = Z2 ? [X2 / Z2, Y2 / Z2]\n : Z1 ? [X1 / Z1, Y1 / Z1]\n : Z0 ? [X0 / Z0, Y0 / Z0]\n : [NaN, NaN];\n X0 = Y0 = Z0 =\n X1 = Y1 = Z1 =\n X2 = Y2 = Z2 = 0;\n return centroid;\n }\n};\n\nfunction centroidPoint(x, y) {\n X0 += x;\n Y0 += y;\n ++Z0;\n}\n\nfunction centroidLineStart() {\n centroidStream.point = centroidPointFirstLine;\n}\n\nfunction centroidPointFirstLine(x, y) {\n centroidStream.point = centroidPointLine;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidPointLine(x, y) {\n var dx = x - x0, dy = y - y0, z = sqrt(dx * dx + dy * dy);\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n centroidPoint(x0 = x, y0 = y);\n}\n\nfunction centroidLineEnd() {\n centroidStream.point = centroidPoint;\n}\n\nfunction centroidRingStart() {\n centroidStream.point = centroidPointFirstRing;\n}\n\nfunction centroidRingEnd() {\n centroidPointRing(x00, y00);\n}\n\nfunction centroidPointFirstRing(x, y) {\n centroidStream.point = centroidPointRing;\n centroidPoint(x00 = x0 = x, y00 = y0 = y);\n}\n\nfunction centroidPointRing(x, y) {\n var dx = x - x0,\n dy = y - y0,\n z = sqrt(dx * dx + dy * dy);\n\n X1 += z * (x0 + x) / 2;\n Y1 += z * (y0 + y) / 2;\n Z1 += z;\n\n z = y0 * x - x0 * y;\n X2 += z * (x0 + x);\n Y2 += z * (y0 + y);\n Z2 += z * 3;\n centroidPoint(x0 = x, y0 = y);\n}\n\nexport default centroidStream;\n","import {tau} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nexport default function PathContext(context) {\n this._context = context;\n}\n\nPathContext.prototype = {\n _radius: 4.5,\n pointRadius: function(_) {\n return this._radius = _, this;\n },\n polygonStart: function() {\n this._line = 0;\n },\n polygonEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line === 0) this._context.closePath();\n this._point = NaN;\n },\n point: function(x, y) {\n switch (this._point) {\n case 0: {\n this._context.moveTo(x, y);\n this._point = 1;\n break;\n }\n case 1: {\n this._context.lineTo(x, y);\n break;\n }\n default: {\n this._context.moveTo(x + this._radius, y);\n this._context.arc(x, y, this._radius, 0, tau);\n break;\n }\n }\n },\n result: noop\n};\n","import {Adder} from \"d3-array\";\nimport {sqrt} from \"../math.js\";\nimport noop from \"../noop.js\";\n\nvar lengthSum = new Adder(),\n lengthRing,\n x00,\n y00,\n x0,\n y0;\n\nvar lengthStream = {\n point: noop,\n lineStart: function() {\n lengthStream.point = lengthPointFirst;\n },\n lineEnd: function() {\n if (lengthRing) lengthPoint(x00, y00);\n lengthStream.point = noop;\n },\n polygonStart: function() {\n lengthRing = true;\n },\n polygonEnd: function() {\n lengthRing = null;\n },\n result: function() {\n var length = +lengthSum;\n lengthSum = new Adder();\n return length;\n }\n};\n\nfunction lengthPointFirst(x, y) {\n lengthStream.point = lengthPoint;\n x00 = x0 = x, y00 = y0 = y;\n}\n\nfunction lengthPoint(x, y) {\n x0 -= x, y0 -= y;\n lengthSum.add(sqrt(x0 * x0 + y0 * y0));\n x0 = x, y0 = y;\n}\n\nexport default lengthStream;\n","// Simple caching for constant-radius points.\nlet cacheDigits, cacheAppend, cacheRadius, cacheCircle;\n\nexport default class PathString {\n constructor(digits) {\n this._append = digits == null ? append : appendRound(digits);\n this._radius = 4.5;\n this._ = \"\";\n }\n pointRadius(_) {\n this._radius = +_;\n return this;\n }\n polygonStart() {\n this._line = 0;\n }\n polygonEnd() {\n this._line = NaN;\n }\n lineStart() {\n this._point = 0;\n }\n lineEnd() {\n if (this._line === 0) this._ += \"Z\";\n this._point = NaN;\n }\n point(x, y) {\n switch (this._point) {\n case 0: {\n this._append`M${x},${y}`;\n this._point = 1;\n break;\n }\n case 1: {\n this._append`L${x},${y}`;\n break;\n }\n default: {\n this._append`M${x},${y}`;\n if (this._radius !== cacheRadius || this._append !== cacheAppend) {\n const r = this._radius;\n const s = this._;\n this._ = \"\"; // stash the old string so we can cache the circle path fragment\n this._append`m0,${r}a${r},${r} 0 1,1 0,${-2 * r}a${r},${r} 0 1,1 0,${2 * r}z`;\n cacheRadius = r;\n cacheAppend = this._append;\n cacheCircle = this._;\n this._ = s;\n }\n this._ += cacheCircle;\n break;\n }\n }\n }\n result() {\n const result = this._;\n this._ = \"\";\n return result.length ? result : null;\n }\n}\n\nfunction append(strings) {\n let i = 1;\n this._ += strings[0];\n for (const j = strings.length; i < j; ++i) {\n this._ += arguments[i] + strings[i];\n }\n}\n\nfunction appendRound(digits) {\n const d = Math.floor(digits);\n if (!(d >= 0)) throw new RangeError(`invalid digits: ${digits}`);\n if (d > 15) return append;\n if (d !== cacheDigits) {\n const k = 10 ** d;\n cacheDigits = d;\n cacheAppend = function append(strings) {\n let i = 1;\n this._ += strings[0];\n for (const j = strings.length; i < j; ++i) {\n this._ += Math.round(arguments[i] * k) / k + strings[i];\n }\n };\n }\n return cacheAppend;\n}\n","import identity from \"../identity.js\";\nimport stream from \"../stream.js\";\nimport pathArea from \"./area.js\";\nimport pathBounds from \"./bounds.js\";\nimport pathCentroid from \"./centroid.js\";\nimport PathContext from \"./context.js\";\nimport pathMeasure from \"./measure.js\";\nimport PathString from \"./string.js\";\n\nexport default function(projection, context) {\n let digits = 3,\n pointRadius = 4.5,\n projectionStream,\n contextStream;\n\n function path(object) {\n if (object) {\n if (typeof pointRadius === \"function\") contextStream.pointRadius(+pointRadius.apply(this, arguments));\n stream(object, projectionStream(contextStream));\n }\n return contextStream.result();\n }\n\n path.area = function(object) {\n stream(object, projectionStream(pathArea));\n return pathArea.result();\n };\n\n path.measure = function(object) {\n stream(object, projectionStream(pathMeasure));\n return pathMeasure.result();\n };\n\n path.bounds = function(object) {\n stream(object, projectionStream(pathBounds));\n return pathBounds.result();\n };\n\n path.centroid = function(object) {\n stream(object, projectionStream(pathCentroid));\n return pathCentroid.result();\n };\n\n path.projection = function(_) {\n if (!arguments.length) return projection;\n projectionStream = _ == null ? (projection = null, identity) : (projection = _).stream;\n return path;\n };\n\n path.context = function(_) {\n if (!arguments.length) return context;\n contextStream = _ == null ? (context = null, new PathString(digits)) : new PathContext(context = _);\n if (typeof pointRadius !== \"function\") contextStream.pointRadius(pointRadius);\n return path;\n };\n\n path.pointRadius = function(_) {\n if (!arguments.length) return pointRadius;\n pointRadius = typeof _ === \"function\" ? _ : (contextStream.pointRadius(+_), +_);\n return path;\n };\n\n path.digits = function(_) {\n if (!arguments.length) return digits;\n if (_ == null) digits = null;\n else {\n const d = Math.floor(_);\n if (!(d >= 0)) throw new RangeError(`invalid digits: ${_}`);\n digits = d;\n }\n if (context === null) contextStream = new PathString(digits);\n return path;\n };\n\n return path.projection(projection).digits(digits).context(context);\n}\n","export default function(methods) {\n return {\n stream: transformer(methods)\n };\n}\n\nexport function transformer(methods) {\n return function(stream) {\n var s = new TransformStream;\n for (var key in methods) s[key] = methods[key];\n s.stream = stream;\n return s;\n };\n}\n\nfunction TransformStream() {}\n\nTransformStream.prototype = {\n constructor: TransformStream,\n point: function(x, y) { this.stream.point(x, y); },\n sphere: function() { this.stream.sphere(); },\n lineStart: function() { this.stream.lineStart(); },\n lineEnd: function() { this.stream.lineEnd(); },\n polygonStart: function() { this.stream.polygonStart(); },\n polygonEnd: function() { this.stream.polygonEnd(); }\n};\n","import {default as geoStream} from \"../stream.js\";\nimport boundsStream from \"../path/bounds.js\";\n\nfunction fit(projection, fitBounds, object) {\n var clip = projection.clipExtent && projection.clipExtent();\n projection.scale(150).translate([0, 0]);\n if (clip != null) projection.clipExtent(null);\n geoStream(object, projection.stream(boundsStream));\n fitBounds(boundsStream.result());\n if (clip != null) projection.clipExtent(clip);\n return projection;\n}\n\nexport function fitExtent(projection, extent, object) {\n return fit(projection, function(b) {\n var w = extent[1][0] - extent[0][0],\n h = extent[1][1] - extent[0][1],\n k = Math.min(w / (b[1][0] - b[0][0]), h / (b[1][1] - b[0][1])),\n x = +extent[0][0] + (w - k * (b[1][0] + b[0][0])) / 2,\n y = +extent[0][1] + (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitSize(projection, size, object) {\n return fitExtent(projection, [[0, 0], size], object);\n}\n\nexport function fitWidth(projection, width, object) {\n return fit(projection, function(b) {\n var w = +width,\n k = w / (b[1][0] - b[0][0]),\n x = (w - k * (b[1][0] + b[0][0])) / 2,\n y = -k * b[0][1];\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n\nexport function fitHeight(projection, height, object) {\n return fit(projection, function(b) {\n var h = +height,\n k = h / (b[1][1] - b[0][1]),\n x = -k * b[0][0],\n y = (h - k * (b[1][1] + b[0][1])) / 2;\n projection.scale(150 * k).translate([x, y]);\n }, object);\n}\n","import {cartesian} from \"../cartesian.js\";\nimport {abs, asin, atan2, cos, epsilon, radians, sqrt} from \"../math.js\";\nimport {transformer} from \"../transform.js\";\n\nvar maxDepth = 16, // maximum depth of subdivision\n cosMinDistance = cos(30 * radians); // cos(minimum angular distance)\n\nexport default function(project, delta2) {\n return +delta2 ? resample(project, delta2) : resampleNone(project);\n}\n\nfunction resampleNone(project) {\n return transformer({\n point: function(x, y) {\n x = project(x, y);\n this.stream.point(x[0], x[1]);\n }\n });\n}\n\nfunction resample(project, delta2) {\n\n function resampleLineTo(x0, y0, lambda0, a0, b0, c0, x1, y1, lambda1, a1, b1, c1, depth, stream) {\n var dx = x1 - x0,\n dy = y1 - y0,\n d2 = dx * dx + dy * dy;\n if (d2 > 4 * delta2 && depth--) {\n var a = a0 + a1,\n b = b0 + b1,\n c = c0 + c1,\n m = sqrt(a * a + b * b + c * c),\n phi2 = asin(c /= m),\n lambda2 = abs(abs(c) - 1) < epsilon || abs(lambda0 - lambda1) < epsilon ? (lambda0 + lambda1) / 2 : atan2(b, a),\n p = project(lambda2, phi2),\n x2 = p[0],\n y2 = p[1],\n dx2 = x2 - x0,\n dy2 = y2 - y0,\n dz = dy * dx2 - dx * dy2;\n if (dz * dz / d2 > delta2 // perpendicular projected distance\n || abs((dx * dx2 + dy * dy2) / d2 - 0.5) > 0.3 // midpoint close to an end\n || a0 * a1 + b0 * b1 + c0 * c1 < cosMinDistance) { // angular distance\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x2, y2, lambda2, a /= m, b /= m, c, depth, stream);\n stream.point(x2, y2);\n resampleLineTo(x2, y2, lambda2, a, b, c, x1, y1, lambda1, a1, b1, c1, depth, stream);\n }\n }\n }\n return function(stream) {\n var lambda00, x00, y00, a00, b00, c00, // first point\n lambda0, x0, y0, a0, b0, c0; // previous point\n\n var resampleStream = {\n point: point,\n lineStart: lineStart,\n lineEnd: lineEnd,\n polygonStart: function() { stream.polygonStart(); resampleStream.lineStart = ringStart; },\n polygonEnd: function() { stream.polygonEnd(); resampleStream.lineStart = lineStart; }\n };\n\n function point(x, y) {\n x = project(x, y);\n stream.point(x[0], x[1]);\n }\n\n function lineStart() {\n x0 = NaN;\n resampleStream.point = linePoint;\n stream.lineStart();\n }\n\n function linePoint(lambda, phi) {\n var c = cartesian([lambda, phi]), p = project(lambda, phi);\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x0 = p[0], y0 = p[1], lambda0 = lambda, a0 = c[0], b0 = c[1], c0 = c[2], maxDepth, stream);\n stream.point(x0, y0);\n }\n\n function lineEnd() {\n resampleStream.point = point;\n stream.lineEnd();\n }\n\n function ringStart() {\n lineStart();\n resampleStream.point = ringPoint;\n resampleStream.lineEnd = ringEnd;\n }\n\n function ringPoint(lambda, phi) {\n linePoint(lambda00 = lambda, phi), x00 = x0, y00 = y0, a00 = a0, b00 = b0, c00 = c0;\n resampleStream.point = linePoint;\n }\n\n function ringEnd() {\n resampleLineTo(x0, y0, lambda0, a0, b0, c0, x00, y00, lambda00, a00, b00, c00, maxDepth, stream);\n resampleStream.lineEnd = lineEnd;\n lineEnd();\n }\n\n return resampleStream;\n };\n}\n","import clipAntimeridian from \"../clip/antimeridian.js\";\nimport clipCircle from \"../clip/circle.js\";\nimport clipRectangle from \"../clip/rectangle.js\";\nimport compose from \"../compose.js\";\nimport identity from \"../identity.js\";\nimport {cos, degrees, radians, sin, sqrt} from \"../math.js\";\nimport {rotateRadians} from \"../rotation.js\";\nimport {transformer} from \"../transform.js\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit.js\";\nimport resample from \"./resample.js\";\n\nvar transformRadians = transformer({\n point: function(x, y) {\n this.stream.point(x * radians, y * radians);\n }\n});\n\nfunction transformRotate(rotate) {\n return transformer({\n point: function(x, y) {\n var r = rotate(x, y);\n return this.stream.point(r[0], r[1]);\n }\n });\n}\n\nfunction scaleTranslate(k, dx, dy, sx, sy) {\n function transform(x, y) {\n x *= sx; y *= sy;\n return [dx + k * x, dy - k * y];\n }\n transform.invert = function(x, y) {\n return [(x - dx) / k * sx, (dy - y) / k * sy];\n };\n return transform;\n}\n\nfunction scaleTranslateRotate(k, dx, dy, sx, sy, alpha) {\n if (!alpha) return scaleTranslate(k, dx, dy, sx, sy);\n var cosAlpha = cos(alpha),\n sinAlpha = sin(alpha),\n a = cosAlpha * k,\n b = sinAlpha * k,\n ai = cosAlpha / k,\n bi = sinAlpha / k,\n ci = (sinAlpha * dy - cosAlpha * dx) / k,\n fi = (sinAlpha * dx + cosAlpha * dy) / k;\n function transform(x, y) {\n x *= sx; y *= sy;\n return [a * x - b * y + dx, dy - b * x - a * y];\n }\n transform.invert = function(x, y) {\n return [sx * (ai * x - bi * y + ci), sy * (fi - bi * x - ai * y)];\n };\n return transform;\n}\n\nexport default function projection(project) {\n return projectionMutator(function() { return project; })();\n}\n\nexport function projectionMutator(projectAt) {\n var project,\n k = 150, // scale\n x = 480, y = 250, // translate\n lambda = 0, phi = 0, // center\n deltaLambda = 0, deltaPhi = 0, deltaGamma = 0, rotate, // pre-rotate\n alpha = 0, // post-rotate angle\n sx = 1, // reflectX\n sy = 1, // reflectX\n theta = null, preclip = clipAntimeridian, // pre-clip angle\n x0 = null, y0, x1, y1, postclip = identity, // post-clip extent\n delta2 = 0.5, // precision\n projectResample,\n projectTransform,\n projectRotateTransform,\n cache,\n cacheStream;\n\n function projection(point) {\n return projectRotateTransform(point[0] * radians, point[1] * radians);\n }\n\n function invert(point) {\n point = projectRotateTransform.invert(point[0], point[1]);\n return point && [point[0] * degrees, point[1] * degrees];\n }\n\n projection.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = transformRadians(transformRotate(rotate)(preclip(projectResample(postclip(cacheStream = stream)))));\n };\n\n projection.preclip = function(_) {\n return arguments.length ? (preclip = _, theta = undefined, reset()) : preclip;\n };\n\n projection.postclip = function(_) {\n return arguments.length ? (postclip = _, x0 = y0 = x1 = y1 = null, reset()) : postclip;\n };\n\n projection.clipAngle = function(_) {\n return arguments.length ? (preclip = +_ ? clipCircle(theta = _ * radians) : (theta = null, clipAntimeridian), reset()) : theta * degrees;\n };\n\n projection.clipExtent = function(_) {\n return arguments.length ? (postclip = _ == null ? (x0 = y0 = x1 = y1 = null, identity) : clipRectangle(x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1]), reset()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n projection.scale = function(_) {\n return arguments.length ? (k = +_, recenter()) : k;\n };\n\n projection.translate = function(_) {\n return arguments.length ? (x = +_[0], y = +_[1], recenter()) : [x, y];\n };\n\n projection.center = function(_) {\n return arguments.length ? (lambda = _[0] % 360 * radians, phi = _[1] % 360 * radians, recenter()) : [lambda * degrees, phi * degrees];\n };\n\n projection.rotate = function(_) {\n return arguments.length ? (deltaLambda = _[0] % 360 * radians, deltaPhi = _[1] % 360 * radians, deltaGamma = _.length > 2 ? _[2] % 360 * radians : 0, recenter()) : [deltaLambda * degrees, deltaPhi * degrees, deltaGamma * degrees];\n };\n\n projection.angle = function(_) {\n return arguments.length ? (alpha = _ % 360 * radians, recenter()) : alpha * degrees;\n };\n\n projection.reflectX = function(_) {\n return arguments.length ? (sx = _ ? -1 : 1, recenter()) : sx < 0;\n };\n\n projection.reflectY = function(_) {\n return arguments.length ? (sy = _ ? -1 : 1, recenter()) : sy < 0;\n };\n\n projection.precision = function(_) {\n return arguments.length ? (projectResample = resample(projectTransform, delta2 = _ * _), reset()) : sqrt(delta2);\n };\n\n projection.fitExtent = function(extent, object) {\n return fitExtent(projection, extent, object);\n };\n\n projection.fitSize = function(size, object) {\n return fitSize(projection, size, object);\n };\n\n projection.fitWidth = function(width, object) {\n return fitWidth(projection, width, object);\n };\n\n projection.fitHeight = function(height, object) {\n return fitHeight(projection, height, object);\n };\n\n function recenter() {\n var center = scaleTranslateRotate(k, 0, 0, sx, sy, alpha).apply(null, project(lambda, phi)),\n transform = scaleTranslateRotate(k, x - center[0], y - center[1], sx, sy, alpha);\n rotate = rotateRadians(deltaLambda, deltaPhi, deltaGamma);\n projectTransform = compose(project, transform);\n projectRotateTransform = compose(rotate, projectTransform);\n projectResample = resample(projectTransform, delta2);\n return reset();\n }\n\n function reset() {\n cache = cacheStream = null;\n return projection;\n }\n\n return function() {\n project = projectAt.apply(this, arguments);\n projection.invert = project.invert && invert;\n return recenter();\n };\n}\n","import {degrees, pi, radians} from \"../math.js\";\nimport {projectionMutator} from \"./index.js\";\n\nexport function conicProjection(projectAt) {\n var phi0 = 0,\n phi1 = pi / 3,\n m = projectionMutator(projectAt),\n p = m(phi0, phi1);\n\n p.parallels = function(_) {\n return arguments.length ? m(phi0 = _[0] * radians, phi1 = _[1] * radians) : [phi0 * degrees, phi1 * degrees];\n };\n\n return p;\n}\n","import {abs, asin, atan2, cos, epsilon, pi, sign, sin, sqrt} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {cylindricalEqualAreaRaw} from \"./cylindricalEqualArea.js\";\n\nexport function conicEqualAreaRaw(y0, y1) {\n var sy0 = sin(y0), n = (sy0 + sin(y1)) / 2;\n\n // Are the parallels symmetrical around the Equator?\n if (abs(n) < epsilon) return cylindricalEqualAreaRaw(y0);\n\n var c = 1 + sy0 * (2 * n - sy0), r0 = sqrt(c) / n;\n\n function project(x, y) {\n var r = sqrt(c - 2 * n * sin(y)) / n;\n return [r * sin(x *= n), r0 - r * cos(x)];\n }\n\n project.invert = function(x, y) {\n var r0y = r0 - y,\n l = atan2(x, abs(r0y)) * sign(r0y);\n if (r0y * n < 0)\n l -= pi * sign(x) * sign(r0y);\n return [l / n, asin((c - (x * x + r0y * r0y) * n * n) / (2 * n))];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEqualAreaRaw)\n .scale(155.424)\n .center([0, 33.6442]);\n}\n","import {asin, cos, sin} from \"../math.js\";\n\nexport function cylindricalEqualAreaRaw(phi0) {\n var cosPhi0 = cos(phi0);\n\n function forward(lambda, phi) {\n return [lambda * cosPhi0, sin(phi) / cosPhi0];\n }\n\n forward.invert = function(x, y) {\n return [x / cosPhi0, asin(y * cosPhi0)];\n };\n\n return forward;\n}\n","import conicEqualArea from \"./conicEqualArea.js\";\n\nexport default function() {\n return conicEqualArea()\n .parallels([29.5, 45.5])\n .scale(1070)\n .translate([480, 250])\n .rotate([96, 0])\n .center([-0.6, 38.7]);\n}\n","import {epsilon} from \"../math.js\";\nimport albers from \"./albers.js\";\nimport conicEqualArea from \"./conicEqualArea.js\";\nimport {fitExtent, fitSize, fitWidth, fitHeight} from \"./fit.js\";\n\n// The projections must have mutually exclusive clip regions on the sphere,\n// as this will avoid emitting interleaving lines and polygons.\nfunction multiplex(streams) {\n var n = streams.length;\n return {\n point: function(x, y) { var i = -1; while (++i < n) streams[i].point(x, y); },\n sphere: function() { var i = -1; while (++i < n) streams[i].sphere(); },\n lineStart: function() { var i = -1; while (++i < n) streams[i].lineStart(); },\n lineEnd: function() { var i = -1; while (++i < n) streams[i].lineEnd(); },\n polygonStart: function() { var i = -1; while (++i < n) streams[i].polygonStart(); },\n polygonEnd: function() { var i = -1; while (++i < n) streams[i].polygonEnd(); }\n };\n}\n\n// A composite projection for the United States, configured by default for\n// 960×500. The projection also works quite well at 960×600 if you change the\n// scale to 1285 and adjust the translate accordingly. The set of standard\n// parallels for each region comes from USGS, which is published here:\n// http://egsc.usgs.gov/isb/pubs/MapProjections/projections.html#albers\nexport default function() {\n var cache,\n cacheStream,\n lower48 = albers(), lower48Point,\n alaska = conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]), alaskaPoint, // EPSG:3338\n hawaii = conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]), hawaiiPoint, // ESRI:102007\n point, pointStream = {point: function(x, y) { point = [x, y]; }};\n\n function albersUsa(coordinates) {\n var x = coordinates[0], y = coordinates[1];\n return point = null,\n (lower48Point.point(x, y), point)\n || (alaskaPoint.point(x, y), point)\n || (hawaiiPoint.point(x, y), point);\n }\n\n albersUsa.invert = function(coordinates) {\n var k = lower48.scale(),\n t = lower48.translate(),\n x = (coordinates[0] - t[0]) / k,\n y = (coordinates[1] - t[1]) / k;\n return (y >= 0.120 && y < 0.234 && x >= -0.425 && x < -0.214 ? alaska\n : y >= 0.166 && y < 0.234 && x >= -0.214 && x < -0.115 ? hawaii\n : lower48).invert(coordinates);\n };\n\n albersUsa.stream = function(stream) {\n return cache && cacheStream === stream ? cache : cache = multiplex([lower48.stream(cacheStream = stream), alaska.stream(stream), hawaii.stream(stream)]);\n };\n\n albersUsa.precision = function(_) {\n if (!arguments.length) return lower48.precision();\n lower48.precision(_), alaska.precision(_), hawaii.precision(_);\n return reset();\n };\n\n albersUsa.scale = function(_) {\n if (!arguments.length) return lower48.scale();\n lower48.scale(_), alaska.scale(_ * 0.35), hawaii.scale(_);\n return albersUsa.translate(lower48.translate());\n };\n\n albersUsa.translate = function(_) {\n if (!arguments.length) return lower48.translate();\n var k = lower48.scale(), x = +_[0], y = +_[1];\n\n lower48Point = lower48\n .translate(_)\n .clipExtent([[x - 0.455 * k, y - 0.238 * k], [x + 0.455 * k, y + 0.238 * k]])\n .stream(pointStream);\n\n alaskaPoint = alaska\n .translate([x - 0.307 * k, y + 0.201 * k])\n .clipExtent([[x - 0.425 * k + epsilon, y + 0.120 * k + epsilon], [x - 0.214 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n hawaiiPoint = hawaii\n .translate([x - 0.205 * k, y + 0.212 * k])\n .clipExtent([[x - 0.214 * k + epsilon, y + 0.166 * k + epsilon], [x - 0.115 * k - epsilon, y + 0.234 * k - epsilon]])\n .stream(pointStream);\n\n return reset();\n };\n\n albersUsa.fitExtent = function(extent, object) {\n return fitExtent(albersUsa, extent, object);\n };\n\n albersUsa.fitSize = function(size, object) {\n return fitSize(albersUsa, size, object);\n };\n\n albersUsa.fitWidth = function(width, object) {\n return fitWidth(albersUsa, width, object);\n };\n\n albersUsa.fitHeight = function(height, object) {\n return fitHeight(albersUsa, height, object);\n };\n\n function reset() {\n cache = cacheStream = null;\n return albersUsa;\n }\n\n return albersUsa.scale(1070);\n}\n","import {asin, atan2, cos, sin, sqrt} from \"../math.js\";\n\nexport function azimuthalRaw(scale) {\n return function(x, y) {\n var cx = cos(x),\n cy = cos(y),\n k = scale(cx * cy);\n if (k === Infinity) return [2, 0];\n return [\n k * cy * sin(x),\n k * sin(y)\n ];\n }\n}\n\nexport function azimuthalInvert(angle) {\n return function(x, y) {\n var z = sqrt(x * x + y * y),\n c = angle(z),\n sc = sin(c),\n cc = cos(c);\n return [\n atan2(x * sc, z * cc),\n asin(z && y * sc / z)\n ];\n }\n}\n","import {asin, sqrt} from \"../math.js\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport var azimuthalEqualAreaRaw = azimuthalRaw(function(cxcy) {\n return sqrt(2 / (1 + cxcy));\n});\n\nazimuthalEqualAreaRaw.invert = azimuthalInvert(function(z) {\n return 2 * asin(z / 2);\n});\n\nexport default function() {\n return projection(azimuthalEqualAreaRaw)\n .scale(124.75)\n .clipAngle(180 - 1e-3);\n}\n","import {acos, sin} from \"../math.js\";\nimport {azimuthalRaw, azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport var azimuthalEquidistantRaw = azimuthalRaw(function(c) {\n return (c = acos(c)) && c / sin(c);\n});\n\nazimuthalEquidistantRaw.invert = azimuthalInvert(function(z) {\n return z;\n});\n\nexport default function() {\n return projection(azimuthalEquidistantRaw)\n .scale(79.4188)\n .clipAngle(180 - 1e-3);\n}\n","import {atan, exp, halfPi, log, pi, tan, tau} from \"../math.js\";\nimport rotation from \"../rotation.js\";\nimport projection from \"./index.js\";\n\nexport function mercatorRaw(lambda, phi) {\n return [lambda, log(tan((halfPi + phi) / 2))];\n}\n\nmercatorRaw.invert = function(x, y) {\n return [x, 2 * atan(exp(y)) - halfPi];\n};\n\nexport default function() {\n return mercatorProjection(mercatorRaw)\n .scale(961 / tau);\n}\n\nexport function mercatorProjection(project) {\n var m = projection(project),\n center = m.center,\n scale = m.scale,\n translate = m.translate,\n clipExtent = m.clipExtent,\n x0 = null, y0, x1, y1; // clip extent\n\n m.scale = function(_) {\n return arguments.length ? (scale(_), reclip()) : scale();\n };\n\n m.translate = function(_) {\n return arguments.length ? (translate(_), reclip()) : translate();\n };\n\n m.center = function(_) {\n return arguments.length ? (center(_), reclip()) : center();\n };\n\n m.clipExtent = function(_) {\n return arguments.length ? ((_ == null ? x0 = y0 = x1 = y1 = null : (x0 = +_[0][0], y0 = +_[0][1], x1 = +_[1][0], y1 = +_[1][1])), reclip()) : x0 == null ? null : [[x0, y0], [x1, y1]];\n };\n\n function reclip() {\n var k = pi * scale(),\n t = m(rotation(m.rotate()).invert([0, 0]));\n return clipExtent(x0 == null\n ? [[t[0] - k, t[1] - k], [t[0] + k, t[1] + k]] : project === mercatorRaw\n ? [[Math.max(t[0] - k, x0), y0], [Math.min(t[0] + k, x1), y1]]\n : [[x0, Math.max(t[1] - k, y0)], [x1, Math.min(t[1] + k, y1)]]);\n }\n\n return reclip();\n}\n","import {abs, atan, atan2, cos, epsilon, halfPi, log, pi, pow, sign, sin, sqrt, tan} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {mercatorRaw} from \"./mercator.js\";\n\nfunction tany(y) {\n return tan((halfPi + y) / 2);\n}\n\nexport function conicConformalRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : log(cy0 / cos(y1)) / log(tany(y1) / tany(y0)),\n f = cy0 * pow(tany(y0), n) / n;\n\n if (!n) return mercatorRaw;\n\n function project(x, y) {\n if (f > 0) { if (y < -halfPi + epsilon) y = -halfPi + epsilon; }\n else { if (y > halfPi - epsilon) y = halfPi - epsilon; }\n var r = f / pow(tany(y), n);\n return [r * sin(n * x), f - r * cos(n * x)];\n }\n\n project.invert = function(x, y) {\n var fy = f - y, r = sign(n) * sqrt(x * x + fy * fy),\n l = atan2(x, abs(fy)) * sign(fy);\n if (fy * n < 0)\n l -= pi * sign(x) * sign(fy);\n return [l / n, 2 * atan(pow(f / r, 1 / n)) - halfPi];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicConformalRaw)\n .scale(109.5)\n .parallels([30, 30]);\n}\n","import projection from \"./index.js\";\n\nexport function equirectangularRaw(lambda, phi) {\n return [lambda, phi];\n}\n\nequirectangularRaw.invert = equirectangularRaw;\n\nexport default function() {\n return projection(equirectangularRaw)\n .scale(152.63);\n}\n","import {abs, atan2, cos, epsilon, pi, sign, sin, sqrt} from \"../math.js\";\nimport {conicProjection} from \"./conic.js\";\nimport {equirectangularRaw} from \"./equirectangular.js\";\n\nexport function conicEquidistantRaw(y0, y1) {\n var cy0 = cos(y0),\n n = y0 === y1 ? sin(y0) : (cy0 - cos(y1)) / (y1 - y0),\n g = cy0 / n + y0;\n\n if (abs(n) < epsilon) return equirectangularRaw;\n\n function project(x, y) {\n var gy = g - y, nx = n * x;\n return [gy * sin(nx), g - gy * cos(nx)];\n }\n\n project.invert = function(x, y) {\n var gy = g - y,\n l = atan2(x, abs(gy)) * sign(gy);\n if (gy * n < 0)\n l -= pi * sign(x) * sign(gy);\n return [l / n, g - sign(n) * sqrt(x * x + gy * gy)];\n };\n\n return project;\n}\n\nexport default function() {\n return conicProjection(conicEquidistantRaw)\n .scale(131.154)\n .center([0, 13.9389]);\n}\n","import projection from \"./index.js\";\nimport {abs, asin, cos, epsilon2, sin, sqrt} from \"../math.js\";\n\nvar A1 = 1.340264,\n A2 = -0.081106,\n A3 = 0.000893,\n A4 = 0.003796,\n M = sqrt(3) / 2,\n iterations = 12;\n\nexport function equalEarthRaw(lambda, phi) {\n var l = asin(M * sin(phi)), l2 = l * l, l6 = l2 * l2 * l2;\n return [\n lambda * cos(l) / (M * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2))),\n l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2))\n ];\n}\n\nequalEarthRaw.invert = function(x, y) {\n var l = y, l2 = l * l, l6 = l2 * l2 * l2;\n for (var i = 0, delta, fy, fpy; i < iterations; ++i) {\n fy = l * (A1 + A2 * l2 + l6 * (A3 + A4 * l2)) - y;\n fpy = A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2);\n l -= delta = fy / fpy, l2 = l * l, l6 = l2 * l2 * l2;\n if (abs(delta) < epsilon2) break;\n }\n return [\n M * x * (A1 + 3 * A2 * l2 + l6 * (7 * A3 + 9 * A4 * l2)) / cos(l),\n asin(sin(l) / M)\n ];\n};\n\nexport default function() {\n return projection(equalEarthRaw)\n .scale(177.158);\n}\n","import {atan, cos, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function gnomonicRaw(x, y) {\n var cy = cos(y), k = cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\ngnomonicRaw.invert = azimuthalInvert(atan);\n\nexport default function() {\n return projection(gnomonicRaw)\n .scale(144.049)\n .clipAngle(60);\n}\n","import {asin, cos, epsilon, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function orthographicRaw(x, y) {\n return [cos(y) * sin(x), sin(y)];\n}\n\northographicRaw.invert = azimuthalInvert(asin);\n\nexport default function() {\n return projection(orthographicRaw)\n .scale(249.5)\n .clipAngle(90 + epsilon);\n}\n","import {atan, cos, sin} from \"../math.js\";\nimport {azimuthalInvert} from \"./azimuthal.js\";\nimport projection from \"./index.js\";\n\nexport function stereographicRaw(x, y) {\n var cy = cos(y), k = 1 + cos(x) * cy;\n return [cy * sin(x) / k, sin(y) / k];\n}\n\nstereographicRaw.invert = azimuthalInvert(function(z) {\n return 2 * atan(z);\n});\n\nexport default function() {\n return projection(stereographicRaw)\n .scale(250)\n .clipAngle(142);\n}\n","import {atan, exp, halfPi, log, tan} from \"../math.js\";\nimport {mercatorProjection} from \"./mercator.js\";\n\nexport function transverseMercatorRaw(lambda, phi) {\n return [log(tan((halfPi + phi) / 2)), -lambda];\n}\n\ntransverseMercatorRaw.invert = function(x, y) {\n return [-y, 2 * atan(exp(x)) - halfPi];\n};\n\nexport default function() {\n var m = mercatorProjection(transverseMercatorRaw),\n center = m.center,\n rotate = m.rotate;\n\n m.center = function(_) {\n return arguments.length ? center([-_[1], _[0]]) : (_ = center(), [_[1], -_[0]]);\n };\n\n m.rotate = function(_) {\n return arguments.length ? rotate([_[0], _[1], _.length > 2 ? _[2] + 90 : 90]) : (_ = rotate(), [_[0], _[1], _[2] - 90]);\n };\n\n return rotate([0, 0, 90])\n .scale(159.155);\n}\n","export function initRange(domain, range) {\n switch (arguments.length) {\n case 0: break;\n case 1: this.range(domain); break;\n default: this.range(range).domain(domain); break;\n }\n return this;\n}\n\nexport function initInterpolator(domain, interpolator) {\n switch (arguments.length) {\n case 0: break;\n case 1: {\n if (typeof domain === \"function\") this.interpolator(domain);\n else this.range(domain);\n break;\n }\n default: {\n this.domain(domain);\n if (typeof interpolator === \"function\") this.interpolator(interpolator);\n else this.range(interpolator);\n break;\n }\n }\n return this;\n}\n","import {InternMap} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport const implicit = Symbol(\"implicit\");\n\nexport default function ordinal() {\n var index = new InternMap(),\n domain = [],\n range = [],\n unknown = implicit;\n\n function scale(d) {\n let i = index.get(d);\n if (i === undefined) {\n if (unknown !== implicit) return unknown;\n index.set(d, i = domain.push(d) - 1);\n }\n return range[i % range.length];\n }\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [], index = new InternMap();\n for (const value of _) {\n if (index.has(value)) continue;\n index.set(value, domain.push(value) - 1);\n }\n return scale;\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), scale) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return ordinal(domain, range).unknown(unknown);\n };\n\n initRange.apply(scale, arguments);\n\n return scale;\n}\n","import {range as sequence} from \"d3-array\";\nimport {initRange} from \"./init.js\";\nimport ordinal from \"./ordinal.js\";\n\nexport default function band() {\n var scale = ordinal().unknown(undefined),\n domain = scale.domain,\n ordinalRange = scale.range,\n r0 = 0,\n r1 = 1,\n step,\n bandwidth,\n round = false,\n paddingInner = 0,\n paddingOuter = 0,\n align = 0.5;\n\n delete scale.unknown;\n\n function rescale() {\n var n = domain().length,\n reverse = r1 < r0,\n start = reverse ? r1 : r0,\n stop = reverse ? r0 : r1;\n step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);\n if (round) step = Math.floor(step);\n start += (stop - start - step * (n - paddingInner)) * align;\n bandwidth = step * (1 - paddingInner);\n if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);\n var values = sequence(n).map(function(i) { return start + step * i; });\n return ordinalRange(reverse ? values.reverse() : values);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.range = function(_) {\n return arguments.length ? ([r0, r1] = _, r0 = +r0, r1 = +r1, rescale()) : [r0, r1];\n };\n\n scale.rangeRound = function(_) {\n return [r0, r1] = _, r0 = +r0, r1 = +r1, round = true, rescale();\n };\n\n scale.bandwidth = function() {\n return bandwidth;\n };\n\n scale.step = function() {\n return step;\n };\n\n scale.round = function(_) {\n return arguments.length ? (round = !!_, rescale()) : round;\n };\n\n scale.padding = function(_) {\n return arguments.length ? (paddingInner = Math.min(1, paddingOuter = +_), rescale()) : paddingInner;\n };\n\n scale.paddingInner = function(_) {\n return arguments.length ? (paddingInner = Math.min(1, _), rescale()) : paddingInner;\n };\n\n scale.paddingOuter = function(_) {\n return arguments.length ? (paddingOuter = +_, rescale()) : paddingOuter;\n };\n\n scale.align = function(_) {\n return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;\n };\n\n scale.copy = function() {\n return band(domain(), [r0, r1])\n .round(round)\n .paddingInner(paddingInner)\n .paddingOuter(paddingOuter)\n .align(align);\n };\n\n return initRange.apply(rescale(), arguments);\n}\n\nfunction pointish(scale) {\n var copy = scale.copy;\n\n scale.padding = scale.paddingOuter;\n delete scale.paddingInner;\n delete scale.paddingOuter;\n\n scale.copy = function() {\n return pointish(copy());\n };\n\n return scale;\n}\n\nexport function point() {\n return pointish(band.apply(null, arguments).paddingInner(1));\n}\n","export default function number(x) {\n return +x;\n}\n","import {bisect} from \"d3-array\";\nimport {interpolate as interpolateValue, interpolateNumber, interpolateRound} from \"d3-interpolate\";\nimport constant from \"./constant.js\";\nimport number from \"./number.js\";\n\nvar unit = [0, 1];\n\nexport function identity(x) {\n return x;\n}\n\nfunction normalize(a, b) {\n return (b -= (a = +a))\n ? function(x) { return (x - a) / b; }\n : constant(isNaN(b) ? NaN : 0.5);\n}\n\nfunction clamper(a, b) {\n var t;\n if (a > b) t = a, a = b, b = t;\n return function(x) { return Math.max(a, Math.min(b, x)); };\n}\n\n// normalize(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].\n// interpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding range value x in [a,b].\nfunction bimap(domain, range, interpolate) {\n var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];\n if (d1 < d0) d0 = normalize(d1, d0), r0 = interpolate(r1, r0);\n else d0 = normalize(d0, d1), r0 = interpolate(r0, r1);\n return function(x) { return r0(d0(x)); };\n}\n\nfunction polymap(domain, range, interpolate) {\n var j = Math.min(domain.length, range.length) - 1,\n d = new Array(j),\n r = new Array(j),\n i = -1;\n\n // Reverse descending domains.\n if (domain[j] < domain[0]) {\n domain = domain.slice().reverse();\n range = range.slice().reverse();\n }\n\n while (++i < j) {\n d[i] = normalize(domain[i], domain[i + 1]);\n r[i] = interpolate(range[i], range[i + 1]);\n }\n\n return function(x) {\n var i = bisect(domain, x, 1, j) - 1;\n return r[i](d[i](x));\n };\n}\n\nexport function copy(source, target) {\n return target\n .domain(source.domain())\n .range(source.range())\n .interpolate(source.interpolate())\n .clamp(source.clamp())\n .unknown(source.unknown());\n}\n\nexport function transformer() {\n var domain = unit,\n range = unit,\n interpolate = interpolateValue,\n transform,\n untransform,\n unknown,\n clamp = identity,\n piecewise,\n output,\n input;\n\n function rescale() {\n var n = Math.min(domain.length, range.length);\n if (clamp !== identity) clamp = clamper(domain[0], domain[n - 1]);\n piecewise = n > 2 ? polymap : bimap;\n output = input = null;\n return scale;\n }\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : (output || (output = piecewise(domain.map(transform), range, interpolate)))(transform(clamp(x)));\n }\n\n scale.invert = function(y) {\n return clamp(untransform((input || (input = piecewise(range, domain.map(transform), interpolateNumber)))(y)));\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain = Array.from(_, number), rescale()) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), rescale()) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return range = Array.from(_), interpolate = interpolateRound, rescale();\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = _ ? true : identity, rescale()) : clamp !== identity;\n };\n\n scale.interpolate = function(_) {\n return arguments.length ? (interpolate = _, rescale()) : interpolate;\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t, u) {\n transform = t, untransform = u;\n return rescale();\n };\n}\n\nexport default function continuous() {\n return transformer()(identity, identity);\n}\n","export default function constants(x) {\n return function() {\n return x;\n };\n}\n","import {tickStep} from \"d3-array\";\nimport {format, formatPrefix, formatSpecifier, precisionFixed, precisionPrefix, precisionRound} from \"d3-format\";\n\nexport default function tickFormat(start, stop, count, specifier) {\n var step = tickStep(start, stop, count),\n precision;\n specifier = formatSpecifier(specifier == null ? \",f\" : specifier);\n switch (specifier.type) {\n case \"s\": {\n var value = Math.max(Math.abs(start), Math.abs(stop));\n if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;\n return formatPrefix(specifier, value);\n }\n case \"\":\n case \"e\":\n case \"g\":\n case \"p\":\n case \"r\": {\n if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === \"e\");\n break;\n }\n case \"f\":\n case \"%\": {\n if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === \"%\") * 2;\n break;\n }\n }\n return format(specifier);\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step, value) {\n return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent(value) / 3))) * 3 - exponent(Math.abs(step)));\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step, max) {\n step = Math.abs(step), max = Math.abs(max) - step;\n return Math.max(0, exponent(max) - exponent(step)) + 1;\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step) {\n return Math.max(0, -exponent(Math.abs(step)));\n}\n","import {ticks, tickIncrement} from \"d3-array\";\nimport continuous, {copy} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\nimport tickFormat from \"./tickFormat.js\";\n\nexport function linearish(scale) {\n var domain = scale.domain;\n\n scale.ticks = function(count) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], count == null ? 10 : count);\n };\n\n scale.tickFormat = function(count, specifier) {\n var d = domain();\n return tickFormat(d[0], d[d.length - 1], count == null ? 10 : count, specifier);\n };\n\n scale.nice = function(count) {\n if (count == null) count = 10;\n\n var d = domain();\n var i0 = 0;\n var i1 = d.length - 1;\n var start = d[i0];\n var stop = d[i1];\n var prestep;\n var step;\n var maxIter = 10;\n\n if (stop < start) {\n step = start, start = stop, stop = step;\n step = i0, i0 = i1, i1 = step;\n }\n \n while (maxIter-- > 0) {\n step = tickIncrement(start, stop, count);\n if (step === prestep) {\n d[i0] = start\n d[i1] = stop\n return domain(d);\n } else if (step > 0) {\n start = Math.floor(start / step) * step;\n stop = Math.ceil(stop / step) * step;\n } else if (step < 0) {\n start = Math.ceil(start * step) / step;\n stop = Math.floor(stop * step) / step;\n } else {\n break;\n }\n prestep = step;\n }\n\n return scale;\n };\n\n return scale;\n}\n\nexport default function linear() {\n var scale = continuous();\n\n scale.copy = function() {\n return copy(scale, linear());\n };\n\n initRange.apply(scale, arguments);\n\n return linearish(scale);\n}\n","import {linearish} from \"./linear.js\";\nimport number from \"./number.js\";\n\nexport default function identity(domain) {\n var unknown;\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : x;\n }\n\n scale.invert = scale;\n\n scale.domain = scale.range = function(_) {\n return arguments.length ? (domain = Array.from(_, number), scale) : domain.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return identity(domain).unknown(unknown);\n };\n\n domain = arguments.length ? Array.from(domain, number) : [0, 1];\n\n return linearish(scale);\n}\n","export default function nice(domain, interval) {\n domain = domain.slice();\n\n var i0 = 0,\n i1 = domain.length - 1,\n x0 = domain[i0],\n x1 = domain[i1],\n t;\n\n if (x1 < x0) {\n t = i0, i0 = i1, i1 = t;\n t = x0, x0 = x1, x1 = t;\n }\n\n domain[i0] = interval.floor(x0);\n domain[i1] = interval.ceil(x1);\n return domain;\n}\n","import {ticks} from \"d3-array\";\nimport {format, formatSpecifier} from \"d3-format\";\nimport nice from \"./nice.js\";\nimport {copy, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformLog(x) {\n return Math.log(x);\n}\n\nfunction transformExp(x) {\n return Math.exp(x);\n}\n\nfunction transformLogn(x) {\n return -Math.log(-x);\n}\n\nfunction transformExpn(x) {\n return -Math.exp(-x);\n}\n\nfunction pow10(x) {\n return isFinite(x) ? +(\"1e\" + x) : x < 0 ? 0 : x;\n}\n\nfunction powp(base) {\n return base === 10 ? pow10\n : base === Math.E ? Math.exp\n : x => Math.pow(base, x);\n}\n\nfunction logp(base) {\n return base === Math.E ? Math.log\n : base === 10 && Math.log10\n || base === 2 && Math.log2\n || (base = Math.log(base), x => Math.log(x) / base);\n}\n\nfunction reflect(f) {\n return (x, k) => -f(-x, k);\n}\n\nexport function loggish(transform) {\n const scale = transform(transformLog, transformExp);\n const domain = scale.domain;\n let base = 10;\n let logs;\n let pows;\n\n function rescale() {\n logs = logp(base), pows = powp(base);\n if (domain()[0] < 0) {\n logs = reflect(logs), pows = reflect(pows);\n transform(transformLogn, transformExpn);\n } else {\n transform(transformLog, transformExp);\n }\n return scale;\n }\n\n scale.base = function(_) {\n return arguments.length ? (base = +_, rescale()) : base;\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.ticks = count => {\n const d = domain();\n let u = d[0];\n let v = d[d.length - 1];\n const r = v < u;\n\n if (r) ([u, v] = [v, u]);\n\n let i = logs(u);\n let j = logs(v);\n let k;\n let t;\n const n = count == null ? 10 : +count;\n let z = [];\n\n if (!(base % 1) && j - i < n) {\n i = Math.floor(i), j = Math.ceil(j);\n if (u > 0) for (; i <= j; ++i) {\n for (k = 1; k < base; ++k) {\n t = i < 0 ? k / pows(-i) : k * pows(i);\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n } else for (; i <= j; ++i) {\n for (k = base - 1; k >= 1; --k) {\n t = i > 0 ? k / pows(-i) : k * pows(i);\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n }\n if (z.length * 2 < n) z = ticks(u, v, n);\n } else {\n z = ticks(i, j, Math.min(j - i, n)).map(pows);\n }\n return r ? z.reverse() : z;\n };\n\n scale.tickFormat = (count, specifier) => {\n if (count == null) count = 10;\n if (specifier == null) specifier = base === 10 ? \"s\" : \",\";\n if (typeof specifier !== \"function\") {\n if (!(base % 1) && (specifier = formatSpecifier(specifier)).precision == null) specifier.trim = true;\n specifier = format(specifier);\n }\n if (count === Infinity) return specifier;\n const k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?\n return d => {\n let i = d / pows(Math.round(logs(d)));\n if (i * base < base - 0.5) i *= base;\n return i <= k ? specifier(d) : \"\";\n };\n };\n\n scale.nice = () => {\n return domain(nice(domain(), {\n floor: x => pows(Math.floor(logs(x))),\n ceil: x => pows(Math.ceil(logs(x)))\n }));\n };\n\n return scale;\n}\n\nexport default function log() {\n const scale = loggish(transformer()).domain([1, 10]);\n scale.copy = () => copy(scale, log()).base(scale.base());\n initRange.apply(scale, arguments);\n return scale;\n}\n","import {linearish} from \"./linear.js\";\nimport {copy, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformSymlog(c) {\n return function(x) {\n return Math.sign(x) * Math.log1p(Math.abs(x / c));\n };\n}\n\nfunction transformSymexp(c) {\n return function(x) {\n return Math.sign(x) * Math.expm1(Math.abs(x)) * c;\n };\n}\n\nexport function symlogish(transform) {\n var c = 1, scale = transform(transformSymlog(c), transformSymexp(c));\n\n scale.constant = function(_) {\n return arguments.length ? transform(transformSymlog(c = +_), transformSymexp(c)) : c;\n };\n\n return linearish(scale);\n}\n\nexport default function symlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, symlog()).constant(scale.constant());\n };\n\n return initRange.apply(scale, arguments);\n}\n","import {linearish} from \"./linear.js\";\nimport {copy, identity, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformPow(exponent) {\n return function(x) {\n return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);\n };\n}\n\nfunction transformSqrt(x) {\n return x < 0 ? -Math.sqrt(-x) : Math.sqrt(x);\n}\n\nfunction transformSquare(x) {\n return x < 0 ? -x * x : x * x;\n}\n\nexport function powish(transform) {\n var scale = transform(identity, identity),\n exponent = 1;\n\n function rescale() {\n return exponent === 1 ? transform(identity, identity)\n : exponent === 0.5 ? transform(transformSqrt, transformSquare)\n : transform(transformPow(exponent), transformPow(1 / exponent));\n }\n\n scale.exponent = function(_) {\n return arguments.length ? (exponent = +_, rescale()) : exponent;\n };\n\n return linearish(scale);\n}\n\nexport default function pow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, pow()).exponent(scale.exponent());\n };\n\n initRange.apply(scale, arguments);\n\n return scale;\n}\n\nexport function sqrt() {\n return pow.apply(null, arguments).exponent(0.5);\n}\n","import {ascending, bisect, quantileSorted as threshold} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport default function quantile() {\n var domain = [],\n range = [],\n thresholds = [],\n unknown;\n\n function rescale() {\n var i = 0, n = Math.max(1, range.length);\n thresholds = new Array(n - 1);\n while (++i < n) thresholds[i - 1] = threshold(domain, i / n);\n return scale;\n }\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : range[bisect(thresholds, x)];\n }\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN] : [\n i > 0 ? thresholds[i - 1] : domain[0],\n i < thresholds.length ? thresholds[i] : domain[domain.length - 1]\n ];\n };\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [];\n for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);\n domain.sort(ascending);\n return rescale();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), rescale()) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.quantiles = function() {\n return thresholds.slice();\n };\n\n scale.copy = function() {\n return quantile()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return initRange.apply(scale, arguments);\n}\n","import {bisect} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport default function threshold() {\n var domain = [0.5],\n range = [0, 1],\n unknown,\n n = 1;\n\n function scale(x) {\n return x != null && x <= x ? range[bisect(domain, x, 0, n)] : unknown;\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return [domain[i - 1], domain[i]];\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return threshold()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return initRange.apply(scale, arguments);\n}\n","const t0 = new Date, t1 = new Date;\n\nexport function timeInterval(floori, offseti, count, field) {\n\n function interval(date) {\n return floori(date = arguments.length === 0 ? new Date : new Date(+date)), date;\n }\n\n interval.floor = (date) => {\n return floori(date = new Date(+date)), date;\n };\n\n interval.ceil = (date) => {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = (date) => {\n const d0 = interval(date), d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = (date, step) => {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = (start, stop, step) => {\n const range = [];\n start = interval.ceil(start);\n step = step == null ? 1 : Math.floor(step);\n if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n let previous;\n do range.push(previous = new Date(+start)), offseti(start, step), floori(start);\n while (previous < start && start < stop);\n return range;\n };\n\n interval.filter = (test) => {\n return timeInterval((date) => {\n if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);\n }, (date, step) => {\n if (date >= date) {\n if (step < 0) while (++step <= 0) {\n while (offseti(date, -1), !test(date)) {} // eslint-disable-line no-empty\n } else while (--step >= 0) {\n while (offseti(date, +1), !test(date)) {} // eslint-disable-line no-empty\n }\n }\n });\n };\n\n if (count) {\n interval.count = (start, end) => {\n t0.setTime(+start), t1.setTime(+end);\n floori(t0), floori(t1);\n return Math.floor(count(t0, t1));\n };\n\n interval.every = (step) => {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? (d) => field(d) % step === 0\n : (d) => interval.count(0, d) % step === 0);\n };\n }\n\n return interval;\n}\n","import {timeInterval} from \"./interval.js\";\n\nexport const millisecond = timeInterval(() => {\n // noop\n}, (date, step) => {\n date.setTime(+date + step);\n}, (start, end) => {\n return end - start;\n});\n\n// An optimized implementation for this simple case.\nmillisecond.every = (k) => {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return timeInterval((date) => {\n date.setTime(Math.floor(date / k) * k);\n }, (date, step) => {\n date.setTime(+date + step * k);\n }, (start, end) => {\n return (end - start) / k;\n });\n};\n\nexport const milliseconds = millisecond.range;\n","export const durationSecond = 1000;\nexport const durationMinute = durationSecond * 60;\nexport const durationHour = durationMinute * 60;\nexport const durationDay = durationHour * 24;\nexport const durationWeek = durationDay * 7;\nexport const durationMonth = durationDay * 30;\nexport const durationYear = durationDay * 365;\n","import {timeInterval} from \"./interval.js\";\nimport {durationSecond} from \"./duration.js\";\n\nexport const second = timeInterval((date) => {\n date.setTime(date - date.getMilliseconds());\n}, (date, step) => {\n date.setTime(+date + step * durationSecond);\n}, (start, end) => {\n return (end - start) / durationSecond;\n}, (date) => {\n return date.getUTCSeconds();\n});\n\nexport const seconds = second.range;\n","import {timeInterval} from \"./interval.js\";\nimport {durationMinute, durationSecond} from \"./duration.js\";\n\nexport const timeMinute = timeInterval((date) => {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond);\n}, (date, step) => {\n date.setTime(+date + step * durationMinute);\n}, (start, end) => {\n return (end - start) / durationMinute;\n}, (date) => {\n return date.getMinutes();\n});\n\nexport const timeMinutes = timeMinute.range;\n\nexport const utcMinute = timeInterval((date) => {\n date.setUTCSeconds(0, 0);\n}, (date, step) => {\n date.setTime(+date + step * durationMinute);\n}, (start, end) => {\n return (end - start) / durationMinute;\n}, (date) => {\n return date.getUTCMinutes();\n});\n\nexport const utcMinutes = utcMinute.range;\n","import {timeInterval} from \"./interval.js\";\nimport {durationHour, durationMinute, durationSecond} from \"./duration.js\";\n\nexport const timeHour = timeInterval((date) => {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond - date.getMinutes() * durationMinute);\n}, (date, step) => {\n date.setTime(+date + step * durationHour);\n}, (start, end) => {\n return (end - start) / durationHour;\n}, (date) => {\n return date.getHours();\n});\n\nexport const timeHours = timeHour.range;\n\nexport const utcHour = timeInterval((date) => {\n date.setUTCMinutes(0, 0, 0);\n}, (date, step) => {\n date.setTime(+date + step * durationHour);\n}, (start, end) => {\n return (end - start) / durationHour;\n}, (date) => {\n return date.getUTCHours();\n});\n\nexport const utcHours = utcHour.range;\n","import {timeInterval} from \"./interval.js\";\nimport {durationDay, durationMinute} from \"./duration.js\";\n\nexport const timeDay = timeInterval(\n date => date.setHours(0, 0, 0, 0),\n (date, step) => date.setDate(date.getDate() + step),\n (start, end) => (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay,\n date => date.getDate() - 1\n);\n\nexport const timeDays = timeDay.range;\n\nexport const utcDay = timeInterval((date) => {\n date.setUTCHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setUTCDate(date.getUTCDate() + step);\n}, (start, end) => {\n return (end - start) / durationDay;\n}, (date) => {\n return date.getUTCDate() - 1;\n});\n\nexport const utcDays = utcDay.range;\n\nexport const unixDay = timeInterval((date) => {\n date.setUTCHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setUTCDate(date.getUTCDate() + step);\n}, (start, end) => {\n return (end - start) / durationDay;\n}, (date) => {\n return Math.floor(date / durationDay);\n});\n\nexport const unixDays = unixDay.range;\n","import {timeInterval} from \"./interval.js\";\nimport {durationMinute, durationWeek} from \"./duration.js\";\n\nfunction timeWeekday(i) {\n return timeInterval((date) => {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, (date, step) => {\n date.setDate(date.getDate() + step * 7);\n }, (start, end) => {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n}\n\nexport const timeSunday = timeWeekday(0);\nexport const timeMonday = timeWeekday(1);\nexport const timeTuesday = timeWeekday(2);\nexport const timeWednesday = timeWeekday(3);\nexport const timeThursday = timeWeekday(4);\nexport const timeFriday = timeWeekday(5);\nexport const timeSaturday = timeWeekday(6);\n\nexport const timeSundays = timeSunday.range;\nexport const timeMondays = timeMonday.range;\nexport const timeTuesdays = timeTuesday.range;\nexport const timeWednesdays = timeWednesday.range;\nexport const timeThursdays = timeThursday.range;\nexport const timeFridays = timeFriday.range;\nexport const timeSaturdays = timeSaturday.range;\n\nfunction utcWeekday(i) {\n return timeInterval((date) => {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, (date, step) => {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, (start, end) => {\n return (end - start) / durationWeek;\n });\n}\n\nexport const utcSunday = utcWeekday(0);\nexport const utcMonday = utcWeekday(1);\nexport const utcTuesday = utcWeekday(2);\nexport const utcWednesday = utcWeekday(3);\nexport const utcThursday = utcWeekday(4);\nexport const utcFriday = utcWeekday(5);\nexport const utcSaturday = utcWeekday(6);\n\nexport const utcSundays = utcSunday.range;\nexport const utcMondays = utcMonday.range;\nexport const utcTuesdays = utcTuesday.range;\nexport const utcWednesdays = utcWednesday.range;\nexport const utcThursdays = utcThursday.range;\nexport const utcFridays = utcFriday.range;\nexport const utcSaturdays = utcSaturday.range;\n","import {timeInterval} from \"./interval.js\";\n\nexport const timeMonth = timeInterval((date) => {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setMonth(date.getMonth() + step);\n}, (start, end) => {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n}, (date) => {\n return date.getMonth();\n});\n\nexport const timeMonths = timeMonth.range;\n\nexport const utcMonth = timeInterval((date) => {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setUTCMonth(date.getUTCMonth() + step);\n}, (start, end) => {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n}, (date) => {\n return date.getUTCMonth();\n});\n\nexport const utcMonths = utcMonth.range;\n","import {timeInterval} from \"./interval.js\";\n\nexport const timeYear = timeInterval((date) => {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setFullYear(date.getFullYear() + step);\n}, (start, end) => {\n return end.getFullYear() - start.getFullYear();\n}, (date) => {\n return date.getFullYear();\n});\n\n// An optimized implementation for this simple case.\ntimeYear.every = (k) => {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : timeInterval((date) => {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, (date, step) => {\n date.setFullYear(date.getFullYear() + step * k);\n });\n};\n\nexport const timeYears = timeYear.range;\n\nexport const utcYear = timeInterval((date) => {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n}, (date, step) => {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n}, (start, end) => {\n return end.getUTCFullYear() - start.getUTCFullYear();\n}, (date) => {\n return date.getUTCFullYear();\n});\n\n// An optimized implementation for this simple case.\nutcYear.every = (k) => {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : timeInterval((date) => {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, (date, step) => {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n};\n\nexport const utcYears = utcYear.range;\n","import {bisector, tickStep} from \"d3-array\";\nimport {durationDay, durationHour, durationMinute, durationMonth, durationSecond, durationWeek, durationYear} from \"./duration.js\";\nimport {millisecond} from \"./millisecond.js\";\nimport {second} from \"./second.js\";\nimport {timeMinute, utcMinute} from \"./minute.js\";\nimport {timeHour, utcHour} from \"./hour.js\";\nimport {timeDay, unixDay} from \"./day.js\";\nimport {timeSunday, utcSunday} from \"./week.js\";\nimport {timeMonth, utcMonth} from \"./month.js\";\nimport {timeYear, utcYear} from \"./year.js\";\n\nfunction ticker(year, month, week, day, hour, minute) {\n\n const tickIntervals = [\n [second, 1, durationSecond],\n [second, 5, 5 * durationSecond],\n [second, 15, 15 * durationSecond],\n [second, 30, 30 * durationSecond],\n [minute, 1, durationMinute],\n [minute, 5, 5 * durationMinute],\n [minute, 15, 15 * durationMinute],\n [minute, 30, 30 * durationMinute],\n [ hour, 1, durationHour ],\n [ hour, 3, 3 * durationHour ],\n [ hour, 6, 6 * durationHour ],\n [ hour, 12, 12 * durationHour ],\n [ day, 1, durationDay ],\n [ day, 2, 2 * durationDay ],\n [ week, 1, durationWeek ],\n [ month, 1, durationMonth ],\n [ month, 3, 3 * durationMonth ],\n [ year, 1, durationYear ]\n ];\n\n function ticks(start, stop, count) {\n const reverse = stop < start;\n if (reverse) [start, stop] = [stop, start];\n const interval = count && typeof count.range === \"function\" ? count : tickInterval(start, stop, count);\n const ticks = interval ? interval.range(start, +stop + 1) : []; // inclusive stop\n return reverse ? ticks.reverse() : ticks;\n }\n\n function tickInterval(start, stop, count) {\n const target = Math.abs(stop - start) / count;\n const i = bisector(([,, step]) => step).right(tickIntervals, target);\n if (i === tickIntervals.length) return year.every(tickStep(start / durationYear, stop / durationYear, count));\n if (i === 0) return millisecond.every(Math.max(tickStep(start, stop, count), 1));\n const [t, step] = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n return t.every(step);\n }\n\n return [ticks, tickInterval];\n}\n\nconst [utcTicks, utcTickInterval] = ticker(utcYear, utcMonth, utcSunday, unixDay, utcHour, utcMinute);\nconst [timeTicks, timeTickInterval] = ticker(timeYear, timeMonth, timeSunday, timeDay, timeHour, timeMinute);\n\nexport {utcTicks, utcTickInterval, timeTicks, timeTickInterval};\n","import {\n timeDay,\n timeSunday,\n timeMonday,\n timeThursday,\n timeYear,\n utcDay,\n utcSunday,\n utcMonday,\n utcThursday,\n utcYear\n} from \"d3-time\";\n\nfunction localDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n date.setFullYear(d.y);\n return date;\n }\n return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n}\n\nfunction utcDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n date.setUTCFullYear(d.y);\n return date;\n }\n return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n}\n\nfunction newDate(y, m, d) {\n return {y: y, m: m, d: d, H: 0, M: 0, S: 0, L: 0};\n}\n\nexport default function formatLocale(locale) {\n var locale_dateTime = locale.dateTime,\n locale_date = locale.date,\n locale_time = locale.time,\n locale_periods = locale.periods,\n locale_weekdays = locale.days,\n locale_shortWeekdays = locale.shortDays,\n locale_months = locale.months,\n locale_shortMonths = locale.shortMonths;\n\n var periodRe = formatRe(locale_periods),\n periodLookup = formatLookup(locale_periods),\n weekdayRe = formatRe(locale_weekdays),\n weekdayLookup = formatLookup(locale_weekdays),\n shortWeekdayRe = formatRe(locale_shortWeekdays),\n shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n monthRe = formatRe(locale_months),\n monthLookup = formatLookup(locale_months),\n shortMonthRe = formatRe(locale_shortMonths),\n shortMonthLookup = formatLookup(locale_shortMonths);\n\n var formats = {\n \"a\": formatShortWeekday,\n \"A\": formatWeekday,\n \"b\": formatShortMonth,\n \"B\": formatMonth,\n \"c\": null,\n \"d\": formatDayOfMonth,\n \"e\": formatDayOfMonth,\n \"f\": formatMicroseconds,\n \"g\": formatYearISO,\n \"G\": formatFullYearISO,\n \"H\": formatHour24,\n \"I\": formatHour12,\n \"j\": formatDayOfYear,\n \"L\": formatMilliseconds,\n \"m\": formatMonthNumber,\n \"M\": formatMinutes,\n \"p\": formatPeriod,\n \"q\": formatQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatSeconds,\n \"u\": formatWeekdayNumberMonday,\n \"U\": formatWeekNumberSunday,\n \"V\": formatWeekNumberISO,\n \"w\": formatWeekdayNumberSunday,\n \"W\": formatWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatYear,\n \"Y\": formatFullYear,\n \"Z\": formatZone,\n \"%\": formatLiteralPercent\n };\n\n var utcFormats = {\n \"a\": formatUTCShortWeekday,\n \"A\": formatUTCWeekday,\n \"b\": formatUTCShortMonth,\n \"B\": formatUTCMonth,\n \"c\": null,\n \"d\": formatUTCDayOfMonth,\n \"e\": formatUTCDayOfMonth,\n \"f\": formatUTCMicroseconds,\n \"g\": formatUTCYearISO,\n \"G\": formatUTCFullYearISO,\n \"H\": formatUTCHour24,\n \"I\": formatUTCHour12,\n \"j\": formatUTCDayOfYear,\n \"L\": formatUTCMilliseconds,\n \"m\": formatUTCMonthNumber,\n \"M\": formatUTCMinutes,\n \"p\": formatUTCPeriod,\n \"q\": formatUTCQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatUTCSeconds,\n \"u\": formatUTCWeekdayNumberMonday,\n \"U\": formatUTCWeekNumberSunday,\n \"V\": formatUTCWeekNumberISO,\n \"w\": formatUTCWeekdayNumberSunday,\n \"W\": formatUTCWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatUTCYear,\n \"Y\": formatUTCFullYear,\n \"Z\": formatUTCZone,\n \"%\": formatLiteralPercent\n };\n\n var parses = {\n \"a\": parseShortWeekday,\n \"A\": parseWeekday,\n \"b\": parseShortMonth,\n \"B\": parseMonth,\n \"c\": parseLocaleDateTime,\n \"d\": parseDayOfMonth,\n \"e\": parseDayOfMonth,\n \"f\": parseMicroseconds,\n \"g\": parseYear,\n \"G\": parseFullYear,\n \"H\": parseHour24,\n \"I\": parseHour24,\n \"j\": parseDayOfYear,\n \"L\": parseMilliseconds,\n \"m\": parseMonthNumber,\n \"M\": parseMinutes,\n \"p\": parsePeriod,\n \"q\": parseQuarter,\n \"Q\": parseUnixTimestamp,\n \"s\": parseUnixTimestampSeconds,\n \"S\": parseSeconds,\n \"u\": parseWeekdayNumberMonday,\n \"U\": parseWeekNumberSunday,\n \"V\": parseWeekNumberISO,\n \"w\": parseWeekdayNumberSunday,\n \"W\": parseWeekNumberMonday,\n \"x\": parseLocaleDate,\n \"X\": parseLocaleTime,\n \"y\": parseYear,\n \"Y\": parseFullYear,\n \"Z\": parseZone,\n \"%\": parseLiteralPercent\n };\n\n // These recursive directive definitions must be deferred.\n formats.x = newFormat(locale_date, formats);\n formats.X = newFormat(locale_time, formats);\n formats.c = newFormat(locale_dateTime, formats);\n utcFormats.x = newFormat(locale_date, utcFormats);\n utcFormats.X = newFormat(locale_time, utcFormats);\n utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n function newFormat(specifier, formats) {\n return function(date) {\n var string = [],\n i = -1,\n j = 0,\n n = specifier.length,\n c,\n pad,\n format;\n\n if (!(date instanceof Date)) date = new Date(+date);\n\n while (++i < n) {\n if (specifier.charCodeAt(i) === 37) {\n string.push(specifier.slice(j, i));\n if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n else pad = c === \"e\" ? \" \" : \"0\";\n if (format = formats[c]) c = format(date, pad);\n string.push(c);\n j = i + 1;\n }\n }\n\n string.push(specifier.slice(j, i));\n return string.join(\"\");\n };\n }\n\n function newParse(specifier, Z) {\n return function(string) {\n var d = newDate(1900, undefined, 1),\n i = parseSpecifier(d, specifier, string += \"\", 0),\n week, day;\n if (i != string.length) return null;\n\n // If a UNIX timestamp is specified, return it.\n if (\"Q\" in d) return new Date(d.Q);\n if (\"s\" in d) return new Date(d.s * 1000 + (\"L\" in d ? d.L : 0));\n\n // If this is utcParse, never use the local timezone.\n if (Z && !(\"Z\" in d)) d.Z = 0;\n\n // The am-pm flag is 0 for AM, and 1 for PM.\n if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n // If the month was not specified, inherit from the quarter.\n if (d.m === undefined) d.m = \"q\" in d ? d.q : 0;\n\n // Convert day-of-week and week-of-year to day-of-year.\n if (\"V\" in d) {\n if (d.V < 1 || d.V > 53) return null;\n if (!(\"w\" in d)) d.w = 1;\n if (\"Z\" in d) {\n week = utcDate(newDate(d.y, 0, 1)), day = week.getUTCDay();\n week = day > 4 || day === 0 ? utcMonday.ceil(week) : utcMonday(week);\n week = utcDay.offset(week, (d.V - 1) * 7);\n d.y = week.getUTCFullYear();\n d.m = week.getUTCMonth();\n d.d = week.getUTCDate() + (d.w + 6) % 7;\n } else {\n week = localDate(newDate(d.y, 0, 1)), day = week.getDay();\n week = day > 4 || day === 0 ? timeMonday.ceil(week) : timeMonday(week);\n week = timeDay.offset(week, (d.V - 1) * 7);\n d.y = week.getFullYear();\n d.m = week.getMonth();\n d.d = week.getDate() + (d.w + 6) % 7;\n }\n } else if (\"W\" in d || \"U\" in d) {\n if (!(\"w\" in d)) d.w = \"u\" in d ? d.u % 7 : \"W\" in d ? 1 : 0;\n day = \"Z\" in d ? utcDate(newDate(d.y, 0, 1)).getUTCDay() : localDate(newDate(d.y, 0, 1)).getDay();\n d.m = 0;\n d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7;\n }\n\n // If a time zone is specified, all fields are interpreted as UTC and then\n // offset according to the specified time zone.\n if (\"Z\" in d) {\n d.H += d.Z / 100 | 0;\n d.M += d.Z % 100;\n return utcDate(d);\n }\n\n // Otherwise, all fields are in local time.\n return localDate(d);\n };\n }\n\n function parseSpecifier(d, specifier, string, j) {\n var i = 0,\n n = specifier.length,\n m = string.length,\n c,\n parse;\n\n while (i < n) {\n if (j >= m) return -1;\n c = specifier.charCodeAt(i++);\n if (c === 37) {\n c = specifier.charAt(i++);\n parse = parses[c in pads ? specifier.charAt(i++) : c];\n if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n } else if (c != string.charCodeAt(j++)) {\n return -1;\n }\n }\n\n return j;\n }\n\n function parsePeriod(d, string, i) {\n var n = periodRe.exec(string.slice(i));\n return n ? (d.p = periodLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseShortWeekday(d, string, i) {\n var n = shortWeekdayRe.exec(string.slice(i));\n return n ? (d.w = shortWeekdayLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseWeekday(d, string, i) {\n var n = weekdayRe.exec(string.slice(i));\n return n ? (d.w = weekdayLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseShortMonth(d, string, i) {\n var n = shortMonthRe.exec(string.slice(i));\n return n ? (d.m = shortMonthLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseMonth(d, string, i) {\n var n = monthRe.exec(string.slice(i));\n return n ? (d.m = monthLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseLocaleDateTime(d, string, i) {\n return parseSpecifier(d, locale_dateTime, string, i);\n }\n\n function parseLocaleDate(d, string, i) {\n return parseSpecifier(d, locale_date, string, i);\n }\n\n function parseLocaleTime(d, string, i) {\n return parseSpecifier(d, locale_time, string, i);\n }\n\n function formatShortWeekday(d) {\n return locale_shortWeekdays[d.getDay()];\n }\n\n function formatWeekday(d) {\n return locale_weekdays[d.getDay()];\n }\n\n function formatShortMonth(d) {\n return locale_shortMonths[d.getMonth()];\n }\n\n function formatMonth(d) {\n return locale_months[d.getMonth()];\n }\n\n function formatPeriod(d) {\n return locale_periods[+(d.getHours() >= 12)];\n }\n\n function formatQuarter(d) {\n return 1 + ~~(d.getMonth() / 3);\n }\n\n function formatUTCShortWeekday(d) {\n return locale_shortWeekdays[d.getUTCDay()];\n }\n\n function formatUTCWeekday(d) {\n return locale_weekdays[d.getUTCDay()];\n }\n\n function formatUTCShortMonth(d) {\n return locale_shortMonths[d.getUTCMonth()];\n }\n\n function formatUTCMonth(d) {\n return locale_months[d.getUTCMonth()];\n }\n\n function formatUTCPeriod(d) {\n return locale_periods[+(d.getUTCHours() >= 12)];\n }\n\n function formatUTCQuarter(d) {\n return 1 + ~~(d.getUTCMonth() / 3);\n }\n\n return {\n format: function(specifier) {\n var f = newFormat(specifier += \"\", formats);\n f.toString = function() { return specifier; };\n return f;\n },\n parse: function(specifier) {\n var p = newParse(specifier += \"\", false);\n p.toString = function() { return specifier; };\n return p;\n },\n utcFormat: function(specifier) {\n var f = newFormat(specifier += \"\", utcFormats);\n f.toString = function() { return specifier; };\n return f;\n },\n utcParse: function(specifier) {\n var p = newParse(specifier += \"\", true);\n p.toString = function() { return specifier; };\n return p;\n }\n };\n}\n\nvar pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"},\n numberRe = /^\\s*\\d+/, // note: ignores next directive\n percentRe = /^%/,\n requoteRe = /[\\\\^$*+?|[\\]().{}]/g;\n\nfunction pad(value, fill, width) {\n var sign = value < 0 ? \"-\" : \"\",\n string = (sign ? -value : value) + \"\",\n length = string.length;\n return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n}\n\nfunction requote(s) {\n return s.replace(requoteRe, \"\\\\$&\");\n}\n\nfunction formatRe(names) {\n return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n}\n\nfunction formatLookup(names) {\n return new Map(names.map((name, i) => [name.toLowerCase(), i]));\n}\n\nfunction parseWeekdayNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.w = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekdayNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.u = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.U = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberISO(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.V = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.W = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseFullYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 4));\n return n ? (d.y = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n}\n\nfunction parseZone(d, string, i) {\n var n = /^(Z)|([+-]\\d\\d)(?::?(\\d\\d))?/.exec(string.slice(i, i + 6));\n return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n}\n\nfunction parseQuarter(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.q = n[0] * 3 - 3, i + n[0].length) : -1;\n}\n\nfunction parseMonthNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n}\n\nfunction parseDayOfMonth(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseDayOfYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseHour24(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.H = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMinutes(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.M = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.S = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMilliseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.L = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMicroseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 6));\n return n ? (d.L = Math.floor(n[0] / 1000), i + n[0].length) : -1;\n}\n\nfunction parseLiteralPercent(d, string, i) {\n var n = percentRe.exec(string.slice(i, i + 1));\n return n ? i + n[0].length : -1;\n}\n\nfunction parseUnixTimestamp(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.Q = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseUnixTimestampSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.s = +n[0], i + n[0].length) : -1;\n}\n\nfunction formatDayOfMonth(d, p) {\n return pad(d.getDate(), p, 2);\n}\n\nfunction formatHour24(d, p) {\n return pad(d.getHours(), p, 2);\n}\n\nfunction formatHour12(d, p) {\n return pad(d.getHours() % 12 || 12, p, 2);\n}\n\nfunction formatDayOfYear(d, p) {\n return pad(1 + timeDay.count(timeYear(d), d), p, 3);\n}\n\nfunction formatMilliseconds(d, p) {\n return pad(d.getMilliseconds(), p, 3);\n}\n\nfunction formatMicroseconds(d, p) {\n return formatMilliseconds(d, p) + \"000\";\n}\n\nfunction formatMonthNumber(d, p) {\n return pad(d.getMonth() + 1, p, 2);\n}\n\nfunction formatMinutes(d, p) {\n return pad(d.getMinutes(), p, 2);\n}\n\nfunction formatSeconds(d, p) {\n return pad(d.getSeconds(), p, 2);\n}\n\nfunction formatWeekdayNumberMonday(d) {\n var day = d.getDay();\n return day === 0 ? 7 : day;\n}\n\nfunction formatWeekNumberSunday(d, p) {\n return pad(timeSunday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction dISO(d) {\n var day = d.getDay();\n return (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n}\n\nfunction formatWeekNumberISO(d, p) {\n d = dISO(d);\n return pad(timeThursday.count(timeYear(d), d) + (timeYear(d).getDay() === 4), p, 2);\n}\n\nfunction formatWeekdayNumberSunday(d) {\n return d.getDay();\n}\n\nfunction formatWeekNumberMonday(d, p) {\n return pad(timeMonday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction formatYear(d, p) {\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatYearISO(d, p) {\n d = dISO(d);\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatFullYear(d, p) {\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatFullYearISO(d, p) {\n var day = d.getDay();\n d = (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatZone(d) {\n var z = d.getTimezoneOffset();\n return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n + pad(z / 60 | 0, \"0\", 2)\n + pad(z % 60, \"0\", 2);\n}\n\nfunction formatUTCDayOfMonth(d, p) {\n return pad(d.getUTCDate(), p, 2);\n}\n\nfunction formatUTCHour24(d, p) {\n return pad(d.getUTCHours(), p, 2);\n}\n\nfunction formatUTCHour12(d, p) {\n return pad(d.getUTCHours() % 12 || 12, p, 2);\n}\n\nfunction formatUTCDayOfYear(d, p) {\n return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n}\n\nfunction formatUTCMilliseconds(d, p) {\n return pad(d.getUTCMilliseconds(), p, 3);\n}\n\nfunction formatUTCMicroseconds(d, p) {\n return formatUTCMilliseconds(d, p) + \"000\";\n}\n\nfunction formatUTCMonthNumber(d, p) {\n return pad(d.getUTCMonth() + 1, p, 2);\n}\n\nfunction formatUTCMinutes(d, p) {\n return pad(d.getUTCMinutes(), p, 2);\n}\n\nfunction formatUTCSeconds(d, p) {\n return pad(d.getUTCSeconds(), p, 2);\n}\n\nfunction formatUTCWeekdayNumberMonday(d) {\n var dow = d.getUTCDay();\n return dow === 0 ? 7 : dow;\n}\n\nfunction formatUTCWeekNumberSunday(d, p) {\n return pad(utcSunday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction UTCdISO(d) {\n var day = d.getUTCDay();\n return (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n}\n\nfunction formatUTCWeekNumberISO(d, p) {\n d = UTCdISO(d);\n return pad(utcThursday.count(utcYear(d), d) + (utcYear(d).getUTCDay() === 4), p, 2);\n}\n\nfunction formatUTCWeekdayNumberSunday(d) {\n return d.getUTCDay();\n}\n\nfunction formatUTCWeekNumberMonday(d, p) {\n return pad(utcMonday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction formatUTCYear(d, p) {\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCYearISO(d, p) {\n d = UTCdISO(d);\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCFullYear(d, p) {\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCFullYearISO(d, p) {\n var day = d.getUTCDay();\n d = (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCZone() {\n return \"+0000\";\n}\n\nfunction formatLiteralPercent() {\n return \"%\";\n}\n\nfunction formatUnixTimestamp(d) {\n return +d;\n}\n\nfunction formatUnixTimestampSeconds(d) {\n return Math.floor(+d / 1000);\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var timeFormat;\nexport var timeParse;\nexport var utcFormat;\nexport var utcParse;\n\ndefaultLocale({\n dateTime: \"%x, %X\",\n date: \"%-m/%-d/%Y\",\n time: \"%-I:%M:%S %p\",\n periods: [\"AM\", \"PM\"],\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n timeFormat = locale.format;\n timeParse = locale.parse;\n utcFormat = locale.utcFormat;\n utcParse = locale.utcParse;\n return locale;\n}\n","import {timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeTicks, timeTickInterval} from \"d3-time\";\nimport {timeFormat} from \"d3-time-format\";\nimport continuous, {copy} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\nimport nice from \"./nice.js\";\n\nfunction date(t) {\n return new Date(t);\n}\n\nfunction number(t) {\n return t instanceof Date ? +t : +new Date(+t);\n}\n\nexport function calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format) {\n var scale = continuous(),\n invert = scale.invert,\n domain = scale.domain;\n\n var formatMillisecond = format(\".%L\"),\n formatSecond = format(\":%S\"),\n formatMinute = format(\"%I:%M\"),\n formatHour = format(\"%I %p\"),\n formatDay = format(\"%a %d\"),\n formatWeek = format(\"%b %d\"),\n formatMonth = format(\"%B\"),\n formatYear = format(\"%Y\");\n\n function tickFormat(date) {\n return (second(date) < date ? formatMillisecond\n : minute(date) < date ? formatSecond\n : hour(date) < date ? formatMinute\n : day(date) < date ? formatHour\n : month(date) < date ? (week(date) < date ? formatDay : formatWeek)\n : year(date) < date ? formatMonth\n : formatYear)(date);\n }\n\n scale.invert = function(y) {\n return new Date(invert(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? domain(Array.from(_, number)) : domain().map(date);\n };\n\n scale.ticks = function(interval) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], interval == null ? 10 : interval);\n };\n\n scale.tickFormat = function(count, specifier) {\n return specifier == null ? tickFormat : format(specifier);\n };\n\n scale.nice = function(interval) {\n var d = domain();\n if (!interval || typeof interval.range !== \"function\") interval = tickInterval(d[0], d[d.length - 1], interval == null ? 10 : interval);\n return interval ? domain(nice(d, interval)) : scale;\n };\n\n scale.copy = function() {\n return copy(scale, calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format));\n };\n\n return scale;\n}\n\nexport default function time() {\n return initRange.apply(calendar(timeTicks, timeTickInterval, timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]), arguments);\n}\n","import {interpolate, interpolateRound} from \"d3-interpolate\";\nimport {identity} from \"./continuous.js\";\nimport {initInterpolator} from \"./init.js\";\nimport {linearish} from \"./linear.js\";\nimport {loggish} from \"./log.js\";\nimport {symlogish} from \"./symlog.js\";\nimport {powish} from \"./pow.js\";\n\nfunction transformer() {\n var x0 = 0,\n x1 = 1,\n t0,\n t1,\n k10,\n transform,\n interpolator = identity,\n clamp = false,\n unknown;\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : interpolator(k10 === 0 ? 0.5 : (x = (transform(x) - t0) * k10, clamp ? Math.max(0, Math.min(1, x)) : x));\n }\n\n scale.domain = function(_) {\n return arguments.length ? ([x0, x1] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0), scale) : [x0, x1];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n function range(interpolate) {\n return function(_) {\n var r0, r1;\n return arguments.length ? ([r0, r1] = _, interpolator = interpolate(r0, r1), scale) : [interpolator(0), interpolator(1)];\n };\n }\n\n scale.range = range(interpolate);\n\n scale.rangeRound = range(interpolateRound);\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t) {\n transform = t, t0 = t(x0), t1 = t(x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0);\n return scale;\n };\n}\n\nexport function copy(source, target) {\n return target\n .domain(source.domain())\n .interpolator(source.interpolator())\n .clamp(source.clamp())\n .unknown(source.unknown());\n}\n\nexport default function sequential() {\n var scale = linearish(transformer()(identity));\n\n scale.copy = function() {\n return copy(scale, sequential());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialLog() {\n var scale = loggish(transformer()).domain([1, 10]);\n\n scale.copy = function() {\n return copy(scale, sequentialLog()).base(scale.base());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialSymlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, sequentialSymlog()).constant(scale.constant());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialPow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, sequentialPow()).exponent(scale.exponent());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialSqrt() {\n return sequentialPow.apply(null, arguments).exponent(0.5);\n}\n","import {interpolate, interpolateRound, piecewise} from \"d3-interpolate\";\nimport {identity} from \"./continuous.js\";\nimport {initInterpolator} from \"./init.js\";\nimport {linearish} from \"./linear.js\";\nimport {loggish} from \"./log.js\";\nimport {copy} from \"./sequential.js\";\nimport {symlogish} from \"./symlog.js\";\nimport {powish} from \"./pow.js\";\n\nfunction transformer() {\n var x0 = 0,\n x1 = 0.5,\n x2 = 1,\n s = 1,\n t0,\n t1,\n t2,\n k10,\n k21,\n interpolator = identity,\n transform,\n clamp = false,\n unknown;\n\n function scale(x) {\n return isNaN(x = +x) ? unknown : (x = 0.5 + ((x = +transform(x)) - t1) * (s * x < s * t1 ? k10 : k21), interpolator(clamp ? Math.max(0, Math.min(1, x)) : x));\n }\n\n scale.domain = function(_) {\n return arguments.length ? ([x0, x1, x2] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), t2 = transform(x2 = +x2), k10 = t0 === t1 ? 0 : 0.5 / (t1 - t0), k21 = t1 === t2 ? 0 : 0.5 / (t2 - t1), s = t1 < t0 ? -1 : 1, scale) : [x0, x1, x2];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n function range(interpolate) {\n return function(_) {\n var r0, r1, r2;\n return arguments.length ? ([r0, r1, r2] = _, interpolator = piecewise(interpolate, [r0, r1, r2]), scale) : [interpolator(0), interpolator(0.5), interpolator(1)];\n };\n }\n\n scale.range = range(interpolate);\n\n scale.rangeRound = range(interpolateRound);\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t) {\n transform = t, t0 = t(x0), t1 = t(x1), t2 = t(x2), k10 = t0 === t1 ? 0 : 0.5 / (t1 - t0), k21 = t1 === t2 ? 0 : 0.5 / (t2 - t1), s = t1 < t0 ? -1 : 1;\n return scale;\n };\n}\n\nexport default function diverging() {\n var scale = linearish(transformer()(identity));\n\n scale.copy = function() {\n return copy(scale, diverging());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingLog() {\n var scale = loggish(transformer()).domain([0.1, 1, 10]);\n\n scale.copy = function() {\n return copy(scale, divergingLog()).base(scale.base());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingSymlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, divergingSymlog()).constant(scale.constant());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingPow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, divergingPow()).exponent(scale.exponent());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingSqrt() {\n return divergingPow.apply(null, arguments).exponent(0.5);\n}\n","export default function(specifier) {\n var n = specifier.length / 6 | 0, colors = new Array(n), i = 0;\n while (i < n) colors[i] = \"#\" + specifier.slice(i * 6, ++i * 6);\n return colors;\n}\n","import colors from \"../colors.js\";\n\nexport default colors(\"1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f\");\n","import colors from \"../colors.js\";\n\nexport default colors(\"4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab\");\n","import {interpolateRgbBasis} from \"d3-interpolate\";\n\nexport default scheme => interpolateRgbBasis(scheme[scheme.length - 1]);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"d8b365f5f5f55ab4ac\",\n \"a6611adfc27d80cdc1018571\",\n \"a6611adfc27df5f5f580cdc1018571\",\n \"8c510ad8b365f6e8c3c7eae55ab4ac01665e\",\n \"8c510ad8b365f6e8c3f5f5f5c7eae55ab4ac01665e\",\n \"8c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e\",\n \"8c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e\",\n \"5430058c510abf812ddfc27df6e8c3c7eae580cdc135978f01665e003c30\",\n \"5430058c510abf812ddfc27df6e8c3f5f5f5c7eae580cdc135978f01665e003c30\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"af8dc3f7f7f77fbf7b\",\n \"7b3294c2a5cfa6dba0008837\",\n \"7b3294c2a5cff7f7f7a6dba0008837\",\n \"762a83af8dc3e7d4e8d9f0d37fbf7b1b7837\",\n \"762a83af8dc3e7d4e8f7f7f7d9f0d37fbf7b1b7837\",\n \"762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b7837\",\n \"762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b7837\",\n \"40004b762a839970abc2a5cfe7d4e8d9f0d3a6dba05aae611b783700441b\",\n \"40004b762a839970abc2a5cfe7d4e8f7f7f7d9f0d3a6dba05aae611b783700441b\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e9a3c9f7f7f7a1d76a\",\n \"d01c8bf1b6dab8e1864dac26\",\n \"d01c8bf1b6daf7f7f7b8e1864dac26\",\n \"c51b7de9a3c9fde0efe6f5d0a1d76a4d9221\",\n \"c51b7de9a3c9fde0eff7f7f7e6f5d0a1d76a4d9221\",\n \"c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221\",\n \"c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221\",\n \"8e0152c51b7dde77aef1b6dafde0efe6f5d0b8e1867fbc414d9221276419\",\n \"8e0152c51b7dde77aef1b6dafde0eff7f7f7e6f5d0b8e1867fbc414d9221276419\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"998ec3f7f7f7f1a340\",\n \"5e3c99b2abd2fdb863e66101\",\n \"5e3c99b2abd2f7f7f7fdb863e66101\",\n \"542788998ec3d8daebfee0b6f1a340b35806\",\n \"542788998ec3d8daebf7f7f7fee0b6f1a340b35806\",\n \"5427888073acb2abd2d8daebfee0b6fdb863e08214b35806\",\n \"5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b35806\",\n \"2d004b5427888073acb2abd2d8daebfee0b6fdb863e08214b358067f3b08\",\n \"2d004b5427888073acb2abd2d8daebf7f7f7fee0b6fdb863e08214b358067f3b08\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"ef8a62f7f7f767a9cf\",\n \"ca0020f4a58292c5de0571b0\",\n \"ca0020f4a582f7f7f792c5de0571b0\",\n \"b2182bef8a62fddbc7d1e5f067a9cf2166ac\",\n \"b2182bef8a62fddbc7f7f7f7d1e5f067a9cf2166ac\",\n \"b2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac\",\n \"b2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac\",\n \"67001fb2182bd6604df4a582fddbc7d1e5f092c5de4393c32166ac053061\",\n \"67001fb2182bd6604df4a582fddbc7f7f7f7d1e5f092c5de4393c32166ac053061\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"ef8a62ffffff999999\",\n \"ca0020f4a582bababa404040\",\n \"ca0020f4a582ffffffbababa404040\",\n \"b2182bef8a62fddbc7e0e0e09999994d4d4d\",\n \"b2182bef8a62fddbc7ffffffe0e0e09999994d4d4d\",\n \"b2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d\",\n \"b2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d\",\n \"67001fb2182bd6604df4a582fddbc7e0e0e0bababa8787874d4d4d1a1a1a\",\n \"67001fb2182bd6604df4a582fddbc7ffffffe0e0e0bababa8787874d4d4d1a1a1a\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fc8d59ffffbf91bfdb\",\n \"d7191cfdae61abd9e92c7bb6\",\n \"d7191cfdae61ffffbfabd9e92c7bb6\",\n \"d73027fc8d59fee090e0f3f891bfdb4575b4\",\n \"d73027fc8d59fee090ffffbfe0f3f891bfdb4575b4\",\n \"d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4\",\n \"d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4\",\n \"a50026d73027f46d43fdae61fee090e0f3f8abd9e974add14575b4313695\",\n \"a50026d73027f46d43fdae61fee090ffffbfe0f3f8abd9e974add14575b4313695\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fc8d59ffffbf91cf60\",\n \"d7191cfdae61a6d96a1a9641\",\n \"d7191cfdae61ffffbfa6d96a1a9641\",\n \"d73027fc8d59fee08bd9ef8b91cf601a9850\",\n \"d73027fc8d59fee08bffffbfd9ef8b91cf601a9850\",\n \"d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850\",\n \"d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850\",\n \"a50026d73027f46d43fdae61fee08bd9ef8ba6d96a66bd631a9850006837\",\n \"a50026d73027f46d43fdae61fee08bffffbfd9ef8ba6d96a66bd631a9850006837\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fc8d59ffffbf99d594\",\n \"d7191cfdae61abdda42b83ba\",\n \"d7191cfdae61ffffbfabdda42b83ba\",\n \"d53e4ffc8d59fee08be6f59899d5943288bd\",\n \"d53e4ffc8d59fee08bffffbfe6f59899d5943288bd\",\n \"d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd\",\n \"d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd\",\n \"9e0142d53e4ff46d43fdae61fee08be6f598abdda466c2a53288bd5e4fa2\",\n \"9e0142d53e4ff46d43fdae61fee08bffffbfe6f598abdda466c2a53288bd5e4fa2\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e5f5f999d8c92ca25f\",\n \"edf8fbb2e2e266c2a4238b45\",\n \"edf8fbb2e2e266c2a42ca25f006d2c\",\n \"edf8fbccece699d8c966c2a42ca25f006d2c\",\n \"edf8fbccece699d8c966c2a441ae76238b45005824\",\n \"f7fcfde5f5f9ccece699d8c966c2a441ae76238b45005824\",\n \"f7fcfde5f5f9ccece699d8c966c2a441ae76238b45006d2c00441b\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e0ecf49ebcda8856a7\",\n \"edf8fbb3cde38c96c688419d\",\n \"edf8fbb3cde38c96c68856a7810f7c\",\n \"edf8fbbfd3e69ebcda8c96c68856a7810f7c\",\n \"edf8fbbfd3e69ebcda8c96c68c6bb188419d6e016b\",\n \"f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d6e016b\",\n \"f7fcfde0ecf4bfd3e69ebcda8c96c68c6bb188419d810f7c4d004b\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e0f3dba8ddb543a2ca\",\n \"f0f9e8bae4bc7bccc42b8cbe\",\n \"f0f9e8bae4bc7bccc443a2ca0868ac\",\n \"f0f9e8ccebc5a8ddb57bccc443a2ca0868ac\",\n \"f0f9e8ccebc5a8ddb57bccc44eb3d32b8cbe08589e\",\n \"f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe08589e\",\n \"f7fcf0e0f3dbccebc5a8ddb57bccc44eb3d32b8cbe0868ac084081\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fee8c8fdbb84e34a33\",\n \"fef0d9fdcc8afc8d59d7301f\",\n \"fef0d9fdcc8afc8d59e34a33b30000\",\n \"fef0d9fdd49efdbb84fc8d59e34a33b30000\",\n \"fef0d9fdd49efdbb84fc8d59ef6548d7301f990000\",\n \"fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301f990000\",\n \"fff7ecfee8c8fdd49efdbb84fc8d59ef6548d7301fb300007f0000\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"ece2f0a6bddb1c9099\",\n \"f6eff7bdc9e167a9cf02818a\",\n \"f6eff7bdc9e167a9cf1c9099016c59\",\n \"f6eff7d0d1e6a6bddb67a9cf1c9099016c59\",\n \"f6eff7d0d1e6a6bddb67a9cf3690c002818a016450\",\n \"fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016450\",\n \"fff7fbece2f0d0d1e6a6bddb67a9cf3690c002818a016c59014636\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"ece7f2a6bddb2b8cbe\",\n \"f1eef6bdc9e174a9cf0570b0\",\n \"f1eef6bdc9e174a9cf2b8cbe045a8d\",\n \"f1eef6d0d1e6a6bddb74a9cf2b8cbe045a8d\",\n \"f1eef6d0d1e6a6bddb74a9cf3690c00570b0034e7b\",\n \"fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0034e7b\",\n \"fff7fbece7f2d0d1e6a6bddb74a9cf3690c00570b0045a8d023858\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e7e1efc994c7dd1c77\",\n \"f1eef6d7b5d8df65b0ce1256\",\n \"f1eef6d7b5d8df65b0dd1c77980043\",\n \"f1eef6d4b9dac994c7df65b0dd1c77980043\",\n \"f1eef6d4b9dac994c7df65b0e7298ace125691003f\",\n \"f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125691003f\",\n \"f7f4f9e7e1efd4b9dac994c7df65b0e7298ace125698004367001f\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fde0ddfa9fb5c51b8a\",\n \"feebe2fbb4b9f768a1ae017e\",\n \"feebe2fbb4b9f768a1c51b8a7a0177\",\n \"feebe2fcc5c0fa9fb5f768a1c51b8a7a0177\",\n \"feebe2fcc5c0fa9fb5f768a1dd3497ae017e7a0177\",\n \"fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a0177\",\n \"fff7f3fde0ddfcc5c0fa9fb5f768a1dd3497ae017e7a017749006a\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"edf8b17fcdbb2c7fb8\",\n \"ffffcca1dab441b6c4225ea8\",\n \"ffffcca1dab441b6c42c7fb8253494\",\n \"ffffccc7e9b47fcdbb41b6c42c7fb8253494\",\n \"ffffccc7e9b47fcdbb41b6c41d91c0225ea80c2c84\",\n \"ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea80c2c84\",\n \"ffffd9edf8b1c7e9b47fcdbb41b6c41d91c0225ea8253494081d58\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"f7fcb9addd8e31a354\",\n \"ffffccc2e69978c679238443\",\n \"ffffccc2e69978c67931a354006837\",\n \"ffffccd9f0a3addd8e78c67931a354006837\",\n \"ffffccd9f0a3addd8e78c67941ab5d238443005a32\",\n \"ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443005a32\",\n \"ffffe5f7fcb9d9f0a3addd8e78c67941ab5d238443006837004529\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fff7bcfec44fd95f0e\",\n \"ffffd4fed98efe9929cc4c02\",\n \"ffffd4fed98efe9929d95f0e993404\",\n \"ffffd4fee391fec44ffe9929d95f0e993404\",\n \"ffffd4fee391fec44ffe9929ec7014cc4c028c2d04\",\n \"ffffe5fff7bcfee391fec44ffe9929ec7014cc4c028c2d04\",\n \"ffffe5fff7bcfee391fec44ffe9929ec7014cc4c02993404662506\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"ffeda0feb24cf03b20\",\n \"ffffb2fecc5cfd8d3ce31a1c\",\n \"ffffb2fecc5cfd8d3cf03b20bd0026\",\n \"ffffb2fed976feb24cfd8d3cf03b20bd0026\",\n \"ffffb2fed976feb24cfd8d3cfc4e2ae31a1cb10026\",\n \"ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cb10026\",\n \"ffffccffeda0fed976feb24cfd8d3cfc4e2ae31a1cbd0026800026\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"deebf79ecae13182bd\",\n \"eff3ffbdd7e76baed62171b5\",\n \"eff3ffbdd7e76baed63182bd08519c\",\n \"eff3ffc6dbef9ecae16baed63182bd08519c\",\n \"eff3ffc6dbef9ecae16baed64292c62171b5084594\",\n \"f7fbffdeebf7c6dbef9ecae16baed64292c62171b5084594\",\n \"f7fbffdeebf7c6dbef9ecae16baed64292c62171b508519c08306b\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"e5f5e0a1d99b31a354\",\n \"edf8e9bae4b374c476238b45\",\n \"edf8e9bae4b374c47631a354006d2c\",\n \"edf8e9c7e9c0a1d99b74c47631a354006d2c\",\n \"edf8e9c7e9c0a1d99b74c47641ab5d238b45005a32\",\n \"f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45005a32\",\n \"f7fcf5e5f5e0c7e9c0a1d99b74c47641ab5d238b45006d2c00441b\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"f0f0f0bdbdbd636363\",\n \"f7f7f7cccccc969696525252\",\n \"f7f7f7cccccc969696636363252525\",\n \"f7f7f7d9d9d9bdbdbd969696636363252525\",\n \"f7f7f7d9d9d9bdbdbd969696737373525252252525\",\n \"fffffff0f0f0d9d9d9bdbdbd969696737373525252252525\",\n \"fffffff0f0f0d9d9d9bdbdbd969696737373525252252525000000\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"efedf5bcbddc756bb1\",\n \"f2f0f7cbc9e29e9ac86a51a3\",\n \"f2f0f7cbc9e29e9ac8756bb154278f\",\n \"f2f0f7dadaebbcbddc9e9ac8756bb154278f\",\n \"f2f0f7dadaebbcbddc9e9ac8807dba6a51a34a1486\",\n \"fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a34a1486\",\n \"fcfbfdefedf5dadaebbcbddc9e9ac8807dba6a51a354278f3f007d\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fee0d2fc9272de2d26\",\n \"fee5d9fcae91fb6a4acb181d\",\n \"fee5d9fcae91fb6a4ade2d26a50f15\",\n \"fee5d9fcbba1fc9272fb6a4ade2d26a50f15\",\n \"fee5d9fcbba1fc9272fb6a4aef3b2ccb181d99000d\",\n \"fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181d99000d\",\n \"fff5f0fee0d2fcbba1fc9272fb6a4aef3b2ccb181da50f1567000d\"\n).map(colors);\n\nexport default ramp(scheme);\n","import colors from \"../colors.js\";\nimport ramp from \"../ramp.js\";\n\nexport var scheme = new Array(3).concat(\n \"fee6cefdae6be6550d\",\n \"feeddefdbe85fd8d3cd94701\",\n \"feeddefdbe85fd8d3ce6550da63603\",\n \"feeddefdd0a2fdae6bfd8d3ce6550da63603\",\n \"feeddefdd0a2fdae6bfd8d3cf16913d948018c2d04\",\n \"fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d948018c2d04\",\n \"fff5ebfee6cefdd0a2fdae6bfd8d3cf16913d94801a636037f2704\"\n).map(colors);\n\nexport default ramp(scheme);\n","export default function(t) {\n t = Math.max(0, Math.min(1, t));\n return \"rgb(\"\n + Math.max(0, Math.min(255, Math.round(-4.54 - t * (35.34 - t * (2381.73 - t * (6402.7 - t * (7024.72 - t * 2710.57))))))) + \", \"\n + Math.max(0, Math.min(255, Math.round(32.49 + t * (170.73 + t * (52.82 - t * (131.46 - t * (176.58 - t * 67.37))))))) + \", \"\n + Math.max(0, Math.min(255, Math.round(81.24 + t * (442.36 - t * (2482.43 - t * (6167.24 - t * (6614.94 - t * 2475.67)))))))\n + \")\";\n}\n","import {cubehelix} from \"d3-color\";\nimport {interpolateCubehelixLong} from \"d3-interpolate\";\n\nexport default interpolateCubehelixLong(cubehelix(300, 0.5, 0.0), cubehelix(-240, 0.5, 1.0));\n","import {cubehelix} from \"d3-color\";\nimport {interpolateCubehelixLong} from \"d3-interpolate\";\n\nexport var warm = interpolateCubehelixLong(cubehelix(-100, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\nexport var cool = interpolateCubehelixLong(cubehelix(260, 0.75, 0.35), cubehelix(80, 1.50, 0.8));\n\nvar c = cubehelix();\n\nexport default function(t) {\n if (t < 0 || t > 1) t -= Math.floor(t);\n var ts = Math.abs(t - 0.5);\n c.h = 360 * t - 100;\n c.s = 1.5 - 1.5 * ts;\n c.l = 0.8 - 0.9 * ts;\n return c + \"\";\n}\n","import {rgb} from \"d3-color\";\n\nvar c = rgb(),\n pi_1_3 = Math.PI / 3,\n pi_2_3 = Math.PI * 2 / 3;\n\nexport default function(t) {\n var x;\n t = (0.5 - t) * Math.PI;\n c.r = 255 * (x = Math.sin(t)) * x;\n c.g = 255 * (x = Math.sin(t + pi_1_3)) * x;\n c.b = 255 * (x = Math.sin(t + pi_2_3)) * x;\n return c + \"\";\n}\n","export default function(t) {\n t = Math.max(0, Math.min(1, t));\n return \"rgb(\"\n + Math.max(0, Math.min(255, Math.round(34.61 + t * (1172.33 - t * (10793.56 - t * (33300.12 - t * (38394.49 - t * 14825.05))))))) + \", \"\n + Math.max(0, Math.min(255, Math.round(23.31 + t * (557.33 + t * (1225.33 - t * (3574.96 - t * (1073.77 + t * 707.56))))))) + \", \"\n + Math.max(0, Math.min(255, Math.round(27.2 + t * (3211.1 - t * (15327.97 - t * (27814 - t * (22569.18 - t * 6838.66)))))))\n + \")\";\n}\n","import colors from \"../colors.js\";\n\nfunction ramp(range) {\n var n = range.length;\n return function(t) {\n return range[Math.max(0, Math.min(n - 1, Math.floor(t * n)))];\n };\n}\n\nexport default ramp(colors(\"44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725\"));\n\nexport var magma = ramp(colors(\"00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf\"));\n\nexport var inferno = ramp(colors(\"00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4\"));\n\nexport var plasma = ramp(colors(\"0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921\"));\n","export default function(x) {\n return function constant() {\n return x;\n };\n}\n","export const abs = Math.abs;\nexport const atan2 = Math.atan2;\nexport const cos = Math.cos;\nexport const max = Math.max;\nexport const min = Math.min;\nexport const sin = Math.sin;\nexport const sqrt = Math.sqrt;\n\nexport const epsilon = 1e-12;\nexport const pi = Math.PI;\nexport const halfPi = pi / 2;\nexport const tau = 2 * pi;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x >= 1 ? halfPi : x <= -1 ? -halfPi : Math.asin(x);\n}\n","function Linear(context) {\n this._context = context;\n}\n\nLinear.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // falls through\n default: this._context.lineTo(x, y); break;\n }\n }\n};\n\nexport default function(context) {\n return new Linear(context);\n}\n","export function x(p) {\n return p[0];\n}\n\nexport function y(p) {\n return p[1];\n}\n","import array from \"./array.js\";\nimport constant from \"./constant.js\";\nimport curveLinear from \"./curve/linear.js\";\nimport {withPath} from \"./path.js\";\nimport {x as pointX, y as pointY} from \"./point.js\";\n\nexport default function(x, y) {\n var defined = constant(true),\n context = null,\n curve = curveLinear,\n output = null,\n path = withPath(line);\n\n x = typeof x === \"function\" ? x : (x === undefined) ? pointX : constant(x);\n y = typeof y === \"function\" ? y : (y === undefined) ? pointY : constant(y);\n\n function line(data) {\n var i,\n n = (data = array(data)).length,\n d,\n defined0 = false,\n buffer;\n\n if (context == null) output = curve(buffer = path());\n\n for (i = 0; i <= n; ++i) {\n if (!(i < n && defined(d = data[i], i, data)) === defined0) {\n if (defined0 = !defined0) output.lineStart();\n else output.lineEnd();\n }\n if (defined0) output.point(+x(d, i, data), +y(d, i, data));\n }\n\n if (buffer) return output = null, buffer + \"\" || null;\n }\n\n line.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), line) : x;\n };\n\n line.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), line) : y;\n };\n\n line.defined = function(_) {\n return arguments.length ? (defined = typeof _ === \"function\" ? _ : constant(!!_), line) : defined;\n };\n\n line.curve = function(_) {\n return arguments.length ? (curve = _, context != null && (output = curve(context)), line) : curve;\n };\n\n line.context = function(_) {\n return arguments.length ? (_ == null ? context = output = null : output = curve(context = _), line) : context;\n };\n\n return line;\n}\n","import {Path} from \"d3-path\";\n\nexport function withPath(shape) {\n let digits = 3;\n\n shape.digits = function(_) {\n if (!arguments.length) return digits;\n if (_ == null) {\n digits = null;\n } else {\n const d = Math.floor(_);\n if (!(d >= 0)) throw new RangeError(`invalid digits: ${_}`);\n digits = d;\n }\n return shape;\n };\n\n return () => new Path(digits);\n}\n","export var slice = Array.prototype.slice;\n\nexport default function(x) {\n return typeof x === \"object\" && \"length\" in x\n ? x // Array, TypedArray, NodeList, array-like\n : Array.from(x); // Map, Set, iterable, string, or anything else\n}\n","import pointRadial from \"../pointRadial.js\";\n\nclass Bump {\n constructor(context, x) {\n this._context = context;\n this._x = x;\n }\n areaStart() {\n this._line = 0;\n }\n areaEnd() {\n this._line = NaN;\n }\n lineStart() {\n this._point = 0;\n }\n lineEnd() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n }\n point(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: {\n this._point = 1;\n if (this._line) this._context.lineTo(x, y);\n else this._context.moveTo(x, y);\n break;\n }\n case 1: this._point = 2; // falls through\n default: {\n if (this._x) this._context.bezierCurveTo(this._x0 = (this._x0 + x) / 2, this._y0, this._x0, y, x, y);\n else this._context.bezierCurveTo(this._x0, this._y0 = (this._y0 + y) / 2, x, this._y0, x, y);\n break;\n }\n }\n this._x0 = x, this._y0 = y;\n }\n}\n\nclass BumpRadial {\n constructor(context) {\n this._context = context;\n }\n lineStart() {\n this._point = 0;\n }\n lineEnd() {}\n point(x, y) {\n x = +x, y = +y;\n if (this._point === 0) {\n this._point = 1;\n } else {\n const p0 = pointRadial(this._x0, this._y0);\n const p1 = pointRadial(this._x0, this._y0 = (this._y0 + y) / 2);\n const p2 = pointRadial(x, this._y0);\n const p3 = pointRadial(x, y);\n this._context.moveTo(...p0);\n this._context.bezierCurveTo(...p1, ...p2, ...p3);\n }\n this._x0 = x, this._y0 = y;\n }\n}\n\nexport function bumpX(context) {\n return new Bump(context, true);\n}\n\nexport function bumpY(context) {\n return new Bump(context, false);\n}\n\nexport function bumpRadial(context) {\n return new BumpRadial(context);\n}\n","import {min, sqrt} from \"../math.js\";\n\nconst sqrt3 = sqrt(3);\n\nexport default {\n draw(context, size) {\n const r = sqrt(size + min(size / 28, 0.75)) * 0.59436;\n const t = r / 2;\n const u = t * sqrt3;\n context.moveTo(0, r);\n context.lineTo(0, -r);\n context.moveTo(-u, -t);\n context.lineTo(u, t);\n context.moveTo(-u, t);\n context.lineTo(u, -t);\n }\n};\n","import {pi, sqrt, tau} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size / pi);\n context.moveTo(r, 0);\n context.arc(0, 0, r, 0, tau);\n }\n};\n","import {sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size / 5) / 2;\n context.moveTo(-3 * r, -r);\n context.lineTo(-r, -r);\n context.lineTo(-r, -3 * r);\n context.lineTo(r, -3 * r);\n context.lineTo(r, -r);\n context.lineTo(3 * r, -r);\n context.lineTo(3 * r, r);\n context.lineTo(r, r);\n context.lineTo(r, 3 * r);\n context.lineTo(-r, 3 * r);\n context.lineTo(-r, r);\n context.lineTo(-3 * r, r);\n context.closePath();\n }\n};\n","import {sqrt} from \"../math.js\";\n\nconst tan30 = sqrt(1 / 3);\nconst tan30_2 = tan30 * 2;\n\nexport default {\n draw(context, size) {\n const y = sqrt(size / tan30_2);\n const x = y * tan30;\n context.moveTo(0, -y);\n context.lineTo(x, 0);\n context.lineTo(0, y);\n context.lineTo(-x, 0);\n context.closePath();\n }\n};\n","import {sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size) * 0.62625;\n context.moveTo(0, -r);\n context.lineTo(r, 0);\n context.lineTo(0, r);\n context.lineTo(-r, 0);\n context.closePath();\n }\n};\n","import {min, sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size - min(size / 7, 2)) * 0.87559;\n context.moveTo(-r, 0);\n context.lineTo(r, 0);\n context.moveTo(0, r);\n context.lineTo(0, -r);\n }\n};\n","import {sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const w = sqrt(size);\n const x = -w / 2;\n context.rect(x, x, w, w);\n }\n};\n","import {sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size) * 0.4431;\n context.moveTo(r, r);\n context.lineTo(r, -r);\n context.lineTo(-r, -r);\n context.lineTo(-r, r);\n context.closePath();\n }\n};\n","import {sin, cos, sqrt, pi, tau} from \"../math.js\";\n\nconst ka = 0.89081309152928522810;\nconst kr = sin(pi / 10) / sin(7 * pi / 10);\nconst kx = sin(tau / 10) * kr;\nconst ky = -cos(tau / 10) * kr;\n\nexport default {\n draw(context, size) {\n const r = sqrt(size * ka);\n const x = kx * r;\n const y = ky * r;\n context.moveTo(0, -r);\n context.lineTo(x, y);\n for (let i = 1; i < 5; ++i) {\n const a = tau * i / 5;\n const c = cos(a);\n const s = sin(a);\n context.lineTo(s * r, -c * r);\n context.lineTo(c * x - s * y, s * x + c * y);\n }\n context.closePath();\n }\n};\n","import {sqrt} from \"../math.js\";\n\nconst sqrt3 = sqrt(3);\n\nexport default {\n draw(context, size) {\n const y = -sqrt(size / (sqrt3 * 3));\n context.moveTo(0, y * 2);\n context.lineTo(-sqrt3 * y, -y);\n context.lineTo(sqrt3 * y, -y);\n context.closePath();\n }\n};\n","import {sqrt} from \"../math.js\";\n\nconst sqrt3 = sqrt(3);\n\nexport default {\n draw(context, size) {\n const s = sqrt(size) * 0.6824;\n const t = s / 2;\n const u = (s * sqrt3) / 2; // cos(Math.PI / 6)\n context.moveTo(0, -s);\n context.lineTo(u, t);\n context.lineTo(-u, t);\n context.closePath();\n }\n};\n","import {sqrt} from \"../math.js\";\n\nconst c = -0.5;\nconst s = sqrt(3) / 2;\nconst k = 1 / sqrt(12);\nconst a = (k / 2 + 1) * 3;\n\nexport default {\n draw(context, size) {\n const r = sqrt(size / a);\n const x0 = r / 2, y0 = r * k;\n const x1 = x0, y1 = r * k + r;\n const x2 = -x1, y2 = y1;\n context.moveTo(x0, y0);\n context.lineTo(x1, y1);\n context.lineTo(x2, y2);\n context.lineTo(c * x0 - s * y0, s * x0 + c * y0);\n context.lineTo(c * x1 - s * y1, s * x1 + c * y1);\n context.lineTo(c * x2 - s * y2, s * x2 + c * y2);\n context.lineTo(c * x0 + s * y0, c * y0 - s * x0);\n context.lineTo(c * x1 + s * y1, c * y1 - s * x1);\n context.lineTo(c * x2 + s * y2, c * y2 - s * x2);\n context.closePath();\n }\n};\n","import {min, sqrt} from \"../math.js\";\n\nexport default {\n draw(context, size) {\n const r = sqrt(size - min(size / 6, 1.7)) * 0.6189;\n context.moveTo(-r, -r);\n context.lineTo(r, r);\n context.moveTo(-r, r);\n context.lineTo(r, -r);\n }\n};\n","import constant from \"./constant.js\";\nimport {withPath} from \"./path.js\";\nimport asterisk from \"./symbol/asterisk.js\";\nimport circle from \"./symbol/circle.js\";\nimport cross from \"./symbol/cross.js\";\nimport diamond from \"./symbol/diamond.js\";\nimport diamond2 from \"./symbol/diamond2.js\";\nimport plus from \"./symbol/plus.js\";\nimport square from \"./symbol/square.js\";\nimport square2 from \"./symbol/square2.js\";\nimport star from \"./symbol/star.js\";\nimport triangle from \"./symbol/triangle.js\";\nimport triangle2 from \"./symbol/triangle2.js\";\nimport wye from \"./symbol/wye.js\";\nimport times from \"./symbol/times.js\";\n\n// These symbols are designed to be filled.\nexport const symbolsFill = [\n circle,\n cross,\n diamond,\n square,\n star,\n triangle,\n wye\n];\n\n// These symbols are designed to be stroked (with a width of 1.5px and round caps).\nexport const symbolsStroke = [\n circle,\n plus,\n times,\n triangle2,\n asterisk,\n square2,\n diamond2\n];\n\nexport default function Symbol(type, size) {\n let context = null,\n path = withPath(symbol);\n\n type = typeof type === \"function\" ? type : constant(type || circle);\n size = typeof size === \"function\" ? size : constant(size === undefined ? 64 : +size);\n\n function symbol() {\n let buffer;\n if (!context) context = buffer = path();\n type.apply(this, arguments).draw(context, +size.apply(this, arguments));\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n symbol.type = function(_) {\n return arguments.length ? (type = typeof _ === \"function\" ? _ : constant(_), symbol) : type;\n };\n\n symbol.size = function(_) {\n return arguments.length ? (size = typeof _ === \"function\" ? _ : constant(+_), symbol) : size;\n };\n\n symbol.context = function(_) {\n return arguments.length ? (context = _ == null ? null : _, symbol) : context;\n };\n\n return symbol;\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n (2 * that._x0 + that._x1) / 3,\n (2 * that._y0 + that._y1) / 3,\n (that._x0 + 2 * that._x1) / 3,\n (that._y0 + 2 * that._y1) / 3,\n (that._x0 + 4 * that._x1 + x) / 6,\n (that._y0 + 4 * that._y1 + y) / 6\n );\n}\n\nexport function Basis(context) {\n this._context = context;\n}\n\nBasis.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 3: point(this, this._x1, this._y1); // falls through\n case 2: this._context.lineTo(this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new Basis(context);\n}\n","import noop from \"../noop.js\";\nimport {point} from \"./basis.js\";\n\nfunction BasisClosed(context) {\n this._context = context;\n}\n\nBasisClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x2, this._y2);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);\n this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x2, this._y2);\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x2 = x, this._y2 = y; break;\n case 1: this._point = 2; this._x3 = x, this._y3 = y; break;\n case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new BasisClosed(context);\n}\n","import {point} from \"./basis.js\";\n\nfunction BasisOpen(context) {\n this._context = context;\n}\n\nBasisOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new BasisOpen(context);\n}\n","import {Basis} from \"./basis.js\";\n\nfunction Bundle(context, beta) {\n this._basis = new Basis(context);\n this._beta = beta;\n}\n\nBundle.prototype = {\n lineStart: function() {\n this._x = [];\n this._y = [];\n this._basis.lineStart();\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n j = x.length - 1;\n\n if (j > 0) {\n var x0 = x[0],\n y0 = y[0],\n dx = x[j] - x0,\n dy = y[j] - y0,\n i = -1,\n t;\n\n while (++i <= j) {\n t = i / j;\n this._basis.point(\n this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),\n this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)\n );\n }\n }\n\n this._x = this._y = null;\n this._basis.lineEnd();\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n};\n\nexport default (function custom(beta) {\n\n function bundle(context) {\n return beta === 1 ? new Basis(context) : new Bundle(context, beta);\n }\n\n bundle.beta = function(beta) {\n return custom(+beta);\n };\n\n return bundle;\n})(0.85);\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import {point} from \"./cardinal.js\";\n\nexport function CardinalOpen(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalOpen(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import {epsilon} from \"../math.js\";\nimport {Cardinal} from \"./cardinal.js\";\n\nexport function point(that, x, y) {\n var x1 = that._x1,\n y1 = that._y1,\n x2 = that._x2,\n y2 = that._y2;\n\n if (that._l01_a > epsilon) {\n var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,\n n = 3 * that._l01_a * (that._l01_a + that._l12_a);\n x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;\n y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;\n }\n\n if (that._l23_a > epsilon) {\n var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,\n m = 3 * that._l23_a * (that._l23_a + that._l12_a);\n x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;\n y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;\n }\n\n that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);\n}\n\nfunction CatmullRom(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRom.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: this.point(this._x2, this._y2); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import {CardinalClosed} from \"./cardinalClosed.js\";\nimport noop from \"../noop.js\";\nimport {point} from \"./catmullRom.js\";\n\nfunction CatmullRomClosed(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRomClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import {CardinalOpen} from \"./cardinalOpen.js\";\nimport {point} from \"./catmullRom.js\";\n\nfunction CatmullRomOpen(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRomOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","function sign(x) {\n return x < 0 ? -1 : 1;\n}\n\n// Calculate the slopes of the tangents (Hermite-type interpolation) based on\n// the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n// Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n// NOV(II), P. 443, 1990.\nfunction slope3(that, x2, y2) {\n var h0 = that._x1 - that._x0,\n h1 = x2 - that._x1,\n s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),\n s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),\n p = (s0 * h1 + s1 * h0) / (h0 + h1);\n return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;\n}\n\n// Calculate a one-sided slope.\nfunction slope2(that, t) {\n var h = that._x1 - that._x0;\n return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;\n}\n\n// According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n// \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n// with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\nfunction point(that, t0, t1) {\n var x0 = that._x0,\n y0 = that._y0,\n x1 = that._x1,\n y1 = that._y1,\n dx = (x1 - x0) / 3;\n that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);\n}\n\nfunction MonotoneX(context) {\n this._context = context;\n}\n\nMonotoneX.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 =\n this._t0 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x1, this._y1); break;\n case 3: point(this, this._t0, slope2(this, this._t0)); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n var t1 = NaN;\n\n x = +x, y = +y;\n if (x === this._x1 && y === this._y1) return; // Ignore coincident points.\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; point(this, slope2(this, t1 = slope3(this, x, y)), t1); break;\n default: point(this, this._t0, t1 = slope3(this, x, y)); break;\n }\n\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n this._t0 = t1;\n }\n}\n\nfunction MonotoneY(context) {\n this._context = new ReflectContext(context);\n}\n\n(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {\n MonotoneX.prototype.point.call(this, y, x);\n};\n\nfunction ReflectContext(context) {\n this._context = context;\n}\n\nReflectContext.prototype = {\n moveTo: function(x, y) { this._context.moveTo(y, x); },\n closePath: function() { this._context.closePath(); },\n lineTo: function(x, y) { this._context.lineTo(y, x); },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }\n};\n\nexport function monotoneX(context) {\n return new MonotoneX(context);\n}\n\nexport function monotoneY(context) {\n return new MonotoneY(context);\n}\n","function Natural(context) {\n this._context = context;\n}\n\nNatural.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = [];\n this._y = [];\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n n = x.length;\n\n if (n) {\n this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);\n if (n === 2) {\n this._context.lineTo(x[1], y[1]);\n } else {\n var px = controlPoints(x),\n py = controlPoints(y);\n for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {\n this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);\n }\n }\n }\n\n if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();\n this._line = 1 - this._line;\n this._x = this._y = null;\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n};\n\n// See https://www.particleincell.com/2012/bezier-splines/ for derivation.\nfunction controlPoints(x) {\n var i,\n n = x.length - 1,\n m,\n a = new Array(n),\n b = new Array(n),\n r = new Array(n);\n a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];\n for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];\n a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];\n for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];\n a[n - 1] = r[n - 1] / b[n - 1];\n for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];\n b[n - 1] = (x[n] + a[n - 1]) / 2;\n for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];\n return [a, b];\n}\n\nexport default function(context) {\n return new Natural(context);\n}\n","function Step(context, t) {\n this._context = context;\n this._t = t;\n}\n\nStep.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = this._y = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // falls through\n default: {\n if (this._t <= 0) {\n this._context.lineTo(this._x, y);\n this._context.lineTo(x, y);\n } else {\n var x1 = this._x * (1 - this._t) + x * this._t;\n this._context.lineTo(x1, this._y);\n this._context.lineTo(x1, y);\n }\n break;\n }\n }\n this._x = x, this._y = y;\n }\n};\n\nexport default function(context) {\n return new Step(context, 0.5);\n}\n\nexport function stepBefore(context) {\n return new Step(context, 0);\n}\n\nexport function stepAfter(context) {\n return new Step(context, 1);\n}\n","export function Transform(k, x, y) {\n this.k = k;\n this.x = x;\n this.y = y;\n}\n\nTransform.prototype = {\n constructor: Transform,\n scale: function(k) {\n return k === 1 ? this : new Transform(this.k * k, this.x, this.y);\n },\n translate: function(x, y) {\n return x === 0 & y === 0 ? this : new Transform(this.k, this.x + this.k * x, this.y + this.k * y);\n },\n apply: function(point) {\n return [point[0] * this.k + this.x, point[1] * this.k + this.y];\n },\n applyX: function(x) {\n return x * this.k + this.x;\n },\n applyY: function(y) {\n return y * this.k + this.y;\n },\n invert: function(location) {\n return [(location[0] - this.x) / this.k, (location[1] - this.y) / this.k];\n },\n invertX: function(x) {\n return (x - this.x) / this.k;\n },\n invertY: function(y) {\n return (y - this.y) / this.k;\n },\n rescaleX: function(x) {\n return x.copy().domain(x.range().map(this.invertX, this).map(x.invert, x));\n },\n rescaleY: function(y) {\n return y.copy().domain(y.range().map(this.invertY, this).map(y.invert, y));\n },\n toString: function() {\n return \"translate(\" + this.x + \",\" + this.y + \") scale(\" + this.k + \")\";\n }\n};\n\nexport var identity = new Transform(1, 0, 0);\n\ntransform.prototype = Transform.prototype;\n\nexport default function transform(node) {\n while (!node.__zoom) if (!(node = node.parentNode)) return identity;\n return node.__zoom;\n}\n","\nimport {\n LitElement,\n css,\n svg,\n unsafeCSS,\n} from 'lit';\nimport * as d3 from 'd3';\n\n/*\n DecidablesElement Base Class - Not intended for instantiation!\n <decidables-element>\n*/\nexport default class DecidablesElement extends LitElement {\n getComputedStyleValue(property) {\n return getComputedStyle(this).getPropertyValue(property).trim();\n }\n\n firstUpdated(changedProperties) {\n super.firstUpdated(changedProperties);\n\n // Use focus highlighting if keyboard is used at all\n d3.select(this.renderRoot.host)\n .classed('keyboard', true)\n .on('mousemove.keyboard touchstart.keyboard', (event) => {\n const element = event.currentTarget;\n d3.select(element.renderRoot.host)\n .classed('keyboard', false)\n .on('mousemove.keyboard touchstart.keyboard', null);\n })\n .on('keydown.keyboard', (event) => {\n const element = event.currentTarget;\n d3.select(element.renderRoot.host)\n .classed('keyboard', true)\n .on('keydown.keyboard mousemove.keyboard touchstart.keyboard', null);\n });\n }\n\n static get greys() {\n const grey = '#999999';\n const greys = {};\n greys.white = '#ffffff';\n greys.light75 = d3.interpolateRgb(grey, '#ffffff')(0.75);\n greys.light50 = d3.interpolateRgb(grey, '#ffffff')(0.5);\n greys.light25 = d3.interpolateRgb(grey, '#ffffff')(0.25);\n greys.grey = grey;\n greys.dark25 = d3.interpolateRgb(grey, '#000000')(0.25);\n greys.dark50 = d3.interpolateRgb(grey, '#000000')(0.5);\n greys.dark75 = d3.interpolateRgb(grey, '#000000')(0.75);\n greys.black = '#000000';\n return greys;\n }\n\n static get shadows() {\n // Material Design elevation styles\n // References:\n // https://github.com/material-components/material-components-web/tree/master/packages/mdc-elevation\n // https://codepen.io/hanger/pen/yOGvQp\n /* eslint-disable key-spacing, object-curly-newline */\n return {\n elevations: [0, 2, 4, 8, 16],\n baselineColor: '#000000',\n baselineColorString: '0, 0, 0',\n inverseBaselineColor: '#FFFFFF',\n inverseBaselineColorString: '255, 255, 255',\n opacityUmbra: 0.2,\n opacityPenumbra: 0.14,\n opacityAmbient: 0.12,\n opacityBoost: 0.2,\n mapUmbra: {// $mdc-elevation-umbra-map\n 0: {x: 0, y: 0, b: 0, s: 0}, // offset-x, offset-y, blur-radius, spread-radius\n 2: {x: 0, y: 3, b: 1, s: -2},\n 4: {x: 0, y: 2, b: 4, s: -1},\n 8: {x: 0, y: 5, b: 5, s: -3},\n 16: {x: 0, y: 8, b: 10, s: -5},\n },\n mapPenumbra: {// $mdc-elevation-penumbra-map\n 0: {x: 0, y: 0, b: 0, s: 0}, // offset-x, offset-y, blur-radius, spread-radius\n 2: {x: 0, y: 2, b: 2, s: 0},\n 4: {x: 0, y: 4, b: 5, s: 0},\n 8: {x: 0, y: 8, b: 10, s: 1},\n 16: {x: 0, y: 16, b: 24, s: 2},\n },\n mapAmbient: {// $mdc-elevation-ambient-map\n 0: {x: 0, y: 0, b: 0, s: 0}, // offset-x, offset-y, blur-radius, spread-radius\n 2: {x: 0, y: 1, b: 5, s: 0},\n 4: {x: 0, y: 1, b: 10, s: 0},\n 8: {x: 0, y: 3, b: 14, s: 2},\n 16: {x: 0, y: 6, b: 30, s: 5},\n },\n };\n /* eslint-enable key-spacing, object-curly-newline */\n }\n\n static cssBoxShadow(elevation, rotate = false, inverse = false) {\n const umbraO = this.shadows.opacityUmbra + this.shadows.opacityBoost;\n const penumbraO = this.shadows.opacityPenumbra + this.shadows.opacityBoost;\n const ambientO = this.shadows.opacityAmbient + this.shadows.opacityBoost;\n\n const umbraC = (inverse)\n ? `rgba(${this.shadows.inverseBaselineColorString}, ${umbraO})`\n : `rgba(${this.shadows.baselineColorString}, ${umbraO})`;\n const penumbraC = (inverse)\n ? `rgba(${this.shadows.inverseBaselineColorString}, ${penumbraO})`\n : `rgba(${this.shadows.baselineColorString}, ${penumbraO})`;\n const ambientC = (inverse)\n ? `rgba(${this.shadows.inverseBaselineColorString}, ${ambientO})`\n : `rgba(${this.shadows.baselineColorString}, ${ambientO})`;\n\n const umbraM = this.shadows.mapUmbra[elevation];\n const penumbraM = this.shadows.mapPenumbra[elevation];\n const ambientM = this.shadows.mapAmbient[elevation];\n\n const umbraS = (rotate)\n ? `${-umbraM.y}px ${umbraM.y / 2}px ${umbraM.b}px ${umbraM.s}px`\n : `${umbraM.y / 2}px ${umbraM.y}px ${umbraM.b}px ${umbraM.s}px`;\n const penumbraS = (rotate)\n ? `${-penumbraM.y}px ${penumbraM.y / 2}px ${penumbraM.b}px ${penumbraM.s}px`\n : `${penumbraM.y / 2}px ${penumbraM.y}px ${penumbraM.b}px ${penumbraM.s}px`;\n const ambientS = (rotate)\n ? `${-ambientM.y}px ${ambientM.y / 2}px ${ambientM.b}px ${ambientM.s}px`\n : `${ambientM.y / 2}px ${ambientM.y}px ${ambientM.b}px ${ambientM.s}px`;\n\n return `${umbraS} ${umbraC}, ${penumbraS} ${penumbraC}, ${ambientS} ${ambientC}`;\n }\n\n static get svgDefs() {\n const shadows = DecidablesElement.shadows; /* eslint-disable-line prefer-destructuring */\n\n const filters = shadows.elevations.map((z) => {\n return `\n <filter id=${`shadow-${z}`} filterUnits=\"userSpaceOnUse\" x=\"-100%\" y=\"-100%\" width=\"200%\" height=\"200%\">\n <feComponentTransfer in=\"SourceAlpha\" result=\"solid\">\n <feFuncA type=\"table\" tableValues=\"0 1 1\"/>\n </feComponentTransfer>\n <feOffset in=\"solid\" result=\"offU\" dx=${shadows.mapUmbra[z].y / 2} dy=${shadows.mapUmbra[z].y} />\n <feOffset in=\"solid\" result=\"offP\" dx=${shadows.mapPenumbra[z].y / 2} dy=${shadows.mapPenumbra[z].y} />\n <feOffset in=\"solid\" result=\"offA\" dx=${shadows.mapAmbient[z].y / 2} dy=${shadows.mapAmbient[z].y} />\n ${(shadows.mapUmbra[z].s === 0)\n ? ''\n : `<feMorphology in=\"offU\" result=\"spreadU\" operator=${(shadows.mapUmbra[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapUmbra[z].s)} />`\n }\n ${(shadows.mapPenumbra[z].s === 0)\n ? ''\n : `<feMorphology in=\"offP\" result=\"spreadP\" operator=${(shadows.mapPenumbra[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapPenumbra[z].s)} />`\n }\n ${(shadows.mapAmbient[z].s === 0)\n ? ''\n : `<feMorphology in=\"offA\" result=\"spreadA\" operator=${(shadows.mapAmbient[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapAmbient[z].s)} />`\n }\n <feGaussianBlur in=${(shadows.mapUmbra[z].s === 0) ? 'offU' : 'spreadU'} result=\"blurU\" stdDeviation=${shadows.mapUmbra[z].b / 2} />\n <feGaussianBlur in=${(shadows.mapPenumbra[z].s === 0) ? 'offP' : 'spreadP'} result=\"blurP\" stdDeviation=${shadows.mapPenumbra[z].b / 2} />\n <feGaussianBlur in=${(shadows.mapAmbient[z].s === 0) ? 'offA' : 'spreadA'} result=\"blurA\" stdDeviation=${shadows.mapAmbient[z].b / 2} />\n <feFlood in=\"SourceGraphic\" result=\"opU\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityUmbra + shadows.opacityBoost} />\n <feFlood in=\"SourceGraphic\" result=\"opP\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityPenumbra + shadows.opacityBoost} />\n <feFlood in=\"SourceGraphic\" result=\"opA\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityAmbient + shadows.opacityBoost} />\n <feComposite in=\"opU\" in2=\"blurU\" result=\"shU\" operator=\"in\" />\n <feComposite in=\"opP\" in2=\"blurP\" result=\"shP\" operator=\"in\" />\n <feComposite in=\"opA\" in2=\"blurA\" result=\"shA\" operator=\"in\" />\n <feMorphology in=\"solid\" result=\"smaller\" operator=\"erode\" radius=\"1\" />\n <feComposite in=\"shU\" in2=\"smaller\" result=\"finalU\" operator=\"out\" />\n <feComposite in=\"shP\" in2=\"smaller\" result=\"finalP\" operator=\"out\" />\n <feComposite in=\"shA\" in2=\"smaller\" result=\"finalA\" operator=\"out\" />\n <feMerge>\n <feMergeNode in=\"finalU\" />\n <feMergeNode in=\"finalP\" />\n <feMergeNode in=\"finalA\" />\n <feMergeNode in=\"SourceGraphic\" />\n </feMerge>\n </filter>`;\n });\n\n return `\n <defs>\n ${filters}\n </defs>\n `;\n }\n\n static get svgFilters() {\n const shadows = DecidablesElement.shadows; /* eslint-disable-line prefer-destructuring */\n\n const filters = shadows.elevations.map((z) => {\n return svg`\n <filter id=${`shadow-${z}`} x=\"-250%\" y=\"-250%\" width=\"600%\" height=\"600%\">\n <feComponentTransfer in=\"SourceAlpha\" result=\"solid\">\n <feFuncA type=\"table\" tableValues=\"0 1 1\"/>\n </feComponentTransfer>\n <feOffset in=\"solid\" result=\"offU\" dx=${shadows.mapUmbra[z].y / 2} dy=${shadows.mapUmbra[z].y} />\n <feOffset in=\"solid\" result=\"offP\" dx=${shadows.mapPenumbra[z].y / 2} dy=${shadows.mapPenumbra[z].y} />\n <feOffset in=\"solid\" result=\"offA\" dx=${shadows.mapAmbient[z].y / 2} dy=${shadows.mapAmbient[z].y} />\n ${(shadows.mapUmbra[z].s === 0)\n ? svg``\n : svg`<feMorphology in=\"offU\" result=\"spreadU\" operator=${(shadows.mapUmbra[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapUmbra[z].s)} />`\n }\n ${(shadows.mapPenumbra[z].s === 0)\n ? svg``\n : svg`<feMorphology in=\"offP\" result=\"spreadP\" operator=${(shadows.mapPenumbra[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapPenumbra[z].s)} />`\n }\n ${(shadows.mapAmbient[z].s === 0)\n ? svg``\n : svg`<feMorphology in=\"offA\" result=\"spreadA\" operator=${(shadows.mapAmbient[z].s > 0) ? 'dilate' : 'erode'} radius=${Math.abs(shadows.mapAmbient[z].s)} />`\n }\n <feGaussianBlur in=${(shadows.mapUmbra[z].s === 0) ? 'offU' : 'spreadU'} result=\"blurU\" stdDeviation=${shadows.mapUmbra[z].b / 2} />\n <feGaussianBlur in=${(shadows.mapPenumbra[z].s === 0) ? 'offP' : 'spreadP'} result=\"blurP\" stdDeviation=${shadows.mapPenumbra[z].b / 2} />\n <feGaussianBlur in=${(shadows.mapAmbient[z].s === 0) ? 'offA' : 'spreadA'} result=\"blurA\" stdDeviation=${shadows.mapAmbient[z].b / 2} />\n <feFlood in=\"SourceGraphic\" result=\"opU\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityUmbra + shadows.opacityBoost} />\n <feFlood in=\"SourceGraphic\" result=\"opP\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityPenumbra + shadows.opacityBoost} />\n <feFlood in=\"SourceGraphic\" result=\"opA\" flood-color=${shadows.baselineColor} flood-opacity=${shadows.opacityAmbient + shadows.opacityBoost} />\n <feComposite in=\"opU\" in2=\"blurU\" result=\"shU\" operator=\"in\" />\n <feComposite in=\"opP\" in2=\"blurP\" result=\"shP\" operator=\"in\" />\n <feComposite in=\"opA\" in2=\"blurA\" result=\"shA\" operator=\"in\" />\n <feMorphology in=\"solid\" result=\"smaller\" operator=\"erode\" radius=\"1\" />\n <feComposite in=\"shU\" in2=\"smaller\" result=\"finalU\" operator=\"out\" />\n <feComposite in=\"shP\" in2=\"smaller\" result=\"finalP\" operator=\"out\" />\n <feComposite in=\"shA\" in2=\"smaller\" result=\"finalA\" operator=\"out\" />\n <feMerge>\n <feMergeNode in=\"finalU\" />\n <feMergeNode in=\"finalP\" />\n <feMergeNode in=\"finalA\" />\n <feMergeNode in=\"SourceGraphic\" />\n </feMerge>\n </filter>`;\n });\n\n return svg`\n <svg class=\"defs\">\n <defs>\n ${filters}\n </defs>\n </svg>\n `;\n }\n\n static get styles() {\n return css`\n :host {\n ---shadow-0: var(--shadow-0, ${unsafeCSS(this.cssBoxShadow(0))});\n ---shadow-2: var(--shadow-2, ${unsafeCSS(this.cssBoxShadow(2))});\n ---shadow-4: var(--shadow-4, ${unsafeCSS(this.cssBoxShadow(4))});\n ---shadow-8: var(--shadow-8, ${unsafeCSS(this.cssBoxShadow(8))});\n\n ---color-background: var(--color-background, ${unsafeCSS(this.greys.white)});\n ---color-border: var(--color-border, ${unsafeCSS(this.greys.light75)});\n ---color-text: var(--color-text, ${unsafeCSS(this.greys.dark75)});\n ---color-text-inverse: var(--color-text-inverse, ${unsafeCSS(this.greys.white)});\n ---color-link: var(--color-link, ${unsafeCSS(this.greys.dark25)});\n ---color-element-background: var(--color-element-background, ${unsafeCSS(this.greys.light75)});\n ---color-element-disabled: var(--color-element-disabled, ${unsafeCSS(this.greys.light50)});\n ---color-element-enabled: var(--color-element-enabled, ${unsafeCSS(this.greys.dark25)});\n ---color-element-selected: var(--color-element-selected, ${unsafeCSS(this.greys.grey)});\n ---color-element-border: var(--color-element-border, ${unsafeCSS(this.greys.dark50)});\n ---color-element-emphasis: var(--color-element-emphasis, ${unsafeCSS(this.greys.dark75)});\n\n ---font-family-base: var(--font-family-base, \"Source Sans\", sans-serif);\n ---font-family-math: var(--font-family-math, \"Source Serif\", serif);\n\n ---border: var(--border, 1px solid var(---color-border));\n ---border-radius: var(--border-radius, 0.25rem);\n ---transition-duration: var(--transition-duration, 500ms);\n\n font-family: var(---font-family-base);\n }\n\n :host,\n :host *,\n :host *::before,\n :host *::after {\n box-sizing: border-box;\n }\n\n .math-greek {\n font-family: var(---font-family-math);\n font-style: normal;\n }\n\n .math-num {\n font-family: var(---font-family-base);\n font-style: normal;\n }\n\n .math-var {\n font-family: var(---font-family-math);\n font-style: italic;\n }\n\n .defs {\n display: block;\n\n width: 0;\n height: 0;\n }\n `;\n }\n}\n","\nimport {html, css} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesButton extends DecidablesElement {\n static get properties() {\n return {\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.disabled = false;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n margin: 0.25rem;\n }\n\n button {\n width: 100%;\n height: 100%;\n padding: 0.375rem 0.75rem;\n\n font-family: var(---font-family-base);\n font-size: 1.125rem;\n line-height: 1.5;\n color: var(---color-text-inverse);\n\n border: 0;\n border-radius: var(---border-radius);\n outline: none;\n }\n\n button:disabled {\n background-color: var(--decidables-button-background-color, var(---color-element-disabled));\n outline: none;\n box-shadow: none;\n }\n\n button:enabled {\n cursor: pointer;\n\n background-color: var(--decidables-button-background-color, var(---color-element-enabled));\n outline: none;\n box-shadow: var(---shadow-2);\n }\n\n button:enabled:hover {\n outline: none;\n box-shadow: var(---shadow-4);\n }\n\n button:enabled:active {\n outline: none;\n box-shadow: var(---shadow-8);\n }\n\n :host(.keyboard) button:enabled:focus {\n outline: none;\n box-shadow: var(---shadow-4);\n }\n\n :host(.keyboard) button:enabled:focus:active {\n outline: none;\n box-shadow: var(---shadow-8);\n }\n `,\n ];\n }\n\n render() {\n return html`\n <button ?disabled=${this.disabled}>\n <slot></slot>\n </button>\n `;\n }\n}\n\ncustomElements.define('decidables-button', DecidablesButton);\n","import{nothing as t}from\"../lit-html.js\";\n/**\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const l=l=>null!=l?l:t;export{l as ifDefined};\n//# sourceMappingURL=if-defined.js.map\n","\nimport {ifDefined} from 'lit/directives/if-defined.js'; /* eslint-disable-line import/extensions */\nimport {html, css, unsafeCSS} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesSlider extends DecidablesElement {\n static get properties() {\n return {\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n max: {\n attribute: 'max',\n type: Number,\n reflect: true,\n },\n min: {\n attribute: 'min',\n type: Number,\n reflect: true,\n },\n step: {\n attribute: 'step',\n type: Number,\n reflect: true,\n },\n value: {\n attribute: 'value',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.disabled = false;\n this.max = undefined;\n this.min = undefined;\n this.step = undefined;\n this.value = undefined;\n }\n\n changed(event) {\n this.value = event.target.value;\n this.dispatchEvent(new CustomEvent('change', {\n detail: {\n value: this.value,\n },\n bubbles: true,\n }));\n }\n\n inputted(event) {\n this.value = event.target.value;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n ---shadow-2-rotate: var(--shadow-2-rotate, ${unsafeCSS(this.cssBoxShadow(2, true, false))});\n ---shadow-4-rotate: var(--shadow-4-rotate, ${unsafeCSS(this.cssBoxShadow(4, true, false))});\n ---shadow-8-rotate: var(--shadow-8-rotate, ${unsafeCSS(this.cssBoxShadow(8, true, false))});\n\n display: flex;\n\n flex-direction: column;\n\n align-items: center;\n justify-content: center;\n }\n\n label {\n margin: 0.25rem 0.25rem 0;\n }\n\n .range {\n display: inline-block;\n\n width: 3.5rem;\n height: 4.75rem;\n margin: 0 0.25rem 0.25rem;\n }\n\n decidables-spinner {\n --decidables-spinner-input-width: 3.5rem;\n\n margin: 0 0.25rem 0.25rem;\n }\n\n /* Adapted from http://danielstern.ca/range.css/#/ */\n /* Overall */\n input[type=range] {\n width: 4.75rem;\n height: 3.5rem;\n padding: 0;\n margin: 0;\n\n background-color: unset;\n\n transform: rotate(-90deg);\n transform-origin: 2.375rem 2.375rem;\n\n /* stylelint-disable-next-line property-no-vendor-prefix */\n -webkit-appearance: none;\n }\n\n input[type=range]:enabled {\n cursor: ns-resize;\n }\n\n input[type=range]:focus {\n outline: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-ms-tooltip {\n display: none;\n }\n\n /* Track */\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-webkit-slider-runnable-track {\n width: 100%;\n height: 4px;\n\n background: var(---color-element-disabled);\n border: 0;\n border-radius: 2px;\n box-shadow: none;\n }\n\n input[type=range]:focus::-webkit-slider-runnable-track {\n background: var(---color-element-disabled);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-moz-range-track {\n width: 100%;\n height: 4px;\n\n background: var(---color-element-disabled);\n border: 0;\n border-radius: 2px;\n box-shadow: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-ms-track {\n width: 100%;\n height: 4px;\n\n color: transparent;\n\n background: transparent;\n border-color: transparent;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-ms-fill-lower {\n background: #cccccc;\n /* background: var(---color-element-disabled); */\n border: 0;\n border-radius: 2px;\n box-shadow: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-ms-fill-upper {\n background: #cccccc;\n /* background: var(---color-element-disabled); */\n border: 0;\n border-radius: 2px;\n box-shadow: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:focus::-ms-fill-lower {\n background: var(---color-element-disabled);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:focus::-ms-fill-upper {\n background: var(---color-element-disabled);\n }\n\n /* Thumb */\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-webkit-slider-thumb {\n width: 10px;\n height: 20px;\n margin-top: -8px;\n\n border: 0;\n border-radius: 4px;\n\n /* stylelint-disable-next-line property-no-vendor-prefix */\n -webkit-appearance: none;\n }\n\n input[type=range]:disabled::-webkit-slider-thumb {\n background: var(---color-element-disabled);\n box-shadow: none;\n }\n\n input[type=range]:enabled::-webkit-slider-thumb {\n background: var(---color-element-enabled);\n box-shadow: var(---shadow-2-rotate);\n }\n\n input[type=range]:enabled:hover::-webkit-slider-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n input[type=range]:enabled:active::-webkit-slider-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n\n :host(.keyboard) input[type=range]:enabled:focus::-webkit-slider-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n :host(.keyboard) input[type=range]:focus:active::-webkit-slider-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-moz-range-thumb {\n width: 10px;\n height: 20px;\n\n border: 0;\n border-radius: 4px;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:disabled::-moz-range-thumb {\n background: var(---color-element-disabled);\n box-shadow: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled::-moz-range-thumb {\n background: var(---color-element-enabled);\n box-shadow: var(---shadow-2-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled:hover::-moz-range-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled:active::-moz-range-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n\n :host(.keyboard) input[type=range]:enabled:focus::-moz-range-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n :host(.keyboard) input[type=range]:enabled:focus:active::-moz-range-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]::-ms-thumb {\n width: 10px;\n height: 20px;\n margin-top: 0;\n\n background: #999999;\n /* background: var(---color-element-enabled); */\n border: 0;\n border-radius: 4px;\n box-shadow: var(---shadow-2-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:disabled::-ms-thumb {\n background: var(---color-element-disabled);\n box-shadow: none;\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled::-ms-thumb {\n background: var(---color-element-enabled);\n box-shadow: var(---shadow-2-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled:hover::-ms-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n input[type=range]:enabled:active::-ms-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n\n /* stylelint-disable-next-line no-descending-specificity */ /* stylelint ERROR */\n :host(.keyboard) input[type=range]:enabled:focus::-ms-thumb {\n box-shadow: var(---shadow-4-rotate);\n }\n\n :host(.keyboard) input[type=range]:enabled:focus:active::-ms-thumb {\n box-shadow: var(---shadow-8-rotate);\n }\n `,\n ];\n }\n\n render() {\n return html`\n <label for=\"slider\">\n <slot></slot>\n </label>\n <div class=\"range\">\n <input type=\"range\" id=\"slider\" min=${ifDefined(this.min)} max=${ifDefined(this.max)} step=${ifDefined(this.step)} .value=${this.value} @change=${this.changed.bind(this)} @input=${this.inputted.bind(this)}>\n </div>\n <decidables-spinner min=${ifDefined(this.min)} max=${ifDefined(this.max)} step=${ifDefined(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}></decidables-spinner>\n `;\n }\n}\n\ncustomElements.define('decidables-slider', DecidablesSlider);\n","\nimport {ifDefined} from 'lit/directives/if-defined.js'; /* eslint-disable-line import/extensions */\nimport {html, css} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesSpinner extends DecidablesElement {\n static get properties() {\n return {\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n max: {\n attribute: 'max',\n type: Number,\n reflect: true,\n },\n min: {\n attribute: 'min',\n type: Number,\n reflect: true,\n },\n step: {\n attribute: 'step',\n type: Number,\n reflect: true,\n },\n value: {\n attribute: 'value',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.disabled = false;\n this.max = undefined;\n this.min = undefined;\n this.step = undefined;\n this.value = undefined;\n }\n\n inputted(event) {\n this.value = event.target.value;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n ---decidables-spinner-font-size: var(--decidables-spinner-font-size, 1.125rem);\n ---decidables-spinner-input-width: var(--decidables-spinner-input-width, 4rem);\n ---decidables-spinner-prefix: var(--decidables-spinner-prefix, \"\");\n\n ---decidables-spinner-postfix: var(--decidables-spinner-postfix, \"\");\n ---decidables-spinner-postfix-padding: var(--decidables-spinner-postfix-padding, 0);\n\n display: block;\n }\n\n label {\n position: relative;\n display: flex;\n\n flex-direction: column;\n\n align-items: center;\n\n margin: 0;\n\n font-size: 0.75rem;\n }\n\n label::before {\n position: absolute;\n bottom: 1px;\n left: calc(50% - var(---decidables-spinner-input-width) / 2 + 0.25rem);\n\n font-size: var(---decidables-spinner-font-size);\n line-height: normal;\n\n content: var(---decidables-spinner-prefix);\n }\n\n label::after {\n position: absolute;\n right: 0.25rem;\n bottom: 1px;\n\n font-size: var(---decidables-spinner-font-size);\n line-height: normal;\n\n content: var(---decidables-spinner-postfix);\n }\n\n input[type=number] {\n width: var(---decidables-spinner-input-width);\n padding-right: var(---decidables-spinner-postfix-padding);\n\n font-family: var(---font-family-base);\n font-size: var(---decidables-spinner-font-size);\n color: inherit;\n text-align: right;\n\n background: none;\n border: 0;\n border-radius: 0;\n outline: none;\n box-shadow: var(---shadow-2);\n\n -webkit-appearance: none; /* stylelint-disable-line property-no-vendor-prefix */\n }\n\n input[type=number]:hover {\n box-shadow: var(---shadow-4);\n }\n\n input[type=number]:focus,\n input[type=number]:active {\n box-shadow: var(---shadow-8);\n }\n\n input[type=number]:disabled {\n color: var(---color-text);\n\n border: 0;\n box-shadow: none;\n\n /* HACK: Use correct text color in Safari */\n -webkit-opacity: 1;\n /* HACK: Hide spinners in disabled input for Firefox and Safari */\n -moz-appearance: textfield; /* stylelint-disable-line property-no-vendor-prefix */\n /* HACK: Use correct text color in Safari */\n -webkit-text-fill-color: var(---color-text);\n }\n\n /* HACK: Hide spinners in disabled input for Firefox and Safari */\n input[type=number]:disabled::-webkit-outer-spin-button,\n input[type=number]:disabled::-webkit-inner-spin-button {\n margin: 0;\n -webkit-appearance: none; /* stylelint-disable-line property-no-vendor-prefix */\n }\n `,\n ];\n }\n\n render() {\n return html`\n <label>\n <slot></slot>\n <input ?disabled=${this.disabled} type=\"number\" min=${ifDefined(this.min)} max=${ifDefined(this.max)} step=${ifDefined(this.step)} .value=${this.value} @input=${this.inputted.bind(this)}>\n </label>\n `;\n }\n}\n\ncustomElements.define('decidables-spinner', DecidablesSpinner);\n","\nimport {html, css} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesSwitch extends DecidablesElement {\n static get properties() {\n return {\n checked: {\n attribute: 'checked',\n type: Boolean,\n reflect: true,\n },\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.checked = false;\n this.disabled = false;\n }\n\n changed(event) {\n this.checked = event.target.checked;\n this.dispatchEvent(new CustomEvent('change', {\n detail: {\n checked: this.checked,\n },\n bubbles: true,\n }));\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: flex;\n\n flex-direction: column;\n\n align-items: center;\n justify-content: center;\n }\n\n /* Adapted from https://codepen.io/guuslieben/pen/YyPRVP */\n input[type=checkbox] {\n /* visuallyhidden: https://github.com/h5bp/html5-boilerplate/blob/master/dist/doc/css.md */\n position: absolute;\n\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0 0 0 0);\n\n white-space: nowrap;\n\n border: 0;\n clip-path: inset(100%); /* May cause a performance issue: https://github.com/h5bp/html5-boilerplate/issues/2021 */\n }\n\n input[type=checkbox] + label {\n order: 1;\n\n margin: 0 0.25rem 0.25rem;\n\n font-weight: 400;\n }\n\n input[type=checkbox] + label + label {\n position: relative;\n\n min-width: 24px;\n padding: 0 0 36px;\n margin: 0.25rem 0.25rem 0;\n\n font-weight: 400;\n\n outline: none;\n }\n\n input[type=checkbox] + label + label::before,\n input[type=checkbox] + label + label::after {\n position: absolute;\n\n left: 50%;\n\n margin: 0;\n\n content: \"\";\n\n outline: 0;\n\n transition: all var(---transition-duration) ease;\n transform: translate(-50%, 0);\n }\n\n input[type=checkbox] + label + label::before {\n bottom: 1px;\n\n width: 8px;\n height: 34px;\n\n background-color: var(---color-element-disabled);\n border-radius: 4px;\n }\n\n input[type=checkbox] + label + label::after {\n bottom: 0;\n\n width: 18px;\n height: 18px;\n\n background-color: var(---color-element-enabled);\n border-radius: 50%;\n box-shadow: var(---shadow-2);\n }\n\n input[type=checkbox]:checked + label + label::after {\n transform: translate(-50%, -100%);\n }\n\n input[type=checkbox]:disabled + label + label::after {\n background-color: var(---color-element-disabled);\n box-shadow: none;\n }\n\n input[type=checkbox]:enabled + label,\n input[type=checkbox]:enabled + label + label {\n cursor: pointer;\n }\n\n input[type=checkbox]:enabled + label:hover + label::after,\n input[type=checkbox]:enabled + label + label:hover::after {\n box-shadow: var(---shadow-4);\n }\n\n input[type=checkbox]:enabled + label:active + label::after,\n input[type=checkbox]:enabled + label + label:active::after {\n box-shadow: var(---shadow-8);\n }\n\n /* stylelint-disable-next-line selector-max-compound-selectors */\n :host(.keyboard) input[type=checkbox]:enabled:focus + label + label::after {\n box-shadow: var(---shadow-4);\n }\n\n /* stylelint-disable-next-line selector-max-compound-selectors */\n :host(.keyboard) input[type=checkbox]:enabled:focus + label + label:active::after,\n :host(.keyboard) input[type=checkbox]:enabled:focus:active + label + label::after {\n box-shadow: var(---shadow-8);\n }\n `,\n ];\n }\n\n render() {\n return html`\n <input type=\"checkbox\" id=\"switch\" ?checked=${this.checked} ?disabled=${this.disabled} @change=${this.changed.bind(this)}>\n <label for=\"switch\">\n <slot name=\"off-label\"></slot>\n </label>\n <label for=\"switch\">\n <slot></slot>\n </label>\n `;\n }\n}\n\ncustomElements.define('decidables-switch', DecidablesSwitch);\n","\nimport {html, css} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesToggle extends DecidablesElement {\n static get properties() {\n return {\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.disabled = false;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n fieldset {\n display: flex;\n\n flex-direction: column;\n\n align-items: stretch;\n justify-content: center;\n\n margin: 0.25rem;\n\n border: 0;\n }\n\n legend {\n text-align: center;\n }\n `,\n ];\n }\n\n render() {\n return html`\n <fieldset ?disabled=${this.disabled}>\n <legend><slot name=\"label\"></slot></legend>\n <slot></slot>\n </fieldset>\n `;\n }\n}\n\ncustomElements.define('decidables-toggle', DecidablesToggle);\n","\nimport {html, css} from 'lit';\n\nimport DecidablesElement from './decidables-element';\n\nexport default class DecidablesToggleOption extends DecidablesElement {\n static get properties() {\n return {\n checked: {\n attribute: 'checked',\n type: Boolean,\n reflect: true,\n },\n disabled: {\n attribute: 'disabled',\n type: Boolean,\n reflect: true,\n },\n name: {\n attribute: 'name',\n type: String,\n reflect: true,\n },\n value: {\n attribute: 'value',\n type: String,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.checked = false;\n this.disabled = false;\n this.name = undefined;\n this.value = undefined;\n }\n\n changed(event) {\n this.checked = event.target.checked;\n this.dispatchEvent(new CustomEvent('change', {\n detail: {\n checked: this.checked,\n value: this.value,\n },\n bubbles: true,\n }));\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: flex;\n }\n\n input[type=radio] {\n /* visuallyhidden: https://github.com/h5bp/html5-boilerplate/blob/master/dist/doc/css.md */\n position: absolute;\n\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0 0 0 0);\n\n white-space: nowrap;\n\n border: 0;\n clip-path: inset(100%); /* May cause a performance issue: https://github.com/h5bp/html5-boilerplate/issues/2021 */\n }\n\n input[type=radio] + label {\n width: 100%;\n padding: 0.375rem 0.75rem;\n\n font-family: var(---font-family-base);\n font-size: 1.125rem;\n line-height: 1.5;\n color: var(---color-text-inverse);\n text-align: center;\n\n cursor: pointer;\n\n background-color: var(---color-element-enabled);\n border: 0;\n border-radius: 0;\n outline: none;\n\n box-shadow: var(---shadow-2);\n }\n\n input[type=radio]:checked + label {\n background-color: var(---color-element-selected);\n outline: none;\n box-shadow: var(---shadow-2);\n }\n\n input[type=radio] + label:hover {\n z-index: 1;\n\n outline: none;\n box-shadow: var(---shadow-4);\n }\n\n input[type=radio] + label:active {\n z-index: 2;\n\n outline: none;\n box-shadow: var(---shadow-8);\n }\n\n :host(:first-of-type) input[type=radio] + label {\n border-top-left-radius: 0.25rem;\n border-top-right-radius: 0.25rem;\n }\n\n :host(:last-of-type) input[type=radio] + label {\n border-bottom-right-radius: 0.25rem;\n border-bottom-left-radius: 0.25rem;\n }\n\n :host(.keyboard) input[type=radio]:focus + label {\n z-index: 1;\n\n outline: none;\n box-shadow: var(---shadow-4);\n }\n\n :host(.keyboard) input[type=radio]:focus:checked + label {\n z-index: 1;\n\n background-color: var(---color-element-selected);\n outline: none;\n box-shadow: var(---shadow-4);\n }\n\n :host(.keyboard) input[type=radio]:focus + label:active {\n z-index: 2;\n\n outline: none;\n box-shadow: var(---shadow-8);\n }\n `,\n ];\n }\n\n render() {\n return html`\n <input type=\"radio\" id=\"toggle-option\" name=${this.name} value=${this.value} .checked=${this.checked} @change=${this.changed.bind(this)}>\n <label for=\"toggle-option\">\n <slot></slot>\n </label>\n `;\n }\n}\n\ncustomElements.define('decidables-toggle-option', DecidablesToggleOption);\n","\nimport {\n css,\n unsafeCSS,\n} from 'lit';\nimport * as d3 from 'd3';\n\nimport {DecidablesElement} from '@decidables/decidables-elements';\n\n/*\n DiscountableElement Base Class - Not intended for instantiation!\n <sdt-element>\n*/\nexport default class DiscountableElement extends DecidablesElement {\n static get properties() {\n return {\n interactive: {\n attribute: 'interactive',\n type: Boolean,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n this.interactive = false;\n }\n\n static get colors() {\n return {\n a: d3.schemeSet1[0],\n d: d3.schemeSet1[1],\n k: d3.schemeSet1[2],\n v: d3.schemeSet1[3],\n chosen: d3.schemeSet1[8],\n better: '#4545d0',\n worse: '#f032e6',\n even: '#10dbc9',\n correct: '#ffffff',\n error: '#000000',\n nr: '#cccccc',\n };\n }\n\n static get lights() {\n return Object.keys(DiscountableElement.colors).reduce((acc, cur) => {\n acc[cur] = d3.interpolateRgb(DiscountableElement.colors[cur], '#ffffff')(0.5);\n return acc;\n }, {});\n }\n\n static get darks() {\n return Object.keys(DiscountableElement.colors).reduce((acc, cur) => {\n acc[cur] = d3.interpolateRgb(DiscountableElement.colors[cur], '#000000')(0.5);\n return acc;\n }, {});\n }\n\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n ---color-a: var(--color-a, ${unsafeCSS(this.colors.a)});\n ---color-d: var(--color-d, ${unsafeCSS(this.colors.d)});\n ---color-k: var(--color-k, ${unsafeCSS(this.colors.k)});\n ---color-v: var(--color-v, ${unsafeCSS(this.colors.v)});\n ---color-chosen: var(--color-chosen, ${unsafeCSS(this.colors.chosen)});\n ---color-better: var(--color-better, ${unsafeCSS(this.colors.better)});\n ---color-worse: var(--color-worse, ${unsafeCSS(this.colors.worse)});\n ---color-even: var(--color-even, ${unsafeCSS(this.colors.even)});\n ---color-correct: var(--color-correct, ${unsafeCSS(this.colors.correct)});\n ---color-error: var(--color-error, ${unsafeCSS(this.colors.error)});\n ---color-nr: var(--color-nr, ${unsafeCSS(this.colors.nr)});\n\n ---color-a-light: var(--color-a-light, ${unsafeCSS(this.lights.a)});\n ---color-d-light: var(--color-d-light, ${unsafeCSS(this.lights.d)});\n ---color-k-light: var(--color-k-light, ${unsafeCSS(this.lights.k)});\n ---color-v-light: var(--color-v-light, ${unsafeCSS(this.lights.v)});\n ---color-chosen-light: var(--color-chosen-light, ${unsafeCSS(this.lights.chosen)});\n ---color-better-light: var(--color-better-light, ${unsafeCSS(this.lights.better)});\n ---color-worse-light: var(--color-worse-light, ${unsafeCSS(this.lights.worse)});\n ---color-even-light: var(--color-even-light, ${unsafeCSS(this.lights.even)});\n ---color-correct-light: var(--color-correct-light, ${unsafeCSS(this.lights.correct)});\n ---color-error-light: var(--color-error-light, ${unsafeCSS(this.lights.error)});\n ---color-nr-light: var(--color-nr-light, ${unsafeCSS(this.lights.nr)});\n\n ---color-a-dark: var(--color-a-dark, ${unsafeCSS(this.darks.a)});\n ---color-d-dark: var(--color-d-dark, ${unsafeCSS(this.darks.d)});\n ---color-k-dark: var(--color-k-dark, ${unsafeCSS(this.darks.k)});\n ---color-v-dark: var(--color-v-dark, ${unsafeCSS(this.darks.v)});\n ---color-chosen-dark: var(--color-chosen-dark, ${unsafeCSS(this.darks.chosen)});\n ---color-better-dark: var(--color-better-dark, ${unsafeCSS(this.darks.better)});\n ---color-worse-dark: var(--color-worse-dark, ${unsafeCSS(this.darks.worse)});\n ---color-even-dark: var(--color-even-dark, ${unsafeCSS(this.darks.even)});\n ---color-correct-dark: var(--color-correct-dark, ${unsafeCSS(this.darks.correct)});\n ---color-error-dark: var(--color-error-dark, ${unsafeCSS(this.darks.error)});\n ---color-nr-dark: var(--color-nr-dark, ${unsafeCSS(this.darks.nr)});\n }\n `,\n ];\n }\n}\n","\nimport {html, css} from 'lit';\n\nimport '@decidables/decidables-elements/button';\nimport '@decidables/decidables-elements/slider';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n DiscountableControl element\n <discountable-control>\n\n Attributes:\n\n*/\nexport default class DiscountableControl extends DiscountableElement {\n static get properties() {\n return {\n trials: {\n attribute: 'trials',\n type: Number,\n reflect: true,\n },\n duration: {\n attribute: 'duration',\n type: Number,\n reflect: true,\n },\n run: {\n attribute: 'run',\n type: Boolean,\n reflect: true,\n },\n pause: {\n attribute: 'pause',\n type: Boolean,\n reflect: true,\n },\n reset: {\n attribute: 'reset',\n type: Boolean,\n reflect: true,\n },\n\n state: {\n atribute: false,\n type: String,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.trials = undefined;\n this.duration = undefined;\n this.run = false;\n this.pause = false;\n this.reset = false;\n\n // Properties\n this.states = ['resetted', 'running', 'paused', 'ended'];\n this.state = 'resetted';\n }\n\n setTrials(e) {\n this.trials = e.target.value;\n this.dispatchEvent(new CustomEvent('discountable-control-trials', {\n detail: {\n trials: this.trials,\n },\n bubbles: true,\n }));\n }\n\n setDuration(e) {\n this.duration = e.target.value;\n this.dispatchEvent(new CustomEvent('discountable-control-duration', {\n detail: {\n duration: this.duration,\n },\n bubbles: true,\n }));\n }\n\n doRun() {\n this.state = 'running';\n this.dispatchEvent(new CustomEvent('discountable-control-run', {\n detail: {},\n bubbles: true,\n }));\n }\n\n doPause() {\n this.state = 'paused';\n this.dispatchEvent(new CustomEvent('discountable-control-pause', {\n detail: {},\n bubbles: true,\n }));\n }\n\n doReset() {\n this.state = 'resetted';\n this.dispatchEvent(new CustomEvent('discountable-control-reset', {\n detail: {},\n bubbles: true,\n }));\n }\n\n complete() {\n this.state = 'ended';\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n }\n\n .holder {\n display: flex;\n\n flex-direction: row;\n\n align-items: stretch;\n justify-content: center;\n }\n\n .buttons {\n display: flex;\n\n flex-direction: column;\n\n align-items: stretch;\n justify-content: center;\n }\n `,\n ];\n }\n\n render() {\n return html`\n <div class=\"holder\">\n ${this.trials\n ? html`<decidables-slider min=\"1\" max=\"100\" step=\"1\" .value=${this.trials} @change=${this.setTrials.bind(this)} @input=${this.setTrials.bind(this)}>Trials</decidables-slider>`\n : html``}\n ${this.duration\n ? html`<decidables-slider min=\"10\" max=\"4000\" step=\"10\" .value=${this.duration} @change=${this.setDuration.bind(this)} @input=${this.setDuration.bind(this)}>Duration</decidables-slider>`\n : html``}\n ${this.run || this.pause || this.reset\n ? html`\n <div class=\"buttons\">\n ${this.run\n ? html`<decidables-button name=\"run\" ?disabled=${this.state === 'running' || this.state === 'ended'} @click=${this.doRun.bind(this)}>Run</decidables-button>`\n : html``}\n ${this.pause\n ? html`<decidables-button name=\"pause\" ?disabled=${this.state !== 'running'} @click=${this.doPause.bind(this)}>Pause</decidables-button>`\n : html``}\n ${this.reset\n ? html`<decidables-button name=\"reset\" ?disabled=${this.state === 'resetted'} @click=${this.doReset.bind(this)}>Reset</decidables-button>`\n : html``}\n </div>\n `\n : html``}\n </div>`;\n }\n}\n\ncustomElements.define('discountable-control', DiscountableControl);\n","\nimport {html, css} from 'lit';\n\nimport '@decidables/decidables-elements/button';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n DiscountableResponse element\n <discountable-response>\n\n Attributes:\n\n*/\nexport default class DiscountableResponse extends DiscountableElement {\n static get properties() {\n return {\n trial: {\n attribute: 'trial',\n type: Boolean,\n reflect: true,\n },\n feedback: {\n attribute: 'feedback',\n type: Boolean,\n reflect: true,\n },\n\n state: {\n attribute: false,\n type: String,\n reflect: false,\n },\n trialCount: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n trialTotal: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.trial = false; // Show trial count?\n this.feedback = false; // Show response feedback?\n\n // Properties\n this.states = ['off', 'waiting', 'feedback']; // Possible states\n this.state = 'off'; // Current state\n\n this.trialCount = 0; // Current trial\n this.trialTotal = 0; // Total trials\n\n // Private\n this.as = 0;\n this.ds = 0;\n this.al = 0;\n this.dl = 0;\n this.responses = ['first', 'second', 'nr']; // Possible values of 'response'\n this.response = undefined; // Response for current trial\n }\n\n start(as, ds, al, dl, trial) {\n this.state = 'waiting';\n\n this.as = as;\n this.ds = ds;\n this.al = al;\n this.dl = dl;\n this.trialCount = trial;\n\n this.response = undefined;\n }\n\n stop() {\n this.state = 'feedback';\n if (this.response === undefined) {\n this.response = 'nr';\n }\n }\n\n first() {\n this.responded('first');\n }\n\n second() {\n this.responded('second');\n }\n\n responded(response) {\n this.state = 'feedback';\n this.response = response;\n\n this.dispatchEvent(new CustomEvent('discountable-response', {\n detail: {\n trial: this.trialCount,\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n response: this.response,\n },\n bubbles: true,\n }));\n }\n\n reset() {\n this.state = 'off';\n this.trialCount = 0;\n this.response = undefined;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n }\n\n /* Overall container */\n .holder {\n display: flex;\n\n flex-direction: column;\n }\n\n /* Trial messages */\n .trials {\n display: flex;\n\n flex-direction: column;\n\n justify-content: center;\n }\n\n .trial {\n text-align: center;\n }\n\n .trial .label {\n font-weight: 600;\n }\n\n /* Response buttons */\n .responses {\n display: flex;\n\n flex-direction: row;\n\n align-items: stretch;\n justify-content: center;\n }\n\n .response {\n width: 5.25rem;\n }\n\n .waiting[disabled] {\n --decidables-button-background-color: var(---color-element-enabled);\n }\n\n .selected[disabled][name=\"first\"] {\n --decidables-button-background-color: var(---color-worse);\n }\n\n .selected[disabled][name=\"second\"] {\n --decidables-button-background-color: var(---color-better);\n }\n\n /* Feedback messages */\n .feedbacks {\n display: flex;\n\n flex-direction: row;\n\n justify-content: center;\n }\n\n /* Outcome feedback */\n .feedback {\n display: flex;\n\n flex-direction: column;\n\n align-items: center;\n justify-content: center;\n\n width: 5.25rem;\n height: 3.5rem;\n padding: 0.375rem 0.75rem;\n margin: 0.25rem;\n\n text-align: center;\n\n background-color: var(---color-element-background);\n border: 1px solid var(---color-element-border);\n }\n\n .feedback.first {\n background-color: var(---color-worse-light);\n }\n\n .feedback.second {\n background-color: var(---color-better-light);\n }\n\n .feedback.nr {\n background-color: var(---color-nr-light);\n }\n `,\n ];\n }\n\n render() {\n return html`\n <div class=\"holder\">\n ${(this.trial)\n ? html`\n <div class=\"trials\">\n <div class=\"trial\">\n <span class=\"label\">Trial: </span\n ><span class=\"count\">${this.trialCount}</span\n ><span class=\"of\"> of </span\n ><span class=\"total\">${this.trialTotal}</span>\n </div>\n </div>`\n : html``}\n <div class=\"responses\">\n <decidables-button \n name=\"first\"\n class=\"response ${\n (this.state === 'feedback' && this.response === 'first')\n ? 'selected'\n : (this.state === 'waiting')\n ? 'waiting'\n : ''\n }\"\n ?disabled=${this.state !== 'waiting' || this.interactive !== true}\n @click=${this.first.bind(this)}\n >First</decidables-button>\n <decidables-button \n name=\"second\"\n class=\"response ${\n (this.state === 'feedback' && this.response === 'second')\n ? 'selected'\n : (this.state === 'waiting')\n ? 'waiting'\n : ''\n }\"\n ?disabled=${this.state !== 'waiting' || this.interactive !== true}\n @click=${this.second.bind(this)}\n >Second</decidables-button>\n </div>\n ${this.feedback\n ? html`\n <div class=\"feedbacks\">\n <div class=\"feedback\n ${((this.state === 'feedback') && this.feedback)\n ? this.response\n : ''}\">\n ${((this.state === 'feedback') && this.feedback)\n ? (this.response === 'first')\n ? html`<span class=\"response\">First</span>`\n : (this.response === 'second')\n ? html`<span class=\"response\">Second</span>`\n : html`<span class=\"response\">No<br>Response</span>`\n : ''}\n </div>\n </div>`\n : html``}\n </div>`;\n }\n}\n\ncustomElements.define('discountable-response', DiscountableResponse);\n","/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst t={ATTRIBUTE:1,CHILD:2,PROPERTY:3,BOOLEAN_ATTRIBUTE:4,EVENT:5,ELEMENT:6},e=t=>(...e)=>({_$litDirective$:t,values:e});class i{constructor(t){}get _$AU(){return this._$AM._$AU}_$AT(t,e,i){this._$Ct=t,this._$AM=e,this._$Ci=i}_$AS(t,e){return this.update(t,e)}update(t,e){return this.render(...e)}}export{i as Directive,t as PartType,e as directive};\n//# sourceMappingURL=directive.js.map\n","import{_$LH as o}from\"./lit-html.js\";\n/**\n * @license\n * Copyright 2020 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{I:l}=o,i=o=>null===o||\"object\"!=typeof o&&\"function\"!=typeof o,n={HTML:1,SVG:2},t=(o,l)=>void 0===l?void 0!==(null==o?void 0:o._$litType$):(null==o?void 0:o._$litType$)===l,v=o=>{var l;return null!=(null===(l=null==o?void 0:o._$litType$)||void 0===l?void 0:l.h)},d=o=>void 0!==(null==o?void 0:o._$litDirective$),u=o=>null==o?void 0:o._$litDirective$,e=o=>void 0===o.strings,r=()=>document.createComment(\"\"),c=(o,i,n)=>{var t;const v=o._$AA.parentNode,d=void 0===i?o._$AB:i._$AA;if(void 0===n){const i=v.insertBefore(r(),d),t=v.insertBefore(r(),d);n=new l(i,t,o,o.options)}else{const l=n._$AB.nextSibling,i=n._$AM,u=i!==o;if(u){let l;null===(t=n._$AQ)||void 0===t||t.call(n,o),n._$AM=o,void 0!==n._$AP&&(l=o._$AU)!==i._$AU&&n._$AP(l)}if(l!==d||u){let o=n._$AA;for(;o!==l;){const l=o.nextSibling;v.insertBefore(o,d),o=l}}}return n},f=(o,l,i=o)=>(o._$AI(l,i),o),s={},a=(o,l=s)=>o._$AH=l,m=o=>o._$AH,p=o=>{var l;null===(l=o._$AP)||void 0===l||l.call(o,!1,!0);let i=o._$AA;const n=o._$AB.nextSibling;for(;i!==n;){const o=i.nextSibling;i.remove(),i=o}},h=o=>{o._$AR()};export{n as TemplateResultType,h as clearPart,m as getCommittedValue,u as getDirectiveClass,c as insertPart,v as isCompiledTemplateResult,d as isDirectiveResult,i as isPrimitive,e as isSingleExpression,t as isTemplateResult,p as removePart,f as setChildPartValue,a as setCommittedValue};\n//# sourceMappingURL=directive-helpers.js.map\n","import{isSingleExpression as i}from\"./directive-helpers.js\";import{Directive as t,PartType as e}from\"./directive.js\";export{Directive,PartType,directive}from\"./directive.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const s=(i,t)=>{var e,o;const r=i._$AN;if(void 0===r)return!1;for(const i of r)null===(o=(e=i)._$AO)||void 0===o||o.call(e,t,!1),s(i,t);return!0},o=i=>{let t,e;do{if(void 0===(t=i._$AM))break;e=t._$AN,e.delete(i),i=t}while(0===(null==e?void 0:e.size))},r=i=>{for(let t;t=i._$AM;i=t){let e=t._$AN;if(void 0===e)t._$AN=e=new Set;else if(e.has(i))break;e.add(i),l(t)}};function n(i){void 0!==this._$AN?(o(this),this._$AM=i,r(this)):this._$AM=i}function h(i,t=!1,e=0){const r=this._$AH,n=this._$AN;if(void 0!==n&&0!==n.size)if(t)if(Array.isArray(r))for(let i=e;i<r.length;i++)s(r[i],!1),o(r[i]);else null!=r&&(s(r,!1),o(r));else s(this,i)}const l=i=>{var t,s,o,r;i.type==e.CHILD&&(null!==(t=(o=i)._$AP)&&void 0!==t||(o._$AP=h),null!==(s=(r=i)._$AQ)&&void 0!==s||(r._$AQ=n))};class c extends t{constructor(){super(...arguments),this._$AN=void 0}_$AT(i,t,e){super._$AT(i,t,e),r(this),this.isConnected=i._$AU}_$AO(i,t=!0){var e,r;i!==this.isConnected&&(this.isConnected=i,i?null===(e=this.reconnected)||void 0===e||e.call(this):null===(r=this.disconnected)||void 0===r||r.call(this)),t&&(s(this,i),o(this))}setValue(t){if(i(this._$Ct))this._$Ct._$AI(t,this);else{const i=[...this._$Ct._$AH];i[this._$Ci]=t,this._$Ct._$AI(i,this,0)}}disconnected(){}reconnected(){}}export{c as AsyncDirective};\n//# sourceMappingURL=async-directive.js.map\n","const i=new WeakMap;class t{constructor(t,s){this.startPaused=!1,this.disabled=!1,this.clients=new Set,this.pendingComplete=!1,this.host=t,this.defaultOptions=s.defaultOptions||{},this.startPaused=!!s.startPaused,this.disabled=!!s.disabled,this.onComplete=s.onComplete,i.set(this.host,this)}async add(i){var t,s;this.clients.add(i),this.startPaused&&(null===(t=i.webAnimation)||void 0===t||t.pause()),this.pendingComplete=!0,await i.finished,this.pendingComplete&&!this.isAnimating&&(this.pendingComplete=!1,null===(s=this.onComplete)||void 0===s||s.call(this))}remove(i){this.clients.delete(i)}pause(){this.clients.forEach((i=>{var t;return null===(t=i.webAnimation)||void 0===t?void 0:t.pause()}))}play(){this.clients.forEach((i=>{var t;return null===(t=i.webAnimation)||void 0===t?void 0:t.play()}))}cancel(){this.clients.forEach((i=>{var t;return null===(t=i.webAnimation)||void 0===t?void 0:t.cancel()})),this.clients.clear()}finish(){this.clients.forEach((i=>{var t;return null===(t=i.webAnimation)||void 0===t?void 0:t.finish()})),this.clients.clear()}togglePlay(){this.isPlaying?this.pause():this.play()}get isAnimating(){return this.clients.size>0}get isPlaying(){return Array.from(this.clients).some((i=>{var t;return\"running\"===(null===(t=i.webAnimation)||void 0===t?void 0:t.playState)}))}async finished(){await Promise.all(Array.from(this.clients).map((i=>i.finished)))}}export{t as AnimateController,i as controllerMap};\n//# sourceMappingURL=animate-controller.js.map\n","import{nothing as t}from\"lit/html.js\";import{directive as i,PartType as s}from\"lit/directive.js\";import{AsyncDirective as e}from\"lit/async-directive.js\";import{controllerMap as o}from\"./animate-controller.js\";export{AnimateController}from\"./animate-controller.js\";let h=0;const r=new Map,n=new WeakSet,a=()=>new Promise((t=>requestAnimationFrame(t))),l=[{transform:\"translateY(100%) scale(0)\",opacity:0}],c=[{transform:\"translateY(-100%) scale(0)\",opacity:0}],d=[{transform:\"translateX(-100%) scale(0)\",opacity:0}],u=[{transform:\"translateX(100%) scale(0)\",opacity:0}],v=[{}],m=[{opacity:0}],f=m,p=[{opacity:0},{opacity:1}],y=[{opacity:0},{opacity:.25,offset:.75},{opacity:1}],g=(t,i)=>{const s=t-i;return 0===s?void 0:s},w=(t,i)=>{const s=t/i;return 1===s?void 0:s},N={left:(t,i)=>{const s=g(t,i);return{value:s,transform:null==s||isNaN(s)?void 0:`translateX(${s}px)`}},top:(t,i)=>{const s=g(t,i);return{value:s,transform:null==s||isNaN(s)?void 0:`translateY(${s}px)`}},width:(t,i)=>{let s;0===i&&(i=1,s={width:\"1px\"});const e=w(t,i);return{value:e,overrideFrom:s,transform:null==e||isNaN(e)?void 0:`scaleX(${e})`}},height:(t,i)=>{let s;0===i&&(i=1,s={height:\"1px\"});const e=w(t,i);return{value:e,overrideFrom:s,transform:null==e||isNaN(e)?void 0:`scaleY(${e})`}}},A={duration:333,easing:\"ease-in-out\"},b=[\"left\",\"top\",\"width\",\"height\",\"opacity\",\"color\",\"background\"],j=new WeakMap;class x extends e{constructor(t){if(super(t),this.t=null,this.i=null,this.o=!0,this.shouldLog=!1,t.type===s.CHILD)throw Error(\"The `animate` directive must be used in attribute position.\");this.createFinished()}createFinished(){var t;null===(t=this.resolveFinished)||void 0===t||t.call(this),this.finished=new Promise((t=>{this.h=t}))}async resolveFinished(){var t;null===(t=this.h)||void 0===t||t.call(this),this.h=void 0}render(i){return t}getController(){return o.get(this.l)}isDisabled(){var t;return this.options.disabled||(null===(t=this.getController())||void 0===t?void 0:t.disabled)}update(t,[i]){var s;const e=void 0===this.l;return e&&(this.l=null===(s=t.options)||void 0===s?void 0:s.host,this.l.addController(this),this.element=t.element,j.set(this.element,this)),this.optionsOrCallback=i,(e||\"function\"!=typeof i)&&this.u(i),this.render(i)}u(t){var i,s;t=null!=t?t:{};const e=this.getController();void 0!==e&&((t={...e.defaultOptions,...t}).keyframeOptions={...e.defaultOptions.keyframeOptions,...t.keyframeOptions}),null!==(i=(s=t).properties)&&void 0!==i||(s.properties=b),this.options=t}v(){const t={},i=this.element.getBoundingClientRect(),s=getComputedStyle(this.element);return this.options.properties.forEach((e=>{var o;const h=null!==(o=i[e])&&void 0!==o?o:N[e]?void 0:s[e],r=Number(h);t[e]=isNaN(r)?h+\"\":r})),t}p(){let t,i=!0;return this.options.guard&&(t=this.options.guard(),i=((t,i)=>{if(Array.isArray(t)){if(Array.isArray(i)&&i.length===t.length&&t.every(((t,s)=>t===i[s])))return!1}else if(i===t)return!1;return!0})(t,this.m)),this.o=this.l.hasUpdated&&!this.isDisabled()&&!this.isAnimating()&&i&&this.element.isConnected,this.o&&(this.m=Array.isArray(t)?Array.from(t):t),this.o}hostUpdate(){var t;\"function\"==typeof this.optionsOrCallback&&this.u(this.optionsOrCallback()),this.p()&&(this.g=this.v(),this.t=null!==(t=this.t)&&void 0!==t?t:this.element.parentNode,this.i=this.element.nextSibling)}async hostUpdated(){if(!this.o||!this.element.isConnected||this.options.skipInitial&&!this.isHostRendered)return;let t;this.prepare(),await a;const i=this._(),s=this.A(this.options.keyframeOptions,i),e=this.v();if(void 0!==this.g){const{from:s,to:o}=this.O(this.g,e,i);this.log(\"measured\",[this.g,e,s,o]),t=this.calculateKeyframes(s,o)}else{const s=r.get(this.options.inId);if(s){r.delete(this.options.inId);const{from:o,to:n}=this.O(s,e,i);t=this.calculateKeyframes(o,n),t=this.options.in?[{...this.options.in[0],...t[0]},...this.options.in.slice(1),t[1]]:t,h++,t.forEach((t=>t.zIndex=h))}else this.options.in&&(t=[...this.options.in,{}])}this.animate(t,s)}resetStyles(){var t;void 0!==this.j&&(this.element.setAttribute(\"style\",null!==(t=this.j)&&void 0!==t?t:\"\"),this.j=void 0)}commitStyles(){var t,i;this.j=this.element.getAttribute(\"style\"),null===(t=this.webAnimation)||void 0===t||t.commitStyles(),null===(i=this.webAnimation)||void 0===i||i.cancel()}reconnected(){}async disconnected(){var t;if(!this.o)return;if(void 0!==this.options.id&&r.set(this.options.id,this.g),void 0===this.options.out)return;if(this.prepare(),await a(),null===(t=this.t)||void 0===t?void 0:t.isConnected){const t=this.i&&this.i.parentNode===this.t?this.i:null;if(this.t.insertBefore(this.element,t),this.options.stabilizeOut){const t=this.v();this.log(\"stabilizing out\");const i=this.g.left-t.left,s=this.g.top-t.top;!(\"static\"===getComputedStyle(this.element).position)||0===i&&0===s||(this.element.style.position=\"relative\"),0!==i&&(this.element.style.left=i+\"px\"),0!==s&&(this.element.style.top=s+\"px\")}}const i=this.A(this.options.keyframeOptions);await this.animate(this.options.out,i),this.element.remove()}prepare(){this.createFinished()}start(){var t,i;null===(i=(t=this.options).onStart)||void 0===i||i.call(t,this)}didFinish(t){var i,s;t&&(null===(s=(i=this.options).onComplete)||void 0===s||s.call(i,this)),this.g=void 0,this.animatingProperties=void 0,this.frames=void 0,this.resolveFinished()}_(){const t=[];for(let i=this.element.parentNode;i;i=null==i?void 0:i.parentNode){const s=j.get(i);s&&!s.isDisabled()&&s&&t.push(s)}return t}get isHostRendered(){const t=n.has(this.l);return t||this.l.updateComplete.then((()=>{n.add(this.l)})),t}A(t,i=this._()){const s={...A};return i.forEach((t=>Object.assign(s,t.options.keyframeOptions))),Object.assign(s,t),s}O(t,i,s){t={...t},i={...i};const e=s.map((t=>t.animatingProperties)).filter((t=>void 0!==t));let o=1,h=1;return void 0!==e&&(e.forEach((t=>{t.width&&(o/=t.width),t.height&&(h/=t.height)})),void 0!==t.left&&void 0!==i.left&&(t.left=o*t.left,i.left=o*i.left),void 0!==t.top&&void 0!==i.top&&(t.top=h*t.top,i.top=h*i.top)),{from:t,to:i}}calculateKeyframes(t,i,s=!1){var e;const o={},h={};let r=!1;const n={};for(const s in i){const a=t[s],l=i[s];if(s in N){const t=N[s];if(void 0===a||void 0===l)continue;const i=t(a,l);void 0!==i.transform&&(n[s]=i.value,r=!0,o.transform=`${null!==(e=o.transform)&&void 0!==e?e:\"\"} ${i.transform}`,void 0!==i.overrideFrom&&Object.assign(o,i.overrideFrom))}else a!==l&&void 0!==a&&void 0!==l&&(r=!0,o[s]=a,h[s]=l)}return o.transformOrigin=h.transformOrigin=s?\"center center\":\"top left\",this.animatingProperties=n,r?[o,h]:void 0}async animate(t,i=this.options.keyframeOptions){this.start(),this.frames=t;let s=!1;if(!this.isAnimating()&&!this.isDisabled()&&(this.options.onFrames&&(this.frames=t=this.options.onFrames(this),this.log(\"modified frames\",t)),void 0!==t)){this.log(\"animate\",[t,i]),s=!0,this.webAnimation=this.element.animate(t,i);const e=this.getController();null==e||e.add(this);try{await this.webAnimation.finished}catch(t){}null==e||e.remove(this)}return this.didFinish(s),s}isAnimating(){var t,i;return\"running\"===(null===(t=this.webAnimation)||void 0===t?void 0:t.playState)||(null===(i=this.webAnimation)||void 0===i?void 0:i.pending)}log(t,i){this.shouldLog&&!this.isDisabled()&&console.log(t,this.options.id,i)}}const F=i(x);export{x as Animate,F as animate,a as animationFrame,b as defaultCssProperties,A as defaultKeyframeOptions,f as fade,p as fadeIn,y as fadeInSlow,m as fadeOut,c as flyAbove,l as flyBelow,d as flyLeft,u as flyRight,v as none,N as transformProps};\n//# sourceMappingURL=animate.js.map\n","\n/*\n HTDMath Static Class - Not intended for instantiation!\n\n Variables:\n A = amount\n D = delay\n V = subjective value\n\n k = discount factor\n\n Equations:\n V = A / (1 + kD)\n*/\nexport default class HTDMath {\n static adk2v(a, d, k) {\n return a / (1 + k * d);\n }\n\n static adv2k(a, d, v) {\n return (a - v) / (v * d);\n }\n}\n","\nimport {css} from 'lit';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n HTDEquation Base Class - Not intended for instantiation!\n <cpt-equation>\n*/\nexport default class HTDEquation extends DiscountableElement {\n static get properties() {\n return {\n numeric: {\n attribute: 'numeric',\n type: Boolean,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n this.numeric = false;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: block;\n\n margin: 1rem;\n }\n\n /* Containing <div> */\n .holder {\n display: flex;\n\n flex-direction: row;\n\n justify-content: left;\n }\n\n /* Overall <table> */\n .equation {\n text-align: center;\n white-space: nowrap;\n\n border-collapse: collapse;\n\n border: 0;\n }\n\n /* Modifies <td> */\n .underline {\n border-bottom: 1px solid var(---color-text);\n }\n\n /* Basic <span> and <var> w/modifiers */\n span,\n var {\n padding: 0 0.25rem;\n\n font-style: normal;\n }\n\n var {\n border-radius: var(---border-radius);\n }\n\n .tight {\n padding: 0;\n }\n\n .paren {\n font-size: 150%;\n }\n\n .bracket {\n font-size: 175%;\n }\n\n .brace {\n font-size: 200%;\n }\n\n .addend {\n position: relative;\n display: inline-block;\n }\n\n .comparison {\n position: relative;\n display: inline-block;\n\n font-size: 125%;\n font-weight: 600;\n }\n\n .function {\n display: inline-block;\n\n border-radius: var(---border-radius);\n }\n\n :host([numeric]) .function {\n padding: 0.25rem;\n }\n\n .exp {\n display: inline-block;\n\n font-size: 0.75rem;\n }\n\n .subscript {\n display: inline-block;\n\n font-size: 66.667%;\n }\n\n .summation {\n display: flex;\n\n flex-direction: column;\n\n line-height: 0.8;\n }\n\n .sigma {\n display: inline-block;\n\n font-size: 200%;\n }\n\n /* Input wrapping <label> */\n decidables-spinner {\n --decidables-spinner-input-width: 4rem;\n\n display: inline-block;\n\n padding: 0.125rem 0.375rem 0.375rem;\n\n line-height: 1.5;\n vertical-align: middle;\n\n border-radius: var(---border-radius);\n }\n\n .n {\n --decidables-spinner-input-width: 2rem;\n }\n\n .left {\n text-align: left;\n }\n\n .right {\n text-align: right;\n }\n\n .bottom {\n vertical-align: bottom;\n }\n\n .top {\n vertical-align: top;\n }\n\n /* Color scheme */\n /* .win {\n background: var(---color-better);\n }\n\n .loss {\n background: var(---color-worse);\n }\n\n .sure {\n background: var(---color-even);\n } */\n\n .a {\n background: var(---color-a-light);\n }\n\n .d {\n background: var(---color-d-light);\n }\n\n .k {\n background: var(---color-k-light);\n }\n\n .v {\n background: var(---color-v-light);\n }\n `,\n ];\n }\n}\n","\nimport {html, css} from 'lit';\nimport {animate, fadeIn} from '@lit-labs/motion';\n\nimport '@decidables/decidables-elements/spinner';\nimport HTDMath from '@decidables/discountable-math';\n\nimport HTDEquation from '../equations/htd-equation';\n\n/*\n HTDCalculation element\n <htd-calculation>\n*/\nexport default class HTDCalculation extends HTDEquation {\n static get properties() {\n return {\n numeric: {\n attribute: 'numeric',\n type: Boolean,\n reflect: true,\n },\n\n as: {\n attribute: 'amount-ss',\n type: Number,\n reflect: true,\n },\n ds: {\n attribute: 'delay-ss',\n type: Number,\n reflect: true,\n },\n al: {\n attribute: 'amount-ll',\n type: Number,\n reflect: true,\n },\n dl: {\n attribute: 'delay-ll',\n type: Number,\n reflect: true,\n },\n\n k: {\n attribute: 'k',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n this.numeric = false;\n\n this.as = 20;\n this.ds = 5;\n this.al = 50;\n this.dl = 40;\n\n this.k = 0.1;\n\n this.alignState();\n }\n\n alignState() {\n // Calculate value\n this.vs = HTDMath.adk2v(this.as, this.ds, this.k);\n this.vl = HTDMath.adk2v(this.al, this.dl, this.k);\n // Calculate difference\n this.vDiff = this.vs - this.vl;\n }\n\n sendEvent() {\n this.dispatchEvent(new CustomEvent('htd-calculation-change', {\n detail: {\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n\n k: this.k,\n },\n bubbles: true,\n }));\n }\n\n asInput(e) {\n this.as = parseFloat(e.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n dsInput(e) {\n this.ds = parseFloat(e.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n alInput(e) {\n this.al = parseFloat(e.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n dlInput(e) {\n this.dl = parseFloat(e.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n kInput(e) {\n this.k = parseFloat(e.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n /* :host {\n display: inline-block;\n } */\n\n var {\n border-radius: var(---border-radius);\n }\n\n decidables-spinner {\n border-radius: var(---border-radius);\n }\n `,\n ];\n }\n\n render() {\n this.alignState();\n let as;\n let ds;\n let al;\n let dl;\n let k;\n let vs;\n let vl;\n let vDiff;\n if (this.numeric) {\n as = html`<decidables-spinner class=\"a as\" ?disabled=${!this.interactive} step=\"1\" .value=\"${this.as}\" @input=${this.asInput.bind(this)}>\n <var class=\"math-var\">A<sub class=\"subscript\">ss</sub></var>\n </decidables-spinner>`;\n ds = html`<decidables-spinner class=\"d ds\" ?disabled=${!this.interactive} min=\"0\" step=\"1\" .value=\"${this.ds}\" @input=${this.dsInput.bind(this)}>\n <var class=\"math-var\">D<sub class=\"subscript\">ss</sub></var>\n </decidables-spinner>`;\n al = html`<decidables-spinner class=\"a al\" ?disabled=${!this.interactive} step=\"1\" .value=\"${this.al}\" @input=${this.alInput.bind(this)}>\n <var class=\"math-var\">A<sub class=\"subscript\">ll</sub></var>\n </decidables-spinner>`;\n dl = html`<decidables-spinner class=\"d dl\" ?disabled=${!this.interactive} min=\"0\" step=\"1\" .value=\"${this.dl}\" @input=${this.dlInput.bind(this)}>\n <var class=\"math-var\">D<sub class=\"subscript\">ll</sub></var>\n </decidables-spinner>`;\n k = html`<decidables-spinner class=\"k\" ?disabled=${!this.interactive} min=\"0\" max=\"100\" step=\".001\" .value=\"${this.k}\" @input=${this.kInput.bind(this)}>\n <var class=\"math-var\">k</var>\n </decidables-spinner>`;\n\n vs = html`<decidables-spinner class=\"v vs\" disabled .value=\"${+this.vs.toFixed(2)}\">\n <var class=\"math-var\">V<sub class=\"subscript\">ss</sub></var>\n </decidables-spinner>`;\n vl = html`<decidables-spinner class=\"v vl\" disabled .value=\"${+this.vl.toFixed(2)}\">\n <var class=\"math-var\">V<sub class=\"subscript\">ll</sub></var>\n </decidables-spinner>`;\n vDiff = html`${(this.vDiff > 0)\n ? html`<span class=\"comparison\" ${animate({in: fadeIn})}>&gt;</span>`\n : (this.vDiff < 0)\n ? html`<span class=\"comparison\" ${animate({in: fadeIn})}>&lt;</span>`\n : html`<span class=\"comparison\" ${animate({in: fadeIn})}>=</span>`}`;\n } else {\n as = html`<var class=\"math-var a as\">A<sub class=\"subscript\">ss</sub></var>`;\n ds = html`<var class=\"math-var d ds\">D<sub class=\"subscript\">ss</sub></var>`;\n al = html`<var class=\"math-var a al\">A<sub class=\"subscript\">ll</sub></var>`;\n dl = html`<var class=\"math-var d dl\">D<sub class=\"subscript\">ll</sub></var>`;\n\n k = html`<var class=\"math-var k\">k</var>`;\n\n vs = html`<var class=\"math-var v vs\">V<sub class=\"subscript\">ss</sub></var>`;\n vl = html`<var class=\"math-var v vl\">V<sub class=\"subscript\">ll</sub></var>`;\n vDiff = html`<span class=\"comparison\">≟</span>`;\n }\n const equation = html`\n <tr>\n <td class=\"underline\">\n ${as}\n </td>\n <td rowspan=\"2\">\n ${vDiff}\n </td>\n <td class=\"underline\">\n ${al}\n </td>\n </tr>\n <tr>\n <td class=\"\">\n <span class=\"paren tight\">(</span>1<span class=\"plus\">+</span>${k}${ds}<span class=\"paren tight\">)</span>\n </td>\n <td class=\"\">\n <span class=\"paren tight\">(</span>1<span class=\"plus\">+</span>${k}${dl}<span class=\"paren tight\">)</span>\n </td>\n </tr>\n <tr>\n <td class=\"right\">\n ${vs}\n </td>\n <td>\n ${vDiff}\n </td>\n <td class=\"left\">\n ${vl}\n </td>\n </tr>`;\n return html`\n <div class=\"holder\">\n <table class=\"equation\">\n <tbody>\n ${equation}\n </tbody>\n </table>\n </div>`;\n }\n}\n\ncustomElements.define('htd-calculation', HTDCalculation);\n","\nimport {html, css} from 'lit';\nimport * as d3 from 'd3';\n\nimport HTDMath from '@decidables/discountable-math';\nimport {DecidablesMixinResizeable} from '@decidables/decidables-elements';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n HTDCurves element\n <htd-curves>\n\n Attributes:\n interactive: true/false\n\n a: numeric (-infinity, infinity)\n d: numeric [0, infinity)\n k: numeric [0, infinity)\n label: string\n\n Styles:\n ??\n*/\nexport default class HTDCurves extends DecidablesMixinResizeable(DiscountableElement) {\n static get properties() {\n return {\n a: {\n attribute: 'amount',\n type: Number,\n reflect: true,\n },\n d: {\n attribute: 'delay',\n type: Number,\n reflect: true,\n },\n label: {\n attribute: 'label',\n type: String,\n reflect: true,\n },\n\n k: {\n attribute: 'k',\n type: Number,\n reflect: true,\n },\n\n v: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n\n this.firstUpdate = true;\n this.drag = false;\n\n this.scale = {\n value: {\n min: 0,\n max: 80,\n step: 1,\n round: Math.round,\n },\n time: {\n min: 0,\n max: 100,\n step: 1,\n round: Math.round,\n },\n discount: {\n min: 0,\n max: 100,\n step: 0.001,\n round: (k) => { return +k.toFixed(3); },\n },\n };\n\n this.a = null;\n this.d = null;\n this.label = '';\n this.k = 0.1;\n\n this.options = [\n {\n name: 'default',\n a: this.a,\n d: this.d,\n label: this.label,\n },\n ];\n\n this.as = null;\n this.ds = null;\n this.al = null;\n this.dl = null;\n this.trialCount = null;\n this.response = null;\n\n this.alignState();\n }\n\n alignState() {\n // Default options\n this.options[0].a = this.a;\n this.options[0].d = this.d;\n this.options[0].label = this.label;\n\n // Update values\n this.options.forEach((option) => {\n option.v = HTDMath.adk2v(option.a, option.d, this.k);\n });\n this.v = this.options[0].v;\n }\n\n trial(as, ds, al, dl, trial, response) {\n // Remove the old trial\n if (this.trialCount) this.removeOption(`${this.trialCount}-s`);\n if (this.trialCount) this.removeOption(`${this.trialCount}-l`);\n\n this.as = as;\n this.ds = ds;\n this.al = al;\n this.dl = dl;\n this.trialCount = trial;\n this.response = response;\n\n // Add the new trial\n this.setOption(this.as, this.ds, `${this.trialCount}-s`, 's', true);\n this.setOption(this.al, this.dl, `${this.trialCount}-l`, 'l', true);\n }\n\n // Called to pause trial animations!\n pauseTrial() {\n const lineNew = d3.select(this.renderRoot).selectAll('.lines[data-animating-ease-time-1]');\n lineNew.interrupt('new-1');\n lineNew.interrupt('new-2');\n lineNew.datum((datum) => {\n datum.paused = true;\n return datum;\n });\n }\n\n // Called to resume trial animations!\n resumeTrial() {\n const lineNew = d3.select(this.renderRoot).selectAll('.lines[data-animating-ease-time-1]');\n lineNew.datum((datum) => {\n datum.paused = false;\n return datum;\n });\n this.requestUpdate();\n }\n\n clearOptions() {\n this.options.splice(1);\n\n this.requestUpdate();\n }\n\n removeOption(name) {\n this.options = this.options.filter((option) => {\n return (option.name !== name);\n });\n\n this.requestUpdate();\n }\n\n getOption(name = 'default') {\n return this.options.find((option) => {\n return (option.name === name);\n });\n }\n\n setOption(a, d, name = 'default', label = '', trial = false) {\n if (name === 'default') {\n this.a = a;\n this.d = d;\n this.label = label;\n }\n\n const myOption = this.options.find((option) => {\n return (option.name === name);\n });\n if (myOption === undefined) {\n this.options.push({\n name: name,\n a: a,\n d: d,\n label: label,\n trial: trial,\n new: trial,\n });\n } else {\n myOption.a = a;\n myOption.d = d;\n myOption.label = label;\n }\n\n this.requestUpdate();\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n\n width: 27rem;\n height: 15rem;\n }\n\n .main {\n width: 100%;\n height: 100%;\n }\n\n text {\n /* stylelint-disable property-no-vendor-prefix */\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n }\n\n .background {\n fill: var(---color-element-background);\n stroke: var(---color-element-border);\n stroke-width: 1;\n shape-rendering: crispEdges;\n }\n\n .title-x,\n .title-y {\n font-weight: 600;\n\n fill: currentColor;\n }\n\n .tick {\n font-size: 0.75rem;\n }\n\n .axis-x path,\n .axis-x line,\n .axis-y path,\n .axis-y line {\n stroke: var(---color-element-border);\n /* shape-rendering: crispEdges; */\n }\n\n .curve {\n fill: none;\n stroke: var(---color-element-emphasis);\n stroke-width: 2;\n }\n\n .curve.interactive {\n cursor: nwse-resize;\n \n filter: url(\"#shadow-2\");\n outline: none;\n }\n\n .curve.interactive:hover {\n filter: url(\"#shadow-4\");\n }\n\n .curve.interactive:active {\n filter: url(\"#shadow-8\");\n }\n\n :host(.keyboard) .curve.interactive:focus {\n filter: url(\"#shadow-8\");\n }\n\n .bar {\n fill: none;\n stroke: var(---color-element-emphasis);\n stroke-width: 2;\n }\n\n .bar.interactive {\n cursor: ew-resize;\n \n filter: url(\"#shadow-2\");\n outline: none;\n }\n\n .bar.interactive:hover {\n filter: url(\"#shadow-4\");\n }\n\n .bar.interactive:active {\n filter: url(\"#shadow-8\");\n }\n\n :host(.keyboard) .bar.interactive:focus {\n filter: url(\"#shadow-8\");\n }\n\n .point .mark {\n fill: var(---color-element-emphasis);\n\n r: 6px;\n }\n\n .point .label {\n font-size: 0.75rem;\n\n dominant-baseline: middle;\n text-anchor: middle;\n\n fill: var(---color-text-inverse);\n }\n\n .point.interactive {\n cursor: ns-resize;\n\n filter: url(\"#shadow-2\");\n outline: none;\n\n /* HACK: This gets Safari to correctly apply the filter! */\n /* https://github.com/emilbjorklund/svg-weirdness/issues/27 */\n stroke: #000000;\n stroke-opacity: 0;\n stroke-width: 0;\n }\n\n .point.interactive:hover {\n filter: url(\"#shadow-4\");\n\n /* HACK: This gets Safari to correctly apply the filter! */\n stroke: #ff0000;\n }\n\n .point.interactive:active {\n filter: url(\"#shadow-8\");\n\n /* HACK: This gets Safari to correctly apply the filter! */\n stroke: #00ff00;\n }\n\n :host(.keyboard) .point.interactive:focus {\n filter: url(\"#shadow-8\");\n\n /* HACK: This gets Safari to correctly apply the filter! */\n stroke: #0000ff;\n }\n `,\n ];\n }\n\n render() { /* eslint-disable-line class-methods-use-this */\n return html``;\n // ${DiscountableElement.svgFilters}\n // `;\n }\n\n update(changedProperties) {\n super.update(changedProperties);\n\n this.alignState();\n\n // Bail out if we can't get the width/height\n if (Number.isNaN(this.width) || Number.isNaN(this.height) || Number.isNaN(this.rem)) {\n return;\n }\n\n const hostWidth = this.width;\n const hostHeight = this.height;\n const hostAspectRatio = hostWidth / hostHeight;\n\n const elementAspectRatio = 1.8;\n let elementWidth;\n let elementHeight;\n\n if (hostAspectRatio > elementAspectRatio) {\n elementHeight = hostHeight;\n elementWidth = elementHeight * elementAspectRatio;\n } else {\n elementWidth = hostWidth;\n elementHeight = elementWidth / elementAspectRatio;\n }\n\n const margin = {\n top: 2 * this.rem,\n bottom: 3 * this.rem,\n left: 3 * this.rem,\n right: 2 * this.rem,\n };\n const height = elementHeight - (margin.top + margin.bottom);\n const width = elementWidth - (margin.left + margin.right);\n\n const transitionDuration = parseInt(this.getComputedStyleValue('---transition-duration'), 10);\n\n // X Scale\n const xScale = d3.scaleLinear()\n .domain([this.scale.time.min, this.scale.time.max])\n .range([0, width]);\n\n // Y Scale\n const yScale = d3.scaleLinear()\n .domain([this.scale.value.min, this.scale.value.max])\n .range([height, 0]);\n\n // Line for time/value space\n const line = d3.line()\n .x((datum) => { return xScale(datum.d); })\n .y((datum) => { return yScale(datum.v); });\n\n // Svg\n // DATA-JOIN\n const svgUpdate = d3.select(this.renderRoot).selectAll('.main')\n .data([{\n width: this.width,\n height: this.height,\n rem: this.rem,\n }]);\n // ENTER\n const svgEnter = svgUpdate.enter().append('svg')\n .classed('main', true);\n svgEnter.html(DiscountableElement.svgDefs);\n // MERGE\n const svgMerge = svgEnter.merge(svgUpdate)\n .attr('viewBox', `0 0 ${elementWidth} ${elementHeight}`);\n\n // Plot\n // ENTER\n const plotEnter = svgEnter.append('g')\n .classed('plot', true);\n // MERGE\n const plotMerge = svgMerge.select('.plot')\n .attr('transform', `translate(${margin.left}, ${margin.top})`);\n\n // Clippath\n // ENTER\n plotEnter.append('clipPath')\n .attr('id', 'clip-htd-curves')\n .append('rect');\n // MERGE\n plotMerge.select('clipPath rect')\n .attr('height', height + 1)\n .attr('width', width + 1);\n\n // Underlayer\n // ENTER\n const underlayerEnter = plotEnter.append('g')\n .classed('underlayer', true);\n // MERGE\n const underlayerMerge = plotMerge.select('.underlayer');\n\n // Background\n // ENTER\n underlayerEnter.append('rect')\n .classed('background', true);\n // MERGE\n underlayerMerge.select('.background')\n .attr('height', height)\n .attr('width', width);\n\n // X Axis\n // ENTER\n underlayerEnter.append('g')\n .classed('axis-x', true);\n // MERGE\n const scaleXMerge = underlayerMerge.select('.axis-x')\n .attr('transform', `translate(0, ${yScale(0)})`);\n const scaleXTransition = scaleXMerge.transition()\n .duration(transitionDuration * 2) // Extra long transition!\n .ease(d3.easeCubicOut)\n .call(d3.axisBottom(xScale))\n .attr('font-size', null)\n .attr('font-family', null);\n scaleXTransition.selectAll('line, path')\n .attr('stroke', null);\n\n // X Axis Title\n // ENTER\n const titleXEnter = underlayerEnter.append('text')\n .classed('title-x', true)\n .attr('text-anchor', 'middle');\n titleXEnter.append('tspan')\n .classed('name', true)\n .text('Delay (');\n titleXEnter.append('tspan')\n .classed('math-var d', true)\n .text('D');\n titleXEnter.append('tspan')\n .classed('name', true)\n .text(')');\n // MERGE\n underlayerMerge.select('.title-x')\n .attr('transform', `translate(${(width / 2)}, ${(height + (2.25 * this.rem))})`);\n\n // Y Axis\n // ENTER\n underlayerEnter.append('g')\n .classed('axis-y', true);\n // MERGE\n const scaleYTransition = underlayerMerge.select('.axis-y').transition()\n .duration(transitionDuration * 2) // Extra long transition!\n .ease(d3.easeCubicOut)\n .call(d3.axisLeft(yScale))\n .attr('font-size', null)\n .attr('font-family', null);\n scaleYTransition.selectAll('line, path')\n .attr('stroke', null);\n\n // Y Axis Title\n // ENTER\n const titleYEnter = underlayerEnter.append('text')\n .classed('title-y', true)\n .attr('text-anchor', 'middle');\n titleYEnter.append('tspan')\n .classed('name', true)\n .text('Value (');\n titleYEnter.append('tspan')\n .classed('math-var v', true)\n .text('V');\n titleYEnter.append('tspan')\n .classed('name', true)\n .text(')');\n // MERGE\n underlayerMerge.select('.title-y')\n .attr('transform', `translate(${-2 * this.rem}, ${(height / 2)})rotate(-90)`);\n\n // Content\n // ENTER\n plotEnter.append('g')\n .classed('content', true);\n // MERGE\n const contentMerge = plotMerge.select('.content');\n\n // Options\n // DATA-JOIN\n const optionUpdate = contentMerge.selectAll('.option')\n .data(\n this.options.filter((option) => { return ((option.a !== null) && (option.d !== null)); }),\n (datum) => { return datum.name; },\n );\n // ENTER\n const optionEnter = optionUpdate.enter().append('g')\n .classed('option', true);\n // Curve\n optionEnter.append('path')\n .classed('curve', true)\n .attr('clip-path', 'url(#clip-htd-curves)')\n .attr('d', (datum) => {\n const curve = d3.range(xScale(datum.d), xScale(0), -1).map((range) => {\n return {\n d: xScale.invert(range),\n v: HTDMath.adk2v(\n datum.a,\n datum.d - xScale.invert(range),\n this.k,\n ),\n };\n });\n return line(curve);\n })\n .attr('stroke-dasharray', (datum, index, nodes) => {\n if (datum.trial) {\n const length = nodes[index].getTotalLength();\n return `0,${length}`;\n }\n return 'none';\n });\n // Bar\n optionEnter.append('line')\n .classed('bar', true)\n .attr('x1', (datum) => { return xScale(datum.d); })\n .attr('x2', (datum) => { return xScale(datum.d); })\n .attr('y1', yScale(0))\n .attr('y2', (datum) => { return yScale(datum.a); })\n .attr('stroke-dasharray', (datum, index, nodes) => {\n if (datum.trial) {\n const length = nodes[index].getTotalLength();\n return `0,${length}`;\n }\n return 'none';\n });\n // Point\n const pointEnter = optionEnter.append('g')\n .classed('point', true)\n .attr('transform', (datum) => {\n return `translate(${xScale(datum.d)}, ${yScale(datum.a)})`;\n })\n .attr('opacity', (datum) => {\n if (datum.trial) {\n return 0;\n }\n return 1;\n });\n pointEnter.append('circle')\n .classed('mark', true);\n pointEnter.append('text')\n .classed('label', true);\n // MERGE\n const optionMerge = optionEnter.merge(optionUpdate);\n\n // Interactive options\n // Curve\n optionMerge\n .filter((datum, index, nodes) => {\n return (this.interactive && !nodes[index].classList.contains('interactive'));\n })\n .select('.curve')\n .classed('interactive', true)\n .attr('tabindex', 0)\n // Drag interaction\n .call(d3.drag()\n .subject((event) => {\n return {\n x: event.x,\n y: event.y,\n };\n })\n .on('start', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', true);\n })\n .on('drag', (event, datum) => {\n this.drag = true;\n const dragD = datum.d - xScale.invert(event.x);\n const d = (dragD < 0)\n ? 0\n : (dragD > datum.d)\n ? datum.d\n : dragD;\n const dragV = yScale.invert(event.y);\n const v = (dragV <= 0)\n ? 0.001\n : (dragV > datum.a)\n ? datum.a\n : dragV;\n const k = HTDMath.adv2k(datum.a, d, v);\n this.k = (k < this.scale.discount.min)\n ? this.scale.discount.min\n : (k > this.scale.discount.max)\n ? this.scale.discount.max\n : this.scale.discount.round(k);\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n })\n .on('end', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', false);\n }))\n // Keyboard interaction\n .on('keydown', (event, datum) => {\n if (['ArrowUp', 'ArrowDown', 'ArrowRight', 'ArrowLeft'].includes(event.key)) {\n let keyK = this.k;\n switch (event.key) {\n case 'ArrowUp':\n case 'ArrowLeft':\n keyK *= event.shiftKey ? 0.95 : 0.85;\n break;\n case 'ArrowDown':\n case 'ArrowRight':\n keyK *= event.shiftKey ? 1.05 : 1.15;\n break;\n default:\n // no-op\n }\n keyK = (keyK < this.scale.discount.min)\n ? this.scale.discount.min\n : (keyK > this.scale.discount.max)\n ? this.scale.discount.max\n : this.scale.discount.round(keyK);\n if (keyK !== this.k) {\n this.k = keyK;\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n }\n event.preventDefault();\n }\n });\n // Bar\n optionMerge\n .filter((datum, index, nodes) => {\n return (this.interactive && !datum.trial && !nodes[index].classList.contains('interactive'));\n })\n .select('.bar')\n .classed('interactive', true)\n .attr('tabindex', 0)\n // Drag interaction\n .call(d3.drag()\n .subject((event, datum) => {\n return {\n x: xScale(datum.d),\n y: yScale(datum.a),\n };\n })\n .on('start', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', true);\n })\n .on('drag', (event, datum) => {\n this.drag = true;\n const d = xScale.invert(event.x);\n datum.d = (d < this.scale.time.min)\n ? this.scale.time.min\n : (d > this.scale.time.max)\n ? this.scale.time.max\n : this.scale.time.round(d);\n if (datum.name === 'default') {\n this.d = datum.d;\n }\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n })\n .on('end', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', false);\n }))\n // Keyboard interaction\n .on('keydown', (event, datum) => {\n if (['ArrowLeft', 'ArrowRight'].includes(event.key)) {\n let keyD = datum.d;\n switch (event.key) {\n case 'ArrowRight':\n keyD += event.shiftKey ? 1 : 5;\n break;\n case 'ArrowLeft':\n keyD -= event.shiftKey ? 1 : 5;\n break;\n default:\n // no-op\n }\n keyD = (keyD < this.scale.time.min)\n ? this.scale.time.min\n : ((keyD > this.scale.time.max)\n ? this.scale.time.max\n : keyD);\n if (keyD !== datum.d) {\n datum.d = keyD;\n if (datum.name === 'default') {\n this.d = datum.d;\n }\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n }\n event.preventDefault();\n }\n });\n // Point\n optionMerge\n .filter((datum, index, nodes) => {\n return (this.interactive && !datum.trial && !nodes[index].classList.contains('interactive'));\n })\n .select('.point')\n .classed('interactive', true)\n .attr('tabindex', 0)\n // Drag interaction\n .call(d3.drag()\n .subject((event, datum) => {\n return {\n x: xScale(datum.d),\n y: yScale(datum.a),\n };\n })\n .on('start', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', true);\n })\n .on('drag', (event, datum) => {\n this.drag = true;\n const a = yScale.invert(event.y);\n datum.a = (a < this.scale.value.min)\n ? this.scale.value.min\n : (a > this.scale.value.max)\n ? this.scale.value.max\n : this.scale.value.round(a);\n if (datum.name === 'default') {\n this.a = datum.a;\n }\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n })\n .on('end', (event) => {\n const element = event.currentTarget;\n d3.select(element).classed('dragging', false);\n }))\n // Keyboard interaction\n .on('keydown', (event, datum) => {\n if (['ArrowUp', 'ArrowDown'].includes(event.key)) {\n let keyA = datum.a;\n switch (event.key) {\n case 'ArrowUp':\n keyA += event.shiftKey ? 1 : 5;\n break;\n case 'ArrowDown':\n keyA -= event.shiftKey ? 1 : 5;\n break;\n default:\n // no-op\n }\n keyA = (keyA < this.scale.value.min)\n ? this.scale.value.min\n : ((keyA > this.scale.value.max)\n ? this.scale.value.max\n : keyA);\n if (keyA !== datum.a) {\n datum.a = keyA;\n if (datum.name === 'default') {\n this.a = datum.a;\n }\n this.alignState();\n this.requestUpdate();\n this.dispatchEvent(new CustomEvent('htd-curves-change', {\n detail: {\n name: datum.name,\n a: datum.a,\n d: datum.d,\n k: this.k,\n label: datum.label,\n },\n bubbles: true,\n }));\n }\n event.preventDefault();\n }\n });\n\n // Non-interactive options\n // Curve\n optionMerge\n .filter((datum, index, nodes) => {\n return (!this.interactive && nodes[index].classList.contains('interactive'));\n })\n .select('.curve')\n .classed('interactive', false)\n .attr('tabindex', null)\n .on('drag', null)\n .on('keydown', null);\n // Bar\n optionMerge\n .filter((datum, index, nodes) => {\n return ((!this.interactive || datum.trial) && nodes[index].classList.contains('interactive'));\n })\n .select('.bar')\n .classed('interactive', false)\n .attr('tabindex', null)\n .on('drag', null)\n .on('keydown', null);\n // Point\n optionMerge\n .filter((datum, index, nodes) => {\n return ((!this.interactive || datum.trial) && nodes[index].classList.contains('interactive'));\n })\n .select('.point')\n .classed('interactive', false)\n .attr('tabindex', null)\n .on('drag', null)\n .on('keydown', null);\n\n // Trial Animation\n // Curve\n optionMerge\n .filter((datum) => {\n return (datum.new);\n })\n .select('.curve').transition()\n .duration(transitionDuration)\n .delay(transitionDuration + transitionDuration / 10)\n .ease(d3.easeLinear)\n .attrTween('stroke-dasharray', (datum, index, nodes) => {\n const length = nodes[index].getTotalLength();\n return d3.interpolate(`0,${length}`, `${length},${0}`);\n })\n .on('end', (datum) => {\n datum.new = false;\n this.dispatchEvent(new CustomEvent('discountable-response', {\n detail: {\n trial: this.trialCount,\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n response: this.response,\n },\n bubbles: true,\n }));\n });\n // Bar\n optionMerge\n .filter((datum) => {\n return (datum.new);\n })\n .select('.bar').transition()\n .duration(transitionDuration)\n .ease(d3.easeLinear)\n .attrTween('stroke-dasharray', (datum, index, nodes) => {\n const length = nodes[index].getTotalLength();\n return d3.interpolate(`0,${length}`, `${length},${length}`);\n });\n // Point\n optionMerge\n .filter((datum) => {\n return (datum.new);\n })\n .select('.point').transition()\n .duration(transitionDuration / 10)\n .delay(transitionDuration)\n .ease(d3.easeLinear)\n .attrTween('opacity', () => { return d3.interpolate(0, 1); });\n\n // All options\n optionUpdate.select('.curve').transition()\n .duration(this.drag\n ? 0\n : (this.firstUpdate\n ? (transitionDuration * 2)\n : transitionDuration))\n .ease(d3.easeCubicOut)\n .attrTween('d', (datum, index, elements) => {\n const element = elements[index];\n const interpolateA = d3.interpolate(\n (element.a !== undefined) ? element.a : datum.a,\n datum.a,\n );\n const interpolateD = d3.interpolate(\n (element.d !== undefined) ? element.d : datum.d,\n datum.d,\n );\n return (time) => {\n element.a = interpolateA(time);\n element.d = interpolateD(time);\n const curve = d3.range(xScale(element.d), xScale(0), -1).map((range) => {\n return {\n d: xScale.invert(range),\n v: HTDMath.adk2v(\n element.a,\n element.d - xScale.invert(range),\n this.k,\n ),\n };\n });\n return line(curve);\n };\n });\n optionUpdate.select('.bar').transition()\n .duration(this.drag\n ? 0\n : (this.firstUpdate\n ? (transitionDuration * 2)\n : transitionDuration))\n .ease(d3.easeCubicOut)\n .attrTween('x1', (datum, index, elements) => {\n const element = elements[index];\n const interpolateD = d3.interpolate(\n (element.d !== undefined) ? element.d : datum.d,\n datum.d,\n );\n return (time) => {\n element.d = interpolateD(time);\n return `${xScale(element.d)}`;\n };\n })\n .attrTween('x2', (datum, index, elements) => {\n const element = elements[index];\n const interpolateD = d3.interpolate(\n (element.d !== undefined) ? element.d : datum.d,\n datum.d,\n );\n return (time) => {\n element.d = interpolateD(time);\n return `${xScale(element.d)}`;\n };\n })\n .attrTween('y2', (datum, index, elements) => {\n const element = elements[index];\n const interpolateA = d3.interpolate(\n (element.a !== undefined) ? element.a : datum.a,\n datum.a,\n );\n return (time) => {\n element.a = interpolateA(time);\n return `${yScale(element.a)}`;\n };\n });\n optionUpdate.select('.point').transition()\n .duration(this.drag\n ? 0\n : (this.firstUpdate\n ? (transitionDuration * 2)\n : transitionDuration))\n .ease(d3.easeCubicOut)\n .attrTween('transform', (datum, index, elements) => {\n const element = elements[index];\n const interpolateD = d3.interpolate(\n (element.d !== undefined) ? element.d : datum.d,\n datum.d,\n );\n const interpolateA = d3.interpolate(\n (element.a !== undefined) ? element.a : datum.a,\n datum.a,\n );\n return (time) => {\n element.d = interpolateD(time);\n element.a = interpolateA(time);\n return `translate(${xScale(element.d)}, ${yScale(element.a)})`;\n };\n });\n optionMerge.select('.point .label')\n .text((datum) => { return datum.label; });\n // EXIT\n // NOTE: Could add a transition here\n optionUpdate.exit().remove();\n\n this.drag = false;\n this.firstUpdate = false;\n }\n}\n\ncustomElements.define('htd-curves', HTDCurves);\n","\nexport default function DecidablesMixinResizeable(superClass) {\n return class extends superClass {\n static get properties() {\n return {\n width: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n height: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n rem: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n\n this.width = NaN;\n this.height = NaN;\n this.rem = NaN;\n }\n\n getDimensions() {\n this.width = parseFloat(this.getComputedStyleValue('width'), 10);\n this.height = parseFloat(this.getComputedStyleValue('height'), 10);\n this.rem = parseFloat(getComputedStyle(document.documentElement).getPropertyValue('font-size'), 10);\n }\n\n connectedCallback() {\n super.connectedCallback();\n\n this.resizeObserver = new ResizeObserver(this.getDimensions.bind(this));\n this.resizeObserver.observe(this);\n }\n\n disconnectedCallback() {\n this.resizeObserver.unobserve(this);\n\n super.disconnectedCallback();\n }\n };\n}\n","import {ascending, descending} from \"d3\";\n\nexport function defined(x) {\n return x != null && !Number.isNaN(x);\n}\n\nexport function ascendingDefined(a, b) {\n return +defined(b) - +defined(a) || ascending(a, b);\n}\n\nexport function descendingDefined(a, b) {\n return +defined(b) - +defined(a) || descending(a, b);\n}\n\nexport function nonempty(x) {\n return x != null && `${x}` !== \"\";\n}\n\nexport function finite(x) {\n return isFinite(x) ? x : NaN;\n}\n\nexport function positive(x) {\n return x > 0 && isFinite(x) ? x : NaN;\n}\n\nexport function negative(x) {\n return x < 0 && isFinite(x) ? x : NaN;\n}\n","export default function format(date, fallback) {\n if (!(date instanceof Date)) date = new Date(+date);\n if (isNaN(date)) return typeof fallback === \"function\" ? fallback(date) : fallback;\n const hours = date.getUTCHours();\n const minutes = date.getUTCMinutes();\n const seconds = date.getUTCSeconds();\n const milliseconds = date.getUTCMilliseconds();\n return `${formatYear(date.getUTCFullYear(), 4)}-${pad(date.getUTCMonth() + 1, 2)}-${pad(date.getUTCDate(), 2)}${\n hours || minutes || seconds || milliseconds ? `T${pad(hours, 2)}:${pad(minutes, 2)}${\n seconds || milliseconds ? `:${pad(seconds, 2)}${\n milliseconds ? `.${pad(milliseconds, 3)}` : ``\n }` : ``\n }Z` : ``\n }`;\n}\n\nfunction formatYear(year) {\n return year < 0 ? `-${pad(-year, 6)}`\n : year > 9999 ? `+${pad(year, 6)}`\n : pad(year, 4);\n}\n\nfunction pad(value, width) {\n return `${value}`.padStart(width, \"0\");\n}\n","const re = /^(?:[-+]\\d{2})?\\d{4}(?:-\\d{2}(?:-\\d{2})?)?(?:T\\d{2}:\\d{2}(?::\\d{2}(?:\\.\\d{3})?)?(?:Z|[-+]\\d{2}:?\\d{2})?)?$/;\n\nexport default function parse(string, fallback) {\n if (!re.test(string += \"\")) return typeof fallback === \"function\" ? fallback(string) : fallback;\n return new Date(string);\n}\n","import {bisector, max, pairs, timeFormat, utcFormat} from \"d3\";\nimport {utcSecond, utcMinute, utcHour, unixDay, utcWeek, utcMonth, utcYear} from \"d3\";\nimport {utcMonday, utcTuesday, utcWednesday, utcThursday, utcFriday, utcSaturday, utcSunday} from \"d3\";\nimport {timeSecond, timeMinute, timeHour, timeDay, timeWeek, timeMonth, timeYear} from \"d3\";\nimport {timeMonday, timeTuesday, timeWednesday, timeThursday, timeFriday, timeSaturday, timeSunday} from \"d3\";\nimport {orderof} from \"./options.js\";\n\nconst durationSecond = 1000;\nconst durationMinute = durationSecond * 60;\nconst durationHour = durationMinute * 60;\nconst durationDay = durationHour * 24;\nconst durationWeek = durationDay * 7;\nconst durationMonth = durationDay * 30;\nconst durationYear = durationDay * 365;\n\n// See https://github.com/d3/d3-time/blob/9e8dc940f38f78d7588aad68a54a25b1f0c2d97b/src/ticks.js#L14-L33\nconst tickIntervals = [\n [\"millisecond\", 1],\n [\"2 milliseconds\", 2],\n [\"5 milliseconds\", 5],\n [\"10 milliseconds\", 10],\n [\"20 milliseconds\", 20],\n [\"50 milliseconds\", 50],\n [\"100 milliseconds\", 100],\n [\"200 milliseconds\", 200],\n [\"500 milliseconds\", 500],\n [\"second\", durationSecond],\n [\"5 seconds\", 5 * durationSecond],\n [\"15 seconds\", 15 * durationSecond],\n [\"30 seconds\", 30 * durationSecond],\n [\"minute\", durationMinute],\n [\"5 minutes\", 5 * durationMinute],\n [\"15 minutes\", 15 * durationMinute],\n [\"30 minutes\", 30 * durationMinute],\n [\"hour\", durationHour],\n [\"3 hours\", 3 * durationHour],\n [\"6 hours\", 6 * durationHour],\n [\"12 hours\", 12 * durationHour],\n [\"day\", durationDay],\n [\"2 days\", 2 * durationDay],\n [\"week\", durationWeek],\n [\"2 weeks\", 2 * durationWeek], // https://github.com/d3/d3-time/issues/46\n [\"month\", durationMonth],\n [\"3 months\", 3 * durationMonth],\n [\"6 months\", 6 * durationMonth], // https://github.com/d3/d3-time/issues/46\n [\"year\", durationYear],\n [\"2 years\", 2 * durationYear],\n [\"5 years\", 5 * durationYear],\n [\"10 years\", 10 * durationYear],\n [\"20 years\", 20 * durationYear],\n [\"50 years\", 50 * durationYear],\n [\"100 years\", 100 * durationYear] // TODO generalize to longer time scales\n];\n\nconst durations = new Map([\n [\"second\", durationSecond],\n [\"minute\", durationMinute],\n [\"hour\", durationHour],\n [\"day\", durationDay],\n [\"monday\", durationWeek],\n [\"tuesday\", durationWeek],\n [\"wednesday\", durationWeek],\n [\"thursday\", durationWeek],\n [\"friday\", durationWeek],\n [\"saturday\", durationWeek],\n [\"sunday\", durationWeek],\n [\"week\", durationWeek],\n [\"month\", durationMonth],\n [\"year\", durationYear]\n]);\n\nconst timeIntervals = new Map([\n [\"second\", timeSecond],\n [\"minute\", timeMinute],\n [\"hour\", timeHour],\n [\"day\", timeDay], // https://github.com/d3/d3-time/issues/62\n [\"monday\", timeMonday],\n [\"tuesday\", timeTuesday],\n [\"wednesday\", timeWednesday],\n [\"thursday\", timeThursday],\n [\"friday\", timeFriday],\n [\"saturday\", timeSaturday],\n [\"sunday\", timeSunday],\n [\"week\", timeWeek],\n [\"month\", timeMonth],\n [\"year\", timeYear]\n]);\n\nconst utcIntervals = new Map([\n [\"second\", utcSecond],\n [\"minute\", utcMinute],\n [\"hour\", utcHour],\n [\"day\", unixDay],\n [\"monday\", utcMonday],\n [\"tuesday\", utcTuesday],\n [\"wednesday\", utcWednesday],\n [\"thursday\", utcThursday],\n [\"friday\", utcFriday],\n [\"saturday\", utcSaturday],\n [\"sunday\", utcSunday],\n [\"week\", utcWeek],\n [\"month\", utcMonth],\n [\"year\", utcYear]\n]);\n\n// These hidden fields describe standard intervals so that we can, for example,\n// generalize a scale’s time interval to a larger ticks time interval to reduce\n// the number of displayed ticks. TODO We could instead allow the interval\n// implementation to expose a “generalize” method that returns a larger, aligned\n// interval; that would allow us to move this logic to D3, and allow\n// generalization even when a custom interval is provided.\nexport const intervalDuration = Symbol(\"intervalDuration\");\nexport const intervalType = Symbol(\"intervalType\");\n\n// We greedily mutate D3’s standard intervals on load so that the hidden fields\n// are available even if specified as e.g. d3.utcMonth instead of \"month\".\nfor (const [name, interval] of timeIntervals) {\n interval[intervalDuration] = durations.get(name);\n interval[intervalType] = \"time\";\n}\nfor (const [name, interval] of utcIntervals) {\n interval[intervalDuration] = durations.get(name);\n interval[intervalType] = \"utc\";\n}\n\n// An interleaved array of UTC and local time intervals, in descending order\n// from largest to smallest, used to determine the most specific standard time\n// format for a given array of dates. This is a subset of the tick intervals\n// listed above; we only need the breakpoints where the format changes.\nconst formatIntervals = [\n [\"year\", utcYear, \"utc\"],\n [\"year\", timeYear, \"time\"],\n [\"month\", utcMonth, \"utc\"],\n [\"month\", timeMonth, \"time\"],\n [\"day\", unixDay, \"utc\", 6 * durationMonth],\n [\"day\", timeDay, \"time\", 6 * durationMonth],\n // Below day, local time typically has an hourly offset from UTC and hence the\n // two are aligned and indistinguishable; therefore, we only consider UTC, and\n // we don’t consider these if the domain only has a single value.\n [\"hour\", utcHour, \"utc\", 3 * durationDay],\n [\"minute\", utcMinute, \"utc\", 6 * durationHour],\n [\"second\", utcSecond, \"utc\", 30 * durationMinute]\n];\n\nfunction parseInterval(input, intervals, type) {\n let name = `${input}`.toLowerCase();\n if (name.endsWith(\"s\")) name = name.slice(0, -1); // drop plural\n let period = 1;\n const match = /^(?:(\\d+)\\s+)/.exec(name);\n if (match) {\n name = name.slice(match[0].length);\n period = +match[1];\n }\n switch (name) {\n case \"quarter\":\n name = \"month\";\n period *= 3;\n break;\n case \"half\":\n name = \"month\";\n period *= 6;\n break;\n }\n let interval = intervals.get(name);\n if (!interval) throw new Error(`unknown interval: ${input}`);\n if (period > 1) {\n if (!interval.every) throw new Error(`non-periodic interval: ${name}`);\n interval = interval.every(period);\n interval[intervalDuration] = durations.get(name) * period;\n interval[intervalType] = type;\n }\n return interval;\n}\n\nexport function maybeTimeInterval(interval) {\n return parseInterval(interval, timeIntervals, \"time\");\n}\n\nexport function maybeUtcInterval(interval) {\n return parseInterval(interval, utcIntervals, \"utc\");\n}\n\n// If the given interval is a standard time interval, we may be able to promote\n// it a larger aligned time interval, rather than showing every nth tick.\nexport function generalizeTimeInterval(interval, n) {\n if (!(n > 1)) return; // no need to generalize\n const duration = interval[intervalDuration];\n if (!tickIntervals.some(([, d]) => d === duration)) return; // nonstandard or unknown interval\n if (duration % durationDay === 0 && durationDay < duration && duration < durationMonth) return; // not generalizable\n const [i] = tickIntervals[bisector(([, step]) => Math.log(step)).center(tickIntervals, Math.log(duration * n))];\n return (interval[intervalType] === \"time\" ? maybeTimeInterval : maybeUtcInterval)(i);\n}\n\nfunction formatTimeInterval(name, type, anchor) {\n const format = type === \"time\" ? timeFormat : utcFormat;\n // For tips and legends, use a format that doesn’t require context.\n if (anchor == null) {\n return format(\n name === \"year\"\n ? \"%Y\"\n : name === \"month\"\n ? \"%Y-%m\"\n : name === \"day\"\n ? \"%Y-%m-%d\"\n : name === \"hour\" || name === \"minute\"\n ? \"%Y-%m-%dT%H:%M\"\n : name === \"second\"\n ? \"%Y-%m-%dT%H:%M:%S\"\n : \"%Y-%m-%dT%H:%M:%S.%L\"\n );\n }\n // Otherwise, assume that this is for axis ticks.\n const template = getTimeTemplate(anchor);\n switch (name) {\n case \"millisecond\":\n return formatConditional(format(\".%L\"), format(\":%M:%S\"), template);\n case \"second\":\n return formatConditional(format(\":%S\"), format(\"%-I:%M\"), template);\n case \"minute\":\n return formatConditional(format(\"%-I:%M\"), format(\"%p\"), template);\n case \"hour\":\n return formatConditional(format(\"%-I %p\"), format(\"%b %-d\"), template);\n case \"day\":\n return formatConditional(format(\"%-d\"), format(\"%b\"), template);\n case \"month\":\n return formatConditional(format(\"%b\"), format(\"%Y\"), template);\n case \"year\":\n return format(\"%Y\");\n }\n throw new Error(\"unable to format time ticks\");\n}\n\nfunction getTimeTemplate(anchor) {\n return anchor === \"left\" || anchor === \"right\"\n ? (f1, f2) => `\\n${f1}\\n${f2}` // extra newline to keep f1 centered\n : anchor === \"top\"\n ? (f1, f2) => `${f2}\\n${f1}`\n : (f1, f2) => `${f1}\\n${f2}`;\n}\n\n// Given an array of dates, returns the largest compatible standard time\n// interval. If no standard interval is compatible (other than milliseconds,\n// which is universally compatible), returns undefined.\nexport function inferTimeFormat(dates, anchor) {\n const step = max(pairs(dates, (a, b) => Math.abs(b - a))); // maybe undefined!\n if (step < 1000) return formatTimeInterval(\"millisecond\", \"utc\", anchor);\n for (const [name, interval, type, maxStep] of formatIntervals) {\n if (step > maxStep) break; // e.g., 52 weeks\n if (name === \"hour\" && !step) break; // e.g., domain with a single date\n if (dates.every((d) => interval.floor(d) >= d)) return formatTimeInterval(name, type, anchor);\n }\n}\n\nfunction formatConditional(format1, format2, template) {\n return (x, i, X) => {\n const f1 = format1(x, i); // always shown\n const f2 = format2(x, i); // only shown if different\n const j = i - orderof(X); // detect reversed domains\n return i !== j && X[j] !== undefined && f2 === format2(X[j], j) ? f1 : template(f1, f2);\n };\n}\n","import {descending, quantile, range as rangei} from \"d3\";\nimport {parse as isoParse} from \"isoformat\";\nimport {defined} from \"./defined.js\";\nimport {maybeTimeInterval, maybeUtcInterval} from \"./time.js\";\n\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/TypedArray\nexport const TypedArray = Object.getPrototypeOf(Uint8Array);\nconst objectToString = Object.prototype.toString;\n\n// If a reindex is attached to the data, channel values expressed as arrays will\n// be reindexed when the channels are instantiated. See exclusiveFacets.\nexport const reindex = Symbol(\"reindex\");\n\nexport function valueof(data, value, type) {\n const valueType = typeof value;\n return valueType === \"string\"\n ? maybeTypedMap(data, field(value), type)\n : valueType === \"function\"\n ? maybeTypedMap(data, value, type)\n : valueType === \"number\" || value instanceof Date || valueType === \"boolean\"\n ? map(data, constant(value), type)\n : typeof value?.transform === \"function\"\n ? maybeTypedArrayify(value.transform(data), type)\n : maybeTake(maybeTypedArrayify(value, type), data?.[reindex]);\n}\n\nfunction maybeTake(values, index) {\n return index ? take(values, index) : values;\n}\n\nfunction maybeTypedMap(data, f, type) {\n return map(data, type?.prototype instanceof TypedArray ? floater(f) : f, type);\n}\n\nfunction maybeTypedArrayify(data, type) {\n return type === undefined\n ? arrayify(data) // preserve undefined type\n : data instanceof type\n ? data\n : type.prototype instanceof TypedArray && !(data instanceof TypedArray)\n ? type.from(data, coerceNumber)\n : type.from(data);\n}\n\nfunction floater(f) {\n return (d, i) => coerceNumber(f(d, i));\n}\n\nexport const singleton = [null]; // for data-less decoration marks, e.g. frame\nexport const field = (name) => (d) => d[name];\nexport const indexOf = {transform: range};\nexport const identity = {transform: (d) => d};\nexport const zero = () => 0;\nexport const one = () => 1;\nexport const yes = () => true;\nexport const string = (x) => (x == null ? x : `${x}`);\nexport const number = (x) => (x == null ? x : +x);\nexport const boolean = (x) => (x == null ? x : !!x);\nexport const first = (x) => (x ? x[0] : undefined);\nexport const second = (x) => (x ? x[1] : undefined);\nexport const third = (x) => (x ? x[2] : undefined);\nexport const constant = (x) => () => x;\n\n// Converts a string like “p25” into a function that takes an index I and an\n// accessor function f, returning the corresponding percentile value.\nexport function percentile(reduce) {\n const p = +`${reduce}`.slice(1) / 100;\n return (I, f) => quantile(I, p, f);\n}\n\n// If the values are specified as a typed array, no coercion is required.\nexport function coerceNumbers(values) {\n return values instanceof TypedArray ? values : map(values, coerceNumber, Float64Array);\n}\n\n// Unlike Mark’s number, here we want to convert null and undefined to NaN since\n// the result will be stored in a Float64Array and we don’t want null to be\n// coerced to zero. We use Number instead of unary + to allow BigInt coercion.\nfunction coerceNumber(x) {\n return x == null ? NaN : Number(x);\n}\n\nexport function coerceDates(values) {\n return map(values, coerceDate);\n}\n\n// When coercing strings to dates, we only want to allow the ISO 8601 format\n// since the built-in string parsing of the Date constructor varies across\n// browsers. (In the future, this could be made more liberal if desired, though\n// it is still generally preferable to do date parsing yourself explicitly,\n// rather than rely on Plot.) Any non-string values are coerced to number first\n// and treated as milliseconds since UNIX epoch.\nexport function coerceDate(x) {\n return x instanceof Date && !isNaN(x)\n ? x\n : typeof x === \"string\"\n ? isoParse(x)\n : x == null || isNaN((x = +x))\n ? undefined\n : new Date(x);\n}\n\n// Some channels may allow a string constant to be specified; to differentiate\n// string constants (e.g., \"red\") from named fields (e.g., \"date\"), this\n// function tests whether the given value is a CSS color string and returns a\n// tuple [channel, constant] where one of the two is undefined, and the other is\n// the given value. If you wish to reference a named field that is also a valid\n// CSS color, use an accessor (d => d.red) instead.\nexport function maybeColorChannel(value, defaultValue) {\n if (value === undefined) value = defaultValue;\n return value === null ? [undefined, \"none\"] : isColor(value) ? [undefined, value] : [value, undefined];\n}\n\n// Similar to maybeColorChannel, this tests whether the given value is a number\n// indicating a constant, and otherwise assumes that it’s a channel value.\nexport function maybeNumberChannel(value, defaultValue) {\n if (value === undefined) value = defaultValue;\n return value === null || typeof value === \"number\" ? [undefined, value] : [value, undefined];\n}\n\n// Validates the specified optional string against the allowed list of keywords.\nexport function maybeKeyword(input, name, allowed) {\n if (input != null) return keyword(input, name, allowed);\n}\n\n// Validates the specified required string against the allowed list of keywords.\nexport function keyword(input, name, allowed) {\n const i = `${input}`.toLowerCase();\n if (!allowed.includes(i)) throw new Error(`invalid ${name}: ${input}`);\n return i;\n}\n\n// Promotes the specified data to an array as needed.\nexport function arrayify(data) {\n return data == null || data instanceof Array || data instanceof TypedArray ? data : Array.from(data);\n}\n\n// An optimization of type.from(values, f): if the given values are already an\n// instanceof the desired array type, the faster values.map method is used.\nexport function map(values, f, type = Array) {\n return values == null ? values : values instanceof type ? values.map(f) : type.from(values, f);\n}\n\n// An optimization of type.from(values): if the given values are already an\n// instanceof the desired array type, the faster values.slice method is used.\nexport function slice(values, type = Array) {\n return values instanceof type ? values.slice() : type.from(values);\n}\n\n// Returns true if any of x, x1, or x2 is not (strictly) undefined.\nexport function hasX({x, x1, x2}) {\n return x !== undefined || x1 !== undefined || x2 !== undefined;\n}\n\n// Returns true if any of y, y1, or y2 is not (strictly) undefined.\nexport function hasY({y, y1, y2}) {\n return y !== undefined || y1 !== undefined || y2 !== undefined;\n}\n\n// Returns true if has x or y, or if interval is not (strictly) undefined.\nexport function hasXY(options) {\n return hasX(options) || hasY(options) || options.interval !== undefined;\n}\n\n// Disambiguates an options object (e.g., {y: \"x2\"}) from a primitive value.\nexport function isObject(option) {\n return option?.toString === objectToString;\n}\n\n// Disambiguates a scale options object (e.g., {color: {type: \"linear\"}}) from\n// some other option (e.g., {color: \"red\"}). When creating standalone legends,\n// this is used to test whether a scale is defined; this should be consistent\n// with inferScaleType when there are no channels associated with the scale, and\n// if this returns true, then normalizeScale must return non-null.\nexport function isScaleOptions(option) {\n return isObject(option) && (option.type !== undefined || option.domain !== undefined);\n}\n\n// Disambiguates an options object (e.g., {y: \"x2\"}) from a channel value\n// definition expressed as a channel transform (e.g., {transform: …}).\n// TODO Check typeof option[Symbol.iterator] !== \"function\"?\nexport function isOptions(option) {\n return isObject(option) && typeof option.transform !== \"function\";\n}\n\n// Disambiguates a sort transform (e.g., {sort: \"date\"}) from a channel domain\n// sort definition (e.g., {sort: {y: \"x\"}}).\nexport function isDomainSort(sort) {\n return isOptions(sort) && sort.value === undefined && sort.channel === undefined;\n}\n\n// For marks specified either as [0, x] or [x1, x2], such as areas and bars.\nexport function maybeZero(x, x1, x2, x3 = identity) {\n if (x1 === undefined && x2 === undefined) {\n // {x} or {}\n (x1 = 0), (x2 = x === undefined ? x3 : x);\n } else if (x1 === undefined) {\n // {x, x2} or {x2}\n x1 = x === undefined ? 0 : x;\n } else if (x2 === undefined) {\n // {x, x1} or {x1}\n x2 = x === undefined ? 0 : x;\n }\n return [x1, x2];\n}\n\n// For marks that have x and y channels (e.g., cell, dot, line, text).\nexport function maybeTuple(x, y) {\n return x === undefined && y === undefined ? [first, second] : [x, y];\n}\n\n// A helper for extracting the z channel, if it is variable. Used by transforms\n// that require series, such as moving average and normalize.\nexport function maybeZ({z, fill, stroke} = {}) {\n if (z === undefined) [z] = maybeColorChannel(fill);\n if (z === undefined) [z] = maybeColorChannel(stroke);\n return z;\n}\n\n// Returns a Uint32Array with elements [0, 1, 2, … data.length - 1].\nexport function range(data) {\n const n = data.length;\n const r = new Uint32Array(n);\n for (let i = 0; i < n; ++i) r[i] = i;\n return r;\n}\n\n// Returns a filtered range of data given the test function.\nexport function where(data, test) {\n return range(data).filter((i) => test(data[i], i, data));\n}\n\n// Returns an array [values[index[0]], values[index[1]], …].\nexport function take(values, index) {\n return map(index, (i) => values[i], values.constructor);\n}\n\n// If f does not take exactly one argument, wraps it in a function that uses take.\nexport function taker(f) {\n return f.length === 1 ? (index, values) => f(take(values, index)) : f;\n}\n\n// Uses subarray if available, and otherwise slice.\nexport function subarray(I, i, j) {\n return I.subarray ? I.subarray(i, j) : I.slice(i, j);\n}\n\n// Based on InternMap (d3.group).\nexport function keyof(value) {\n return value !== null && typeof value === \"object\" ? value.valueOf() : value;\n}\n\nexport function maybeInput(key, options) {\n if (options[key] !== undefined) return options[key];\n switch (key) {\n case \"x1\":\n case \"x2\":\n key = \"x\";\n break;\n case \"y1\":\n case \"y2\":\n key = \"y\";\n break;\n }\n return options[key];\n}\n\nexport function column(source) {\n // Defines a column whose values are lazily populated by calling the returned\n // setter. If the given source is labeled, the label is propagated to the\n // returned column definition.\n let value;\n return [\n {\n transform: () => value,\n label: labelof(source)\n },\n (v) => (value = v)\n ];\n}\n\n// Like column, but allows the source to be null.\nexport function maybeColumn(source) {\n return source == null ? [source] : column(source);\n}\n\nexport function labelof(value, defaultValue) {\n return typeof value === \"string\" ? value : value && value.label !== undefined ? value.label : defaultValue;\n}\n\n// Assuming that both x1 and x2 and lazy columns (per above), this derives a new\n// a column that’s the average of the two, and which inherits the column label\n// (if any). Both input columns are assumed to be quantitative. If either column\n// is temporal, the returned column is also temporal.\nexport function mid(x1, x2) {\n return {\n transform(data) {\n const X1 = x1.transform(data);\n const X2 = x2.transform(data);\n return isTemporal(X1) || isTemporal(X2)\n ? map(X1, (_, i) => new Date((+X1[i] + +X2[i]) / 2))\n : map(X1, (_, i) => (+X1[i] + +X2[i]) / 2, Float64Array);\n },\n label: x1.label\n };\n}\n\n// If the scale options declare an interval, applies it to the values V.\nexport function maybeApplyInterval(V, scale) {\n const t = maybeIntervalTransform(scale?.interval, scale?.type);\n return t ? map(V, t) : V;\n}\n\n// Returns the equivalent scale transform for the specified interval option.\nexport function maybeIntervalTransform(interval, type) {\n const i = maybeInterval(interval, type);\n return i && ((v) => (defined(v) ? i.floor(v) : v));\n}\n\n// If interval is not nullish, converts interval shorthand such as a number (for\n// multiples) or a time interval name (such as “day”) to a {floor, offset,\n// range} object similar to a D3 time interval.\nexport function maybeInterval(interval, type) {\n if (interval == null) return;\n if (typeof interval === \"number\") {\n if (0 < interval && interval < 1 && Number.isInteger(1 / interval)) interval = -1 / interval;\n const n = Math.abs(interval);\n return interval < 0\n ? {\n floor: (d) => Math.floor(d * n) / n,\n offset: (d) => (d * n + 1) / n, // note: no optional step for simplicity\n range: (lo, hi) => rangei(Math.ceil(lo * n), hi * n).map((x) => x / n)\n }\n : {\n floor: (d) => Math.floor(d / n) * n,\n offset: (d) => d + n, // note: no optional step for simplicity\n range: (lo, hi) => rangei(Math.ceil(lo / n), hi / n).map((x) => x * n)\n };\n }\n if (typeof interval === \"string\") return (type === \"time\" ? maybeTimeInterval : maybeUtcInterval)(interval);\n if (typeof interval.floor !== \"function\") throw new Error(\"invalid interval; missing floor method\");\n if (typeof interval.offset !== \"function\") throw new Error(\"invalid interval; missing offset method\");\n return interval;\n}\n\n// Like maybeInterval, but requires a range method too.\nexport function maybeRangeInterval(interval, type) {\n interval = maybeInterval(interval, type);\n if (interval && typeof interval.range !== \"function\") throw new Error(\"invalid interval: missing range method\");\n return interval;\n}\n\n// Like maybeRangeInterval, but requires a ceil method too.\nexport function maybeNiceInterval(interval, type) {\n interval = maybeRangeInterval(interval, type);\n if (interval && typeof interval.ceil !== \"function\") throw new Error(\"invalid interval: missing ceil method\");\n return interval;\n}\n\nexport function isTimeInterval(t) {\n return isInterval(t) && typeof t?.floor === \"function\" && t.floor() instanceof Date;\n}\n\nexport function isInterval(t) {\n return typeof t?.range === \"function\";\n}\n\n// This distinguishes between per-dimension options and a standalone value.\nexport function maybeValue(value) {\n return value === undefined || isOptions(value) ? value : {value};\n}\n\n// Coerces the given channel values (if any) to numbers. This is useful when\n// values will be interpolated into other code, such as an SVG transform, and\n// where we don’t wish to allow unexpected behavior for weird input.\nexport function numberChannel(source) {\n return source == null\n ? null\n : {\n transform: (data) => valueof(data, source, Float64Array),\n label: labelof(source)\n };\n}\n\nexport function isTuples(data) {\n if (!isIterable(data)) return false;\n for (const d of data) {\n if (d == null) continue;\n return typeof d === \"object\" && \"0\" in d && \"1\" in d;\n }\n}\n\nexport function isIterable(value) {\n return value && typeof value[Symbol.iterator] === \"function\";\n}\n\nexport function isTextual(values) {\n for (const value of values) {\n if (value == null) continue;\n return typeof value !== \"object\" || value instanceof Date;\n }\n}\n\nexport function isOrdinal(values) {\n for (const value of values) {\n if (value == null) continue;\n const type = typeof value;\n return type === \"string\" || type === \"boolean\";\n }\n}\n\nexport function isTemporal(values) {\n for (const value of values) {\n if (value == null) continue;\n return value instanceof Date;\n }\n}\n\n// Are these strings that might represent dates? This is stricter than ISO 8601\n// because we want to ignore false positives on numbers; for example, the string\n// \"1192\" is more likely to represent a number than a date even though it is\n// valid ISO 8601 representing 1192-01-01.\nexport function isTemporalString(values) {\n for (const value of values) {\n if (value == null) continue;\n return typeof value === \"string\" && isNaN(value) && isoParse(value);\n }\n}\n\n// Are these strings that might represent numbers? This is stricter than\n// coercion because we want to ignore false positives on e.g. empty strings.\nexport function isNumericString(values) {\n for (const value of values) {\n if (value == null) continue;\n if (typeof value !== \"string\") return false;\n if (!value.trim()) continue;\n return !isNaN(value);\n }\n}\n\nexport function isNumeric(values) {\n for (const value of values) {\n if (value == null) continue;\n return typeof value === \"number\";\n }\n}\n\n// Returns true if every non-null value in the specified iterable of values\n// passes the specified predicate, and there is at least one non-null value;\n// returns false if at least one non-null value does not pass the specified\n// predicate; otherwise returns undefined (as if all values are null).\nexport function isEvery(values, is) {\n let every;\n for (const value of values) {\n if (value == null) continue;\n if (!is(value)) return false;\n every = true;\n }\n return every;\n}\n\nconst namedColors = new Set(\"none,currentcolor,transparent,aliceblue,antiquewhite,aqua,aquamarine,azure,beige,bisque,black,blanchedalmond,blue,blueviolet,brown,burlywood,cadetblue,chartreuse,chocolate,coral,cornflowerblue,cornsilk,crimson,cyan,darkblue,darkcyan,darkgoldenrod,darkgray,darkgreen,darkgrey,darkkhaki,darkmagenta,darkolivegreen,darkorange,darkorchid,darkred,darksalmon,darkseagreen,darkslateblue,darkslategray,darkslategrey,darkturquoise,darkviolet,deeppink,deepskyblue,dimgray,dimgrey,dodgerblue,firebrick,floralwhite,forestgreen,fuchsia,gainsboro,ghostwhite,gold,goldenrod,gray,green,greenyellow,grey,honeydew,hotpink,indianred,indigo,ivory,khaki,lavender,lavenderblush,lawngreen,lemonchiffon,lightblue,lightcoral,lightcyan,lightgoldenrodyellow,lightgray,lightgreen,lightgrey,lightpink,lightsalmon,lightseagreen,lightskyblue,lightslategray,lightslategrey,lightsteelblue,lightyellow,lime,limegreen,linen,magenta,maroon,mediumaquamarine,mediumblue,mediumorchid,mediumpurple,mediumseagreen,mediumslateblue,mediumspringgreen,mediumturquoise,mediumvioletred,midnightblue,mintcream,mistyrose,moccasin,navajowhite,navy,oldlace,olive,olivedrab,orange,orangered,orchid,palegoldenrod,palegreen,paleturquoise,palevioletred,papayawhip,peachpuff,peru,pink,plum,powderblue,purple,rebeccapurple,red,rosybrown,royalblue,saddlebrown,salmon,sandybrown,seagreen,seashell,sienna,silver,skyblue,slateblue,slategray,slategrey,snow,springgreen,steelblue,tan,teal,thistle,tomato,turquoise,violet,wheat,white,whitesmoke,yellow\".split(\",\")); // prettier-ignore\n\n// Returns true if value is a valid CSS color string. This is intentionally lax\n// because the CSS color spec keeps growing, and we don’t need to parse these\n// colors—we just need to disambiguate them from column names.\n// https://www.w3.org/TR/SVG11/painting.html#SpecifyingPaint\n// https://www.w3.org/TR/css-color-5/\nexport function isColor(value) {\n if (typeof value !== \"string\") return false;\n value = value.toLowerCase().trim();\n return (\n /^#[0-9a-f]{3,8}$/.test(value) || // hex rgb, rgba, rrggbb, rrggbbaa\n /^(?:url|var|rgb|rgba|hsl|hsla|hwb|lab|lch|oklab|oklch|color|color-mix)\\(.*\\)$/.test(value) || // <funciri>, CSS variable, color, etc.\n namedColors.has(value) // currentColor, red, etc.\n );\n}\n\nexport function isOpacity(value) {\n return typeof value === \"number\" && ((0 <= value && value <= 1) || isNaN(value));\n}\n\nexport function isNoneish(value) {\n return value == null || isNone(value);\n}\n\nexport function isNone(value) {\n return /^\\s*none\\s*$/i.test(value);\n}\n\nexport function isRound(value) {\n return /^\\s*round\\s*$/i.test(value);\n}\n\nexport function maybeAnchor(value, name) {\n return maybeKeyword(value, name, [\n \"middle\",\n \"top-left\",\n \"top\",\n \"top-right\",\n \"right\",\n \"bottom-right\",\n \"bottom\",\n \"bottom-left\",\n \"left\"\n ]);\n}\n\nexport function maybeFrameAnchor(value = \"middle\") {\n return maybeAnchor(value, \"frameAnchor\");\n}\n\n// Like a sort comparator, returns a positive value if the given array of values\n// is in ascending order, a negative value if the values are in descending\n// order. Assumes monotonicity; only tests the first and last values.\nexport function orderof(values) {\n if (values == null) return;\n const first = values[0];\n const last = values[values.length - 1];\n return descending(first, last);\n}\n\n// Unlike {...defaults, ...options}, this ensures that any undefined (but\n// present) properties in options inherit the given default value.\nexport function inherit(options = {}, ...rest) {\n let o = options;\n for (const defaults of rest) {\n for (const key in defaults) {\n if (o[key] === undefined) {\n const value = defaults[key];\n if (o === options) o = {...o, [key]: value};\n else o[key] = value;\n }\n }\n }\n return o;\n}\n\n// Given an iterable of named things (objects with a name property), returns a\n// corresponding object with properties associated with the given name.\nexport function named(things) {\n console.warn(\"named iterables are deprecated; please use an object instead\");\n const names = new Set();\n return Object.fromEntries(\n Array.from(things, (thing) => {\n const {name} = thing;\n if (name == null) throw new Error(\"missing name\");\n const key = `${name}`;\n if (key === \"__proto__\") throw new Error(`illegal name: ${key}`);\n if (names.has(key)) throw new Error(`duplicate name: ${key}`);\n names.add(key);\n return [name, thing];\n })\n );\n}\n\nexport function maybeNamed(things) {\n return isIterable(things) ? named(things) : things;\n}\n","// Positional scales have associated axes, and for ordinal data, a point or band\n// scale is used instead of an ordinal scale.\nexport const position = Symbol(\"position\");\n\n// Color scales default to the turbo interpolator for quantitative data, and to\n// the Tableau10 scheme for ordinal data. Color scales may also have an\n// associated legend.\nexport const color = Symbol(\"color\");\n\n// Radius scales default to the sqrt type, have a default range of [0, 3], and a\n// default domain from 0 to the median first quartile of associated channels.\nexport const radius = Symbol(\"radius\");\n\n// Length scales default to the linear type, have a default range of [0, 12],\n// and a default domain from 0 to the median median of associated channels.\nexport const length = Symbol(\"length\");\n\n// Opacity scales have a default range of [0, 1], and a default domain from 0 to\n// the maximum value of associated channels.\nexport const opacity = Symbol(\"opacity\");\n\n// Symbol scales have a default range of categorical symbols.\nexport const symbol = Symbol(\"symbol\");\n\n// There isn’t really a projection scale; this represents x and y for geometry.\n// This is used to denote channels that should be projected.\nexport const projection = Symbol(\"projection\");\n\n// TODO Rather than hard-coding the list of known scale names, collect the names\n// and categories for each plot specification, so that custom marks can register\n// custom scales.\nexport const registry = new Map([\n [\"x\", position],\n [\"y\", position],\n [\"fx\", position],\n [\"fy\", position],\n [\"r\", radius],\n [\"color\", color],\n [\"opacity\", opacity],\n [\"symbol\", symbol],\n [\"length\", length],\n [\"projection\", projection]\n]);\n\nexport function isPosition(kind) {\n return kind === position || kind === projection;\n}\n\nexport function hasNumericRange(kind) {\n return kind === position || kind === radius || kind === length || kind === opacity;\n}\n","import {symbolAsterisk, symbolDiamond2, symbolPlus, symbolSquare2, symbolTriangle2, symbolTimes} from \"d3\";\nimport {symbolCircle, symbolCross, symbolDiamond, symbolSquare, symbolStar, symbolTriangle, symbolWye} from \"d3\";\n\nexport const sqrt3 = Math.sqrt(3);\nexport const sqrt4_3 = 2 / sqrt3;\n\nconst symbolHexagon = {\n draw(context, size) {\n const rx = Math.sqrt(size / Math.PI),\n ry = rx * sqrt4_3,\n hy = ry / 2;\n context.moveTo(0, ry);\n context.lineTo(rx, hy);\n context.lineTo(rx, -hy);\n context.lineTo(0, -ry);\n context.lineTo(-rx, -hy);\n context.lineTo(-rx, hy);\n context.closePath();\n }\n};\n\nconst symbols = new Map([\n [\"asterisk\", symbolAsterisk],\n [\"circle\", symbolCircle],\n [\"cross\", symbolCross],\n [\"diamond\", symbolDiamond],\n [\"diamond2\", symbolDiamond2],\n [\"hexagon\", symbolHexagon],\n [\"plus\", symbolPlus],\n [\"square\", symbolSquare],\n [\"square2\", symbolSquare2],\n [\"star\", symbolStar],\n [\"times\", symbolTimes],\n [\"triangle\", symbolTriangle],\n [\"triangle2\", symbolTriangle2],\n [\"wye\", symbolWye]\n]);\n\nfunction isSymbolObject(value) {\n return value && typeof value.draw === \"function\";\n}\n\nexport function isSymbol(value) {\n if (isSymbolObject(value)) return true;\n if (typeof value !== \"string\") return false;\n return symbols.has(value.toLowerCase());\n}\n\nexport function maybeSymbol(symbol) {\n if (symbol == null || isSymbolObject(symbol)) return symbol;\n const value = symbols.get(`${symbol}`.toLowerCase());\n if (value) return value;\n throw new Error(`invalid symbol: ${symbol}`);\n}\n\nexport function maybeSymbolChannel(symbol) {\n if (symbol == null || isSymbolObject(symbol)) return [undefined, symbol];\n if (typeof symbol === \"string\") {\n const value = symbols.get(`${symbol}`.toLowerCase());\n if (value) return [undefined, value];\n }\n return [symbol, undefined];\n}\n","import {randomLcg} from \"d3\";\nimport {ascendingDefined, descendingDefined} from \"../defined.js\";\nimport {arrayify, isDomainSort, isOptions, maybeValue, valueof} from \"../options.js\";\n\nexport function basic({filter: f1, sort: s1, reverse: r1, transform: t1, initializer: i1, ...options} = {}, transform) {\n // If both t1 and t2 are defined, returns a composite transform that first\n // applies t1 and then applies t2.\n if (t1 === undefined) {\n // explicit transform overrides filter, sort, and reverse\n if (f1 != null) t1 = filterTransform(f1);\n if (s1 != null && !isDomainSort(s1)) t1 = composeTransform(t1, sortTransform(s1));\n if (r1) t1 = composeTransform(t1, reverseTransform);\n }\n if (transform != null && i1 != null) throw new Error(\"transforms cannot be applied after initializers\");\n return {\n ...options,\n ...((s1 === null || isDomainSort(s1)) && {sort: s1}),\n transform: composeTransform(t1, transform)\n };\n}\n\nexport function initializer({filter: f1, sort: s1, reverse: r1, initializer: i1, ...options} = {}, initializer) {\n // If both i1 and i2 are defined, returns a composite initializer that first\n // applies i1 and then applies i2.\n if (i1 === undefined) {\n // explicit initializer overrides filter, sort, and reverse\n if (f1 != null) i1 = filterTransform(f1);\n if (s1 != null && !isDomainSort(s1)) i1 = composeInitializer(i1, sortTransform(s1));\n if (r1) i1 = composeInitializer(i1, reverseTransform);\n }\n return {\n ...options,\n ...((s1 === null || isDomainSort(s1)) && {sort: s1}),\n initializer: composeInitializer(i1, initializer)\n };\n}\n\nfunction composeTransform(t1, t2) {\n if (t1 == null) return t2 === null ? undefined : t2;\n if (t2 == null) return t1 === null ? undefined : t1;\n return function (data, facets, plotOptions) {\n ({data, facets} = t1.call(this, data, facets, plotOptions));\n return t2.call(this, arrayify(data), facets, plotOptions);\n };\n}\n\nfunction composeInitializer(i1, i2) {\n if (i1 == null) return i2 === null ? undefined : i2;\n if (i2 == null) return i1 === null ? undefined : i1;\n return function (data, facets, channels, ...args) {\n let c1, d1, f1, c2, d2, f2;\n ({data: d1 = data, facets: f1 = facets, channels: c1} = i1.call(this, data, facets, channels, ...args));\n ({data: d2 = d1, facets: f2 = f1, channels: c2} = i2.call(this, d1, f1, {...channels, ...c1}, ...args));\n return {data: d2, facets: f2, channels: {...c1, ...c2}};\n };\n}\n\nfunction apply(options, t) {\n return (options.initializer != null ? initializer : basic)(options, t);\n}\n\nexport function filter(test, options) {\n return apply(options, filterTransform(test));\n}\n\nfunction filterTransform(value) {\n return (data, facets) => {\n const V = valueof(data, value);\n return {data, facets: facets.map((I) => I.filter((i) => V[i]))};\n };\n}\n\nexport function reverse({sort, ...options} = {}) {\n return {\n ...apply(options, reverseTransform),\n sort: isDomainSort(sort) ? sort : null\n };\n}\n\nfunction reverseTransform(data, facets) {\n return {data, facets: facets.map((I) => I.slice().reverse())};\n}\n\nexport function shuffle({seed, sort, ...options} = {}) {\n return {\n ...apply(options, sortValue(seed == null ? Math.random : randomLcg(seed))),\n sort: isDomainSort(sort) ? sort : null\n };\n}\n\nexport function sort(order, {sort, ...options} = {}) {\n return {\n ...(isOptions(order) && order.channel !== undefined ? initializer : apply)(options, sortTransform(order)),\n sort: isDomainSort(sort) ? sort : null\n };\n}\n\nfunction sortTransform(value) {\n return (typeof value === \"function\" && value.length !== 1 ? sortData : sortValue)(value);\n}\n\nfunction sortData(compare) {\n return (data, facets) => {\n const compareData = (i, j) => compare(data[i], data[j]);\n return {data, facets: facets.map((I) => I.slice().sort(compareData))};\n };\n}\n\nfunction sortValue(value) {\n let channel, order;\n ({channel, value, order} = {...maybeValue(value)});\n const negate = channel?.startsWith(\"-\");\n if (negate) channel = channel.slice(1);\n if (order === undefined) order = negate ? descendingDefined : ascendingDefined;\n if (typeof order !== \"function\") {\n switch (`${order}`.toLowerCase()) {\n case \"ascending\":\n order = ascendingDefined;\n break;\n case \"descending\":\n order = descendingDefined;\n break;\n default:\n throw new Error(`invalid order: ${order}`);\n }\n }\n return (data, facets, channels) => {\n let V;\n if (channel === undefined) {\n V = valueof(data, value);\n } else {\n if (channels === undefined) throw new Error(\"channel sort requires an initializer\");\n V = channels[channel];\n if (!V) return {}; // ignore missing channel\n V = V.value;\n }\n const compareValue = (i, j) => order(V[i], V[j]);\n return {data, facets: facets.map((I) => I.slice().sort(compareValue))};\n };\n}\n","import {\n InternSet,\n deviation,\n group as grouper,\n max,\n maxIndex,\n mean,\n median,\n min,\n minIndex,\n mode,\n rollup,\n sort,\n sum,\n variance\n} from \"d3\";\nimport {ascendingDefined} from \"../defined.js\";\nimport {\n column,\n first,\n identity,\n isObject,\n isTemporal,\n labelof,\n maybeApplyInterval,\n maybeColorChannel,\n maybeColumn,\n maybeInput,\n maybeTuple,\n percentile,\n range,\n second,\n take,\n valueof\n} from \"../options.js\";\nimport {basic} from \"./basic.js\";\n\n// Group on {z, fill, stroke}.\nexport function groupZ(outputs, options) {\n return groupn(null, null, outputs, options);\n}\n\n// Group on {z, fill, stroke}, then on x.\nexport function groupX(outputs = {y: \"count\"}, options = {}) {\n const {x = identity} = options;\n if (x == null) throw new Error(\"missing channel: x\");\n return groupn(x, null, outputs, options);\n}\n\n// Group on {z, fill, stroke}, then on y.\nexport function groupY(outputs = {x: \"count\"}, options = {}) {\n const {y = identity} = options;\n if (y == null) throw new Error(\"missing channel: y\");\n return groupn(null, y, outputs, options);\n}\n\n// Group on {z, fill, stroke}, then on x and y.\nexport function group(outputs = {fill: \"count\"}, options = {}) {\n let {x, y} = options;\n [x, y] = maybeTuple(x, y);\n if (x == null) throw new Error(\"missing channel: x\");\n if (y == null) throw new Error(\"missing channel: y\");\n return groupn(x, y, outputs, options);\n}\n\nfunction groupn(\n x, // optionally group on x\n y, // optionally group on y\n {\n data: reduceData = reduceIdentity,\n filter,\n sort,\n reverse,\n ...outputs // output channel definitions\n } = {},\n inputs = {} // input channels and options\n) {\n // Compute the outputs.\n outputs = maybeOutputs(outputs, inputs);\n reduceData = maybeReduce(reduceData, identity);\n sort = sort == null ? undefined : maybeOutput(\"sort\", sort, inputs);\n filter = filter == null ? undefined : maybeEvaluator(\"filter\", filter, inputs);\n\n // Produce x and y output channels as appropriate.\n const [GX, setGX] = maybeColumn(x);\n const [GY, setGY] = maybeColumn(y);\n\n // Greedily materialize the z, fill, and stroke channels (if channels and not\n // constants) so that we can reference them for subdividing groups without\n // computing them more than once.\n const {\n z,\n fill,\n stroke,\n x1,\n x2, // consumed if x is an output\n y1,\n y2, // consumed if y is an output\n ...options\n } = inputs;\n const [GZ, setGZ] = maybeColumn(z);\n const [vfill] = maybeColorChannel(fill);\n const [vstroke] = maybeColorChannel(stroke);\n const [GF, setGF] = maybeColumn(vfill);\n const [GS, setGS] = maybeColumn(vstroke);\n\n return {\n ...(\"z\" in inputs && {z: GZ || z}),\n ...(\"fill\" in inputs && {fill: GF || fill}),\n ...(\"stroke\" in inputs && {stroke: GS || stroke}),\n ...basic(options, (data, facets, plotOptions) => {\n const X = maybeApplyInterval(valueof(data, x), plotOptions?.x);\n const Y = maybeApplyInterval(valueof(data, y), plotOptions?.y);\n const Z = valueof(data, z);\n const F = valueof(data, vfill);\n const S = valueof(data, vstroke);\n const G = maybeSubgroup(outputs, {z: Z, fill: F, stroke: S});\n const groupFacets = [];\n const groupData = [];\n const GX = X && setGX([]);\n const GY = Y && setGY([]);\n const GZ = Z && setGZ([]);\n const GF = F && setGF([]);\n const GS = S && setGS([]);\n let i = 0;\n for (const o of outputs) o.initialize(data);\n if (sort) sort.initialize(data);\n if (filter) filter.initialize(data);\n for (const facet of facets) {\n const groupFacet = [];\n for (const o of outputs) o.scope(\"facet\", facet);\n if (sort) sort.scope(\"facet\", facet);\n if (filter) filter.scope(\"facet\", facet);\n for (const [f, I] of maybeGroup(facet, G)) {\n for (const [y, gg] of maybeGroup(I, Y)) {\n for (const [x, g] of maybeGroup(gg, X)) {\n if (filter && !filter.reduce(g)) continue;\n groupFacet.push(i++);\n groupData.push(reduceData.reduceIndex(g, data));\n if (X) GX.push(x);\n if (Y) GY.push(y);\n if (Z) GZ.push(G === Z ? f : Z[g[0]]);\n if (F) GF.push(G === F ? f : F[g[0]]);\n if (S) GS.push(G === S ? f : S[g[0]]);\n for (const o of outputs) o.reduce(g);\n if (sort) sort.reduce(g);\n }\n }\n }\n groupFacets.push(groupFacet);\n }\n maybeSort(groupFacets, sort, reverse);\n return {data: groupData, facets: groupFacets};\n }),\n ...(!hasOutput(outputs, \"x\") && (GX ? {x: GX} : {x1, x2})),\n ...(!hasOutput(outputs, \"y\") && (GY ? {y: GY} : {y1, y2})),\n ...Object.fromEntries(outputs.map(({name, output}) => [name, output]))\n };\n}\n\nexport function hasOutput(outputs, ...names) {\n for (const {name} of outputs) {\n if (names.includes(name)) {\n return true;\n }\n }\n return false;\n}\n\nexport function maybeOutputs(outputs, inputs, asOutput = maybeOutput) {\n const entries = Object.entries(outputs);\n // Propagate standard mark channels by default.\n if (inputs.title != null && outputs.title === undefined) entries.push([\"title\", reduceTitle]);\n if (inputs.href != null && outputs.href === undefined) entries.push([\"href\", reduceFirst]);\n return entries\n .filter(([, reduce]) => reduce !== undefined)\n .map(([name, reduce]) => (reduce === null ? nullOutput(name) : asOutput(name, reduce, inputs)));\n}\n\nexport function maybeOutput(name, reduce, inputs, asEvaluator = maybeEvaluator) {\n let scale; // optional per-channel scale override\n if (isObject(reduce) && \"reduce\" in reduce) (scale = reduce.scale), (reduce = reduce.reduce); // N.B. array.reduce\n const evaluator = asEvaluator(name, reduce, inputs);\n const [output, setOutput] = column(evaluator.label);\n let O;\n return {\n name,\n output: scale === undefined ? output : {value: output, scale},\n initialize(data) {\n evaluator.initialize(data);\n O = setOutput([]);\n },\n scope(scope, I) {\n evaluator.scope(scope, I);\n },\n reduce(I, extent) {\n O.push(evaluator.reduce(I, extent));\n }\n };\n}\n\nfunction nullOutput(name) {\n return {name, initialize() {}, scope() {}, reduce() {}};\n}\n\nexport function maybeEvaluator(name, reduce, inputs, asReduce = maybeReduce) {\n const input = maybeInput(name, inputs);\n const reducer = asReduce(reduce, input);\n let V, context;\n return {\n label: labelof(reducer === reduceCount ? null : input, reducer.label),\n initialize(data) {\n V = input === undefined ? data : valueof(data, input);\n if (reducer.scope === \"data\") {\n context = reducer.reduceIndex(range(data), V);\n }\n },\n scope(scope, I) {\n if (reducer.scope === scope) {\n context = reducer.reduceIndex(I, V);\n }\n },\n reduce(I, extent) {\n return reducer.scope == null ? reducer.reduceIndex(I, V, extent) : reducer.reduceIndex(I, V, context, extent);\n }\n };\n}\n\nexport function maybeGroup(I, X) {\n return X\n ? sort(\n grouper(I, (i) => X[i]),\n first\n )\n : [[, I]];\n}\n\nexport function maybeReduce(reduce, value, fallback = invalidReduce) {\n if (reduce == null) return fallback(reduce);\n if (typeof reduce.reduceIndex === \"function\") return reduce;\n if (typeof reduce.reduce === \"function\" && isObject(reduce)) return reduceReduce(reduce); // N.B. array.reduce\n if (typeof reduce === \"function\") return reduceFunction(reduce);\n if (/^p\\d{2}$/i.test(reduce)) return reduceAccessor(percentile(reduce));\n switch (`${reduce}`.toLowerCase()) {\n case \"first\":\n return reduceFirst;\n case \"last\":\n return reduceLast;\n case \"identity\":\n return reduceIdentity;\n case \"count\":\n return reduceCount;\n case \"distinct\":\n return reduceDistinct;\n case \"sum\":\n return value == null ? reduceCount : reduceSum;\n case \"proportion\":\n return reduceProportion(value, \"data\");\n case \"proportion-facet\":\n return reduceProportion(value, \"facet\");\n case \"deviation\":\n return reduceAccessor(deviation);\n case \"min\":\n return reduceAccessor(min);\n case \"min-index\":\n return reduceAccessor(minIndex);\n case \"max\":\n return reduceAccessor(max);\n case \"max-index\":\n return reduceAccessor(maxIndex);\n case \"mean\":\n return reduceMaybeTemporalAccessor(mean);\n case \"median\":\n return reduceMaybeTemporalAccessor(median);\n case \"variance\":\n return reduceAccessor(variance);\n case \"mode\":\n return reduceAccessor(mode);\n }\n return fallback(reduce);\n}\n\nfunction invalidReduce(reduce) {\n throw new Error(`invalid reduce: ${reduce}`);\n}\n\nexport function maybeSubgroup(outputs, inputs) {\n for (const name in inputs) {\n const value = inputs[name];\n if (value !== undefined && !outputs.some((o) => o.name === name)) {\n return value;\n }\n }\n}\n\nexport function maybeSort(facets, sort, reverse) {\n if (sort) {\n const S = sort.output.transform();\n const compare = (i, j) => ascendingDefined(S[i], S[j]);\n facets.forEach((f) => f.sort(compare));\n }\n if (reverse) {\n facets.forEach((f) => f.reverse());\n }\n}\n\nfunction reduceReduce(reduce) {\n console.warn(\"deprecated reduce interface; implement reduceIndex instead.\");\n return {...reduce, reduceIndex: reduce.reduce.bind(reduce)};\n}\n\nfunction reduceFunction(f) {\n return {\n reduceIndex(I, X, extent) {\n return f(take(X, I), extent);\n }\n };\n}\n\nfunction reduceAccessor(f) {\n return {\n reduceIndex(I, X) {\n return f(I, (i) => X[i]);\n }\n };\n}\n\nfunction reduceMaybeTemporalAccessor(f) {\n return {\n reduceIndex(I, X) {\n const x = f(I, (i) => X[i]);\n return isTemporal(X) ? new Date(x) : x;\n }\n };\n}\n\nexport const reduceIdentity = {\n reduceIndex(I, X) {\n return take(X, I);\n }\n};\n\nexport const reduceFirst = {\n reduceIndex(I, X) {\n return X[I[0]];\n }\n};\n\nconst reduceTitle = {\n reduceIndex(I, X) {\n const n = 5;\n const groups = sort(\n rollup(\n I,\n (V) => V.length,\n (i) => X[i]\n ),\n second\n );\n const top = groups.slice(-n).reverse();\n if (top.length < groups.length) {\n const bottom = groups.slice(0, 1 - n);\n top[n - 1] = [`… ${bottom.length.toLocaleString(\"en-US\")} more`, sum(bottom, second)];\n }\n return top.map(([key, value]) => `${key} (${value.toLocaleString(\"en-US\")})`).join(\"\\n\");\n }\n};\n\nconst reduceLast = {\n reduceIndex(I, X) {\n return X[I[I.length - 1]];\n }\n};\n\nexport const reduceCount = {\n label: \"Frequency\",\n reduceIndex(I) {\n return I.length;\n }\n};\n\nconst reduceDistinct = {\n label: \"Distinct\",\n reduceIndex(I, X) {\n const s = new InternSet();\n for (const i of I) s.add(X[i]);\n return s.size;\n }\n};\n\nconst reduceSum = reduceAccessor(sum);\n\nfunction reduceProportion(value, scope) {\n return value == null\n ? {scope, label: \"Frequency\", reduceIndex: (I, V, basis = 1) => I.length / basis}\n : {scope, reduceIndex: (I, V, basis = 1) => sum(I, (i) => V[i]) / basis};\n}\n","import {InternSet, rollups} from \"d3\";\nimport {ascendingDefined, descendingDefined} from \"./defined.js\";\nimport {first, isColor, isEvery, isIterable, isOpacity, labelof, map, maybeValue, range, valueof} from \"./options.js\";\nimport {registry} from \"./scales/index.js\";\nimport {isSymbol, maybeSymbol} from \"./symbol.js\";\nimport {maybeReduce} from \"./transforms/group.js\";\n\nexport function createChannel(data, {scale, type, value, filter, hint, label = labelof(value)}, name) {\n if (hint === undefined && typeof value?.transform === \"function\") hint = value.hint;\n return inferChannelScale(name, {\n scale,\n type,\n value: valueof(data, value),\n label,\n filter,\n hint\n });\n}\n\nexport function createChannels(channels, data) {\n return Object.fromEntries(\n Object.entries(channels).map(([name, channel]) => [name, createChannel(data, channel, name)])\n );\n}\n\n// TODO Use Float64Array for scales with numeric ranges, e.g. position?\nexport function valueObject(channels, scales) {\n const values = Object.fromEntries(\n Object.entries(channels).map(([name, {scale: scaleName, value}]) => {\n const scale = scaleName == null ? null : scales[scaleName];\n return [name, scale == null ? value : map(value, scale)];\n })\n );\n values.channels = channels; // expose channel state for advanced usage\n return values;\n}\n\n// If the channel uses the \"auto\" scale (or equivalently true), infer the scale\n// from the channel name and the provided values. For color and symbol channels,\n// no scale is applied if the values are literal; however for symbols, we must\n// promote symbol names (e.g., \"plus\") to symbol implementations (symbolPlus).\n// Note: mutates channel!\nexport function inferChannelScale(name, channel) {\n const {scale, value} = channel;\n if (scale === true || scale === \"auto\") {\n switch (name) {\n case \"fill\":\n case \"stroke\":\n case \"color\":\n channel.scale = scale !== true && isEvery(value, isColor) ? null : \"color\";\n break;\n case \"fillOpacity\":\n case \"strokeOpacity\":\n case \"opacity\":\n channel.scale = scale !== true && isEvery(value, isOpacity) ? null : \"opacity\";\n break;\n case \"symbol\":\n if (scale !== true && isEvery(value, isSymbol)) {\n channel.scale = null;\n channel.value = map(value, maybeSymbol);\n } else {\n channel.scale = \"symbol\";\n }\n break;\n default:\n channel.scale = registry.has(name) ? name : null;\n break;\n }\n } else if (scale === false) {\n channel.scale = null;\n } else if (scale != null && !registry.has(scale)) {\n throw new Error(`unknown scale: ${scale}`);\n }\n return channel;\n}\n\n// Note: mutates channel.domain! This is set to a function so that it is lazily\n// computed; i.e., if the scale’s domain is set explicitly, that takes priority\n// over the sort option, and we don’t need to do additional work.\nexport function channelDomain(data, facets, channels, facetChannels, options) {\n const {order: defaultOrder, reverse: defaultReverse, reduce: defaultReduce = true, limit: defaultLimit} = options;\n for (const x in options) {\n if (!registry.has(x)) continue; // ignore unknown scale keys (including generic options)\n let {value: y, order = defaultOrder, reverse = defaultReverse, reduce = defaultReduce, limit = defaultLimit} = maybeValue(options[x]); // prettier-ignore\n const negate = y?.startsWith(\"-\");\n if (negate) y = y.slice(1);\n order = order === undefined ? negate !== (y === \"width\" || y === \"height\") ? descendingGroup : ascendingGroup : maybeOrder(order); // prettier-ignore\n if (reduce == null || reduce === false) continue; // disabled reducer\n const X = x === \"fx\" || x === \"fy\" ? reindexFacetChannel(facets, facetChannels[x]) : findScaleChannel(channels, x);\n if (!X) throw new Error(`missing channel for scale: ${x}`);\n const XV = X.value;\n const [lo = 0, hi = Infinity] = isIterable(limit) ? limit : limit < 0 ? [limit] : [0, limit];\n if (y == null) {\n X.domain = () => {\n let domain = Array.from(new InternSet(XV)); // remove any duplicates\n if (reverse) domain = domain.reverse();\n if (lo !== 0 || hi !== Infinity) domain = domain.slice(lo, hi);\n return domain;\n };\n } else {\n const YV =\n y === \"data\"\n ? data\n : y === \"height\"\n ? difference(channels, \"y1\", \"y2\")\n : y === \"width\"\n ? difference(channels, \"x1\", \"x2\")\n : values(channels, y, y === \"y\" ? \"y2\" : y === \"x\" ? \"x2\" : undefined);\n const reducer = maybeReduce(reduce === true ? \"max\" : reduce, YV);\n X.domain = () => {\n let domain = rollups(\n range(XV),\n (I) => reducer.reduceIndex(I, YV),\n (i) => XV[i]\n );\n if (order) domain.sort(order);\n if (reverse) domain.reverse();\n if (lo !== 0 || hi !== Infinity) domain = domain.slice(lo, hi);\n return domain.map(first);\n };\n }\n }\n}\n\nfunction findScaleChannel(channels, scale) {\n for (const name in channels) {\n const channel = channels[name];\n if (channel.scale === scale) return channel;\n }\n}\n\n// Facet channels are not affected by transforms; so, to compute the domain of a\n// facet scale, we must first re-index the facet channel according to the\n// transformed mark index. Note: mutates channel, but that should be safe here?\nfunction reindexFacetChannel(facets, channel) {\n const originalFacets = facets.original;\n if (originalFacets === facets) return channel; // not transformed\n const V1 = channel.value;\n const V2 = (channel.value = []); // mutates channel!\n for (let i = 0; i < originalFacets.length; ++i) {\n const vi = V1[originalFacets[i][0]];\n for (const j of facets[i]) V2[j] = vi;\n }\n return channel;\n}\n\nfunction difference(channels, k1, k2) {\n const X1 = values(channels, k1);\n const X2 = values(channels, k2);\n return map(X2, (x2, i) => Math.abs(x2 - X1[i]), Float64Array);\n}\n\nfunction values(channels, name, alias) {\n let channel = channels[name];\n if (!channel && alias !== undefined) channel = channels[alias];\n if (channel) return channel.value;\n throw new Error(`missing channel: ${name}`);\n}\n\nfunction maybeOrder(order) {\n if (order == null || typeof order === \"function\") return order;\n switch (`${order}`.toLowerCase()) {\n case \"ascending\":\n return ascendingGroup;\n case \"descending\":\n return descendingGroup;\n }\n throw new Error(`invalid order: ${order}`);\n}\n\nfunction ascendingGroup([ak, av], [bk, bv]) {\n return ascendingDefined(av, bv) || ascendingDefined(ak, bk);\n}\n\nfunction descendingGroup([ak, av], [bk, bv]) {\n return descendingDefined(av, bv) || ascendingDefined(ak, bk);\n}\n\nexport function getSource(channels, key) {\n let channel = channels[key];\n if (!channel) return;\n while (channel.source) channel = channel.source;\n return channel.source === null ? null : channel;\n}\n","import {format as isoFormat} from \"isoformat\";\nimport {string} from \"./options.js\";\nimport {memoize1} from \"./memoize.js\";\n\nconst numberFormat = memoize1((locale) => {\n return new Intl.NumberFormat(locale);\n});\n\nconst monthFormat = memoize1((locale, month) => {\n return new Intl.DateTimeFormat(locale, {timeZone: \"UTC\", ...(month && {month})});\n});\n\nconst weekdayFormat = memoize1((locale, weekday) => {\n return new Intl.DateTimeFormat(locale, {timeZone: \"UTC\", ...(weekday && {weekday})});\n});\n\nexport function formatNumber(locale = \"en-US\") {\n const format = numberFormat(locale);\n return (i) => (i != null && !isNaN(i) ? format.format(i) : undefined);\n}\n\nexport function formatMonth(locale = \"en-US\", format = \"short\") {\n const fmt = monthFormat(locale, format);\n return (i) => (i != null && !isNaN((i = +new Date(Date.UTC(2000, +i)))) ? fmt.format(i) : undefined);\n}\n\nexport function formatWeekday(locale = \"en-US\", format = \"short\") {\n const fmt = weekdayFormat(locale, format);\n return (i) => (i != null && !isNaN((i = +new Date(Date.UTC(2001, 0, +i)))) ? fmt.format(i) : undefined);\n}\n\nexport function formatIsoDate(date) {\n return isoFormat(date, \"Invalid Date\");\n}\n\nexport function formatAuto(locale = \"en-US\") {\n const number = formatNumber(locale);\n return (v) => (v instanceof Date ? formatIsoDate : typeof v === \"number\" ? number : string)(v);\n}\n\n// TODO When Plot supports a top-level locale option, this should be removed\n// because it lacks context to know which locale to use; formatAuto should be\n// used instead whenever possible.\nexport const formatDefault = formatAuto();\n","export function memoize1(compute) {\n let cacheValue, cacheKeys;\n return (...keys) => {\n if (cacheKeys?.length !== keys.length || cacheKeys.some((k, i) => k !== keys[i])) {\n cacheKeys = keys;\n cacheValue = compute(...keys);\n }\n return cacheValue;\n };\n}\n","let warnings = 0;\nlet lastMessage;\n\nexport function consumeWarnings() {\n const w = warnings;\n warnings = 0;\n lastMessage = undefined;\n return w;\n}\n\nexport function warn(message) {\n if (message === lastMessage) return;\n lastMessage = message;\n console.warn(message);\n ++warnings;\n}\n","import {geoPath, group, namespaces} from \"d3\";\nimport {create} from \"./context.js\";\nimport {defined, nonempty} from \"./defined.js\";\nimport {formatDefault} from \"./format.js\";\nimport {isNone, isNoneish, isRound, maybeColorChannel, maybeNumberChannel} from \"./options.js\";\nimport {keyof, keyword, number, string} from \"./options.js\";\nimport {warn} from \"./warnings.js\";\n\nexport const offset = (typeof window !== \"undefined\" ? window.devicePixelRatio > 1 : typeof it === \"undefined\") ? 0 : 0.5; // prettier-ignore\n\nlet nextClipId = 0;\n\nfunction getClipId() {\n return `plot-clip-${++nextClipId}`;\n}\n\nexport function styles(\n mark,\n {\n title,\n href,\n ariaLabel: variaLabel,\n ariaDescription,\n ariaHidden,\n target,\n fill,\n fillOpacity,\n stroke,\n strokeWidth,\n strokeOpacity,\n strokeLinejoin,\n strokeLinecap,\n strokeMiterlimit,\n strokeDasharray,\n strokeDashoffset,\n opacity,\n mixBlendMode,\n imageFilter,\n paintOrder,\n pointerEvents,\n shapeRendering,\n channels\n },\n {\n ariaLabel: cariaLabel,\n fill: defaultFill = \"currentColor\",\n fillOpacity: defaultFillOpacity,\n stroke: defaultStroke = \"none\",\n strokeOpacity: defaultStrokeOpacity,\n strokeWidth: defaultStrokeWidth,\n strokeLinecap: defaultStrokeLinecap,\n strokeLinejoin: defaultStrokeLinejoin,\n strokeMiterlimit: defaultStrokeMiterlimit,\n paintOrder: defaultPaintOrder\n }\n) {\n // Some marks don’t support fill (e.g., tick and rule).\n if (defaultFill === null) {\n fill = null;\n fillOpacity = null;\n }\n\n // Some marks don’t support stroke (e.g., image).\n if (defaultStroke === null) {\n stroke = null;\n strokeOpacity = null;\n }\n\n // Some marks default to fill with no stroke, while others default to stroke\n // with no fill. For example, bar and area default to fill, while dot and line\n // default to stroke. For marks that fill by default, the default fill only\n // applies if the stroke is (constant) none; if you set a stroke, then the\n // default fill becomes none. Similarly for marks that stroke by stroke, the\n // default stroke only applies if the fill is (constant) none.\n if (isNoneish(defaultFill)) {\n if (!isNoneish(defaultStroke) && (!isNoneish(fill) || channels?.fill)) defaultStroke = \"none\";\n } else {\n if (isNoneish(defaultStroke) && (!isNoneish(stroke) || channels?.stroke)) defaultFill = \"none\";\n }\n\n const [vfill, cfill] = maybeColorChannel(fill, defaultFill);\n const [vfillOpacity, cfillOpacity] = maybeNumberChannel(fillOpacity, defaultFillOpacity);\n const [vstroke, cstroke] = maybeColorChannel(stroke, defaultStroke);\n const [vstrokeOpacity, cstrokeOpacity] = maybeNumberChannel(strokeOpacity, defaultStrokeOpacity);\n const [vopacity, copacity] = maybeNumberChannel(opacity);\n\n // For styles that have no effect if there is no stroke, only apply the\n // defaults if the stroke is not the constant none. (If stroke is a channel,\n // then cstroke will be undefined, but there’s still a stroke; hence we don’t\n // use isNoneish here.)\n if (!isNone(cstroke)) {\n if (strokeWidth === undefined) strokeWidth = defaultStrokeWidth;\n if (strokeLinecap === undefined) strokeLinecap = defaultStrokeLinecap;\n if (strokeLinejoin === undefined) strokeLinejoin = defaultStrokeLinejoin;\n\n // The default stroke miterlimit need not be applied if the current stroke\n // is the constant round; this only has effect on miter joins.\n if (strokeMiterlimit === undefined && !isRound(strokeLinejoin)) strokeMiterlimit = defaultStrokeMiterlimit;\n\n // The paint order only takes effect if there is both a fill and a stroke\n // (at least if we ignore markers, which no built-in marks currently use).\n if (!isNone(cfill) && paintOrder === undefined) paintOrder = defaultPaintOrder;\n }\n\n const [vstrokeWidth, cstrokeWidth] = maybeNumberChannel(strokeWidth);\n\n // Some marks don’t support fill (e.g., tick and rule).\n if (defaultFill !== null) {\n mark.fill = impliedString(cfill, \"currentColor\");\n mark.fillOpacity = impliedNumber(cfillOpacity, 1);\n }\n\n // Some marks don’t support stroke (e.g., image).\n if (defaultStroke !== null) {\n mark.stroke = impliedString(cstroke, \"none\");\n mark.strokeWidth = impliedNumber(cstrokeWidth, 1);\n mark.strokeOpacity = impliedNumber(cstrokeOpacity, 1);\n mark.strokeLinejoin = impliedString(strokeLinejoin, \"miter\");\n mark.strokeLinecap = impliedString(strokeLinecap, \"butt\");\n mark.strokeMiterlimit = impliedNumber(strokeMiterlimit, 4);\n mark.strokeDasharray = impliedString(strokeDasharray, \"none\");\n mark.strokeDashoffset = impliedString(strokeDashoffset, \"0\");\n }\n\n mark.target = string(target);\n mark.ariaLabel = string(cariaLabel);\n mark.ariaDescription = string(ariaDescription);\n mark.ariaHidden = string(ariaHidden);\n mark.opacity = impliedNumber(copacity, 1);\n mark.mixBlendMode = impliedString(mixBlendMode, \"normal\");\n mark.imageFilter = impliedString(imageFilter, \"none\");\n mark.paintOrder = impliedString(paintOrder, \"normal\");\n mark.pointerEvents = impliedString(pointerEvents, \"auto\");\n mark.shapeRendering = impliedString(shapeRendering, \"auto\");\n\n return {\n title: {value: title, optional: true, filter: null},\n href: {value: href, optional: true, filter: null},\n ariaLabel: {value: variaLabel, optional: true, filter: null},\n fill: {value: vfill, scale: \"auto\", optional: true},\n fillOpacity: {value: vfillOpacity, scale: \"auto\", optional: true},\n stroke: {value: vstroke, scale: \"auto\", optional: true},\n strokeOpacity: {value: vstrokeOpacity, scale: \"auto\", optional: true},\n strokeWidth: {value: vstrokeWidth, optional: true},\n opacity: {value: vopacity, scale: \"auto\", optional: true}\n };\n}\n\n// Applies the specified titles via selection.call.\nexport function applyTitle(selection, L) {\n if (L)\n selection\n .filter((i) => nonempty(L[i]))\n .append(\"title\")\n .call(applyText, L);\n}\n\n// Like applyTitle, but for grouped data (lines, areas).\nexport function applyTitleGroup(selection, L) {\n if (L)\n selection\n .filter(([i]) => nonempty(L[i]))\n .append(\"title\")\n .call(applyTextGroup, L);\n}\n\nexport function applyText(selection, T) {\n if (T) selection.text((i) => formatDefault(T[i]));\n}\n\nexport function applyTextGroup(selection, T) {\n if (T) selection.text(([i]) => formatDefault(T[i]));\n}\n\nexport function applyChannelStyles(\n selection,\n {target, tip},\n {\n ariaLabel: AL,\n title: T,\n fill: F,\n fillOpacity: FO,\n stroke: S,\n strokeOpacity: SO,\n strokeWidth: SW,\n opacity: O,\n href: H\n }\n) {\n if (AL) applyAttr(selection, \"aria-label\", (i) => AL[i]);\n if (F) applyAttr(selection, \"fill\", (i) => F[i]);\n if (FO) applyAttr(selection, \"fill-opacity\", (i) => FO[i]);\n if (S) applyAttr(selection, \"stroke\", (i) => S[i]);\n if (SO) applyAttr(selection, \"stroke-opacity\", (i) => SO[i]);\n if (SW) applyAttr(selection, \"stroke-width\", (i) => SW[i]);\n if (O) applyAttr(selection, \"opacity\", (i) => O[i]);\n if (H) applyHref(selection, (i) => H[i], target);\n if (!tip) applyTitle(selection, T);\n}\n\nexport function applyGroupedChannelStyles(\n selection,\n {target, tip},\n {\n ariaLabel: AL,\n title: T,\n fill: F,\n fillOpacity: FO,\n stroke: S,\n strokeOpacity: SO,\n strokeWidth: SW,\n opacity: O,\n href: H\n }\n) {\n if (AL) applyAttr(selection, \"aria-label\", ([i]) => AL[i]);\n if (F) applyAttr(selection, \"fill\", ([i]) => F[i]);\n if (FO) applyAttr(selection, \"fill-opacity\", ([i]) => FO[i]);\n if (S) applyAttr(selection, \"stroke\", ([i]) => S[i]);\n if (SO) applyAttr(selection, \"stroke-opacity\", ([i]) => SO[i]);\n if (SW) applyAttr(selection, \"stroke-width\", ([i]) => SW[i]);\n if (O) applyAttr(selection, \"opacity\", ([i]) => O[i]);\n if (H) applyHref(selection, ([i]) => H[i], target);\n if (!tip) applyTitleGroup(selection, T);\n}\n\nfunction groupAesthetics(\n {\n ariaLabel: AL,\n title: T,\n fill: F,\n fillOpacity: FO,\n stroke: S,\n strokeOpacity: SO,\n strokeWidth: SW,\n opacity: O,\n href: H\n },\n {tip}\n) {\n return [AL, tip ? undefined : T, F, FO, S, SO, SW, O, H].filter((c) => c !== undefined);\n}\n\nexport function groupZ(I, Z, z) {\n const G = group(I, (i) => Z[i]);\n if (z === undefined && G.size > (1 + I.length) >> 1) {\n warn(\n `Warning: the implicit z channel has high cardinality. This may occur when the fill or stroke channel is associated with quantitative data rather than ordinal or categorical data. You can suppress this warning by setting the z option explicitly; if this data represents a single series, set z to null.`\n );\n }\n return G.values();\n}\n\nexport function* groupIndex(I, position, mark, channels) {\n const {z} = mark;\n const {z: Z} = channels; // group channel\n const A = groupAesthetics(channels, mark); // aesthetic channels\n const C = [...position, ...A]; // all channels\n\n // Group the current index by Z (if any).\n for (const G of Z ? groupZ(I, Z, z) : [I]) {\n let Ag; // the A-values (aesthetics) of the current group, if any\n let Gg; // the current group index (a subset of G, and I), if any\n out: for (const i of G) {\n // If any channel has an undefined value for this index, skip it.\n for (const c of C) {\n if (!defined(c[i])) {\n if (Gg) Gg.push(-1);\n continue out;\n }\n }\n\n // Otherwise, if this is a new group, record the aesthetics for this\n // group. Yield the current group and start a new one.\n if (Ag === undefined) {\n if (Gg) yield Gg;\n (Ag = A.map((c) => keyof(c[i]))), (Gg = [i]);\n continue;\n }\n\n // Otherwise, add the current index to the current group. Then, if any of\n // the aesthetics don’t match the current group, yield the current group\n // and start a new group of the current index.\n Gg.push(i);\n for (let j = 0; j < A.length; ++j) {\n const k = keyof(A[j][i]);\n if (k !== Ag[j]) {\n yield Gg;\n (Ag = A.map((c) => keyof(c[i]))), (Gg = [i]);\n continue out;\n }\n }\n }\n\n // Yield the current group, if any.\n if (Gg) yield Gg;\n }\n}\n\n// TODO Accept other types of clips (paths, urls, x, y, other marks…)?\n// https://github.com/observablehq/plot/issues/181\nexport function maybeClip(clip) {\n if (clip === true) clip = \"frame\";\n else if (clip === false) clip = null;\n else if (clip != null) clip = keyword(clip, \"clip\", [\"frame\", \"sphere\"]);\n return clip;\n}\n\n// Note: may mutate selection.node!\nfunction applyClip(selection, mark, dimensions, context) {\n let clipUrl;\n const {clip = context.clip} = mark;\n switch (clip) {\n case \"frame\": {\n const {width, height, marginLeft, marginRight, marginTop, marginBottom} = dimensions;\n const id = getClipId();\n clipUrl = `url(#${id})`;\n selection = create(\"svg:g\", context)\n .call((g) =>\n g\n .append(\"svg:clipPath\")\n .attr(\"id\", id)\n .append(\"rect\")\n .attr(\"x\", marginLeft)\n .attr(\"y\", marginTop)\n .attr(\"width\", width - marginRight - marginLeft)\n .attr(\"height\", height - marginTop - marginBottom)\n )\n .each(function () {\n this.appendChild(selection.node());\n selection.node = () => this; // Note: mutation!\n });\n break;\n }\n case \"sphere\": {\n const {projection} = context;\n if (!projection) throw new Error(`the \"sphere\" clip option requires a projection`);\n const id = getClipId();\n clipUrl = `url(#${id})`;\n selection\n .append(\"clipPath\")\n .attr(\"id\", id)\n .append(\"path\")\n .attr(\"d\", geoPath(projection)({type: \"Sphere\"}));\n break;\n }\n }\n // Here we’re careful to apply the ARIA attributes to the outer G element when\n // clipping is applied, and to apply the ARIA attributes before any other\n // attributes (for readability).\n applyAttr(selection, \"aria-label\", mark.ariaLabel);\n applyAttr(selection, \"aria-description\", mark.ariaDescription);\n applyAttr(selection, \"aria-hidden\", mark.ariaHidden);\n applyAttr(selection, \"clip-path\", clipUrl);\n}\n\n// Note: may mutate selection.node!\nexport function applyIndirectStyles(selection, mark, dimensions, context) {\n applyClip(selection, mark, dimensions, context);\n applyAttr(selection, \"fill\", mark.fill);\n applyAttr(selection, \"fill-opacity\", mark.fillOpacity);\n applyAttr(selection, \"stroke\", mark.stroke);\n applyAttr(selection, \"stroke-width\", mark.strokeWidth);\n applyAttr(selection, \"stroke-opacity\", mark.strokeOpacity);\n applyAttr(selection, \"stroke-linejoin\", mark.strokeLinejoin);\n applyAttr(selection, \"stroke-linecap\", mark.strokeLinecap);\n applyAttr(selection, \"stroke-miterlimit\", mark.strokeMiterlimit);\n applyAttr(selection, \"stroke-dasharray\", mark.strokeDasharray);\n applyAttr(selection, \"stroke-dashoffset\", mark.strokeDashoffset);\n applyAttr(selection, \"shape-rendering\", mark.shapeRendering);\n applyAttr(selection, \"filter\", mark.imageFilter);\n applyAttr(selection, \"paint-order\", mark.paintOrder);\n const {pointerEvents = context.pointerSticky === false ? \"none\" : undefined} = mark;\n applyAttr(selection, \"pointer-events\", pointerEvents);\n}\n\nexport function applyDirectStyles(selection, mark) {\n applyStyle(selection, \"mix-blend-mode\", mark.mixBlendMode);\n applyAttr(selection, \"opacity\", mark.opacity);\n}\n\nfunction applyHref(selection, href, target) {\n selection.each(function (i) {\n const h = href(i);\n if (h != null) {\n const a = this.ownerDocument.createElementNS(namespaces.svg, \"a\");\n a.setAttribute(\"fill\", \"inherit\");\n a.setAttributeNS(namespaces.xlink, \"href\", h);\n if (target != null) a.setAttribute(\"target\", target);\n this.parentNode.insertBefore(a, this).appendChild(this);\n }\n });\n}\n\nexport function applyAttr(selection, name, value) {\n if (value != null) selection.attr(name, value);\n}\n\nexport function applyStyle(selection, name, value) {\n if (value != null) selection.style(name, value);\n}\n\nexport function applyTransform(selection, mark, {x, y}, tx = offset, ty = offset) {\n tx += mark.dx;\n ty += mark.dy;\n if (x?.bandwidth) tx += x.bandwidth() / 2;\n if (y?.bandwidth) ty += y.bandwidth() / 2;\n if (tx || ty) selection.attr(\"transform\", `translate(${tx},${ty})`);\n}\n\nexport function impliedString(value, impliedValue) {\n if ((value = string(value)) !== impliedValue) return value;\n}\n\nexport function impliedNumber(value, impliedValue) {\n if ((value = number(value)) !== impliedValue) return value;\n}\n\n// https://www.w3.org/TR/CSS21/grammar.html\nconst validClassName =\n /^-?([_a-z]|[\\240-\\377]|\\\\[0-9a-f]{1,6}(\\r\\n|[ \\t\\r\\n\\f])?|\\\\[^\\r\\n\\f0-9a-f])([_a-z0-9-]|[\\240-\\377]|\\\\[0-9a-f]{1,6}(\\r\\n|[ \\t\\r\\n\\f])?|\\\\[^\\r\\n\\f0-9a-f])*$/i;\n\nexport function maybeClassName(name) {\n // The default should be changed whenever the default styles are changed, so\n // as to avoid conflict when multiple versions of Plot are on the page.\n if (name === undefined) return \"plot-d6a7b5\";\n name = `${name}`;\n if (!validClassName.test(name)) throw new Error(`invalid class name: ${name}`);\n return name;\n}\n\nexport function applyInlineStyles(selection, style) {\n if (typeof style === \"string\") {\n selection.property(\"style\", style);\n } else if (style != null) {\n for (const element of selection) {\n Object.assign(element.style, style);\n }\n }\n}\n\nexport function applyFrameAnchor({frameAnchor}, {width, height, marginTop, marginRight, marginBottom, marginLeft}) {\n return [\n /left$/.test(frameAnchor)\n ? marginLeft\n : /right$/.test(frameAnchor)\n ? width - marginRight\n : (marginLeft + width - marginRight) / 2,\n /^top/.test(frameAnchor)\n ? marginTop\n : /^bottom/.test(frameAnchor)\n ? height - marginBottom\n : (marginTop + height - marginBottom) / 2\n ];\n}\n","import {creator, select} from \"d3\";\nimport {maybeClip} from \"./style.js\";\n\nexport function createContext(options = {}) {\n const {document = typeof window !== \"undefined\" ? window.document : undefined, clip} = options;\n return {document, clip: maybeClip(clip)};\n}\n\nexport function create(name, {document}) {\n return select(creator(name).call(document.documentElement));\n}\n","import {\n geoAlbers,\n geoAlbersUsa,\n geoAzimuthalEqualArea,\n geoAzimuthalEquidistant,\n geoClipRectangle,\n geoConicConformal,\n geoConicEqualArea,\n geoConicEquidistant,\n geoEqualEarth,\n geoEquirectangular,\n geoGnomonic,\n geoMercator,\n geoOrthographic,\n geoPath,\n geoStereographic,\n geoStream,\n geoTransform,\n geoTransverseMercator\n} from \"d3\";\nimport {valueObject} from \"./channel.js\";\nimport {coerceNumbers, constant, isObject} from \"./options.js\";\nimport {warn} from \"./warnings.js\";\n\nconst pi = Math.PI;\nconst tau = 2 * pi;\nconst defaultAspectRatio = 0.618;\n\nexport function createProjection(\n {\n projection,\n inset: globalInset = 0,\n insetTop = globalInset,\n insetRight = globalInset,\n insetBottom = globalInset,\n insetLeft = globalInset\n } = {},\n dimensions\n) {\n if (projection == null) return;\n if (typeof projection.stream === \"function\") return projection; // d3 projection\n let options;\n let domain;\n let clip = \"frame\";\n\n // If the projection was specified as an object with additional options,\n // extract those. The order of precedence for insetTop (and other insets) is:\n // projection.insetTop, projection.inset, (global) insetTop, (global) inset.\n // Any other options on this object will be passed through to the initializer.\n if (isObject(projection)) {\n let inset;\n ({\n type: projection,\n domain,\n inset,\n insetTop = inset !== undefined ? inset : insetTop,\n insetRight = inset !== undefined ? inset : insetRight,\n insetBottom = inset !== undefined ? inset : insetBottom,\n insetLeft = inset !== undefined ? inset : insetLeft,\n clip = clip,\n ...options\n } = projection);\n if (projection == null) return;\n }\n\n // For named projections, retrieve the corresponding projection initializer.\n if (typeof projection !== \"function\") ({type: projection} = namedProjection(projection));\n\n // Compute the frame dimensions and invoke the projection initializer.\n const {width, height, marginLeft, marginRight, marginTop, marginBottom} = dimensions;\n const dx = width - marginLeft - marginRight - insetLeft - insetRight;\n const dy = height - marginTop - marginBottom - insetTop - insetBottom;\n projection = projection?.({width: dx, height: dy, clip, ...options});\n\n // The projection initializer might decide to not use a projection.\n if (projection == null) return;\n clip = maybePostClip(clip, marginLeft, marginTop, width - marginRight, height - marginBottom);\n\n // Translate the origin to the top-left corner, respecting margins and insets.\n let tx = marginLeft + insetLeft;\n let ty = marginTop + insetTop;\n let transform;\n\n // If a domain is specified, fit the projection to the frame.\n if (domain != null) {\n const [[x0, y0], [x1, y1]] = geoPath(projection).bounds(domain);\n const k = Math.min(dx / (x1 - x0), dy / (y1 - y0));\n if (k > 0) {\n tx -= (k * (x0 + x1) - dx) / 2;\n ty -= (k * (y0 + y1) - dy) / 2;\n transform = geoTransform({\n point(x, y) {\n this.stream.point(x * k + tx, y * k + ty);\n }\n });\n } else {\n warn(`Warning: the projection could not be fit to the specified domain; using the default scale.`);\n }\n }\n\n transform ??=\n tx === 0 && ty === 0\n ? identity()\n : geoTransform({\n point(x, y) {\n this.stream.point(x + tx, y + ty);\n }\n });\n\n return {stream: (s) => projection.stream(transform.stream(clip(s)))};\n}\n\nfunction namedProjection(projection) {\n switch (`${projection}`.toLowerCase()) {\n case \"albers-usa\":\n return scaleProjection(geoAlbersUsa, 0.7463, 0.4673);\n case \"albers\":\n return conicProjection(geoAlbers, 0.7463, 0.4673);\n case \"azimuthal-equal-area\":\n return scaleProjection(geoAzimuthalEqualArea, 4, 4);\n case \"azimuthal-equidistant\":\n return scaleProjection(geoAzimuthalEquidistant, tau, tau);\n case \"conic-conformal\":\n return conicProjection(geoConicConformal, tau, tau);\n case \"conic-equal-area\":\n return conicProjection(geoConicEqualArea, 6.1702, 2.9781);\n case \"conic-equidistant\":\n return conicProjection(geoConicEquidistant, 7.312, 3.6282);\n case \"equal-earth\":\n return scaleProjection(geoEqualEarth, 5.4133, 2.6347);\n case \"equirectangular\":\n return scaleProjection(geoEquirectangular, tau, pi);\n case \"gnomonic\":\n return scaleProjection(geoGnomonic, 3.4641, 3.4641);\n case \"identity\":\n return {type: identity};\n case \"reflect-y\":\n return {type: reflectY};\n case \"mercator\":\n return scaleProjection(geoMercator, tau, tau);\n case \"orthographic\":\n return scaleProjection(geoOrthographic, 2, 2);\n case \"stereographic\":\n return scaleProjection(geoStereographic, 2, 2);\n case \"transverse-mercator\":\n return scaleProjection(geoTransverseMercator, tau, tau);\n default:\n throw new Error(`unknown projection type: ${projection}`);\n }\n}\n\nfunction maybePostClip(clip, x1, y1, x2, y2) {\n if (clip === false || clip == null || typeof clip === \"number\") return (s) => s;\n if (clip === true) clip = \"frame\";\n switch (`${clip}`.toLowerCase()) {\n case \"frame\":\n return geoClipRectangle(x1, y1, x2, y2);\n default:\n throw new Error(`unknown projection clip type: ${clip}`);\n }\n}\n\nfunction scaleProjection(createProjection, kx, ky) {\n return {\n type: ({width, height, rotate, precision = 0.15, clip}) => {\n const projection = createProjection();\n if (precision != null) projection.precision?.(precision);\n if (rotate != null) projection.rotate?.(rotate);\n if (typeof clip === \"number\") projection.clipAngle?.(clip);\n projection.scale(Math.min(width / kx, height / ky));\n projection.translate([width / 2, height / 2]);\n return projection;\n },\n aspectRatio: ky / kx\n };\n}\n\nfunction conicProjection(createProjection, kx, ky) {\n const {type, aspectRatio} = scaleProjection(createProjection, kx, ky);\n return {\n type: (options) => {\n const {parallels, domain, width, height} = options;\n const projection = type(options);\n if (parallels != null) {\n projection.parallels(parallels);\n if (domain === undefined) {\n projection.fitSize([width, height], {type: \"Sphere\"});\n }\n }\n return projection;\n },\n aspectRatio\n };\n}\n\nconst identity = constant({stream: (stream) => stream});\n\nconst reflectY = constant(\n geoTransform({\n point(x, y) {\n this.stream.point(x, -y);\n }\n })\n);\n\n// Applies a point-wise projection to the given paired x and y channels.\n// Note: mutates values!\nexport function project(cx, cy, values, projection) {\n const x = values[cx];\n const y = values[cy];\n const n = x.length;\n const X = (values[cx] = new Float64Array(n).fill(NaN));\n const Y = (values[cy] = new Float64Array(n).fill(NaN));\n let i;\n const stream = projection.stream({\n point(x, y) {\n X[i] = x;\n Y[i] = y;\n }\n });\n for (i = 0; i < n; ++i) {\n stream.point(x[i], y[i]);\n }\n}\n\n// Returns true if a projection was specified. This should match the logic of\n// createProjection above, and is called before we construct the projection.\n// (Though note that we ignore the edge case where the projection initializer\n// may return null.)\nexport function hasProjection({projection} = {}) {\n if (projection == null) return false;\n if (typeof projection.stream === \"function\") return true;\n if (isObject(projection)) projection = projection.type;\n return projection != null;\n}\n\n// When a named projection is specified, we can use its natural aspect ratio to\n// determine a good value for the projection’s height based on the desired\n// width. When we don’t have a way to know, the golden ratio is our best guess.\n// Due to a circular dependency (we need to know the height before we can\n// construct the projection), we have to test the raw projection option rather\n// than the materialized projection; therefore we must be extremely careful that\n// the logic of this function exactly matches createProjection above!\nexport function projectionAspectRatio(projection) {\n if (typeof projection?.stream === \"function\") return defaultAspectRatio;\n if (isObject(projection)) projection = projection.type;\n if (projection == null) return;\n if (typeof projection !== \"function\") {\n const {aspectRatio} = namedProjection(projection);\n if (aspectRatio) return aspectRatio;\n }\n return defaultAspectRatio;\n}\n\n// Extract the (possibly) scaled values for the x and y channels, and apply the\n// projection if any.\nexport function applyPosition(channels, scales, {projection}) {\n const {x, y} = channels;\n let position = {};\n if (x) position.x = x;\n if (y) position.y = y;\n position = valueObject(position, scales);\n if (projection && x?.scale === \"x\" && y?.scale === \"y\") project(\"x\", \"y\", position, projection);\n if (x) position.x = coerceNumbers(position.x);\n if (y) position.y = coerceNumbers(position.y);\n return position;\n}\n\nexport function getGeometryChannels(channel) {\n const X = [];\n const Y = [];\n const x = {scale: \"x\", value: X};\n const y = {scale: \"y\", value: Y};\n const sink = {\n point(x, y) {\n X.push(x);\n Y.push(y);\n },\n lineStart() {},\n lineEnd() {},\n polygonStart() {},\n polygonEnd() {},\n sphere() {}\n };\n for (const object of channel.value) geoStream(object, sink);\n return [x, y];\n}\n","import {\n interpolateBlues,\n interpolateBrBG,\n interpolateBuGn,\n interpolateBuPu,\n interpolateGnBu,\n interpolateGreens,\n interpolateGreys,\n interpolateOranges,\n interpolateOrRd,\n interpolatePiYG,\n interpolatePRGn,\n interpolatePuBu,\n interpolatePuBuGn,\n interpolatePuOr,\n interpolatePuRd,\n interpolatePurples,\n interpolateRdBu,\n interpolateRdGy,\n interpolateRdPu,\n interpolateRdYlBu,\n interpolateRdYlGn,\n interpolateReds,\n interpolateSpectral,\n interpolateYlGn,\n interpolateYlGnBu,\n interpolateYlOrBr,\n interpolateYlOrRd,\n interpolateTurbo,\n interpolateViridis,\n interpolateMagma,\n interpolateInferno,\n interpolatePlasma,\n interpolateCividis,\n interpolateCubehelixDefault,\n interpolateWarm,\n interpolateCool,\n interpolateRainbow,\n interpolateSinebow,\n quantize,\n schemeAccent,\n schemeBlues,\n schemeBrBG,\n schemeBuGn,\n schemeBuPu,\n schemeCategory10,\n schemeDark2,\n schemeGnBu,\n schemeGreens,\n schemeGreys,\n schemeOranges,\n schemeOrRd,\n schemePaired,\n schemePastel1,\n schemePastel2,\n schemePiYG,\n schemePRGn,\n schemePuBu,\n schemePuBuGn,\n schemePuOr,\n schemePuRd,\n schemePurples,\n schemeRdBu,\n schemeRdGy,\n schemeRdPu,\n schemeRdYlBu,\n schemeRdYlGn,\n schemeReds,\n schemeSet1,\n schemeSet2,\n schemeSet3,\n schemeSpectral,\n schemeTableau10,\n schemeYlGn,\n schemeYlGnBu,\n schemeYlOrBr,\n schemeYlOrRd\n} from \"d3\";\n\nconst categoricalSchemes = new Map([\n [\"accent\", schemeAccent],\n [\"category10\", schemeCategory10],\n [\"dark2\", schemeDark2],\n [\"paired\", schemePaired],\n [\"pastel1\", schemePastel1],\n [\"pastel2\", schemePastel2],\n [\"set1\", schemeSet1],\n [\"set2\", schemeSet2],\n [\"set3\", schemeSet3],\n [\"tableau10\", schemeTableau10]\n]);\n\nexport function isCategoricalScheme(scheme) {\n return scheme != null && categoricalSchemes.has(`${scheme}`.toLowerCase());\n}\n\nconst ordinalSchemes = new Map([\n ...categoricalSchemes,\n\n // diverging\n [\"brbg\", scheme11(schemeBrBG, interpolateBrBG)],\n [\"prgn\", scheme11(schemePRGn, interpolatePRGn)],\n [\"piyg\", scheme11(schemePiYG, interpolatePiYG)],\n [\"puor\", scheme11(schemePuOr, interpolatePuOr)],\n [\"rdbu\", scheme11(schemeRdBu, interpolateRdBu)],\n [\"rdgy\", scheme11(schemeRdGy, interpolateRdGy)],\n [\"rdylbu\", scheme11(schemeRdYlBu, interpolateRdYlBu)],\n [\"rdylgn\", scheme11(schemeRdYlGn, interpolateRdYlGn)],\n [\"spectral\", scheme11(schemeSpectral, interpolateSpectral)],\n\n // reversed diverging (for temperature data)\n [\"burd\", scheme11r(schemeRdBu, interpolateRdBu)],\n [\"buylrd\", scheme11r(schemeRdYlBu, interpolateRdYlBu)],\n\n // sequential (single-hue)\n [\"blues\", scheme9(schemeBlues, interpolateBlues)],\n [\"greens\", scheme9(schemeGreens, interpolateGreens)],\n [\"greys\", scheme9(schemeGreys, interpolateGreys)],\n [\"oranges\", scheme9(schemeOranges, interpolateOranges)],\n [\"purples\", scheme9(schemePurples, interpolatePurples)],\n [\"reds\", scheme9(schemeReds, interpolateReds)],\n\n // sequential (multi-hue)\n [\"turbo\", schemei(interpolateTurbo)],\n [\"viridis\", schemei(interpolateViridis)],\n [\"magma\", schemei(interpolateMagma)],\n [\"inferno\", schemei(interpolateInferno)],\n [\"plasma\", schemei(interpolatePlasma)],\n [\"cividis\", schemei(interpolateCividis)],\n [\"cubehelix\", schemei(interpolateCubehelixDefault)],\n [\"warm\", schemei(interpolateWarm)],\n [\"cool\", schemei(interpolateCool)],\n [\"bugn\", scheme9(schemeBuGn, interpolateBuGn)],\n [\"bupu\", scheme9(schemeBuPu, interpolateBuPu)],\n [\"gnbu\", scheme9(schemeGnBu, interpolateGnBu)],\n [\"orrd\", scheme9(schemeOrRd, interpolateOrRd)],\n [\"pubu\", scheme9(schemePuBu, interpolatePuBu)],\n [\"pubugn\", scheme9(schemePuBuGn, interpolatePuBuGn)],\n [\"purd\", scheme9(schemePuRd, interpolatePuRd)],\n [\"rdpu\", scheme9(schemeRdPu, interpolateRdPu)],\n [\"ylgn\", scheme9(schemeYlGn, interpolateYlGn)],\n [\"ylgnbu\", scheme9(schemeYlGnBu, interpolateYlGnBu)],\n [\"ylorbr\", scheme9(schemeYlOrBr, interpolateYlOrBr)],\n [\"ylorrd\", scheme9(schemeYlOrRd, interpolateYlOrRd)],\n\n // cyclical\n [\"rainbow\", schemeicyclical(interpolateRainbow)],\n [\"sinebow\", schemeicyclical(interpolateSinebow)]\n]);\n\nfunction scheme9(scheme, interpolate) {\n return ({length: n}) => {\n if (n === 1) return [scheme[3][1]]; // favor midpoint\n if (n === 2) return [scheme[3][1], scheme[3][2]]; // favor darker\n n = Math.max(3, Math.floor(n));\n return n > 9 ? quantize(interpolate, n) : scheme[n];\n };\n}\n\nfunction scheme11(scheme, interpolate) {\n return ({length: n}) => {\n if (n === 2) return [scheme[3][0], scheme[3][2]]; // favor diverging extrema\n n = Math.max(3, Math.floor(n));\n return n > 11 ? quantize(interpolate, n) : scheme[n];\n };\n}\n\nfunction scheme11r(scheme, interpolate) {\n return ({length: n}) => {\n if (n === 2) return [scheme[3][2], scheme[3][0]]; // favor diverging extrema\n n = Math.max(3, Math.floor(n));\n return n > 11 ? quantize((t) => interpolate(1 - t), n) : scheme[n].slice().reverse();\n };\n}\n\nfunction schemei(interpolate) {\n return ({length: n}) => quantize(interpolate, Math.max(2, Math.floor(n)));\n}\n\nfunction schemeicyclical(interpolate) {\n return ({length: n}) => quantize(interpolate, Math.floor(n) + 1).slice(0, -1);\n}\n\nexport function ordinalScheme(scheme) {\n const s = `${scheme}`.toLowerCase();\n if (!ordinalSchemes.has(s)) throw new Error(`unknown ordinal scheme: ${s}`);\n return ordinalSchemes.get(s);\n}\n\nexport function ordinalRange(scheme, length) {\n const s = ordinalScheme(scheme);\n const r = typeof s === \"function\" ? s({length}) : s;\n return r.length !== length ? r.slice(0, length) : r;\n}\n\n// If the specified domain contains only booleans (ignoring null and undefined),\n// returns a corresponding range where false is mapped to the low color and true\n// is mapped to the high color of the specified scheme.\nexport function maybeBooleanRange(domain, scheme = \"greys\") {\n const range = new Set();\n const [f, t] = ordinalRange(scheme, 2);\n for (const value of domain) {\n if (value == null) continue;\n if (value === true) range.add(t);\n else if (value === false) range.add(f);\n else return;\n }\n return [...range];\n}\n\nconst quantitativeSchemes = new Map([\n // diverging\n [\"brbg\", interpolateBrBG],\n [\"prgn\", interpolatePRGn],\n [\"piyg\", interpolatePiYG],\n [\"puor\", interpolatePuOr],\n [\"rdbu\", interpolateRdBu],\n [\"rdgy\", interpolateRdGy],\n [\"rdylbu\", interpolateRdYlBu],\n [\"rdylgn\", interpolateRdYlGn],\n [\"spectral\", interpolateSpectral],\n\n // reversed diverging (for temperature data)\n [\"burd\", (t) => interpolateRdBu(1 - t)],\n [\"buylrd\", (t) => interpolateRdYlBu(1 - t)],\n\n // sequential (single-hue)\n [\"blues\", interpolateBlues],\n [\"greens\", interpolateGreens],\n [\"greys\", interpolateGreys],\n [\"purples\", interpolatePurples],\n [\"reds\", interpolateReds],\n [\"oranges\", interpolateOranges],\n\n // sequential (multi-hue)\n [\"turbo\", interpolateTurbo],\n [\"viridis\", interpolateViridis],\n [\"magma\", interpolateMagma],\n [\"inferno\", interpolateInferno],\n [\"plasma\", interpolatePlasma],\n [\"cividis\", interpolateCividis],\n [\"cubehelix\", interpolateCubehelixDefault],\n [\"warm\", interpolateWarm],\n [\"cool\", interpolateCool],\n [\"bugn\", interpolateBuGn],\n [\"bupu\", interpolateBuPu],\n [\"gnbu\", interpolateGnBu],\n [\"orrd\", interpolateOrRd],\n [\"pubugn\", interpolatePuBuGn],\n [\"pubu\", interpolatePuBu],\n [\"purd\", interpolatePuRd],\n [\"rdpu\", interpolateRdPu],\n [\"ylgnbu\", interpolateYlGnBu],\n [\"ylgn\", interpolateYlGn],\n [\"ylorbr\", interpolateYlOrBr],\n [\"ylorrd\", interpolateYlOrRd],\n\n // cyclical\n [\"rainbow\", interpolateRainbow],\n [\"sinebow\", interpolateSinebow]\n]);\n\nexport function quantitativeScheme(scheme) {\n const s = `${scheme}`.toLowerCase();\n if (!quantitativeSchemes.has(s)) throw new Error(`unknown quantitative scheme: ${s}`);\n return quantitativeSchemes.get(s);\n}\n\nconst divergingSchemes = new Set([\n \"brbg\",\n \"prgn\",\n \"piyg\",\n \"puor\",\n \"rdbu\",\n \"rdgy\",\n \"rdylbu\",\n \"rdylgn\",\n \"spectral\",\n \"burd\",\n \"buylrd\"\n]);\n\nexport function isDivergingScheme(scheme) {\n return scheme != null && divergingSchemes.has(`${scheme}`.toLowerCase());\n}\n","import {\n descending,\n extent,\n interpolateHcl,\n interpolateHsl,\n interpolateLab,\n interpolateNumber,\n interpolateRgb,\n interpolateRound,\n max,\n median,\n min,\n piecewise,\n quantile,\n quantize,\n reverse as reverseof,\n scaleIdentity,\n scaleLinear,\n scaleLog,\n scalePow,\n scaleQuantile,\n scaleSymlog,\n scaleThreshold,\n ticks\n} from \"d3\";\nimport {finite, negative, positive} from \"../defined.js\";\nimport {arrayify, constant, maybeNiceInterval, maybeRangeInterval, orderof, slice} from \"../options.js\";\nimport {color, length, opacity, radius, registry, hasNumericRange} from \"./index.js\";\nimport {ordinalRange, quantitativeScheme} from \"./schemes.js\";\n\nexport const flip = (i) => (t) => i(1 - t);\nconst unit = [0, 1];\n\nconst interpolators = new Map([\n // numbers\n [\"number\", interpolateNumber],\n\n // color spaces\n [\"rgb\", interpolateRgb],\n [\"hsl\", interpolateHsl],\n [\"hcl\", interpolateHcl],\n [\"lab\", interpolateLab]\n]);\n\nexport function maybeInterpolator(interpolate) {\n const i = `${interpolate}`.toLowerCase();\n if (!interpolators.has(i)) throw new Error(`unknown interpolator: ${i}`);\n return interpolators.get(i);\n}\n\nexport function createScaleQ(\n key,\n scale,\n channels,\n {\n type,\n nice,\n clamp,\n zero,\n domain = inferAutoDomain(key, channels),\n unknown,\n round,\n scheme,\n interval,\n range = registry.get(key) === radius\n ? inferRadialRange(channels, domain)\n : registry.get(key) === length\n ? inferLengthRange(channels, domain)\n : registry.get(key) === opacity\n ? unit\n : undefined,\n interpolate = registry.get(key) === color\n ? scheme == null && range !== undefined\n ? interpolateRgb\n : quantitativeScheme(scheme !== undefined ? scheme : type === \"cyclical\" ? \"rainbow\" : \"turbo\")\n : round\n ? interpolateRound\n : interpolateNumber,\n reverse\n }\n) {\n interval = maybeRangeInterval(interval, type);\n if (type === \"cyclical\" || type === \"sequential\") type = \"linear\"; // shorthand for color schemes\n if (typeof interpolate !== \"function\") interpolate = maybeInterpolator(interpolate); // named interpolator\n reverse = !!reverse;\n\n // If an explicit range is specified, and it has a different length than the\n // domain, then redistribute the range using a piecewise interpolator.\n if (range !== undefined) {\n const n = (domain = arrayify(domain)).length;\n const m = (range = arrayify(range)).length;\n if (n !== m) {\n if (interpolate.length === 1) throw new Error(\"invalid piecewise interpolator\"); // e.g., turbo\n interpolate = piecewise(interpolate, range);\n range = undefined;\n }\n }\n\n // Disambiguate between a two-argument interpolator that is used in\n // conjunction with the range, and a one-argument “fixed” interpolator on the\n // [0, 1] interval as with the RdBu color scheme.\n if (interpolate.length === 1) {\n if (reverse) {\n interpolate = flip(interpolate);\n reverse = false;\n }\n if (range === undefined) {\n range = Float64Array.from(domain, (_, i) => i / (domain.length - 1));\n if (range.length === 2) range = unit; // optimize common case of [0, 1]\n }\n scale.interpolate((range === unit ? constant : interpolatePiecewise)(interpolate));\n } else {\n scale.interpolate(interpolate);\n }\n\n // If a zero option is specified, we assume that the domain is numeric, and we\n // want to ensure that the domain crosses zero. However, note that the domain\n // may be reversed (descending) so we shouldn’t assume that the first value is\n // smaller than the last; and also it’s possible that the domain has more than\n // two values for a “poly” scale. And lastly be careful not to mutate input!\n if (zero) {\n const [min, max] = extent(domain);\n if (min > 0 || max < 0) {\n domain = slice(domain);\n if (orderof(domain) !== Math.sign(min)) domain[domain.length - 1] = 0; // [2, 1] or [-2, -1]\n else domain[0] = 0; // [1, 2] or [-1, -2]\n }\n }\n\n if (reverse) domain = reverseof(domain);\n scale.domain(domain).unknown(unknown);\n if (nice) scale.nice(maybeNice(nice, type)), (domain = scale.domain());\n if (range !== undefined) scale.range(range);\n if (clamp) scale.clamp(clamp);\n return {type, domain, range, scale, interpolate, interval};\n}\n\nfunction maybeNice(nice, type) {\n return nice === true ? undefined : typeof nice === \"number\" ? nice : maybeNiceInterval(nice, type);\n}\n\nexport function createScaleLinear(key, channels, options) {\n return createScaleQ(key, scaleLinear(), channels, options);\n}\n\nexport function createScaleSqrt(key, channels, options) {\n return createScalePow(key, channels, {...options, exponent: 0.5});\n}\n\nexport function createScalePow(key, channels, {exponent = 1, ...options}) {\n return createScaleQ(key, scalePow().exponent(exponent), channels, {...options, type: \"pow\"});\n}\n\nexport function createScaleLog(key, channels, {base = 10, domain = inferLogDomain(channels), ...options}) {\n return createScaleQ(key, scaleLog().base(base), channels, {...options, domain});\n}\n\nexport function createScaleSymlog(key, channels, {constant = 1, ...options}) {\n return createScaleQ(key, scaleSymlog().constant(constant), channels, options);\n}\n\nexport function createScaleQuantile(\n key,\n channels,\n {\n range,\n quantiles = range === undefined ? 5 : (range = [...range]).length, // deprecated; use n instead\n n = quantiles,\n scheme = \"rdylbu\",\n domain = inferQuantileDomain(channels),\n unknown,\n interpolate,\n reverse\n }\n) {\n if (range === undefined) {\n range =\n interpolate !== undefined\n ? quantize(interpolate, n)\n : registry.get(key) === color\n ? ordinalRange(scheme, n)\n : undefined;\n }\n if (domain.length > 0) {\n domain = scaleQuantile(domain, range === undefined ? {length: n} : range).quantiles();\n }\n return createScaleThreshold(key, channels, {domain, range, reverse, unknown});\n}\n\nexport function createScaleQuantize(\n key,\n channels,\n {\n range,\n n = range === undefined ? 5 : (range = [...range]).length,\n scheme = \"rdylbu\",\n domain = inferAutoDomain(key, channels),\n unknown,\n interpolate,\n reverse\n }\n) {\n const [min, max] = extent(domain);\n let thresholds;\n if (range === undefined) {\n thresholds = ticks(min, max, n); // approximate number of nice, round thresholds\n if (thresholds[0] <= min) thresholds.splice(0, 1); // drop exact lower bound\n if (thresholds[thresholds.length - 1] >= max) thresholds.pop(); // drop exact upper bound\n n = thresholds.length + 1;\n range =\n interpolate !== undefined\n ? quantize(interpolate, n)\n : registry.get(key) === color\n ? ordinalRange(scheme, n)\n : undefined;\n } else {\n thresholds = quantize(interpolateNumber(min, max), n + 1).slice(1, -1); // exactly n - 1 thresholds to match range\n if (min instanceof Date) thresholds = thresholds.map((x) => new Date(x)); // preserve date types\n }\n if (orderof(arrayify(domain)) < 0) thresholds.reverse(); // preserve descending domain\n return createScaleThreshold(key, channels, {domain: thresholds, range, reverse, unknown});\n}\n\nexport function createScaleThreshold(\n key,\n channels,\n {\n domain = [0], // explicit thresholds in ascending order\n unknown,\n scheme = \"rdylbu\",\n interpolate,\n range = interpolate !== undefined\n ? quantize(interpolate, domain.length + 1)\n : registry.get(key) === color\n ? ordinalRange(scheme, domain.length + 1)\n : undefined,\n reverse\n }\n) {\n domain = arrayify(domain);\n const sign = orderof(domain); // preserve descending domain\n if (!isNaN(sign) && !isOrdered(domain, sign)) throw new Error(`the ${key} scale has a non-monotonic domain`);\n if (reverse) range = reverseof(range); // domain ascending, so reverse range\n return {\n type: \"threshold\",\n scale: scaleThreshold(sign < 0 ? reverseof(domain) : domain, range === undefined ? [] : range).unknown(unknown),\n domain,\n range\n };\n}\n\nfunction isOrdered(domain, sign) {\n for (let i = 1, n = domain.length, d = domain[0]; i < n; ++i) {\n const s = descending(d, (d = domain[i]));\n if (s !== 0 && s !== sign) return false;\n }\n return true;\n}\n\n// For non-numeric identity scales such as color and symbol, we can’t use D3’s\n// identity scale because it coerces to number; and we can’t compute the domain\n// (and equivalently range) since we can’t know whether the values are\n// continuous or discrete.\nexport function createScaleIdentity(key) {\n return {type: \"identity\", scale: hasNumericRange(registry.get(key)) ? scaleIdentity() : (d) => d};\n}\n\nexport function inferDomain(channels, f = finite) {\n return channels.length\n ? [\n min(channels, ({value}) => (value === undefined ? value : min(value, f))),\n max(channels, ({value}) => (value === undefined ? value : max(value, f)))\n ]\n : [0, 1];\n}\n\nfunction inferAutoDomain(key, channels) {\n const type = registry.get(key);\n return (type === radius || type === opacity || type === length ? inferZeroDomain : inferDomain)(channels);\n}\n\nfunction inferZeroDomain(channels) {\n return [0, channels.length ? max(channels, ({value}) => (value === undefined ? value : max(value, finite))) : 1];\n}\n\n// We don’t want the upper bound of the radial domain to be zero, as this would\n// be degenerate, so we ignore nonpositive values. We also don’t want the\n// maximum default radius to exceed 30px.\nfunction inferRadialRange(channels, domain) {\n const hint = channels.find(({radius}) => radius !== undefined);\n if (hint !== undefined) return [0, hint.radius]; // a natural maximum radius, e.g. hexbins\n const h25 = quantile(channels, 0.5, ({value}) => (value === undefined ? NaN : quantile(value, 0.25, positive)));\n const range = domain.map((d) => 3 * Math.sqrt(d / h25));\n const k = 30 / max(range);\n return k < 1 ? range.map((r) => r * k) : range;\n}\n\n// We want a length scale’s domain to go from zero to a positive value, and to\n// treat negative lengths if any as inverted vectors of equivalent magnitude. We\n// also don’t want the maximum default length to exceed 60px.\nfunction inferLengthRange(channels, domain) {\n const h50 = median(channels, ({value}) => (value === undefined ? NaN : median(value, Math.abs)));\n const range = domain.map((d) => (12 * d) / h50);\n const k = 60 / max(range);\n return k < 1 ? range.map((r) => r * k) : range;\n}\n\nfunction inferLogDomain(channels) {\n for (const {value} of channels) {\n if (value !== undefined) {\n for (let v of value) {\n if (v > 0) return inferDomain(channels, positive);\n if (v < 0) return inferDomain(channels, negative);\n }\n }\n }\n return [1, 10];\n}\n\nfunction inferQuantileDomain(channels) {\n const domain = [];\n for (const {value} of channels) {\n if (value === undefined) continue;\n for (const v of value) domain.push(v);\n }\n return domain;\n}\n\nexport function interpolatePiecewise(interpolate) {\n return (i, j) => (t) => interpolate(i + t * (j - i));\n}\n","import {lab as colorLab} from \"d3-color\";\nimport color from \"./color.js\";\n\nexport default function lab(start, end) {\n var l = color((start = colorLab(start)).l, (end = colorLab(end)).l),\n a = color(start.a, end.a),\n b = color(start.b, end.b),\n opacity = color(start.opacity, end.opacity);\n return function(t) {\n start.l = l(t);\n start.a = a(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n}\n","import {\n descending,\n interpolateNumber,\n interpolateRgb,\n piecewise,\n scaleDiverging,\n scaleDivergingLog,\n scaleDivergingPow,\n scaleDivergingSymlog\n} from \"d3\";\nimport {negative, positive} from \"../defined.js\";\nimport {arrayify} from \"../options.js\";\nimport {warn} from \"../warnings.js\";\nimport {color, registry} from \"./index.js\";\nimport {flip, inferDomain, interpolatePiecewise, maybeInterpolator} from \"./quantitative.js\";\nimport {quantitativeScheme} from \"./schemes.js\";\n\nfunction createScaleD(\n key,\n scale,\n transform,\n channels,\n {\n type,\n nice,\n clamp,\n domain = inferDomain(channels),\n unknown,\n pivot = 0,\n scheme,\n range,\n symmetric = true,\n interpolate = registry.get(key) === color\n ? scheme == null && range !== undefined\n ? interpolateRgb\n : quantitativeScheme(scheme !== undefined ? scheme : \"rdbu\")\n : interpolateNumber,\n reverse\n }\n) {\n pivot = +pivot;\n domain = arrayify(domain);\n let [min, max] = domain;\n if (domain.length > 2) warn(`Warning: the diverging ${key} scale domain contains extra elements.`);\n\n if (descending(min, max) < 0) ([min, max] = [max, min]), (reverse = !reverse);\n min = Math.min(min, pivot);\n max = Math.max(max, pivot);\n\n // Sometimes interpolate is a named interpolator, such as \"lab\" for Lab color\n // space. Other times interpolate is a function that takes two arguments and\n // is used in conjunction with the range. And other times the interpolate\n // function is a “fixed” interpolator on the [0, 1] interval, as when a\n // color scheme such as interpolateRdBu is used.\n if (typeof interpolate !== \"function\") {\n interpolate = maybeInterpolator(interpolate);\n }\n\n // If an explicit range is specified, promote it to a piecewise interpolator.\n if (range !== undefined) {\n interpolate =\n interpolate.length === 1 ? interpolatePiecewise(interpolate)(...range) : piecewise(interpolate, range);\n }\n\n // Reverse before normalization.\n if (reverse) interpolate = flip(interpolate);\n\n // Normalize the interpolator for symmetric difference around the pivot.\n if (symmetric) {\n const mid = transform.apply(pivot);\n const mindelta = mid - transform.apply(min);\n const maxdelta = transform.apply(max) - mid;\n if (mindelta < maxdelta) min = transform.invert(mid - maxdelta);\n else if (mindelta > maxdelta) max = transform.invert(mid + mindelta);\n }\n\n scale.domain([min, pivot, max]).unknown(unknown).interpolator(interpolate);\n if (clamp) scale.clamp(clamp);\n if (nice) scale.nice(nice);\n return {type, domain: [min, max], pivot, interpolate, scale};\n}\n\nexport function createScaleDiverging(key, channels, options) {\n return createScaleD(key, scaleDiverging(), transformIdentity, channels, options);\n}\n\nexport function createScaleDivergingSqrt(key, channels, options) {\n return createScaleDivergingPow(key, channels, {...options, exponent: 0.5});\n}\n\nexport function createScaleDivergingPow(key, channels, {exponent = 1, ...options}) {\n return createScaleD(key, scaleDivergingPow().exponent((exponent = +exponent)), transformPow(exponent), channels, {\n ...options,\n type: \"diverging-pow\"\n });\n}\n\nexport function createScaleDivergingLog(\n key,\n channels,\n {base = 10, pivot = 1, domain = inferDomain(channels, pivot < 0 ? negative : positive), ...options}\n) {\n return createScaleD(key, scaleDivergingLog().base((base = +base)), transformLog, channels, {\n domain,\n pivot,\n ...options\n });\n}\n\nexport function createScaleDivergingSymlog(key, channels, {constant = 1, ...options}) {\n return createScaleD(\n key,\n scaleDivergingSymlog().constant((constant = +constant)),\n transformSymlog(constant),\n channels,\n options\n );\n}\n\nconst transformIdentity = {\n apply(x) {\n return x;\n },\n invert(x) {\n return x;\n }\n};\n\nconst transformLog = {\n apply: Math.log,\n invert: Math.exp\n};\n\nconst transformSqrt = {\n apply(x) {\n return Math.sign(x) * Math.sqrt(Math.abs(x));\n },\n invert(x) {\n return Math.sign(x) * (x * x);\n }\n};\n\nfunction transformPow(exponent) {\n return exponent === 0.5\n ? transformSqrt\n : {\n apply(x) {\n return Math.sign(x) * Math.pow(Math.abs(x), exponent);\n },\n invert(x) {\n return Math.sign(x) * Math.pow(Math.abs(x), 1 / exponent);\n }\n };\n}\n\nfunction transformSymlog(constant) {\n return {\n apply(x) {\n return Math.sign(x) * Math.log1p(Math.abs(x / constant));\n },\n invert(x) {\n return Math.sign(x) * Math.expm1(Math.abs(x)) * constant;\n }\n };\n}\n","import {scaleTime, scaleUtc} from \"d3\";\nimport {createScaleQ} from \"./quantitative.js\";\n\nfunction createScaleT(key, scale, channels, options) {\n return createScaleQ(key, scale, channels, options);\n}\n\nexport function createScaleTime(key, channels, options) {\n return createScaleT(key, scaleTime(), channels, options);\n}\n\nexport function createScaleUtc(key, channels, options) {\n return createScaleT(key, scaleUtc(), channels, options);\n}\n","import {utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, utcSecond, utcTicks, utcTickInterval} from \"d3-time\";\nimport {utcFormat} from \"d3-time-format\";\nimport {calendar} from \"./time.js\";\nimport {initRange} from \"./init.js\";\n\nexport default function utcTime() {\n return initRange.apply(calendar(utcTicks, utcTickInterval, utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, utcSecond, utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]), arguments);\n}\n","import {InternSet, extent, quantize, reverse as reverseof, sort, symbolsFill, symbolsStroke} from \"d3\";\nimport {scaleBand, scaleOrdinal, scalePoint, scaleImplicit} from \"d3\";\nimport {ascendingDefined} from \"../defined.js\";\nimport {isNoneish, map, maybeRangeInterval} from \"../options.js\";\nimport {maybeSymbol} from \"../symbol.js\";\nimport {registry, color, position, symbol} from \"./index.js\";\nimport {maybeBooleanRange, ordinalScheme, quantitativeScheme} from \"./schemes.js\";\n\n// This denotes an implicitly ordinal color scale: the scale type was not set,\n// but the associated values are strings or booleans. If the associated defined\n// values are entirely boolean, the range will default to greys. You can opt out\n// of this by setting the type explicitly.\nexport const ordinalImplicit = Symbol(\"ordinal\");\n\nfunction createScaleO(key, scale, channels, {type, interval, domain, range, reverse, hint}) {\n interval = maybeRangeInterval(interval, type);\n if (domain === undefined) domain = inferDomain(channels, interval, key);\n if (type === \"categorical\" || type === ordinalImplicit) type = \"ordinal\"; // shorthand for color schemes\n if (reverse) domain = reverseof(domain);\n domain = scale.domain(domain).domain(); // deduplicate\n if (range !== undefined) {\n // If the range is specified as a function, pass it the domain.\n if (typeof range === \"function\") range = range(domain);\n scale.range(range);\n }\n return {type, domain, range, scale, hint, interval};\n}\n\nexport function createScaleOrdinal(key, channels, {type, interval, domain, range, scheme, unknown, ...options}) {\n interval = maybeRangeInterval(interval, type);\n if (domain === undefined) domain = inferDomain(channels, interval, key);\n let hint;\n if (registry.get(key) === symbol) {\n hint = inferSymbolHint(channels);\n range = range === undefined ? inferSymbolRange(hint) : map(range, maybeSymbol);\n } else if (registry.get(key) === color) {\n if (range === undefined && (type === \"ordinal\" || type === ordinalImplicit)) {\n range = maybeBooleanRange(domain, scheme);\n if (range !== undefined) scheme = undefined; // Don’t re-apply scheme.\n }\n if (scheme === undefined && range === undefined) {\n scheme = type === \"ordinal\" ? \"turbo\" : \"tableau10\";\n }\n if (scheme !== undefined) {\n if (range !== undefined) {\n const interpolate = quantitativeScheme(scheme);\n const t0 = range[0],\n d = range[1] - range[0];\n range = ({length: n}) => quantize((t) => interpolate(t0 + d * t), n);\n } else {\n range = ordinalScheme(scheme);\n }\n }\n }\n if (unknown === scaleImplicit) {\n throw new Error(`implicit unknown on ${key} scale is not supported`);\n }\n return createScaleO(key, scaleOrdinal().unknown(unknown), channels, {...options, type, domain, range, hint});\n}\n\nexport function createScalePoint(key, channels, {align = 0.5, padding = 0.5, ...options}) {\n return maybeRound(scalePoint().align(align).padding(padding), channels, options, key);\n}\n\nexport function createScaleBand(\n key,\n channels,\n {\n align = 0.5,\n padding = 0.1,\n paddingInner = padding,\n paddingOuter = key === \"fx\" || key === \"fy\" ? 0 : padding,\n ...options\n }\n) {\n return maybeRound(\n scaleBand().align(align).paddingInner(paddingInner).paddingOuter(paddingOuter),\n channels,\n options,\n key\n );\n}\n\nfunction maybeRound(scale, channels, options, key) {\n let {round} = options;\n if (round !== undefined) scale.round((round = !!round));\n scale = createScaleO(key, scale, channels, options);\n scale.round = round; // preserve for autoScaleRound\n return scale;\n}\n\nfunction inferDomain(channels, interval, key) {\n const values = new InternSet();\n for (const {value, domain} of channels) {\n if (domain !== undefined) return domain(); // see channelDomain\n if (value === undefined) continue;\n for (const v of value) values.add(v);\n }\n if (interval !== undefined) {\n const [min, max] = extent(values).map(interval.floor, interval);\n return interval.range(min, interval.offset(max));\n }\n if (values.size > 10e3 && registry.get(key) === position) {\n throw new Error(`implicit ordinal domain of ${key} scale has more than 10,000 values`);\n }\n return sort(values, ascendingDefined);\n}\n\n// If all channels provide a consistent hint, propagate it to the scale.\nfunction inferHint(channels, key) {\n let value;\n for (const {hint} of channels) {\n const candidate = hint?.[key];\n if (candidate === undefined) continue; // no hint here\n if (value === undefined) value = candidate;\n // first hint\n else if (value !== candidate) return; // inconsistent hint\n }\n return value;\n}\n\nfunction inferSymbolHint(channels) {\n return {\n fill: inferHint(channels, \"fill\"),\n stroke: inferHint(channels, \"stroke\")\n };\n}\n\nfunction inferSymbolRange(hint) {\n return isNoneish(hint.fill) ? symbolsStroke : symbolsFill;\n}\n","import {\n isOrdinal,\n isTemporal,\n isTemporalString,\n isNumericString,\n isScaleOptions,\n map,\n slice,\n coerceNumbers,\n coerceDates\n} from \"./options.js\";\nimport {registry, color, position, radius, opacity, symbol, length} from \"./scales/index.js\";\nimport {\n createScaleLinear,\n createScaleSqrt,\n createScalePow,\n createScaleLog,\n createScaleSymlog,\n createScaleQuantile,\n createScaleQuantize,\n createScaleThreshold,\n createScaleIdentity\n} from \"./scales/quantitative.js\";\nimport {\n createScaleDiverging,\n createScaleDivergingSqrt,\n createScaleDivergingPow,\n createScaleDivergingLog,\n createScaleDivergingSymlog\n} from \"./scales/diverging.js\";\nimport {isCategoricalScheme, isDivergingScheme} from \"./scales/schemes.js\";\nimport {createScaleTime, createScaleUtc} from \"./scales/temporal.js\";\nimport {createScaleOrdinal, createScalePoint, createScaleBand, ordinalImplicit} from \"./scales/ordinal.js\";\nimport {maybeSymbol} from \"./symbol.js\";\nimport {warn} from \"./warnings.js\";\n\nexport function createScales(\n channelsByScale,\n {\n label: globalLabel,\n inset: globalInset = 0,\n insetTop: globalInsetTop = globalInset,\n insetRight: globalInsetRight = globalInset,\n insetBottom: globalInsetBottom = globalInset,\n insetLeft: globalInsetLeft = globalInset,\n round,\n nice,\n clamp,\n zero,\n align,\n padding,\n projection,\n facet: {label: facetLabel = globalLabel} = {},\n ...options\n } = {}\n) {\n const scales = {};\n for (const [key, channels] of channelsByScale) {\n const scaleOptions = options[key];\n const scale = createScale(key, channels, {\n round: registry.get(key) === position ? round : undefined, // only for position\n nice,\n clamp,\n zero,\n align,\n padding,\n projection,\n ...scaleOptions\n });\n if (scale) {\n // populate generic scale options (percent, transform, insets)\n let {\n label = key === \"fx\" || key === \"fy\" ? facetLabel : globalLabel,\n percent,\n transform,\n inset,\n insetTop = inset !== undefined ? inset : key === \"y\" ? globalInsetTop : 0, // not fy\n insetRight = inset !== undefined ? inset : key === \"x\" ? globalInsetRight : 0, // not fx\n insetBottom = inset !== undefined ? inset : key === \"y\" ? globalInsetBottom : 0, // not fy\n insetLeft = inset !== undefined ? inset : key === \"x\" ? globalInsetLeft : 0 // not fx\n } = scaleOptions || {};\n if (transform == null) transform = undefined;\n else if (typeof transform !== \"function\") throw new Error(\"invalid scale transform; not a function\");\n scale.percent = !!percent;\n scale.label = label === undefined ? inferScaleLabel(channels, scale) : label;\n scale.transform = transform;\n if (key === \"x\" || key === \"fx\") {\n scale.insetLeft = +insetLeft;\n scale.insetRight = +insetRight;\n } else if (key === \"y\" || key === \"fy\") {\n scale.insetTop = +insetTop;\n scale.insetBottom = +insetBottom;\n }\n scales[key] = scale;\n }\n }\n return scales;\n}\n\nexport function createScaleFunctions(descriptors) {\n const scales = {};\n const scaleFunctions = {scales};\n for (const [key, descriptor] of Object.entries(descriptors)) {\n const {scale, type, interval, label} = descriptor;\n scales[key] = exposeScale(descriptor);\n scaleFunctions[key] = scale;\n // TODO: pass these properties, which are needed for axes, in the descriptor.\n scale.type = type;\n if (interval != null) scale.interval = interval;\n if (label != null) scale.label = label;\n }\n return scaleFunctions;\n}\n\n// Mutates scale.range!\nexport function autoScaleRange(scales, dimensions) {\n const {x, y, fx, fy} = scales;\n const superdimensions = fx || fy ? outerDimensions(dimensions) : dimensions;\n if (fx) autoScaleRangeX(fx, superdimensions);\n if (fy) autoScaleRangeY(fy, superdimensions);\n const subdimensions = fx || fy ? innerDimensions(scales, dimensions) : dimensions;\n if (x) autoScaleRangeX(x, subdimensions);\n if (y) autoScaleRangeY(y, subdimensions);\n}\n\n// Channels can have labels; if all the channels for a given scale are\n// consistently labeled (i.e., have the same value if not undefined), and the\n// corresponding scale doesn’t already have an explicit label, then the\n// channels’ label is promoted to the scale. This inferred label should have an\n// orientation-appropriate arrow added when used as an axis, but we don’t want\n// to add the arrow when the label is set explicitly as an option; so, the\n// inferred label is distinguished as an object with an “inferred” property.\nfunction inferScaleLabel(channels = [], scale) {\n let label;\n for (const {label: l} of channels) {\n if (l === undefined) continue;\n if (label === undefined) label = l;\n else if (label !== l) return;\n }\n if (label === undefined) return;\n if (!isOrdinalScale(scale) && scale.percent) label = `${label} (%)`;\n return {inferred: true, toString: () => label};\n}\n\n// Returns the dimensions of the outer frame; this is subdivided into facets\n// with the margins of each facet collapsing into the outer margins.\nexport function outerDimensions(dimensions) {\n const {\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n width,\n height,\n facet: {\n marginTop: facetMarginTop,\n marginRight: facetMarginRight,\n marginBottom: facetMarginBottom,\n marginLeft: facetMarginLeft\n }\n } = dimensions;\n return {\n marginTop: Math.max(marginTop, facetMarginTop),\n marginRight: Math.max(marginRight, facetMarginRight),\n marginBottom: Math.max(marginBottom, facetMarginBottom),\n marginLeft: Math.max(marginLeft, facetMarginLeft),\n width,\n height\n };\n}\n\n// Returns the dimensions of each facet.\nexport function innerDimensions({fx, fy}, dimensions) {\n const {marginTop, marginRight, marginBottom, marginLeft, width, height} = outerDimensions(dimensions);\n return {\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n width: fx ? fx.scale.bandwidth() + marginLeft + marginRight : width,\n height: fy ? fy.scale.bandwidth() + marginTop + marginBottom : height,\n facet: {width, height}\n };\n}\n\nfunction autoScaleRangeX(scale, dimensions) {\n if (scale.range === undefined) {\n const {insetLeft, insetRight} = scale;\n const {width, marginLeft = 0, marginRight = 0} = dimensions;\n const left = marginLeft + insetLeft;\n const right = width - marginRight - insetRight;\n scale.range = [left, Math.max(left, right)];\n if (!isOrdinalScale(scale)) scale.range = piecewiseRange(scale);\n scale.scale.range(scale.range);\n }\n autoScaleRound(scale);\n}\n\nfunction autoScaleRangeY(scale, dimensions) {\n if (scale.range === undefined) {\n const {insetTop, insetBottom} = scale;\n const {height, marginTop = 0, marginBottom = 0} = dimensions;\n const top = marginTop + insetTop;\n const bottom = height - marginBottom - insetBottom;\n scale.range = [Math.max(top, bottom), top];\n if (!isOrdinalScale(scale)) scale.range = piecewiseRange(scale);\n else scale.range.reverse();\n scale.scale.range(scale.range);\n }\n autoScaleRound(scale);\n}\n\nfunction autoScaleRound(scale) {\n if (scale.round === undefined && isBandScale(scale) && roundError(scale) <= 30) {\n scale.scale.round(true);\n }\n}\n\n// If we were to turn on rounding for this band or point scale, how much wasted\n// space would it introduce (on both ends of the range)? This must match\n// d3.scaleBand’s rounding behavior:\n// https://github.com/d3/d3-scale/blob/83555bd759c7314420bd4240642beda5e258db9e/src/band.js#L20-L32\nfunction roundError({scale}) {\n const n = scale.domain().length;\n const [start, stop] = scale.range();\n const paddingInner = scale.paddingInner ? scale.paddingInner() : 1;\n const paddingOuter = scale.paddingOuter ? scale.paddingOuter() : scale.padding();\n const m = n - paddingInner;\n const step = Math.abs(stop - start) / Math.max(1, m + paddingOuter * 2);\n return (step - Math.floor(step)) * m;\n}\n\nfunction piecewiseRange(scale) {\n const length = scale.scale.domain().length + isThresholdScale(scale);\n if (!(length > 2)) return scale.range;\n const [start, end] = scale.range;\n return Array.from({length}, (_, i) => start + (i / (length - 1)) * (end - start));\n}\n\nexport function normalizeScale(key, scale, hint) {\n return createScale(key, hint === undefined ? undefined : [{hint}], {...scale});\n}\n\nfunction createScale(key, channels = [], options = {}) {\n const type = inferScaleType(key, channels, options);\n\n // Warn for common misuses of implicit ordinal scales. We disable this test if\n // you specify a scale interval or if you set the domain or range explicitly,\n // since setting the domain or range (typically with a cardinality of more than\n // two) is another indication that you intended for the scale to be ordinal; we\n // also disable it for facet scales since these are always band scales.\n if (\n options.type === undefined &&\n options.domain === undefined &&\n options.range === undefined &&\n options.interval == null &&\n key !== \"fx\" &&\n key !== \"fy\" &&\n isOrdinalScale({type})\n ) {\n const values = channels.map(({value}) => value).filter((value) => value !== undefined);\n if (values.some(isTemporal))\n warn(\n `Warning: some data associated with the ${key} scale are dates. Dates are typically associated with a \"utc\" or \"time\" scale rather than a \"${formatScaleType(\n type\n )}\" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can specify the interval of the ${key} scale (e.g., d3.utcDay), or you can suppress this warning by setting the type of the ${key} scale to \"${formatScaleType(\n type\n )}\".`\n );\n else if (values.some(isTemporalString))\n warn(\n `Warning: some data associated with the ${key} scale are strings that appear to be dates (e.g., YYYY-MM-DD). If these strings represent dates, you should parse them to Date objects. Dates are typically associated with a \"utc\" or \"time\" scale rather than a \"${formatScaleType(\n type\n )}\" scale. If you are using a bar mark, you probably want a rect mark with the interval option instead; if you are using a group transform, you probably want a bin transform instead. If you want to treat this data as ordinal, you can suppress this warning by setting the type of the ${key} scale to \"${formatScaleType(\n type\n )}\".`\n );\n else if (values.some(isNumericString))\n warn(\n `Warning: some data associated with the ${key} scale are strings that appear to be numbers. If these strings represent numbers, you should parse or coerce them to numbers. Numbers are typically associated with a \"linear\" scale rather than a \"${formatScaleType(\n type\n )}\" scale. If you want to treat this data as ordinal, you can specify the interval of the ${key} scale (e.g., 1 for integers), or you can suppress this warning by setting the type of the ${key} scale to \"${formatScaleType(\n type\n )}\".`\n );\n }\n\n options.type = type; // Mutates input!\n\n // Once the scale type is known, coerce the associated channel values and any\n // explicitly-specified domain to the expected type.\n switch (type) {\n case \"diverging\":\n case \"diverging-sqrt\":\n case \"diverging-pow\":\n case \"diverging-log\":\n case \"diverging-symlog\":\n case \"cyclical\":\n case \"sequential\":\n case \"linear\":\n case \"sqrt\":\n case \"threshold\":\n case \"quantile\":\n case \"pow\":\n case \"log\":\n case \"symlog\":\n options = coerceType(channels, options, coerceNumbers);\n break;\n case \"identity\":\n switch (registry.get(key)) {\n case position:\n options = coerceType(channels, options, coerceNumbers);\n break;\n case symbol:\n options = coerceType(channels, options, coerceSymbols);\n break;\n }\n break;\n case \"utc\":\n case \"time\":\n options = coerceType(channels, options, coerceDates);\n break;\n }\n\n switch (type) {\n case \"diverging\":\n return createScaleDiverging(key, channels, options);\n case \"diverging-sqrt\":\n return createScaleDivergingSqrt(key, channels, options);\n case \"diverging-pow\":\n return createScaleDivergingPow(key, channels, options);\n case \"diverging-log\":\n return createScaleDivergingLog(key, channels, options);\n case \"diverging-symlog\":\n return createScaleDivergingSymlog(key, channels, options);\n case \"categorical\":\n case \"ordinal\":\n case ordinalImplicit:\n return createScaleOrdinal(key, channels, options);\n case \"cyclical\":\n case \"sequential\":\n case \"linear\":\n return createScaleLinear(key, channels, options);\n case \"sqrt\":\n return createScaleSqrt(key, channels, options);\n case \"threshold\":\n return createScaleThreshold(key, channels, options);\n case \"quantile\":\n return createScaleQuantile(key, channels, options);\n case \"quantize\":\n return createScaleQuantize(key, channels, options);\n case \"pow\":\n return createScalePow(key, channels, options);\n case \"log\":\n return createScaleLog(key, channels, options);\n case \"symlog\":\n return createScaleSymlog(key, channels, options);\n case \"utc\":\n return createScaleUtc(key, channels, options);\n case \"time\":\n return createScaleTime(key, channels, options);\n case \"point\":\n return createScalePoint(key, channels, options);\n case \"band\":\n return createScaleBand(key, channels, options);\n case \"identity\":\n return createScaleIdentity(key);\n case undefined:\n return;\n default:\n throw new Error(`unknown scale type: ${type}`);\n }\n}\n\nfunction formatScaleType(type) {\n return typeof type === \"symbol\" ? type.description : type;\n}\n\n// A special type symbol when the x and y scales are replaced with a projection.\nconst typeProjection = {toString: () => \"projection\"};\n\nfunction inferScaleType(key, channels, {type, domain, range, scheme, pivot, projection}) {\n // The facet scales are always band scales; this cannot be changed.\n if (key === \"fx\" || key === \"fy\") return \"band\";\n\n // If a projection is specified, the x- and y-scales are disabled; these\n // channels will be projected rather than scaled. (But still check that none\n // of the associated channels are incompatible with a projection.)\n if ((key === \"x\" || key === \"y\") && projection != null) type = typeProjection;\n\n // If a channel dictates a scale type, make sure that it is consistent with\n // the user-specified scale type (if any) and all other channels. For example,\n // barY requires x to be a band scale and disallows any other scale type.\n for (const {type: t} of channels) {\n if (t === undefined) continue;\n else if (type === undefined) type = t;\n else if (type !== t) throw new Error(`scale incompatible with channel: ${type} !== ${t}`);\n }\n\n // If the scale, a channel, or user specified a (consistent) type, return it.\n if (type === typeProjection) return;\n if (type !== undefined) return type;\n\n // If there’s no data (and no type) associated with this scale, don’t create a scale.\n if (domain === undefined && !channels.some(({value}) => value !== undefined)) return;\n\n // Some scales have default types.\n const kind = registry.get(key);\n if (kind === radius) return \"sqrt\";\n if (kind === opacity || kind === length) return \"linear\";\n if (kind === symbol) return \"ordinal\";\n\n // If the domain or range has more than two values, assume it’s ordinal. You\n // can still use a “piecewise” (or “polylinear”) scale, but you must set the\n // type explicitly.\n if ((domain || range || []).length > 2) return asOrdinalType(kind);\n\n // Otherwise, infer the scale type from the data! Prefer the domain, if\n // present, over channels. (The domain and channels should be consistently\n // typed, and the domain is more explicit and typically much smaller.) We only\n // check the first defined value for expedience and simplicity; we expect\n // that the types are consistent.\n if (domain !== undefined) {\n if (isOrdinal(domain)) return asOrdinalType(kind);\n if (isTemporal(domain)) return \"utc\";\n } else {\n const values = channels.map(({value}) => value).filter((value) => value !== undefined);\n if (values.some(isOrdinal)) return asOrdinalType(kind);\n if (values.some(isTemporal)) return \"utc\";\n }\n\n // For color scales, take a hint from the color scheme and pivot option.\n if (kind === color) {\n if (pivot != null || isDivergingScheme(scheme)) return \"diverging\";\n if (isCategoricalScheme(scheme)) return \"categorical\";\n }\n\n return \"linear\";\n}\n\n// Positional scales default to a point scale instead of an ordinal scale.\nfunction asOrdinalType(kind) {\n switch (kind) {\n case position:\n return \"point\";\n case color:\n return ordinalImplicit;\n default:\n return \"ordinal\";\n }\n}\n\nexport function isTemporalScale({type}) {\n return type === \"time\" || type === \"utc\";\n}\n\nexport function isOrdinalScale({type}) {\n return type === \"ordinal\" || type === \"point\" || type === \"band\" || type === ordinalImplicit;\n}\n\nexport function isThresholdScale({type}) {\n return type === \"threshold\";\n}\n\nfunction isBandScale({type}) {\n return type === \"point\" || type === \"band\";\n}\n\nexport function isDivergingScale({type}) {\n return /^diverging($|-)/.test(type);\n}\n\n// Certain marks have special behavior if a scale is collapsed, i.e. if the\n// domain is degenerate and represents only a single value such as [3, 3]; for\n// example, a rect will span the full extent of the chart along a collapsed\n// dimension (whereas a dot will simply be drawn in the center).\nexport function isCollapsed(scale) {\n if (scale === undefined) return true; // treat missing scale as collapsed\n const domain = scale.domain();\n const value = scale(domain[0]);\n for (let i = 1, n = domain.length; i < n; ++i) {\n if (scale(domain[i]) - value) {\n return false;\n }\n }\n return true;\n}\n\n// Mutates channel.value!\nfunction coerceType(channels, {domain, ...options}, coerceValues) {\n for (const c of channels) {\n if (c.value !== undefined) {\n c.value = coerceValues(c.value);\n }\n }\n return {\n domain: domain === undefined ? domain : coerceValues(domain),\n ...options\n };\n}\n\nfunction coerceSymbols(values) {\n return map(values, maybeSymbol);\n}\n\nexport function scale(options = {}) {\n let scale;\n for (const key in options) {\n if (!registry.has(key)) continue; // ignore unknown properties\n if (!isScaleOptions(options[key])) continue; // e.g., ignore {color: \"red\"}\n if (scale !== undefined) throw new Error(\"ambiguous scale definition; multiple scales found\");\n scale = exposeScale(normalizeScale(key, options[key]));\n }\n if (scale === undefined) throw new Error(\"invalid scale definition; no scale found\");\n return scale;\n}\n\nexport function exposeScales(scales) {\n return (key) => {\n if (!registry.has((key = `${key}`))) throw new Error(`unknown scale: ${key}`);\n return scales[key];\n };\n}\n\n// Note: axis- and legend-related properties (such as label, ticks and\n// tickFormat) are not included here as they do not affect the scale’s behavior.\nfunction exposeScale({scale, type, domain, range, interpolate, interval, transform, percent, pivot}) {\n if (type === \"identity\") return {type: \"identity\", apply: (d) => d, invert: (d) => d};\n const unknown = scale.unknown ? scale.unknown() : undefined;\n return {\n type,\n domain: slice(domain), // defensive copy\n ...(range !== undefined && {range: slice(range)}), // defensive copy\n ...(transform !== undefined && {transform}),\n ...(percent && {percent}), // only exposed if truthy\n ...(unknown !== undefined && {unknown}),\n ...(interval !== undefined && {interval}),\n\n // quantitative\n ...(interpolate !== undefined && {interpolate}),\n ...(scale.clamp && {clamp: scale.clamp()}),\n\n // diverging (always asymmetric; we never want to apply the symmetric transform twice)\n ...(pivot !== undefined && {pivot, symmetric: false}),\n\n // log, diverging-log\n ...(scale.base && {base: scale.base()}),\n\n // pow, diverging-pow\n ...(scale.exponent && {exponent: scale.exponent()}),\n\n // symlog, diverging-symlog\n ...(scale.constant && {constant: scale.constant()}),\n\n // band, point\n ...(scale.align && {align: scale.align(), round: scale.round()}),\n ...(scale.padding &&\n (scale.paddingInner\n ? {paddingInner: scale.paddingInner(), paddingOuter: scale.paddingOuter()}\n : {padding: scale.padding()})),\n ...(scale.bandwidth && {bandwidth: scale.bandwidth(), step: scale.step()}),\n\n // utilities\n apply: (t) => scale(t),\n ...(scale.invert && {invert: (t) => scale.invert(t)})\n };\n}\n","import {extent} from \"d3\";\nimport {projectionAspectRatio} from \"./projection.js\";\nimport {isOrdinalScale} from \"./scales.js\";\nimport {offset} from \"./style.js\";\n\nexport function createDimensions(scales, marks, options = {}) {\n // Compute the default margins: the maximum of the marks’ margins. While not\n // always used, they may be needed to compute the default height of the plot.\n let marginTopDefault = 0.5 - offset,\n marginRightDefault = 0.5 + offset,\n marginBottomDefault = 0.5 + offset,\n marginLeftDefault = 0.5 - offset;\n\n for (const {marginTop, marginRight, marginBottom, marginLeft} of marks) {\n if (marginTop > marginTopDefault) marginTopDefault = marginTop;\n if (marginRight > marginRightDefault) marginRightDefault = marginRight;\n if (marginBottom > marginBottomDefault) marginBottomDefault = marginBottom;\n if (marginLeft > marginLeftDefault) marginLeftDefault = marginLeft;\n }\n\n // Compute the actual margins. The order of precedence is: the side-specific\n // margin options, then the global margin option, then the defaults.\n let {\n margin,\n marginTop = margin !== undefined ? margin : marginTopDefault,\n marginRight = margin !== undefined ? margin : marginRightDefault,\n marginBottom = margin !== undefined ? margin : marginBottomDefault,\n marginLeft = margin !== undefined ? margin : marginLeftDefault\n } = options;\n\n // Coerce the margin options to numbers.\n marginTop = +marginTop;\n marginRight = +marginRight;\n marginBottom = +marginBottom;\n marginLeft = +marginLeft;\n\n // Compute the outer dimensions of the plot. If the top and bottom margins are\n // specified explicitly, adjust the automatic height accordingly.\n let {\n width = 640,\n height = autoHeight(scales, options, {\n width,\n marginTopDefault,\n marginRightDefault,\n marginBottomDefault,\n marginLeftDefault\n }) + Math.max(0, marginTop - marginTopDefault + marginBottom - marginBottomDefault)\n } = options;\n\n // Coerce the width and height.\n width = +width;\n height = +height;\n\n const dimensions = {\n width,\n height,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft\n };\n\n // Compute the facet margins.\n if (scales.fx || scales.fy) {\n let {\n margin: facetMargin,\n marginTop: facetMarginTop = facetMargin !== undefined ? facetMargin : marginTop,\n marginRight: facetMarginRight = facetMargin !== undefined ? facetMargin : marginRight,\n marginBottom: facetMarginBottom = facetMargin !== undefined ? facetMargin : marginBottom,\n marginLeft: facetMarginLeft = facetMargin !== undefined ? facetMargin : marginLeft\n } = options.facet ?? {};\n\n // Coerce the facet margin options to numbers.\n facetMarginTop = +facetMarginTop;\n facetMarginRight = +facetMarginRight;\n facetMarginBottom = +facetMarginBottom;\n facetMarginLeft = +facetMarginLeft;\n\n dimensions.facet = {\n marginTop: facetMarginTop,\n marginRight: facetMarginRight,\n marginBottom: facetMarginBottom,\n marginLeft: facetMarginLeft\n };\n }\n\n return dimensions;\n}\n\nfunction autoHeight(\n {x, y, fy, fx},\n {projection, aspectRatio},\n {width, marginTopDefault, marginRightDefault, marginBottomDefault, marginLeftDefault}\n) {\n const nfy = fy ? fy.scale.domain().length : 1;\n\n // If a projection is specified, use its natural aspect ratio (if known).\n const ar = projectionAspectRatio(projection);\n if (ar) {\n const nfx = fx ? fx.scale.domain().length : 1;\n const far = ((1.1 * nfy - 0.1) / (1.1 * nfx - 0.1)) * ar; // 0.1 is default facet padding\n const lar = Math.max(0.1, Math.min(10, far)); // clamp the aspect ratio to a “reasonable” value\n return Math.round((width - marginLeftDefault - marginRightDefault) * lar + marginTopDefault + marginBottomDefault);\n }\n\n const ny = y ? (isOrdinalScale(y) ? y.scale.domain().length : Math.max(7, 17 / nfy)) : 1;\n\n // If a desired aspect ratio is given, compute a default height to match.\n if (aspectRatio != null) {\n aspectRatio = +aspectRatio;\n if (!(isFinite(aspectRatio) && aspectRatio > 0)) throw new Error(`invalid aspectRatio: ${aspectRatio}`);\n const ratio = aspectRatioLength(\"y\", y) / (aspectRatioLength(\"x\", x) * aspectRatio);\n const fxb = fx ? fx.scale.bandwidth() : 1;\n const fyb = fy ? fy.scale.bandwidth() : 1;\n const w = fxb * (width - marginLeftDefault - marginRightDefault) - x.insetLeft - x.insetRight;\n return (ratio * w + y.insetTop + y.insetBottom) / fyb + marginTopDefault + marginBottomDefault;\n }\n\n return !!(y || fy) * Math.max(1, Math.min(60, ny * nfy)) * 20 + !!fx * 30 + 60;\n}\n\nfunction aspectRatioLength(k, scale) {\n if (!scale) throw new Error(`aspectRatio requires ${k} scale`);\n const {type, domain} = scale;\n let transform;\n switch (type) {\n case \"linear\":\n case \"utc\":\n case \"time\":\n transform = Number;\n break;\n case \"pow\": {\n const exponent = scale.scale.exponent();\n transform = (x) => Math.pow(x, exponent);\n break;\n }\n case \"log\":\n transform = Math.log;\n break;\n case \"point\":\n case \"band\":\n return domain.length;\n default:\n throw new Error(`unsupported ${k} scale for aspectRatio: ${type}`);\n }\n const [min, max] = extent(domain);\n return Math.abs(transform(max) - transform(min));\n}\n","import {InternMap, cross, rollup, sum} from \"d3\";\nimport {keyof, map, range} from \"./options.js\";\nimport {createScales} from \"./scales.js\";\n\n// Returns an array of {x?, y?, i} objects representing the facet domain.\nexport function createFacets(channelsByScale, options) {\n const {fx, fy} = createScales(channelsByScale, options);\n const fxDomain = fx?.scale.domain();\n const fyDomain = fy?.scale.domain();\n return fxDomain && fyDomain\n ? cross(fxDomain, fyDomain).map(([x, y], i) => ({x, y, i}))\n : fxDomain\n ? fxDomain.map((x, i) => ({x, i}))\n : fyDomain\n ? fyDomain.map((y, i) => ({y, i}))\n : undefined;\n}\n\nexport function recreateFacets(facets, {x: X, y: Y}) {\n X &&= facetIndex(X);\n Y &&= facetIndex(Y);\n return facets\n .filter(\n X && Y // remove any facets no longer present in the domain\n ? (f) => X.has(f.x) && Y.has(f.y)\n : X\n ? (f) => X.has(f.x)\n : (f) => Y.has(f.y)\n )\n .sort(\n X && Y // reorder facets to match the new scale domains\n ? (a, b) => X.get(a.x) - X.get(b.x) || Y.get(a.y) - Y.get(b.y)\n : X\n ? (a, b) => X.get(a.x) - X.get(b.x)\n : (a, b) => Y.get(a.y) - Y.get(b.y)\n );\n}\n\n// Returns a (possibly nested) Map of [[key1, index1], [key2, index2], …]\n// representing the data indexes associated with each facet.\nexport function facetGroups(data, {fx, fy}) {\n const I = range(data);\n const FX = fx?.value;\n const FY = fy?.value;\n return fx && fy\n ? rollup(\n I,\n (G) => ((G.fx = FX[G[0]]), (G.fy = FY[G[0]]), G),\n (i) => FX[i],\n (i) => FY[i]\n )\n : fx\n ? rollup(\n I,\n (G) => ((G.fx = FX[G[0]]), G),\n (i) => FX[i]\n )\n : rollup(\n I,\n (G) => ((G.fy = FY[G[0]]), G),\n (i) => FY[i]\n );\n}\n\nexport function facetTranslator(fx, fy, {marginTop, marginLeft}) {\n return fx && fy\n ? ({x, y}) => `translate(${fx(x) - marginLeft},${fy(y) - marginTop})`\n : fx\n ? ({x}) => `translate(${fx(x) - marginLeft},0)`\n : ({y}) => `translate(0,${fy(y) - marginTop})`;\n}\n\n// Returns an index that for each facet lists all the elements present in other\n// facets in the original index. TODO Memoize to avoid repeated work?\nexport function facetExclude(index) {\n const ex = [];\n const e = new Uint32Array(sum(index, (d) => d.length));\n for (const i of index) {\n let n = 0;\n for (const j of index) {\n if (i === j) continue;\n e.set(j, n);\n n += j.length;\n }\n ex.push(e.slice(0, n));\n }\n return ex;\n}\n\nconst facetAnchors = new Map([\n [\"top\", facetAnchorTop],\n [\"right\", facetAnchorRight],\n [\"bottom\", facetAnchorBottom],\n [\"left\", facetAnchorLeft],\n [\"top-left\", and(facetAnchorTop, facetAnchorLeft)],\n [\"top-right\", and(facetAnchorTop, facetAnchorRight)],\n [\"bottom-left\", and(facetAnchorBottom, facetAnchorLeft)],\n [\"bottom-right\", and(facetAnchorBottom, facetAnchorRight)],\n [\"top-empty\", facetAnchorTopEmpty],\n [\"right-empty\", facetAnchorRightEmpty],\n [\"bottom-empty\", facetAnchorBottomEmpty],\n [\"left-empty\", facetAnchorLeftEmpty],\n [\"empty\", facetAnchorEmpty]\n]);\n\nexport function maybeFacetAnchor(facetAnchor) {\n if (facetAnchor == null) return null;\n const anchor = facetAnchors.get(`${facetAnchor}`.toLowerCase());\n if (anchor) return anchor;\n throw new Error(`invalid facet anchor: ${facetAnchor}`);\n}\n\nconst indexCache = new WeakMap();\n\nfunction facetIndex(V) {\n let I = indexCache.get(V);\n if (!I) indexCache.set(V, (I = new InternMap(map(V, (v, i) => [v, i]))));\n return I;\n}\n\n// Like V.indexOf(v), but with the same semantics as InternMap.\nfunction facetIndexOf(V, v) {\n return facetIndex(V).get(v);\n}\n\n// Like facets.find, but with the same semantics as InternMap.\nfunction facetFind(facets, x, y) {\n x = keyof(x);\n y = keyof(y);\n return facets.find((f) => Object.is(keyof(f.x), x) && Object.is(keyof(f.y), y));\n}\n\nfunction facetEmpty(facets, x, y) {\n return facetFind(facets, x, y)?.empty;\n}\n\nfunction facetAnchorTop(facets, {y: Y}, {y}) {\n return Y ? facetIndexOf(Y, y) === 0 : true;\n}\n\nfunction facetAnchorBottom(facets, {y: Y}, {y}) {\n return Y ? facetIndexOf(Y, y) === Y.length - 1 : true;\n}\n\nfunction facetAnchorLeft(facets, {x: X}, {x}) {\n return X ? facetIndexOf(X, x) === 0 : true;\n}\n\nfunction facetAnchorRight(facets, {x: X}, {x}) {\n return X ? facetIndexOf(X, x) === X.length - 1 : true;\n}\n\nfunction facetAnchorTopEmpty(facets, {y: Y}, {x, y, empty}) {\n if (empty) return false;\n if (!Y) return;\n const i = facetIndexOf(Y, y);\n if (i > 0) return facetEmpty(facets, x, Y[i - 1]);\n}\n\nfunction facetAnchorBottomEmpty(facets, {y: Y}, {x, y, empty}) {\n if (empty) return false;\n if (!Y) return;\n const i = facetIndexOf(Y, y);\n if (i < Y.length - 1) return facetEmpty(facets, x, Y[i + 1]);\n}\n\nfunction facetAnchorLeftEmpty(facets, {x: X}, {x, y, empty}) {\n if (empty) return false;\n if (!X) return;\n const i = facetIndexOf(X, x);\n if (i > 0) return facetEmpty(facets, X[i - 1], y);\n}\n\nfunction facetAnchorRightEmpty(facets, {x: X}, {x, y, empty}) {\n if (empty) return false;\n if (!X) return;\n const i = facetIndexOf(X, x);\n if (i < X.length - 1) return facetEmpty(facets, X[i + 1], y);\n}\n\nfunction facetAnchorEmpty(facets, channels, {empty}) {\n return empty;\n}\n\nfunction and(a, b) {\n return function () {\n return a.apply(null, arguments) && b.apply(null, arguments);\n };\n}\n\n// Facet filter, by mark; for now only the \"eq\" filter is provided.\nexport function facetFilter(facets, {channels: {fx, fy}, groups}) {\n return fx && fy\n ? facets.map(({x, y}) => groups.get(x)?.get(y) ?? [])\n : fx\n ? facets.map(({x}) => groups.get(x) ?? [])\n : facets.map(({y}) => groups.get(y) ?? []);\n}\n","import {channelDomain, createChannels, valueObject} from \"./channel.js\";\nimport {defined} from \"./defined.js\";\nimport {maybeFacetAnchor} from \"./facet.js\";\nimport {maybeNamed, maybeValue} from \"./options.js\";\nimport {arrayify, isDomainSort, isObject, isOptions, keyword, range, singleton} from \"./options.js\";\nimport {project} from \"./projection.js\";\nimport {maybeClip, styles} from \"./style.js\";\nimport {basic, initializer} from \"./transforms/basic.js\";\n\nexport class Mark {\n constructor(data, channels = {}, options = {}, defaults) {\n const {\n facet = \"auto\",\n facetAnchor,\n fx,\n fy,\n sort,\n dx = 0,\n dy = 0,\n margin = 0,\n marginTop = margin,\n marginRight = margin,\n marginBottom = margin,\n marginLeft = margin,\n clip = defaults?.clip,\n channels: extraChannels,\n tip,\n render\n } = options;\n this.data = data;\n this.sort = isDomainSort(sort) ? sort : null;\n this.initializer = initializer(options).initializer;\n this.transform = this.initializer ? options.transform : basic(options).transform;\n if (facet === null || facet === false) {\n this.facet = null;\n } else {\n this.facet = keyword(facet === true ? \"include\" : facet, \"facet\", [\"auto\", \"include\", \"exclude\", \"super\"]);\n this.fx = data === singleton && typeof fx === \"string\" ? [fx] : fx;\n this.fy = data === singleton && typeof fy === \"string\" ? [fy] : fy;\n }\n this.facetAnchor = maybeFacetAnchor(facetAnchor);\n channels = maybeNamed(channels);\n if (extraChannels !== undefined) channels = {...maybeChannels(extraChannels), ...channels};\n if (defaults !== undefined) channels = {...styles(this, options, defaults), ...channels};\n this.channels = Object.fromEntries(\n Object.entries(channels)\n .map(([name, channel]) => {\n if (isOptions(channel.value)) {\n // apply scale and label overrides\n const {value, label = channel.label, scale = channel.scale} = channel.value;\n channel = {...channel, label, scale, value};\n }\n if (data === singleton && typeof channel.value === \"string\") {\n // convert field names to singleton values for decoration marks (e.g., frame)\n const {value} = channel;\n channel = {...channel, value: [value]};\n }\n return [name, channel];\n })\n .filter(([name, {value, optional}]) => {\n if (value != null) return true;\n if (optional) return false;\n throw new Error(`missing channel value: ${name}`);\n })\n );\n this.dx = +dx;\n this.dy = +dy;\n this.marginTop = +marginTop;\n this.marginRight = +marginRight;\n this.marginBottom = +marginBottom;\n this.marginLeft = +marginLeft;\n this.clip = maybeClip(clip);\n this.tip = maybeTip(tip);\n // Super-faceting currently disallow position channels; in the future, we\n // could allow position to be specified in fx and fy in addition to (or\n // instead of) x and y.\n if (this.facet === \"super\") {\n if (fx || fy) throw new Error(`super-faceting cannot use fx or fy`);\n for (const name in this.channels) {\n const {scale} = channels[name];\n if (scale !== \"x\" && scale !== \"y\") continue;\n throw new Error(`super-faceting cannot use x or y`);\n }\n }\n if (render != null) {\n this.render = composeRender(render, this.render);\n }\n }\n initialize(facets, facetChannels, plotOptions) {\n let data = arrayify(this.data);\n if (facets === undefined && data != null) facets = [range(data)];\n const originalFacets = facets;\n if (this.transform != null) ({facets, data} = this.transform(data, facets, plotOptions)), (data = arrayify(data));\n if (facets !== undefined) facets.original = originalFacets; // needed to read facetChannels\n const channels = createChannels(this.channels, data);\n if (this.sort != null) channelDomain(data, facets, channels, facetChannels, this.sort); // mutates facetChannels!\n return {data, facets, channels};\n }\n filter(index, channels, values) {\n for (const name in channels) {\n const {filter = defined} = channels[name];\n if (filter !== null) {\n const value = values[name];\n index = index.filter((i) => filter(value[i]));\n }\n }\n return index;\n }\n // If there is a projection, and there are paired x and y channels associated\n // with the x and y scale respectively (and not already in screen coordinates\n // as with an initializer), then apply the projection, replacing the x and y\n // values. Note that the x and y scales themselves don’t exist if there is a\n // projection, but whether the channels are associated with scales still\n // determines whether the projection should apply; think of the projection as\n // a combination xy-scale.\n project(channels, values, context) {\n for (const cx in channels) {\n if (channels[cx].scale === \"x\" && /^x|x$/.test(cx)) {\n const cy = cx.replace(/^x|x$/, \"y\");\n if (cy in channels && channels[cy].scale === \"y\") {\n project(cx, cy, values, context.projection);\n }\n }\n }\n }\n scale(channels, scales, context) {\n const values = valueObject(channels, scales);\n if (context.projection) this.project(channels, values, context);\n return values;\n }\n}\n\nexport function marks(...marks) {\n marks.plot = Mark.prototype.plot; // Note: depends on side-effect in plot!\n return marks;\n}\n\nexport function composeRender(r1, r2) {\n if (r1 == null) return r2 === null ? undefined : r2;\n if (r2 == null) return r1 === null ? undefined : r1;\n if (typeof r1 !== \"function\") throw new TypeError(`invalid render transform: ${r1}`);\n if (typeof r2 !== \"function\") throw new TypeError(`invalid render transform: ${r2}`);\n return function (i, s, v, d, c, next) {\n return r1.call(this, i, s, v, d, c, (i, s, v, d, c) => {\n return r2.call(this, i, s, v, d, c, next); // preserve this\n });\n };\n}\n\nfunction maybeChannels(channels) {\n return Object.fromEntries(\n Object.entries(maybeNamed(channels)).map(([name, channel]) => {\n channel = typeof channel === \"string\" ? {value: channel, label: name} : maybeValue(channel); // for shorthand extra channels, use name as label\n if (channel.filter === undefined && channel.scale == null) channel = {...channel, filter: null};\n return [name, channel];\n })\n );\n}\n\nfunction maybeTip(tip) {\n return tip === true\n ? \"xy\"\n : tip === false || tip == null\n ? null\n : typeof tip === \"string\"\n ? keyword(tip, \"tip\", [\"x\", \"y\", \"xy\"])\n : tip; // tip options object\n}\n\nexport function withTip(options, pointer) {\n return options?.tip === true\n ? {...options, tip: pointer}\n : isObject(options?.tip) && options.tip.pointer === undefined\n ? {...options, tip: {...options.tip, pointer}}\n : options;\n}\n","import {pointer as pointof} from \"d3\";\nimport {composeRender} from \"../mark.js\";\nimport {applyFrameAnchor} from \"../style.js\";\n\nconst states = new WeakMap();\n\nfunction pointerK(kx, ky, {x, y, px, py, maxRadius = 40, channels, render, ...options} = {}) {\n maxRadius = +maxRadius;\n // When px or py is used, register an extra channel that the pointer\n // interaction can use to control which point is focused; this allows pointing\n // to function independently of where the downstream mark (e.g., a tip) is\n // displayed. Also default x or y to null to disable maybeTuple etc.\n if (px != null) (x ??= null), (channels = {...channels, px: {value: px, scale: \"x\"}});\n if (py != null) (y ??= null), (channels = {...channels, py: {value: py, scale: \"y\"}});\n return {\n x,\n y,\n channels,\n ...options,\n // Unlike other composed transforms, the render transform must be the\n // outermost render function because it will re-render dynamically in\n // response to pointer events.\n render: composeRender(function (index, scales, values, dimensions, context, next) {\n context = {...context, pointerSticky: false};\n const svg = context.ownerSVGElement;\n const {data} = context.getMarkState(this);\n\n // Isolate state per-pointer, per-plot; if the pointer is reused by\n // multiple marks, they will share the same state (e.g., sticky modality).\n let state = states.get(svg);\n if (!state) states.set(svg, (state = {sticky: false, roots: [], renders: []}));\n\n // This serves as a unique identifier of the rendered mark per-plot; it is\n // used to record the currently-rendered elements (state.roots) so that we\n // can tell when a rendered element is clicked on.\n let renderIndex = state.renders.push(render) - 1;\n\n // For faceting, we want to compute the local coordinates of each point,\n // which means subtracting out the facet translation, if any. (It’s\n // tempting to do this using the local coordinates in SVG, but that’s\n // complicated by mark-specific transforms such as dx and dy.) Also, since\n // band scales return the upper bound of the band, we have to offset by\n // half the bandwidth.\n const {x, y, fx, fy} = scales;\n let tx = fx ? fx(index.fx) - dimensions.marginLeft : 0;\n let ty = fy ? fy(index.fy) - dimensions.marginTop : 0;\n if (x?.bandwidth) tx += x.bandwidth() / 2;\n if (y?.bandwidth) ty += y.bandwidth() / 2;\n\n // For faceting, we also need to record the closest point per facet per\n // mark (!), since each facet has its own pointer event listeners; we only\n // want the closest point across facets to be visible.\n const faceted = index.fi != null;\n let facetState;\n if (faceted) {\n let facetStates = state.facetStates;\n if (!facetStates) state.facetStates = facetStates = new Map();\n facetState = facetStates.get(this);\n if (!facetState) facetStates.set(this, (facetState = new Map()));\n }\n\n // The order of precedence for the pointer position is: px & py; the\n // middle of x1 & y1 and x2 & y2; or x1 & y1 (e.g., area); or lastly x &\n // y. If a dimension is unspecified, the frame anchor is used.\n const [cx, cy] = applyFrameAnchor(this, dimensions);\n const {px: PX, py: PY} = values;\n const px = PX ? (i) => PX[i] : anchorX(values, cx);\n const py = PY ? (i) => PY[i] : anchorY(values, cy);\n\n let i; // currently focused index\n let g; // currently rendered mark\n let s; // currently rendered stickiness\n let f; // current animation frame\n\n // When faceting, if more than one pointer would be visible, only show\n // this one if it is the closest. We defer rendering using an animation\n // frame to allow all pointer events to be received before deciding which\n // mark to render; although when hiding, we render immediately.\n function update(ii, ri) {\n if (faceted) {\n if (f) f = cancelAnimationFrame(f);\n if (ii == null) facetState.delete(index.fi);\n else {\n facetState.set(index.fi, ri);\n f = requestAnimationFrame(() => {\n f = null;\n for (const [fi, r] of facetState) {\n if (r < ri || (r === ri && fi < index.fi)) {\n ii = null;\n break;\n }\n }\n render(ii);\n });\n return;\n }\n }\n render(ii);\n }\n\n function render(ii) {\n if (i === ii && s === state.sticky) return; // the tooltip hasn’t moved\n i = ii;\n s = context.pointerSticky = state.sticky;\n const I = i == null ? [] : [i];\n if (faceted) (I.fx = index.fx), (I.fy = index.fy), (I.fi = index.fi);\n const r = next(I, scales, values, dimensions, context);\n if (g) {\n // When faceting, preserve swapped mark and facet transforms; also\n // remove ARIA attributes since these are promoted to the parent. This\n // is perhaps brittle in that it depends on how Plot renders facets,\n // but it produces a cleaner and more accessible SVG structure.\n if (faceted) {\n const p = g.parentNode;\n const ft = g.getAttribute(\"transform\");\n const mt = r.getAttribute(\"transform\");\n ft ? r.setAttribute(\"transform\", ft) : r.removeAttribute(\"transform\");\n mt ? p.setAttribute(\"transform\", mt) : p.removeAttribute(\"transform\");\n r.removeAttribute(\"aria-label\");\n r.removeAttribute(\"aria-description\");\n r.removeAttribute(\"aria-hidden\");\n }\n g.replaceWith(r);\n }\n state.roots[renderIndex] = g = r;\n\n // Dispatch the value. When simultaneously exiting this facet and\n // entering a new one, prioritize the entering facet.\n if (!(i == null && facetState?.size > 1)) context.dispatchValue(i == null ? null : data[i]);\n return r;\n }\n\n // Select the closest point to the mouse in the current facet; for\n // pointerX or pointerY, the orthogonal component of the distance is\n // squashed, selecting primarily on the dominant dimension. Across facets,\n // use unsquashed distance to determine the winner.\n function pointermove(event) {\n if (state.sticky || (event.pointerType === \"mouse\" && event.buttons === 1)) return; // dragging\n let [xp, yp] = pointof(event);\n (xp -= tx), (yp -= ty); // correct for facets and band scales\n const kpx = xp < dimensions.marginLeft || xp > dimensions.width - dimensions.marginRight ? 1 : kx;\n const kpy = yp < dimensions.marginTop || yp > dimensions.height - dimensions.marginBottom ? 1 : ky;\n let ii = null;\n let ri = maxRadius * maxRadius;\n for (const j of index) {\n const dx = kpx * (px(j) - xp);\n const dy = kpy * (py(j) - yp);\n const rj = dx * dx + dy * dy;\n if (rj <= ri) (ii = j), (ri = rj);\n }\n if (ii != null && (kx !== 1 || ky !== 1)) {\n const dx = px(ii) - xp;\n const dy = py(ii) - yp;\n ri = dx * dx + dy * dy;\n }\n update(ii, ri);\n }\n\n function pointerdown(event) {\n if (event.pointerType !== \"mouse\") return;\n if (i == null) return; // not pointing\n if (state.sticky && state.roots.some((r) => r?.contains(event.target))) return; // stay sticky\n if (state.sticky) (state.sticky = false), state.renders.forEach((r) => r(null)); // clear all pointers\n else (state.sticky = true), render(i);\n event.stopImmediatePropagation(); // suppress other pointers\n }\n\n function pointerleave(event) {\n if (event.pointerType !== \"mouse\") return;\n if (!state.sticky) update(null);\n }\n\n // We listen to the svg element; listening to the window instead would let\n // us receive pointer events from farther away, but would also make it\n // hard to know when to remove the listeners. (Using a mutation observer\n // to watch the entire document is likely too expensive.)\n svg.addEventListener(\"pointerenter\", pointermove);\n svg.addEventListener(\"pointermove\", pointermove);\n svg.addEventListener(\"pointerdown\", pointerdown);\n svg.addEventListener(\"pointerleave\", pointerleave);\n\n return render(null);\n }, render)\n };\n}\n\nexport function pointer(options) {\n return pointerK(1, 1, options);\n}\n\nexport function pointerX(options) {\n return pointerK(1, 0.01, options);\n}\n\nexport function pointerY(options) {\n return pointerK(0.01, 1, options);\n}\n\nexport function anchorX({x1: X1, x2: X2, x: X = X1}, cx) {\n return X1 && X2 ? (i) => (X1[i] + X2[i]) / 2 : X ? (i) => X[i] : () => cx;\n}\n\nexport function anchorY({y1: Y1, y2: Y2, y: Y = Y1}, cy) {\n return Y1 && Y2 ? (i) => (Y1[i] + Y2[i]) / 2 : Y ? (i) => Y[i] : () => cy;\n}\n","import {isOrdinalScale} from \"./scales.js\";\n\nexport function inferFontVariant(scale) {\n return isOrdinalScale(scale) && scale.interval === undefined ? undefined : \"tabular-nums\";\n}\n","export const radians = Math.PI / 180;\n","import {create} from \"./context.js\";\n\nexport function markers(mark, {marker, markerStart = marker, markerMid = marker, markerEnd = marker} = {}) {\n mark.markerStart = maybeMarker(markerStart);\n mark.markerMid = maybeMarker(markerMid);\n mark.markerEnd = maybeMarker(markerEnd);\n}\n\nfunction maybeMarker(marker) {\n if (marker == null || marker === false) return null;\n if (marker === true) return markerCircleFill;\n if (typeof marker === \"function\") return marker;\n switch (`${marker}`.toLowerCase()) {\n case \"none\":\n return null;\n case \"arrow\":\n return markerArrow(\"auto\");\n case \"arrow-reverse\":\n return markerArrow(\"auto-start-reverse\");\n case \"dot\":\n return markerDot;\n case \"circle\":\n case \"circle-fill\":\n return markerCircleFill;\n case \"circle-stroke\":\n return markerCircleStroke;\n }\n throw new Error(`invalid marker: ${marker}`);\n}\n\nfunction markerArrow(orient) {\n return (color, context) =>\n create(\"svg:marker\", context)\n .attr(\"viewBox\", \"-5 -5 10 10\")\n .attr(\"markerWidth\", 6.67)\n .attr(\"markerHeight\", 6.67)\n .attr(\"orient\", orient)\n .attr(\"fill\", \"none\")\n .attr(\"stroke\", color)\n .attr(\"stroke-width\", 1.5)\n .attr(\"stroke-linecap\", \"round\")\n .attr(\"stroke-linejoin\", \"round\")\n .call((marker) => marker.append(\"path\").attr(\"d\", \"M-1.5,-3l3,3l-3,3\"))\n .node();\n}\n\nfunction markerDot(color, context) {\n return create(\"svg:marker\", context)\n .attr(\"viewBox\", \"-5 -5 10 10\")\n .attr(\"markerWidth\", 6.67)\n .attr(\"markerHeight\", 6.67)\n .attr(\"fill\", color)\n .attr(\"stroke\", \"none\")\n .call((marker) => marker.append(\"circle\").attr(\"r\", 2.5))\n .node();\n}\n\nfunction markerCircleFill(color, context) {\n return create(\"svg:marker\", context)\n .attr(\"viewBox\", \"-5 -5 10 10\")\n .attr(\"markerWidth\", 6.67)\n .attr(\"markerHeight\", 6.67)\n .attr(\"fill\", color)\n .attr(\"stroke\", \"white\")\n .attr(\"stroke-width\", 1.5)\n .call((marker) => marker.append(\"circle\").attr(\"r\", 3))\n .node();\n}\n\nfunction markerCircleStroke(color, context) {\n return create(\"svg:marker\", context)\n .attr(\"viewBox\", \"-5 -5 10 10\")\n .attr(\"markerWidth\", 6.67)\n .attr(\"markerHeight\", 6.67)\n .attr(\"fill\", \"white\")\n .attr(\"stroke\", color)\n .attr(\"stroke-width\", 1.5)\n .call((marker) => marker.append(\"circle\").attr(\"r\", 3))\n .node();\n}\n\nlet nextMarkerId = 0;\n\nexport function applyMarkers(path, mark, {stroke: S}, context) {\n return applyMarkersColor(path, mark, S && ((i) => S[i]), context);\n}\n\nexport function applyGroupedMarkers(path, mark, {stroke: S}, context) {\n return applyMarkersColor(path, mark, S && (([i]) => S[i]), context);\n}\n\nfunction applyMarkersColor(path, {markerStart, markerMid, markerEnd, stroke}, strokeof = () => stroke, context) {\n const iriByMarkerColor = new Map();\n\n function applyMarker(marker) {\n return function (i) {\n const color = strokeof(i);\n let iriByColor = iriByMarkerColor.get(marker);\n if (!iriByColor) iriByMarkerColor.set(marker, (iriByColor = new Map()));\n let iri = iriByColor.get(color);\n if (!iri) {\n const node = this.parentNode.insertBefore(marker(color, context), this);\n const id = `plot-marker-${++nextMarkerId}`;\n node.setAttribute(\"id\", id);\n iriByColor.set(color, (iri = `url(#${id})`));\n }\n return iri;\n };\n }\n\n if (markerStart) path.attr(\"marker-start\", applyMarker(markerStart));\n if (markerMid) path.attr(\"marker-mid\", applyMarker(markerMid));\n if (markerEnd) path.attr(\"marker-end\", applyMarker(markerEnd));\n}\n","import {offset} from \"../style.js\";\n\nexport function maybeInsetX({inset, insetLeft, insetRight, ...options} = {}) {\n [insetLeft, insetRight] = maybeInset(inset, insetLeft, insetRight);\n return {inset, insetLeft, insetRight, ...options};\n}\n\nexport function maybeInsetY({inset, insetTop, insetBottom, ...options} = {}) {\n [insetTop, insetBottom] = maybeInset(inset, insetTop, insetBottom);\n return {inset, insetTop, insetBottom, ...options};\n}\n\nfunction maybeInset(inset, inset1, inset2) {\n return inset === undefined && inset1 === undefined && inset2 === undefined\n ? offset\n ? [1, 0]\n : [0.5, 0.5]\n : [inset1, inset2];\n}\n","import {isTemporal, labelof, map, maybeInterval, maybeValue, valueof} from \"../options.js\";\nimport {maybeInsetX, maybeInsetY} from \"./inset.js\";\n\n// The interval may be specified either as x: {value, interval} or as {x,\n// interval}. The former can be used to specify separate intervals for x and y,\n// for example with Plot.rect.\nfunction maybeIntervalValue(value, {interval}) {\n value = {...maybeValue(value)};\n value.interval = maybeInterval(value.interval === undefined ? interval : value.interval);\n return value;\n}\n\nfunction maybeIntervalK(k, maybeInsetK, options, trivial) {\n const {[k]: v, [`${k}1`]: v1, [`${k}2`]: v2} = options;\n const {value, interval} = maybeIntervalValue(v, options);\n if (value == null || (interval == null && !trivial)) return options;\n const label = labelof(v);\n if (interval == null) {\n let V;\n const kv = {transform: (data) => V || (V = valueof(data, value)), label};\n return {\n ...options,\n [k]: undefined,\n [`${k}1`]: v1 === undefined ? kv : v1,\n [`${k}2`]: v2 === undefined ? kv : v2\n };\n }\n let D1, V1;\n function transform(data) {\n if (V1 !== undefined && data === D1) return V1; // memoize\n return (V1 = map(valueof((D1 = data), value), (v) => interval.floor(v)));\n }\n return maybeInsetK({\n ...options,\n [k]: undefined,\n [`${k}1`]: v1 === undefined ? {transform, label} : v1,\n [`${k}2`]: v2 === undefined ? {transform: (data) => transform(data).map((v) => interval.offset(v)), label} : v2\n });\n}\n\nfunction maybeIntervalMidK(k, maybeInsetK, options) {\n const {[k]: v} = options;\n const {value, interval} = maybeIntervalValue(v, options);\n if (value == null || interval == null) return options;\n return maybeInsetK({\n ...options,\n [k]: {\n label: labelof(v),\n transform: (data) => {\n const V1 = map(valueof(data, value), (v) => interval.floor(v));\n const V2 = V1.map((v) => interval.offset(v));\n return V1.map(\n isTemporal(V1)\n ? (v1, v2) =>\n v1 == null || isNaN((v1 = +v1)) || ((v2 = V2[v2]), v2 == null) || isNaN((v2 = +v2))\n ? undefined\n : new Date((v1 + v2) / 2)\n : (v1, v2) => (v1 == null || ((v2 = V2[v2]), v2 == null) ? NaN : (+v1 + +v2) / 2)\n );\n }\n }\n });\n}\n\nexport function maybeTrivialIntervalX(options = {}) {\n return maybeIntervalK(\"x\", maybeInsetX, options, true);\n}\n\nexport function maybeTrivialIntervalY(options = {}) {\n return maybeIntervalK(\"y\", maybeInsetY, options, true);\n}\n\nexport function maybeIntervalX(options = {}) {\n return maybeIntervalK(\"x\", maybeInsetX, options);\n}\n\nexport function maybeIntervalY(options = {}) {\n return maybeIntervalK(\"y\", maybeInsetY, options);\n}\n\nexport function maybeIntervalMidX(options = {}) {\n return maybeIntervalMidK(\"x\", maybeInsetX, options);\n}\n\nexport function maybeIntervalMidY(options = {}) {\n return maybeIntervalMidK(\"y\", maybeInsetY, options);\n}\n","import {create} from \"../context.js\";\nimport {Mark, withTip} from \"../mark.js\";\nimport {applyMarkers, markers} from \"../marker.js\";\nimport {identity, number} from \"../options.js\";\nimport {isCollapsed} from \"../scales.js\";\nimport {applyChannelStyles, applyDirectStyles, applyIndirectStyles, applyTransform, offset} from \"../style.js\";\nimport {maybeIntervalX, maybeIntervalY} from \"../transforms/interval.js\";\n\nconst defaults = {\n ariaLabel: \"rule\",\n fill: null,\n stroke: \"currentColor\"\n};\n\nexport class RuleX extends Mark {\n constructor(data, options = {}) {\n const {x, y1, y2, inset = 0, insetTop = inset, insetBottom = inset} = options;\n super(\n data,\n {\n x: {value: x, scale: \"x\", optional: true},\n y1: {value: y1, scale: \"y\", optional: true},\n y2: {value: y2, scale: \"y\", optional: true}\n },\n withTip(options, \"x\"),\n defaults\n );\n this.insetTop = number(insetTop);\n this.insetBottom = number(insetBottom);\n markers(this, options);\n }\n render(index, scales, channels, dimensions, context) {\n const {x, y} = scales;\n const {x: X, y1: Y1, y2: Y2} = channels;\n const {width, height, marginTop, marginRight, marginLeft, marginBottom} = dimensions;\n const {insetTop, insetBottom} = this;\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyTransform, this, {x: X && x}, offset, 0)\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"line\")\n .call(applyDirectStyles, this)\n .attr(\"x1\", X ? (i) => X[i] : (marginLeft + width - marginRight) / 2)\n .attr(\"x2\", X ? (i) => X[i] : (marginLeft + width - marginRight) / 2)\n .attr(\"y1\", Y1 && !isCollapsed(y) ? (i) => Y1[i] + insetTop : marginTop + insetTop)\n .attr(\n \"y2\",\n Y2 && !isCollapsed(y)\n ? y.bandwidth\n ? (i) => Y2[i] + y.bandwidth() - insetBottom\n : (i) => Y2[i] - insetBottom\n : height - marginBottom - insetBottom\n )\n .call(applyChannelStyles, this, channels)\n .call(applyMarkers, this, channels, context)\n )\n .node();\n }\n}\n\nexport class RuleY extends Mark {\n constructor(data, options = {}) {\n const {x1, x2, y, inset = 0, insetRight = inset, insetLeft = inset} = options;\n super(\n data,\n {\n y: {value: y, scale: \"y\", optional: true},\n x1: {value: x1, scale: \"x\", optional: true},\n x2: {value: x2, scale: \"x\", optional: true}\n },\n withTip(options, \"y\"),\n defaults\n );\n this.insetRight = number(insetRight);\n this.insetLeft = number(insetLeft);\n markers(this, options);\n }\n render(index, scales, channels, dimensions, context) {\n const {x, y} = scales;\n const {y: Y, x1: X1, x2: X2} = channels;\n const {width, height, marginTop, marginRight, marginLeft, marginBottom} = dimensions;\n const {insetLeft, insetRight} = this;\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyTransform, this, {y: Y && y}, 0, offset)\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"line\")\n .call(applyDirectStyles, this)\n .attr(\"x1\", X1 && !isCollapsed(x) ? (i) => X1[i] + insetLeft : marginLeft + insetLeft)\n .attr(\n \"x2\",\n X2 && !isCollapsed(x)\n ? x.bandwidth\n ? (i) => X2[i] + x.bandwidth() - insetRight\n : (i) => X2[i] - insetRight\n : width - marginRight - insetRight\n )\n .attr(\"y1\", Y ? (i) => Y[i] : (marginTop + height - marginBottom) / 2)\n .attr(\"y2\", Y ? (i) => Y[i] : (marginTop + height - marginBottom) / 2)\n .call(applyChannelStyles, this, channels)\n .call(applyMarkers, this, channels, context)\n )\n .node();\n }\n}\n\nexport function ruleX(data, options) {\n let {x = identity, y, y1, y2, ...rest} = maybeIntervalY(options);\n [y1, y2] = maybeOptionalZero(y, y1, y2);\n return new RuleX(data, {...rest, x, y1, y2});\n}\n\nexport function ruleY(data, options) {\n let {y = identity, x, x1, x2, ...rest} = maybeIntervalX(options);\n [x1, x2] = maybeOptionalZero(x, x1, x2);\n return new RuleY(data, {...rest, y, x1, x2});\n}\n\n// For marks specified either as [0, x] or [x1, x2], or nothing.\nfunction maybeOptionalZero(x, x1, x2) {\n if (x == null) {\n if (x1 === undefined) {\n if (x2 !== undefined) return [0, x2];\n } else {\n if (x2 === undefined) return [0, x1];\n }\n } else if (x1 === undefined) {\n return x2 === undefined ? [0, x] : [x, x2];\n } else if (x2 === undefined) {\n return [x, x1];\n }\n return [x1, x2];\n}\n","export function template(strings, ...parts) {\n let n = parts.length;\n\n // If any of the interpolated parameters are strings rather than functions,\n // bake them into the template to optimize performance during render.\n for (let j = 0, copy = true; j < n; ++j) {\n if (typeof parts[j] !== \"function\") {\n if (copy) {\n strings = strings.slice(); // copy before mutate\n copy = false;\n }\n strings.splice(j, 2, strings[j] + parts[j] + strings[j + 1]);\n parts.splice(j, 1);\n --j, --n;\n }\n }\n\n return (i) => {\n let s = strings[0];\n for (let j = 0; j < n; ++j) {\n s += parts[j](i) + strings[j + 1];\n }\n return s;\n };\n}\n","import {namespaces} from \"d3\";\nimport {create} from \"../context.js\";\nimport {nonempty} from \"../defined.js\";\nimport {formatDefault} from \"../format.js\";\nimport {Mark} from \"../mark.js\";\nimport {\n indexOf,\n identity,\n string,\n maybeNumberChannel,\n maybeTuple,\n numberChannel,\n isNumeric,\n isTemporal,\n keyword,\n maybeFrameAnchor,\n isTextual,\n isIterable\n} from \"../options.js\";\nimport {\n applyChannelStyles,\n applyDirectStyles,\n applyIndirectStyles,\n applyAttr,\n applyTransform,\n impliedString,\n applyFrameAnchor\n} from \"../style.js\";\nimport {template} from \"../template.js\";\nimport {maybeIntervalMidX, maybeIntervalMidY} from \"../transforms/interval.js\";\n\nconst defaults = {\n ariaLabel: \"text\",\n strokeLinejoin: \"round\",\n strokeWidth: 3,\n paintOrder: \"stroke\"\n};\n\nconst softHyphen = \"\\u00ad\";\n\nexport class Text extends Mark {\n constructor(data, options = {}) {\n const {\n x,\n y,\n text = isIterable(data) && isTextual(data) ? identity : indexOf,\n frameAnchor,\n textAnchor = /right$/i.test(frameAnchor) ? \"end\" : /left$/i.test(frameAnchor) ? \"start\" : \"middle\",\n lineAnchor = /^top/i.test(frameAnchor) ? \"top\" : /^bottom/i.test(frameAnchor) ? \"bottom\" : \"middle\",\n lineHeight = 1,\n lineWidth = Infinity,\n textOverflow,\n monospace,\n fontFamily = monospace ? \"ui-monospace, monospace\" : undefined,\n fontSize,\n fontStyle,\n fontVariant,\n fontWeight,\n rotate\n } = options;\n const [vrotate, crotate] = maybeNumberChannel(rotate, 0);\n const [vfontSize, cfontSize] = maybeFontSizeChannel(fontSize);\n super(\n data,\n {\n x: {value: x, scale: \"x\", optional: true},\n y: {value: y, scale: \"y\", optional: true},\n fontSize: {value: vfontSize, optional: true},\n rotate: {value: numberChannel(vrotate), optional: true},\n text: {value: text, filter: nonempty, optional: true}\n },\n options,\n defaults\n );\n this.rotate = crotate;\n this.textAnchor = impliedString(textAnchor, \"middle\");\n this.lineAnchor = keyword(lineAnchor, \"lineAnchor\", [\"top\", \"middle\", \"bottom\"]);\n this.lineHeight = +lineHeight;\n this.lineWidth = +lineWidth;\n this.textOverflow = maybeTextOverflow(textOverflow);\n this.monospace = !!monospace;\n this.fontFamily = string(fontFamily);\n this.fontSize = cfontSize;\n this.fontStyle = string(fontStyle);\n this.fontVariant = string(fontVariant);\n this.fontWeight = string(fontWeight);\n this.frameAnchor = maybeFrameAnchor(frameAnchor);\n if (!(this.lineWidth >= 0)) throw new Error(`invalid lineWidth: ${lineWidth}`);\n this.splitLines = splitter(this);\n this.clipLine = clipper(this);\n }\n render(index, scales, channels, dimensions, context) {\n const {x, y} = scales;\n const {x: X, y: Y, rotate: R, text: T, title: TL, fontSize: FS} = channels;\n const {rotate} = this;\n const [cx, cy] = applyFrameAnchor(this, dimensions);\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyIndirectTextStyles, this, T, dimensions)\n .call(applyTransform, this, {x: X && x, y: Y && y})\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"text\")\n .call(applyDirectStyles, this)\n .call(applyMultilineText, this, T, TL)\n .attr(\n \"transform\",\n template`translate(${X ? (i) => X[i] : cx},${Y ? (i) => Y[i] : cy})${\n R ? (i) => ` rotate(${R[i]})` : rotate ? ` rotate(${rotate})` : ``\n }`\n )\n .call(applyAttr, \"font-size\", FS && ((i) => FS[i]))\n .call(applyChannelStyles, this, channels)\n )\n .node();\n }\n}\n\nexport function maybeTextOverflow(textOverflow) {\n return textOverflow == null\n ? null\n : keyword(textOverflow, \"textOverflow\", [\n \"clip\", // shorthand for clip-end\n \"ellipsis\", // … ellipsis-end\n \"clip-start\",\n \"clip-end\",\n \"ellipsis-start\",\n \"ellipsis-middle\",\n \"ellipsis-end\"\n ]).replace(/^(clip|ellipsis)$/, \"$1-end\");\n}\n\nfunction applyMultilineText(selection, mark, T, TL) {\n if (!T) return;\n const {lineAnchor, lineHeight, textOverflow, splitLines, clipLine} = mark;\n selection.each(function (i) {\n const lines = splitLines(formatDefault(T[i]) ?? \"\").map(clipLine);\n const n = lines.length;\n const y = lineAnchor === \"top\" ? 0.71 : lineAnchor === \"bottom\" ? 1 - n : (164 - n * 100) / 200;\n if (n > 1) {\n let m = 0;\n for (let i = 0; i < n; ++i) {\n ++m;\n if (!lines[i]) continue;\n const tspan = this.ownerDocument.createElementNS(namespaces.svg, \"tspan\");\n tspan.setAttribute(\"x\", 0);\n if (i === m - 1) tspan.setAttribute(\"y\", `${(y + i) * lineHeight}em`);\n else tspan.setAttribute(\"dy\", `${m * lineHeight}em`);\n tspan.textContent = lines[i];\n this.appendChild(tspan);\n m = 0;\n }\n } else {\n if (y) this.setAttribute(\"y\", `${y * lineHeight}em`);\n this.textContent = lines[0];\n }\n if (textOverflow && !TL && lines[0] !== T[i]) {\n const title = this.ownerDocument.createElementNS(namespaces.svg, \"title\");\n title.textContent = T[i];\n this.appendChild(title);\n }\n });\n}\n\nexport function text(data, {x, y, ...options} = {}) {\n if (options.frameAnchor === undefined) [x, y] = maybeTuple(x, y);\n return new Text(data, {...options, x, y});\n}\n\nexport function textX(data, {x = identity, ...options} = {}) {\n return new Text(data, maybeIntervalMidY({...options, x}));\n}\n\nexport function textY(data, {y = identity, ...options} = {}) {\n return new Text(data, maybeIntervalMidX({...options, y}));\n}\n\nexport function applyIndirectTextStyles(selection, mark, T) {\n applyAttr(selection, \"text-anchor\", mark.textAnchor);\n applyAttr(selection, \"font-family\", mark.fontFamily);\n applyAttr(selection, \"font-size\", mark.fontSize);\n applyAttr(selection, \"font-style\", mark.fontStyle);\n applyAttr(selection, \"font-variant\", mark.fontVariant === undefined ? inferFontVariant(T) : mark.fontVariant);\n applyAttr(selection, \"font-weight\", mark.fontWeight);\n}\n\nfunction inferFontVariant(T) {\n return T && (isNumeric(T) || isTemporal(T)) ? \"tabular-nums\" : undefined;\n}\n\n// https://developer.mozilla.org/en-US/docs/Web/CSS/font-size\nconst fontSizes = new Set([\n // global keywords\n \"inherit\",\n \"initial\",\n \"revert\",\n \"unset\",\n // absolute keywords\n \"xx-small\",\n \"x-small\",\n \"small\",\n \"medium\",\n \"large\",\n \"x-large\",\n \"xx-large\",\n \"xxx-large\",\n // relative keywords\n \"larger\",\n \"smaller\"\n]);\n\n// The font size may be expressed as a constant in the following forms:\n// - number in pixels\n// - string keyword: see above\n// - string <length>: e.g., \"12px\"\n// - string <percentage>: e.g., \"80%\"\n// Anything else is assumed to be a channel definition.\nfunction maybeFontSizeChannel(fontSize) {\n if (fontSize == null || typeof fontSize === \"number\") return [undefined, fontSize];\n if (typeof fontSize !== \"string\") return [fontSize, undefined];\n fontSize = fontSize.trim().toLowerCase();\n return fontSizes.has(fontSize) || /^[+-]?\\d*\\.?\\d+(e[+-]?\\d+)?(\\w*|%)$/.test(fontSize)\n ? [undefined, fontSize]\n : [fontSize, undefined];\n}\n\n// This is a greedy algorithm for line wrapping. It would be better to use the\n// Knuth–Plass line breaking algorithm (but that would be much more complex).\n// https://en.wikipedia.org/wiki/Line_wrap_and_word_wrap\nfunction lineWrap(input, maxWidth, widthof) {\n const lines = [];\n let lineStart,\n lineEnd = 0;\n for (const [wordStart, wordEnd, required] of lineBreaks(input)) {\n // Record the start of a line. This isn’t the same as the previous line’s\n // end because we often skip spaces between lines.\n if (lineStart === undefined) lineStart = wordStart;\n\n // If the current line is not empty, and if adding the current word would\n // make the line longer than the allowed width, then break the line at the\n // previous word end.\n if (lineEnd > lineStart && widthof(input, lineStart, wordEnd) > maxWidth) {\n lines.push(input.slice(lineStart, lineEnd) + (input[lineEnd - 1] === softHyphen ? \"-\" : \"\"));\n lineStart = wordStart;\n }\n\n // If this is a required break (a newline), emit the line and reset.\n if (required) {\n lines.push(input.slice(lineStart, wordEnd));\n lineStart = undefined;\n continue;\n }\n\n // Extend the current line to include the new word.\n lineEnd = wordEnd;\n }\n return lines;\n}\n\n// This is a rudimentary (and U.S.-centric) algorithm for finding opportunities\n// to break lines between words. A better and far more comprehensive approach\n// would be to use the official Unicode Line Breaking Algorithm.\n// https://unicode.org/reports/tr14/\nfunction* lineBreaks(input) {\n let i = 0,\n j = 0;\n const n = input.length;\n while (j < n) {\n let k = 1;\n switch (input[j]) {\n case softHyphen:\n case \"-\": // hyphen\n ++j;\n yield [i, j, false];\n i = j;\n break;\n case \" \":\n yield [i, j, false];\n while (input[++j] === \" \"); // skip multiple spaces\n i = j;\n break;\n case \"\\r\":\n if (input[j + 1] === \"\\n\") ++k; // falls through\n case \"\\n\":\n yield [i, j, true];\n j += k;\n i = j;\n break;\n default:\n ++j;\n break;\n }\n }\n yield [i, j, true];\n}\n\n// Computed as round(measureText(text).width * 10) at 10px system-ui. For\n// characters that are not represented in this map, we’d ideally want to use a\n// weighted average of what we expect to see. But since we don’t really know\n// what that is, using “e” seems reasonable.\nconst defaultWidthMap = {\n a: 56,\n b: 63,\n c: 57,\n d: 63,\n e: 58,\n f: 37,\n g: 62,\n h: 60,\n i: 26,\n j: 26,\n k: 55,\n l: 26,\n m: 88,\n n: 60,\n o: 60,\n p: 62,\n q: 62,\n r: 39,\n s: 54,\n t: 38,\n u: 60,\n v: 55,\n w: 79,\n x: 54,\n y: 55,\n z: 55,\n A: 69,\n B: 67,\n C: 73,\n D: 74,\n E: 61,\n F: 58,\n G: 76,\n H: 75,\n I: 28,\n J: 55,\n K: 67,\n L: 58,\n M: 89,\n N: 75,\n O: 78,\n P: 65,\n Q: 78,\n R: 67,\n S: 65,\n T: 65,\n U: 75,\n V: 69,\n W: 98,\n X: 69,\n Y: 67,\n Z: 67,\n 0: 64,\n 1: 48,\n 2: 62,\n 3: 64,\n 4: 66,\n 5: 63,\n 6: 65,\n 7: 58,\n 8: 65,\n 9: 65,\n \" \": 29,\n \"!\": 32,\n '\"': 49,\n \"'\": 31,\n \"(\": 39,\n \")\": 39,\n \",\": 31,\n \"-\": 48,\n \".\": 31,\n \"/\": 32,\n \":\": 31,\n \";\": 31,\n \"?\": 52,\n \"‘\": 31,\n \"’\": 31,\n \"“\": 47,\n \"”\": 47,\n \"…\": 82\n};\n\n// This is a rudimentary (and U.S.-centric) algorithm for measuring the width of\n// a string based on a technique of Gregor Aisch; it assumes that individual\n// characters are laid out independently and does not implement the Unicode\n// grapheme cluster breaking algorithm. It does understand code points, though,\n// and so treats things like emoji as having the width of a lowercase e (and\n// should be equivalent to using for-of to iterate over code points, while also\n// being fast). TODO Optimize this by noting that we often re-measure characters\n// that were previously measured?\n// http://www.unicode.org/reports/tr29/#Grapheme_Cluster_Boundaries\n// https://exploringjs.com/impatient-js/ch_strings.html#atoms-of-text\nexport function defaultWidth(text, start = 0, end = text.length) {\n let sum = 0;\n for (let i = start; i < end; i = readCharacter(text, i)) {\n sum += defaultWidthMap[text[i]] ?? (isPictographic(text, i) ? 120 : defaultWidthMap.e);\n }\n return sum;\n}\n\n// Even for monospaced text, we can’t assume that the number of UTF-16 code\n// points (i.e., the length of a string) corresponds to the number of visible\n// characters; we still have to count graphemes. And note that pictographic\n// characters such as emojis are typically not monospaced!\nexport function monospaceWidth(text, start = 0, end = text.length) {\n let sum = 0;\n for (let i = start; i < end; i = readCharacter(text, i)) {\n sum += isPictographic(text, i) ? 200 : 100;\n }\n return sum;\n}\n\nexport function splitter({monospace, lineWidth, textOverflow}) {\n if (textOverflow != null || lineWidth == Infinity) return (text) => text.split(/\\r\\n?|\\n/g);\n const widthof = monospace ? monospaceWidth : defaultWidth;\n const maxWidth = lineWidth * 100;\n return (text) => lineWrap(text, maxWidth, widthof);\n}\n\nexport function clipper({monospace, lineWidth, textOverflow}) {\n if (textOverflow == null || lineWidth == Infinity) return (text) => text;\n const widthof = monospace ? monospaceWidth : defaultWidth;\n const maxWidth = lineWidth * 100;\n switch (textOverflow) {\n case \"clip-start\":\n return (text) => clipStart(text, maxWidth, widthof, \"\");\n case \"clip-end\":\n return (text) => clipEnd(text, maxWidth, widthof, \"\");\n case \"ellipsis-start\":\n return (text) => clipStart(text, maxWidth, widthof, ellipsis);\n case \"ellipsis-middle\":\n return (text) => clipMiddle(text, maxWidth, widthof, ellipsis);\n case \"ellipsis-end\":\n return (text) => clipEnd(text, maxWidth, widthof, ellipsis);\n }\n}\n\nexport const ellipsis = \"…\";\n\n// Cuts the given text to the given width, using the specified widthof function;\n// the returned [index, error] guarantees text.slice(0, index) fits within the\n// specified width with the given error. If the text fits naturally within the\n// given width, returns [-1, 0]. If the text needs cutting, the given inset\n// specifies how much space (in the same units as width and widthof) to reserve\n// for a possible ellipsis character.\nexport function cut(text, width, widthof, inset) {\n const I = []; // indexes of read character boundaries\n let w = 0; // current line width\n for (let i = 0, j = 0, n = text.length; i < n; i = j) {\n j = readCharacter(text, i); // read the next character\n const l = widthof(text, i, j); // current character width\n if (w + l > width) {\n w += inset;\n while (w > width && i > 0) (j = i), (i = I.pop()), (w -= widthof(text, i, j)); // remove excess\n return [i, width - w];\n }\n w += l;\n I.push(i);\n }\n return [-1, 0];\n}\n\nexport function clipEnd(text, width, widthof, ellipsis) {\n text = text.trim(); // ignore leading and trailing whitespace\n const e = widthof(ellipsis);\n const [i] = cut(text, width, widthof, e);\n return i < 0 ? text : text.slice(0, i).trimEnd() + ellipsis;\n}\n\nexport function clipMiddle(text, width, widthof, ellipsis) {\n text = text.trim(); // ignore leading and trailing whitespace\n const w = widthof(text);\n if (w <= width) return text;\n const e = widthof(ellipsis) / 2;\n const [i, ei] = cut(text, width / 2, widthof, e);\n const [j] = cut(text, w - width / 2 - ei + e, widthof, -e); // TODO read spaces?\n return j < 0 ? ellipsis : text.slice(0, i).trimEnd() + ellipsis + text.slice(readCharacter(text, j)).trimStart();\n}\n\nexport function clipStart(text, width, widthof, ellipsis) {\n text = text.trim(); // ignore leading and trailing whitespace\n const w = widthof(text);\n if (w <= width) return text;\n const e = widthof(ellipsis);\n const [j] = cut(text, w - width + e, widthof, -e); // TODO read spaces?\n return j < 0 ? ellipsis : ellipsis + text.slice(readCharacter(text, j)).trimStart();\n}\n\nconst reCombiner = /[\\p{Combining_Mark}\\p{Emoji_Modifier}]+/uy;\nconst rePictographic = /\\p{Extended_Pictographic}/uy;\n\n// Reads a single “character” element from the given text starting at the given\n// index, returning the index after the read character. Ideally, this implements\n// the Unicode text segmentation algorithm and understands grapheme cluster\n// boundaries, etc., but in practice this is only smart enough to detect UTF-16\n// surrogate pairs, combining marks, and zero-width joiner (zwj) sequences such\n// as emoji skin color modifiers. https://unicode.org/reports/tr29/\nexport function readCharacter(text, i) {\n i += isSurrogatePair(text, i) ? 2 : 1;\n if (isCombiner(text, i)) i = reCombiner.lastIndex;\n if (isZeroWidthJoiner(text, i)) return readCharacter(text, i + 1);\n return i;\n}\n\n// We avoid more expensive regex tests involving Unicode property classes by\n// first checking for the common case of 7-bit ASCII characters.\nfunction isAscii(text, i) {\n return text.charCodeAt(i) < 0x80;\n}\n\nfunction isSurrogatePair(text, i) {\n const hi = text.charCodeAt(i);\n if (hi >= 0xd800 && hi < 0xdc00) {\n const lo = text.charCodeAt(i + 1);\n return lo >= 0xdc00 && lo < 0xe000;\n }\n return false;\n}\n\nfunction isZeroWidthJoiner(text, i) {\n return text.charCodeAt(i) === 0x200d;\n}\n\nfunction isCombiner(text, i) {\n return isAscii(text, i) ? false : ((reCombiner.lastIndex = i), reCombiner.test(text));\n}\n\nfunction isPictographic(text, i) {\n return isAscii(text, i) ? false : ((rePictographic.lastIndex = i), rePictographic.test(text));\n}\n","import {pathRound as path} from \"d3\";\nimport {create} from \"../context.js\";\nimport {Mark} from \"../mark.js\";\nimport {maybeFrameAnchor, maybeNumberChannel, maybeTuple, keyword, identity} from \"../options.js\";\nimport {\n applyChannelStyles,\n applyDirectStyles,\n applyFrameAnchor,\n applyIndirectStyles,\n applyTransform\n} from \"../style.js\";\nimport {template} from \"../template.js\";\n\nconst defaults = {\n ariaLabel: \"vector\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 1.5,\n strokeLinejoin: \"round\",\n strokeLinecap: \"round\"\n};\n\nconst defaultRadius = 3.5;\n\n// The size of the arrowhead is proportional to its length, but we still allow\n// the relative size of the head to be controlled via the mark’s width option;\n// doubling the default radius will produce an arrowhead that is twice as big.\n// That said, we’ll probably want a arrow with a fixed head size, too.\nconst wingRatio = defaultRadius * 5;\n\nconst shapeArrow = {\n draw(context, l, r) {\n const wing = (l * r) / wingRatio;\n context.moveTo(0, 0);\n context.lineTo(0, -l);\n context.moveTo(-wing, wing - l);\n context.lineTo(0, -l);\n context.lineTo(wing, wing - l);\n }\n};\n\nconst shapeSpike = {\n draw(context, l, r) {\n context.moveTo(-r, 0);\n context.lineTo(0, -l);\n context.lineTo(r, 0);\n }\n};\n\nconst shapes = new Map([\n [\"arrow\", shapeArrow],\n [\"spike\", shapeSpike]\n]);\n\nfunction isShapeObject(value) {\n return value && typeof value.draw === \"function\";\n}\n\nfunction maybeShape(shape) {\n if (isShapeObject(shape)) return shape;\n const value = shapes.get(`${shape}`.toLowerCase());\n if (value) return value;\n throw new Error(`invalid shape: ${shape}`);\n}\n\nexport class Vector extends Mark {\n constructor(data, options = {}) {\n const {x, y, r = defaultRadius, length, rotate, shape = shapeArrow, anchor = \"middle\", frameAnchor} = options;\n const [vl, cl] = maybeNumberChannel(length, 12);\n const [vr, cr] = maybeNumberChannel(rotate, 0);\n super(\n data,\n {\n x: {value: x, scale: \"x\", optional: true},\n y: {value: y, scale: \"y\", optional: true},\n length: {value: vl, scale: \"length\", optional: true},\n rotate: {value: vr, optional: true}\n },\n options,\n defaults\n );\n this.r = +r;\n this.length = cl;\n this.rotate = cr;\n this.shape = maybeShape(shape);\n this.anchor = keyword(anchor, \"anchor\", [\"start\", \"middle\", \"end\"]);\n this.frameAnchor = maybeFrameAnchor(frameAnchor);\n }\n render(index, scales, channels, dimensions, context) {\n const {x, y} = scales;\n const {x: X, y: Y, length: L, rotate: A} = channels;\n const {length, rotate, anchor, shape, r} = this;\n const [cx, cy] = applyFrameAnchor(this, dimensions);\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyTransform, this, {x: X && x, y: Y && y})\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"path\")\n .call(applyDirectStyles, this)\n .attr(\n \"transform\",\n template`translate(${X ? (i) => X[i] : cx},${Y ? (i) => Y[i] : cy})${\n A ? (i) => ` rotate(${A[i]})` : rotate ? ` rotate(${rotate})` : ``\n }${\n anchor === \"start\"\n ? ``\n : anchor === \"end\"\n ? L\n ? (i) => ` translate(0,${L[i]})`\n : ` translate(0,${length})`\n : L\n ? (i) => ` translate(0,${L[i] / 2})`\n : ` translate(0,${length / 2})`\n }`\n )\n .attr(\n \"d\",\n L\n ? (i) => {\n const p = path();\n shape.draw(p, L[i], r);\n return p;\n }\n : (() => {\n const p = path();\n shape.draw(p, length, r);\n return p;\n })()\n )\n .call(applyChannelStyles, this, channels)\n )\n .node();\n }\n}\n\nexport function vector(data, options = {}) {\n let {x, y, ...rest} = options;\n if (options.frameAnchor === undefined) [x, y] = maybeTuple(x, y);\n return new Vector(data, {...rest, x, y});\n}\n\nexport function vectorX(data, options = {}) {\n const {x = identity, ...rest} = options;\n return new Vector(data, {...rest, x});\n}\n\nexport function vectorY(data, options = {}) {\n const {y = identity, ...rest} = options;\n return new Vector(data, {...rest, y});\n}\n\nexport function spike(data, options = {}) {\n const {\n shape = shapeSpike,\n stroke = defaults.stroke,\n strokeWidth = 1,\n fill = stroke,\n fillOpacity = 0.3,\n anchor = \"start\",\n ...rest\n } = options;\n return vector(data, {...rest, shape, stroke, strokeWidth, fill, fillOpacity, anchor});\n}\n","import {InternSet, extent, format, utcFormat} from \"d3\";\nimport {formatDefault} from \"../format.js\";\nimport {marks} from \"../mark.js\";\nimport {radians} from \"../math.js\";\nimport {arrayify, constant, identity, keyword, number, range, valueof} from \"../options.js\";\nimport {isIterable, isNoneish, isTemporal, isInterval, orderof} from \"../options.js\";\nimport {maybeColorChannel, maybeNumberChannel, maybeRangeInterval} from \"../options.js\";\nimport {offset} from \"../style.js\";\nimport {generalizeTimeInterval, inferTimeFormat, intervalDuration} from \"../time.js\";\nimport {initializer} from \"../transforms/basic.js\";\nimport {warn} from \"../warnings.js\";\nimport {ruleX, ruleY} from \"./rule.js\";\nimport {text, textX, textY} from \"./text.js\";\nimport {vectorX, vectorY} from \"./vector.js\";\n\nfunction maybeData(data, options) {\n if (arguments.length < 2 && !isIterable(data)) (options = data), (data = null);\n if (options === undefined) options = {};\n return [data, options];\n}\n\nfunction maybeAnchor({anchor} = {}, anchors) {\n return anchor === undefined ? anchors[0] : keyword(anchor, \"anchor\", anchors);\n}\n\nfunction anchorY(options) {\n return maybeAnchor(options, [\"left\", \"right\"]);\n}\n\nfunction anchorFy(options) {\n return maybeAnchor(options, [\"right\", \"left\"]);\n}\n\nfunction anchorX(options) {\n return maybeAnchor(options, [\"bottom\", \"top\"]);\n}\n\nfunction anchorFx(options) {\n return maybeAnchor(options, [\"top\", \"bottom\"]);\n}\n\nexport function axisY() {\n const [data, options] = maybeData(...arguments);\n return axisKy(\"y\", anchorY(options), data, options);\n}\n\nexport function axisFy() {\n const [data, options] = maybeData(...arguments);\n return axisKy(\"fy\", anchorFy(options), data, options);\n}\n\nexport function axisX() {\n const [data, options] = maybeData(...arguments);\n return axisKx(\"x\", anchorX(options), data, options);\n}\n\nexport function axisFx() {\n const [data, options] = maybeData(...arguments);\n return axisKx(\"fx\", anchorFx(options), data, options);\n}\n\nfunction axisKy(\n k,\n anchor,\n data,\n {\n color = \"currentColor\",\n opacity = 1,\n stroke = color,\n strokeOpacity = opacity,\n strokeWidth = 1,\n fill = color,\n fillOpacity = opacity,\n textAnchor,\n textStroke,\n textStrokeOpacity,\n textStrokeWidth,\n tickSize = k === \"y\" ? 6 : 0,\n tickPadding,\n tickRotate,\n x,\n margin,\n marginTop = margin === undefined ? 20 : margin,\n marginRight = margin === undefined ? (anchor === \"right\" ? 40 : 0) : margin,\n marginBottom = margin === undefined ? 20 : margin,\n marginLeft = margin === undefined ? (anchor === \"left\" ? 40 : 0) : margin,\n label,\n labelAnchor,\n labelArrow,\n labelOffset,\n ...options\n }\n) {\n tickSize = number(tickSize);\n tickPadding = number(tickPadding);\n tickRotate = number(tickRotate);\n if (labelAnchor !== undefined) labelAnchor = keyword(labelAnchor, \"labelAnchor\", [\"center\", \"top\", \"bottom\"]);\n labelArrow = maybeLabelArrow(labelArrow);\n return marks(\n tickSize && !isNoneish(stroke)\n ? axisTickKy(k, anchor, data, {\n stroke,\n strokeOpacity,\n strokeWidth,\n tickSize,\n tickPadding,\n tickRotate,\n x,\n ...options\n })\n : null,\n !isNoneish(fill)\n ? axisTextKy(k, anchor, data, {\n fill,\n fillOpacity,\n stroke: textStroke,\n strokeOpacity: textStrokeOpacity,\n strokeWidth: textStrokeWidth,\n textAnchor,\n tickSize,\n tickPadding,\n tickRotate,\n x,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n ...options\n })\n : null,\n !isNoneish(fill) && label !== null\n ? text(\n [],\n labelOptions({fill, fillOpacity, ...options}, function (data, facets, channels, scales, dimensions) {\n const scale = scales[k];\n const {marginTop, marginRight, marginBottom, marginLeft} = (k === \"y\" && dimensions.inset) || dimensions;\n const cla = labelAnchor ?? (scale.bandwidth ? \"center\" : \"top\");\n const clo = labelOffset ?? (anchor === \"right\" ? marginRight : marginLeft) - 3;\n if (cla === \"center\") {\n this.textAnchor = undefined; // middle\n this.lineAnchor = anchor === \"right\" ? \"bottom\" : \"top\";\n this.frameAnchor = anchor;\n this.rotate = -90;\n } else {\n this.textAnchor = anchor === \"right\" ? \"end\" : \"start\";\n this.lineAnchor = cla;\n this.frameAnchor = `${cla}-${anchor}`;\n this.rotate = 0;\n }\n this.dy = cla === \"top\" ? 3 - marginTop : cla === \"bottom\" ? marginBottom - 3 : 0;\n this.dx = anchor === \"right\" ? clo : -clo;\n this.ariaLabel = `${k}-axis label`;\n return {\n facets: [[0]],\n channels: {text: {value: [formatAxisLabel(k, scale, {anchor, label, labelAnchor: cla, labelArrow})]}}\n };\n })\n )\n : null\n );\n}\n\nfunction axisKx(\n k,\n anchor,\n data,\n {\n color = \"currentColor\",\n opacity = 1,\n stroke = color,\n strokeOpacity = opacity,\n strokeWidth = 1,\n fill = color,\n fillOpacity = opacity,\n textAnchor,\n textStroke,\n textStrokeOpacity,\n textStrokeWidth,\n tickSize = k === \"x\" ? 6 : 0,\n tickPadding,\n tickRotate,\n y,\n margin,\n marginTop = margin === undefined ? (anchor === \"top\" ? 30 : 0) : margin,\n marginRight = margin === undefined ? 20 : margin,\n marginBottom = margin === undefined ? (anchor === \"bottom\" ? 30 : 0) : margin,\n marginLeft = margin === undefined ? 20 : margin,\n label,\n labelAnchor,\n labelArrow,\n labelOffset,\n ...options\n }\n) {\n tickSize = number(tickSize);\n tickPadding = number(tickPadding);\n tickRotate = number(tickRotate);\n if (labelAnchor !== undefined) labelAnchor = keyword(labelAnchor, \"labelAnchor\", [\"center\", \"left\", \"right\"]);\n labelArrow = maybeLabelArrow(labelArrow);\n return marks(\n tickSize && !isNoneish(stroke)\n ? axisTickKx(k, anchor, data, {\n stroke,\n strokeOpacity,\n strokeWidth,\n tickSize,\n tickPadding,\n tickRotate,\n y,\n ...options\n })\n : null,\n !isNoneish(fill)\n ? axisTextKx(k, anchor, data, {\n fill,\n fillOpacity,\n stroke: textStroke,\n strokeOpacity: textStrokeOpacity,\n strokeWidth: textStrokeWidth,\n textAnchor,\n tickSize,\n tickPadding,\n tickRotate,\n y,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n ...options\n })\n : null,\n !isNoneish(fill) && label !== null\n ? text(\n [],\n labelOptions({fill, fillOpacity, ...options}, function (data, facets, channels, scales, dimensions) {\n const scale = scales[k];\n const {marginTop, marginRight, marginBottom, marginLeft} = (k === \"x\" && dimensions.inset) || dimensions;\n const cla = labelAnchor ?? (scale.bandwidth ? \"center\" : \"right\");\n const clo = labelOffset ?? (anchor === \"top\" ? marginTop : marginBottom) - 3;\n if (cla === \"center\") {\n this.frameAnchor = anchor;\n this.textAnchor = undefined; // middle\n } else {\n this.frameAnchor = `${anchor}-${cla}`;\n this.textAnchor = cla === \"right\" ? \"end\" : \"start\";\n }\n this.lineAnchor = anchor;\n this.dy = anchor === \"top\" ? -clo : clo;\n this.dx = cla === \"right\" ? marginRight - 3 : cla === \"left\" ? 3 - marginLeft : 0;\n this.ariaLabel = `${k}-axis label`;\n return {\n facets: [[0]],\n channels: {text: {value: [formatAxisLabel(k, scale, {anchor, label, labelAnchor: cla, labelArrow})]}}\n };\n })\n )\n : null\n );\n}\n\nfunction axisTickKy(\n k,\n anchor,\n data,\n {\n strokeWidth = 1,\n strokeLinecap = null,\n strokeLinejoin = null,\n facetAnchor = anchor + (k === \"y\" ? \"-empty\" : \"\"),\n frameAnchor = anchor,\n tickSize,\n inset = 0,\n insetLeft = inset,\n insetRight = inset,\n dx = 0,\n y = k === \"y\" ? undefined : null,\n ...options\n }\n) {\n return axisMark(vectorY, k, anchor, `${k}-axis tick`, data, {\n strokeWidth,\n strokeLinecap,\n strokeLinejoin,\n facetAnchor,\n frameAnchor,\n y,\n ...options,\n dx: anchor === \"left\" ? +dx - offset + +insetLeft : +dx + offset - insetRight,\n anchor: \"start\",\n length: tickSize,\n shape: anchor === \"left\" ? shapeTickLeft : shapeTickRight\n });\n}\n\nfunction axisTickKx(\n k,\n anchor,\n data,\n {\n strokeWidth = 1,\n strokeLinecap = null,\n strokeLinejoin = null,\n facetAnchor = anchor + (k === \"x\" ? \"-empty\" : \"\"),\n frameAnchor = anchor,\n tickSize,\n inset = 0,\n insetTop = inset,\n insetBottom = inset,\n dy = 0,\n x = k === \"x\" ? undefined : null,\n ...options\n }\n) {\n return axisMark(vectorX, k, anchor, `${k}-axis tick`, data, {\n strokeWidth,\n strokeLinejoin,\n strokeLinecap,\n facetAnchor,\n frameAnchor,\n x,\n ...options,\n dy: anchor === \"bottom\" ? +dy - offset - insetBottom : +dy + offset + +insetTop,\n anchor: \"start\",\n length: tickSize,\n shape: anchor === \"bottom\" ? shapeTickBottom : shapeTickTop\n });\n}\n\nfunction axisTextKy(\n k,\n anchor,\n data,\n {\n facetAnchor = anchor + (k === \"y\" ? \"-empty\" : \"\"),\n frameAnchor = anchor,\n tickSize,\n tickRotate = 0,\n tickPadding = Math.max(3, 9 - tickSize) + (Math.abs(tickRotate) > 60 ? 4 * Math.cos(tickRotate * radians) : 0),\n text,\n textAnchor = Math.abs(tickRotate) > 60 ? \"middle\" : anchor === \"left\" ? \"end\" : \"start\",\n lineAnchor = tickRotate > 60 ? \"top\" : tickRotate < -60 ? \"bottom\" : \"middle\",\n fontVariant,\n inset = 0,\n insetLeft = inset,\n insetRight = inset,\n dx = 0,\n y = k === \"y\" ? undefined : null,\n ...options\n }\n) {\n return axisMark(\n textY,\n k,\n anchor,\n `${k}-axis tick label`,\n data,\n {\n facetAnchor,\n frameAnchor,\n text,\n textAnchor,\n lineAnchor,\n fontVariant,\n rotate: tickRotate,\n y,\n ...options,\n dx: anchor === \"left\" ? +dx - tickSize - tickPadding + +insetLeft : +dx + +tickSize + +tickPadding - insetRight\n },\n function (scale, data, ticks, tickFormat, channels) {\n if (fontVariant === undefined) this.fontVariant = inferFontVariant(scale);\n if (text === undefined) channels.text = inferTextChannel(scale, data, ticks, tickFormat, anchor);\n }\n );\n}\n\nfunction axisTextKx(\n k,\n anchor,\n data,\n {\n facetAnchor = anchor + (k === \"x\" ? \"-empty\" : \"\"),\n frameAnchor = anchor,\n tickSize,\n tickRotate = 0,\n tickPadding = Math.max(3, 9 - tickSize) + (Math.abs(tickRotate) >= 10 ? 4 * Math.cos(tickRotate * radians) : 0),\n text,\n textAnchor = Math.abs(tickRotate) >= 10 ? ((tickRotate < 0) ^ (anchor === \"bottom\") ? \"start\" : \"end\") : \"middle\",\n lineAnchor = Math.abs(tickRotate) >= 10 ? \"middle\" : anchor === \"bottom\" ? \"top\" : \"bottom\",\n fontVariant,\n inset = 0,\n insetTop = inset,\n insetBottom = inset,\n dy = 0,\n x = k === \"x\" ? undefined : null,\n ...options\n }\n) {\n return axisMark(\n textX,\n k,\n anchor,\n `${k}-axis tick label`,\n data,\n {\n facetAnchor,\n frameAnchor,\n text: text === undefined ? null : text,\n textAnchor,\n lineAnchor,\n fontVariant,\n rotate: tickRotate,\n x,\n ...options,\n dy: anchor === \"bottom\" ? +dy + +tickSize + +tickPadding - insetBottom : +dy - tickSize - tickPadding + +insetTop\n },\n function (scale, data, ticks, tickFormat, channels) {\n if (fontVariant === undefined) this.fontVariant = inferFontVariant(scale);\n if (text === undefined) channels.text = inferTextChannel(scale, data, ticks, tickFormat, anchor);\n }\n );\n}\n\nexport function gridY() {\n const [data, options] = maybeData(...arguments);\n return gridKy(\"y\", anchorY(options), data, options);\n}\n\nexport function gridFy() {\n const [data, options] = maybeData(...arguments);\n return gridKy(\"fy\", anchorFy(options), data, options);\n}\n\nexport function gridX() {\n const [data, options] = maybeData(...arguments);\n return gridKx(\"x\", anchorX(options), data, options);\n}\n\nexport function gridFx() {\n const [data, options] = maybeData(...arguments);\n return gridKx(\"fx\", anchorFx(options), data, options);\n}\n\nfunction gridKy(\n k,\n anchor,\n data,\n {\n y = k === \"y\" ? undefined : null,\n x = null,\n x1 = anchor === \"left\" ? x : null,\n x2 = anchor === \"right\" ? x : null,\n ...options\n }\n) {\n return axisMark(ruleY, k, anchor, `${k}-grid`, data, {y, x1, x2, ...gridDefaults(options)});\n}\n\nfunction gridKx(\n k,\n anchor,\n data,\n {\n x = k === \"x\" ? undefined : null,\n y = null,\n y1 = anchor === \"top\" ? y : null,\n y2 = anchor === \"bottom\" ? y : null,\n ...options\n }\n) {\n return axisMark(ruleX, k, anchor, `${k}-grid`, data, {x, y1, y2, ...gridDefaults(options)});\n}\n\nfunction gridDefaults({\n color = \"currentColor\",\n opacity = 0.1,\n stroke = color,\n strokeOpacity = opacity,\n strokeWidth = 1,\n ...options\n}) {\n return {stroke, strokeOpacity, strokeWidth, ...options};\n}\n\nfunction labelOptions(\n {\n fill,\n fillOpacity,\n fontFamily,\n fontSize,\n fontStyle,\n fontVariant,\n fontWeight,\n monospace,\n pointerEvents,\n shapeRendering,\n clip = false\n },\n initializer\n) {\n // Only propagate these options if constant.\n [, fill] = maybeColorChannel(fill);\n [, fillOpacity] = maybeNumberChannel(fillOpacity);\n return {\n facet: \"super\",\n x: null,\n y: null,\n fill,\n fillOpacity,\n fontFamily,\n fontSize,\n fontStyle,\n fontVariant,\n fontWeight,\n monospace,\n pointerEvents,\n shapeRendering,\n clip,\n initializer\n };\n}\n\nfunction axisMark(mark, k, anchor, ariaLabel, data, options, initialize) {\n let channels;\n\n function axisInitializer(data, facets, _channels, scales, dimensions, context) {\n const initializeFacets = data == null && (k === \"fx\" || k === \"fy\");\n const {[k]: scale} = scales;\n if (!scale) throw new Error(`missing scale: ${k}`);\n const domain = scale.domain();\n let {interval, ticks, tickFormat, tickSpacing = k === \"x\" ? 80 : 35} = options;\n // For a scale with a temporal domain, also allow the ticks to be specified\n // as a string which is promoted to a time interval. In the case of ordinal\n // scales, the interval is interpreted as UTC.\n if (typeof ticks === \"string\" && hasTemporalDomain(scale)) (interval = ticks), (ticks = undefined);\n // The interval axis option is an alternative method of specifying ticks;\n // for example, for a numeric scale, ticks = 5 means “about 5 ticks” whereas\n // interval = 5 means “ticks every 5 units”. (This is not to be confused\n // with the interval scale option, which affects the scale’s behavior!)\n // Lastly use the tickSpacing option to infer the desired tick count.\n if (ticks === undefined) ticks = maybeRangeInterval(interval, scale.type) ?? inferTickCount(scale, tickSpacing);\n if (data == null) {\n if (isIterable(ticks)) {\n // Use explicit ticks, if specified.\n data = arrayify(ticks);\n } else if (isInterval(ticks)) {\n // Use the tick interval, if specified.\n data = inclusiveRange(ticks, ...extent(domain));\n } else if (scale.interval) {\n // If the scale interval is a standard time interval such as \"day\", we\n // may be able to generalize the scale interval it to a larger aligned\n // time interval to create the desired number of ticks.\n let interval = scale.interval;\n if (scale.ticks) {\n const [min, max] = extent(domain);\n const n = (max - min) / interval[intervalDuration]; // current tick count\n // We don’t explicitly check that given interval is a time interval;\n // in that case the generalized interval will be undefined, just like\n // a nonstandard interval. TODO Generalize integer intervals, too.\n interval = generalizeTimeInterval(interval, n / ticks) ?? interval;\n data = inclusiveRange(interval, min, max);\n } else {\n data = domain;\n const n = data.length; // current tick count\n interval = generalizeTimeInterval(interval, n / ticks) ?? interval;\n if (interval !== scale.interval) data = inclusiveRange(interval, ...extent(data));\n }\n if (interval === scale.interval) {\n // If we weren’t able to generalize the scale’s interval, compute the\n // positive number n such that taking every nth value from the scale’s\n // domain produces as close as possible to the desired number of\n // ticks. For example, if the domain has 100 values and 5 ticks are\n // desired, n = 20.\n const n = Math.round(data.length / ticks);\n if (n > 1) data = data.filter((d, i) => i % n === 0);\n }\n } else if (scale.ticks) {\n data = scale.ticks(ticks);\n } else {\n // For ordinal scales, the domain will already be generated using the\n // scale’s interval, if any.\n data = domain;\n }\n if (!scale.ticks && data.length && data !== domain) {\n // For ordinal scales, intersect the ticks with the scale domain since\n // the scale is only defined on its domain. If all of the ticks are\n // removed, then warn that the ticks and scale domain may be misaligned\n // (e.g., \"year\" ticks and \"4 weeks\" interval).\n const domainSet = new InternSet(domain);\n data = data.filter((d) => domainSet.has(d));\n if (!data.length) warn(`Warning: the ${k}-axis ticks appear to not align with the scale domain, resulting in no ticks. Try different ticks?`); // prettier-ignore\n }\n if (k === \"y\" || k === \"x\") {\n facets = [range(data)];\n } else {\n channels[k] = {scale: k, value: identity};\n }\n }\n initialize?.call(this, scale, data, ticks, tickFormat, channels);\n const initializedChannels = Object.fromEntries(\n Object.entries(channels).map(([name, channel]) => {\n return [name, {...channel, value: valueof(data, channel.value)}];\n })\n );\n if (initializeFacets) facets = context.filterFacets(data, initializedChannels);\n return {data, facets, channels: initializedChannels};\n }\n\n // Apply any basic initializers after the axis initializer computes the ticks.\n const basicInitializer = initializer(options).initializer;\n const m = mark(data, initializer({...options, initializer: axisInitializer}, basicInitializer));\n if (data == null) {\n channels = m.channels;\n m.channels = {};\n } else {\n channels = {};\n }\n m.ariaLabel = ariaLabel;\n if (m.clip === undefined) m.clip = false; // don’t clip axes by default\n return m;\n}\n\nfunction inferTickCount(scale, tickSpacing) {\n const [min, max] = extent(scale.range());\n return (max - min) / tickSpacing;\n}\n\nfunction inferTextChannel(scale, data, ticks, tickFormat, anchor) {\n return {value: inferTickFormat(scale, data, ticks, tickFormat, anchor)};\n}\n\n// D3’s ordinal scales simply use toString by default, but if the ordinal scale\n// domain (or ticks) are numbers or dates (say because we’re applying a time\n// interval to the ordinal scale), we want Plot’s default formatter. And for\n// time ticks, we want to use the multi-line time format (e.g., Jan 26) if\n// possible, or the default ISO format (2014-01-26). TODO We need a better way\n// to infer whether the ordinal scale is UTC or local time.\nexport function inferTickFormat(scale, data, ticks, tickFormat, anchor) {\n return typeof tickFormat === \"function\"\n ? tickFormat\n : tickFormat === undefined && data && isTemporal(data)\n ? inferTimeFormat(data, anchor) ?? formatDefault\n : scale.tickFormat\n ? scale.tickFormat(typeof ticks === \"number\" ? ticks : null, tickFormat)\n : tickFormat === undefined\n ? formatDefault\n : typeof tickFormat === \"string\"\n ? (isTemporal(scale.domain()) ? utcFormat : format)(tickFormat)\n : constant(tickFormat);\n}\n\nfunction inclusiveRange(interval, min, max) {\n return interval.range(min, interval.offset(interval.floor(max)));\n}\n\nconst shapeTickBottom = {\n draw(context, l) {\n context.moveTo(0, 0);\n context.lineTo(0, l);\n }\n};\n\nconst shapeTickTop = {\n draw(context, l) {\n context.moveTo(0, 0);\n context.lineTo(0, -l);\n }\n};\n\nconst shapeTickLeft = {\n draw(context, l) {\n context.moveTo(0, 0);\n context.lineTo(-l, 0);\n }\n};\n\nconst shapeTickRight = {\n draw(context, l) {\n context.moveTo(0, 0);\n context.lineTo(l, 0);\n }\n};\n\n// TODO Unify this with the other inferFontVariant; here we only have a scale\n// function rather than a scale descriptor.\nfunction inferFontVariant(scale) {\n return scale.bandwidth && !scale.interval ? undefined : \"tabular-nums\";\n}\n\n// Determines whether the scale points in the “positive” (right or down) or\n// “negative” (left or up) direction; if the scale order cannot be determined,\n// returns NaN; used to assign an appropriate label arrow.\nfunction inferScaleOrder(scale) {\n return Math.sign(orderof(scale.domain())) * Math.sign(orderof(scale.range()));\n}\n\n// Takes the scale label, and if this is not an ordinal scale and the label was\n// inferred from an associated channel, adds an orientation-appropriate arrow.\nfunction formatAxisLabel(k, scale, {anchor, label = scale.label, labelAnchor, labelArrow} = {}) {\n if (label == null || (label.inferred && hasTemporalDomain(scale) && /^(date|time|year)$/i.test(label))) return;\n label = String(label); // coerce to a string after checking if inferred\n if (labelArrow === \"auto\") labelArrow = (!scale.bandwidth || scale.interval) && !/[↑↓→←]/.test(label);\n if (!labelArrow) return label;\n if (labelArrow === true) {\n const order = inferScaleOrder(scale);\n if (order)\n labelArrow =\n /x$/.test(k) || labelAnchor === \"center\"\n ? /x$/.test(k) === order < 0\n ? \"left\"\n : \"right\"\n : order < 0\n ? \"up\"\n : \"down\";\n }\n switch (labelArrow) {\n case \"left\":\n return `← ${label}`;\n case \"right\":\n return `${label} →`;\n case \"up\":\n return anchor === \"right\" ? `${label} ↑` : `↑ ${label}`;\n case \"down\":\n return anchor === \"right\" ? `${label} ↓` : `↓ ${label}`;\n }\n return label;\n}\n\nfunction maybeLabelArrow(labelArrow = \"auto\") {\n return isNoneish(labelArrow)\n ? false\n : typeof labelArrow === \"boolean\"\n ? labelArrow\n : keyword(labelArrow, \"labelArrow\", [\"auto\", \"up\", \"right\", \"down\", \"left\"]);\n}\n\nfunction hasTemporalDomain(scale) {\n return isTemporal(scale.domain());\n}\n","import {pathRound as path} from \"d3\";\nimport {inferFontVariant} from \"../axes.js\";\nimport {create, createContext} from \"../context.js\";\nimport {isNoneish, maybeColorChannel, maybeNumberChannel} from \"../options.js\";\nimport {isOrdinalScale, isThresholdScale} from \"../scales.js\";\nimport {applyInlineStyles, impliedString, maybeClassName} from \"../style.js\";\nimport {inferTickFormat} from \"../marks/axis.js\";\n\nfunction maybeScale(scale, key) {\n if (key == null) return key;\n const s = scale(key);\n if (!s) throw new Error(`scale not found: ${key}`);\n return s;\n}\n\nexport function legendSwatches(color, {opacity, ...options} = {}) {\n if (!isOrdinalScale(color) && !isThresholdScale(color))\n throw new Error(`swatches legend requires ordinal or threshold color scale (not ${color.type})`);\n return legendItems(color, options, (selection, scale, width, height) =>\n selection\n .append(\"svg\")\n .attr(\"width\", width)\n .attr(\"height\", height)\n .attr(\"fill\", scale.scale)\n .attr(\"fill-opacity\", maybeNumberChannel(opacity)[1])\n .append(\"rect\")\n .attr(\"width\", \"100%\")\n .attr(\"height\", \"100%\")\n );\n}\n\nexport function legendSymbols(\n symbol,\n {\n fill = symbol.hint?.fill !== undefined ? symbol.hint.fill : \"none\",\n fillOpacity = 1,\n stroke = symbol.hint?.stroke !== undefined ? symbol.hint.stroke : isNoneish(fill) ? \"currentColor\" : \"none\",\n strokeOpacity = 1,\n strokeWidth = 1.5,\n r = 4.5,\n ...options\n } = {},\n scale\n) {\n const [vf, cf] = maybeColorChannel(fill);\n const [vs, cs] = maybeColorChannel(stroke);\n const sf = maybeScale(scale, vf);\n const ss = maybeScale(scale, vs);\n const size = r * r * Math.PI;\n fillOpacity = maybeNumberChannel(fillOpacity)[1];\n strokeOpacity = maybeNumberChannel(strokeOpacity)[1];\n strokeWidth = maybeNumberChannel(strokeWidth)[1];\n return legendItems(symbol, options, (selection, scale, width, height) =>\n selection\n .append(\"svg\")\n .attr(\"viewBox\", \"-8 -8 16 16\")\n .attr(\"width\", width)\n .attr(\"height\", height)\n .attr(\"fill\", vf === \"color\" ? (d) => sf.scale(d) : cf)\n .attr(\"fill-opacity\", fillOpacity)\n .attr(\"stroke\", vs === \"color\" ? (d) => ss.scale(d) : cs)\n .attr(\"stroke-opacity\", strokeOpacity)\n .attr(\"stroke-width\", strokeWidth)\n .append(\"path\")\n .attr(\"d\", (d) => {\n const p = path();\n symbol.scale(d).draw(p, size);\n return p;\n })\n );\n}\n\nfunction legendItems(scale, options = {}, swatch) {\n let {\n columns,\n tickFormat,\n fontVariant = inferFontVariant(scale),\n // TODO label,\n swatchSize = 15,\n swatchWidth = swatchSize,\n swatchHeight = swatchSize,\n marginLeft = 0,\n className,\n style,\n width\n } = options;\n const context = createContext(options);\n className = maybeClassName(className);\n tickFormat = inferTickFormat(scale.scale, scale.domain, undefined, tickFormat);\n\n const swatches = create(\"div\", context).attr(\n \"class\",\n `${className}-swatches ${className}-swatches-${columns != null ? \"columns\" : \"wrap\"}`\n );\n\n let extraStyle;\n\n if (columns != null) {\n extraStyle = `.${className}-swatches-columns .${className}-swatch {\n display: flex;\n align-items: center;\n break-inside: avoid;\n padding-bottom: 1px;\n}\n.${className}-swatches-columns .${className}-swatch::before {\n flex-shrink: 0;\n}\n.${className}-swatches-columns .${className}-swatch-label {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}`;\n\n swatches\n .style(\"columns\", columns)\n .selectAll()\n .data(scale.domain)\n .enter()\n .append(\"div\")\n .attr(\"class\", `${className}-swatch`)\n .call(swatch, scale, swatchWidth, swatchHeight)\n .call((item) =>\n item.append(\"div\").attr(\"class\", `${className}-swatch-label`).attr(\"title\", tickFormat).text(tickFormat)\n );\n } else {\n extraStyle = `.${className}-swatches-wrap {\n display: flex;\n align-items: center;\n min-height: 33px;\n flex-wrap: wrap;\n}\n.${className}-swatches-wrap .${className}-swatch {\n display: inline-flex;\n align-items: center;\n margin-right: 1em;\n}`;\n\n swatches\n .selectAll()\n .data(scale.domain)\n .enter()\n .append(\"span\")\n .attr(\"class\", `${className}-swatch`)\n .call(swatch, scale, swatchWidth, swatchHeight)\n .append(function () {\n return this.ownerDocument.createTextNode(tickFormat.apply(this, arguments));\n });\n }\n\n return swatches\n .call((div) =>\n div.insert(\"style\", \"*\").text(\n `.${className}-swatches {\n font-family: system-ui, sans-serif;\n font-size: 10px;\n margin-bottom: 0.5em;\n}\n.${className}-swatch > svg {\n margin-right: 0.5em;\n overflow: visible;\n}\n${extraStyle}`\n )\n )\n .style(\"margin-left\", marginLeft ? `${+marginLeft}px` : null)\n .style(\"width\", width === undefined ? null : `${+width}px`)\n .style(\"font-variant\", impliedString(fontVariant, \"normal\"))\n .call(applyInlineStyles, style)\n .node();\n}\n","import {rgb} from \"d3\";\nimport {createContext} from \"./context.js\";\nimport {legendRamp} from \"./legends/ramp.js\";\nimport {legendSwatches, legendSymbols} from \"./legends/swatches.js\";\nimport {inherit, isScaleOptions} from \"./options.js\";\nimport {normalizeScale} from \"./scales.js\";\n\nconst legendRegistry = new Map([\n [\"symbol\", legendSymbols],\n [\"color\", legendColor],\n [\"opacity\", legendOpacity]\n]);\n\nexport function legend(options = {}) {\n for (const [key, value] of legendRegistry) {\n const scale = options[key];\n if (isScaleOptions(scale)) {\n // e.g., ignore {color: \"red\"}\n const context = createContext(options);\n let hint;\n // For symbol legends, pass a hint to the symbol scale.\n if (key === \"symbol\") {\n const {fill, stroke = fill === undefined && isScaleOptions(options.color) ? \"color\" : undefined} = options;\n hint = {fill, stroke};\n }\n return value(normalizeScale(key, scale, hint), legendOptions(context, scale, options), (key) =>\n isScaleOptions(options[key]) ? normalizeScale(key, options[key]) : null\n );\n }\n }\n throw new Error(\"unknown legend type; no scale found\");\n}\n\nexport function exposeLegends(scales, context, defaults = {}) {\n return (key, options) => {\n if (!legendRegistry.has(key)) throw new Error(`unknown legend type: ${key}`);\n if (!(key in scales)) return;\n return legendRegistry.get(key)(scales[key], legendOptions(context, defaults[key], options), (key) => scales[key]);\n };\n}\n\nfunction legendOptions({className, ...context}, {label, ticks, tickFormat} = {}, options) {\n return inherit(options, {className, ...context}, {label, ticks, tickFormat});\n}\n\nfunction legendColor(color, {legend = true, ...options}) {\n if (legend === true) legend = color.type === \"ordinal\" ? \"swatches\" : \"ramp\";\n if (color.domain === undefined) return;\n switch (`${legend}`.toLowerCase()) {\n case \"swatches\":\n return legendSwatches(color, options);\n case \"ramp\":\n return legendRamp(color, options);\n default:\n throw new Error(`unknown legend type: ${legend}`);\n }\n}\n\nfunction legendOpacity({type, interpolate, ...scale}, {legend = true, color = rgb(0, 0, 0), ...options}) {\n if (!interpolate) throw new Error(`${type} opacity scales are not supported`);\n if (legend === true) legend = \"ramp\";\n if (`${legend}`.toLowerCase() !== \"ramp\") throw new Error(`${legend} opacity legends are not supported`);\n return legendColor({type, ...scale, interpolate: interpolateOpacity(color)}, {legend, ...options});\n}\n\nfunction interpolateOpacity(color) {\n const {r, g, b} = rgb(color) || rgb(0, 0, 0); // treat invalid color as black\n return (t) => `rgba(${r},${g},${b},${t})`;\n}\n\nexport function createLegends(scales, context, options) {\n const legends = [];\n for (const [key, value] of legendRegistry) {\n const o = options[key];\n if (o?.legend && key in scales) {\n const legend = value(scales[key], legendOptions(context, scales[key], o), (key) => scales[key]);\n if (legend != null) legends.push(legend);\n }\n }\n return legends;\n}\n","import {quantize, interpolateNumber, piecewise, format, scaleBand, scaleLinear, axisBottom} from \"d3\";\nimport {inferFontVariant} from \"../axes.js\";\nimport {createContext, create} from \"../context.js\";\nimport {map, maybeNumberChannel} from \"../options.js\";\nimport {interpolatePiecewise} from \"../scales/quantitative.js\";\nimport {applyInlineStyles, impliedString, maybeClassName} from \"../style.js\";\n\nexport function legendRamp(color, options) {\n let {\n label = color.label,\n tickSize = 6,\n width = 240,\n height = 44 + tickSize,\n marginTop = 18,\n marginRight = 0,\n marginBottom = 16 + tickSize,\n marginLeft = 0,\n style,\n ticks = (width - marginLeft - marginRight) / 64,\n tickFormat,\n fontVariant = inferFontVariant(color),\n round = true,\n opacity,\n className\n } = options;\n const context = createContext(options);\n className = maybeClassName(className);\n opacity = maybeNumberChannel(opacity)[1];\n if (tickFormat === null) tickFormat = () => null;\n\n const svg = create(\"svg\", context)\n .attr(\"class\", `${className}-ramp`)\n .attr(\"font-family\", \"system-ui, sans-serif\")\n .attr(\"font-size\", 10)\n .attr(\"width\", width)\n .attr(\"height\", height)\n .attr(\"viewBox\", `0 0 ${width} ${height}`)\n .call((svg) =>\n // Warning: if you edit this, change defaultClassName.\n svg.append(\"style\").text(\n `.${className}-ramp {\n display: block;\n background: white;\n height: auto;\n height: intrinsic;\n max-width: 100%;\n overflow: visible;\n}\n.${className}-ramp text {\n white-space: pre;\n}`\n )\n )\n .call(applyInlineStyles, style);\n\n let tickAdjust = (g) => g.selectAll(\".tick line\").attr(\"y1\", marginTop + marginBottom - height);\n\n let x;\n\n // Some D3 scales use scale.interpolate, some scale.interpolator, and some\n // scale.round; this normalizes the API so it works with all scale types.\n const applyRange = round ? (x, range) => x.rangeRound(range) : (x, range) => x.range(range);\n\n const {type, domain, range, interpolate, scale, pivot} = color;\n\n // Continuous\n if (interpolate) {\n // Often interpolate is a “fixed” interpolator on the [0, 1] interval, as\n // with a built-in color scheme, but sometimes it is a function that takes\n // two arguments and is used in conjunction with the range.\n const interpolator =\n range === undefined\n ? interpolate\n : piecewise(interpolate.length === 1 ? interpolatePiecewise(interpolate) : interpolate, range);\n\n // Construct a D3 scale of the same type, but with a range that evenly\n // divides the horizontal extent of the legend. (In the common case, the\n // domain.length is two, and so the range is simply the extent.) For a\n // diverging scale, we need an extra point in the range for the pivot such\n // that the pivot is always drawn in the middle.\n x = applyRange(\n scale.copy(),\n quantize(\n interpolateNumber(marginLeft, width - marginRight),\n Math.min(domain.length + (pivot !== undefined), range === undefined ? Infinity : range.length)\n )\n );\n\n // Construct a 256×1 canvas, filling each pixel using the interpolator.\n const n = 256;\n const canvas = context.document.createElement(\"canvas\");\n canvas.width = n;\n canvas.height = 1;\n const context2 = canvas.getContext(\"2d\");\n for (let i = 0, j = n - 1; i < n; ++i) {\n context2.fillStyle = interpolator(i / j);\n context2.fillRect(i, 0, 1, 1);\n }\n\n svg\n .append(\"image\")\n .attr(\"opacity\", opacity)\n .attr(\"x\", marginLeft)\n .attr(\"y\", marginTop)\n .attr(\"width\", width - marginLeft - marginRight)\n .attr(\"height\", height - marginTop - marginBottom)\n .attr(\"preserveAspectRatio\", \"none\")\n .attr(\"xlink:href\", canvas.toDataURL());\n }\n\n // Threshold\n else if (type === \"threshold\") {\n const thresholds = domain;\n\n const thresholdFormat =\n tickFormat === undefined ? (d) => d : typeof tickFormat === \"string\" ? format(tickFormat) : tickFormat;\n\n // Construct a linear scale with evenly-spaced ticks for each of the\n // thresholds; the domain extends one beyond the threshold extent.\n x = applyRange(scaleLinear().domain([-1, range.length - 1]), [marginLeft, width - marginRight]);\n\n svg\n .append(\"g\")\n .attr(\"fill-opacity\", opacity)\n .selectAll()\n .data(range)\n .enter()\n .append(\"rect\")\n .attr(\"x\", (d, i) => x(i - 1))\n .attr(\"y\", marginTop)\n .attr(\"width\", (d, i) => x(i) - x(i - 1))\n .attr(\"height\", height - marginTop - marginBottom)\n .attr(\"fill\", (d) => d);\n\n ticks = map(thresholds, (_, i) => i);\n tickFormat = (i) => thresholdFormat(thresholds[i], i);\n }\n\n // Ordinal (hopefully!)\n else {\n x = applyRange(scaleBand().domain(domain), [marginLeft, width - marginRight]);\n\n svg\n .append(\"g\")\n .attr(\"fill-opacity\", opacity)\n .selectAll()\n .data(domain)\n .enter()\n .append(\"rect\")\n .attr(\"x\", x)\n .attr(\"y\", marginTop)\n .attr(\"width\", Math.max(0, x.bandwidth() - 1))\n .attr(\"height\", height - marginTop - marginBottom)\n .attr(\"fill\", scale);\n\n tickAdjust = () => {};\n }\n\n svg\n .append(\"g\")\n .attr(\"transform\", `translate(0,${height - marginBottom})`)\n .call(\n axisBottom(x)\n .ticks(Array.isArray(ticks) ? null : ticks, typeof tickFormat === \"string\" ? tickFormat : undefined)\n .tickFormat(typeof tickFormat === \"function\" ? tickFormat : undefined)\n .tickSize(tickSize)\n .tickValues(Array.isArray(ticks) ? ticks : null)\n )\n .attr(\"font-size\", null)\n .attr(\"font-family\", null)\n .attr(\"font-variant\", impliedString(fontVariant, \"normal\"))\n .call(tickAdjust)\n .call((g) => g.select(\".domain\").remove());\n\n if (label !== undefined) {\n svg\n .append(\"text\")\n .attr(\"x\", marginLeft)\n .attr(\"y\", marginTop - 6)\n .attr(\"fill\", \"currentColor\") // TODO move to stylesheet?\n .attr(\"font-weight\", \"bold\")\n .text(label);\n }\n\n return svg.node();\n}\n","import {create} from \"../context.js\";\nimport {Mark} from \"../mark.js\";\nimport {maybeKeyword, number, singleton} from \"../options.js\";\nimport {applyChannelStyles, applyDirectStyles, applyIndirectStyles, applyTransform} from \"../style.js\";\n\nconst defaults = {\n ariaLabel: \"frame\",\n fill: \"none\",\n stroke: \"currentColor\",\n clip: false\n};\n\nconst lineDefaults = {\n ariaLabel: \"frame\",\n fill: null,\n stroke: \"currentColor\",\n strokeLinecap: \"square\",\n clip: false\n};\n\nexport class Frame extends Mark {\n constructor(options = {}) {\n const {\n anchor = null,\n inset = 0,\n insetTop = inset,\n insetRight = inset,\n insetBottom = inset,\n insetLeft = inset,\n rx,\n ry\n } = options;\n super(singleton, undefined, options, anchor == null ? defaults : lineDefaults);\n this.anchor = maybeKeyword(anchor, \"anchor\", [\"top\", \"right\", \"bottom\", \"left\"]);\n this.insetTop = number(insetTop);\n this.insetRight = number(insetRight);\n this.insetBottom = number(insetBottom);\n this.insetLeft = number(insetLeft);\n this.rx = number(rx);\n this.ry = number(ry);\n }\n render(index, scales, channels, dimensions, context) {\n const {marginTop, marginRight, marginBottom, marginLeft, width, height} = dimensions;\n const {anchor, insetTop, insetRight, insetBottom, insetLeft, rx, ry} = this;\n const x1 = marginLeft + insetLeft;\n const x2 = width - marginRight - insetRight;\n const y1 = marginTop + insetTop;\n const y2 = height - marginBottom - insetBottom;\n return create(anchor ? \"svg:line\" : \"svg:rect\", context)\n .datum(0)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyDirectStyles, this)\n .call(applyChannelStyles, this, channels)\n .call(applyTransform, this, {})\n .call(\n anchor === \"left\"\n ? (line) => line.attr(\"x1\", x1).attr(\"x2\", x1).attr(\"y1\", y1).attr(\"y2\", y2)\n : anchor === \"right\"\n ? (line) => line.attr(\"x1\", x2).attr(\"x2\", x2).attr(\"y1\", y1).attr(\"y2\", y2)\n : anchor === \"top\"\n ? (line) => line.attr(\"x1\", x1).attr(\"x2\", x2).attr(\"y1\", y1).attr(\"y2\", y1)\n : anchor === \"bottom\"\n ? (line) => line.attr(\"x1\", x1).attr(\"x2\", x2).attr(\"y1\", y2).attr(\"y2\", y2)\n : (rect) =>\n rect\n .attr(\"x\", x1)\n .attr(\"y\", y1)\n .attr(\"width\", x2 - x1)\n .attr(\"height\", y2 - y1)\n .attr(\"rx\", rx)\n .attr(\"ry\", ry)\n )\n .node();\n }\n}\n\nexport function frame(options) {\n return new Frame(options);\n}\n","import {select, format as numberFormat, utcFormat} from \"d3\";\nimport {getSource} from \"../channel.js\";\nimport {create} from \"../context.js\";\nimport {defined} from \"../defined.js\";\nimport {formatDefault} from \"../format.js\";\nimport {anchorX, anchorY} from \"../interactions/pointer.js\";\nimport {Mark} from \"../mark.js\";\nimport {maybeAnchor, maybeFrameAnchor, maybeTuple, number, string} from \"../options.js\";\nimport {applyDirectStyles, applyFrameAnchor, applyIndirectStyles, applyTransform, impliedString} from \"../style.js\";\nimport {identity, isIterable, isTemporal, isTextual} from \"../options.js\";\nimport {inferTickFormat} from \"./axis.js\";\nimport {applyIndirectTextStyles, defaultWidth, ellipsis, monospaceWidth} from \"./text.js\";\nimport {cut, clipper, splitter, maybeTextOverflow} from \"./text.js\";\n\nconst defaults = {\n ariaLabel: \"tip\",\n fill: \"white\",\n stroke: \"currentColor\"\n};\n\n// These channels are not displayed in the default tip; see formatChannels.\nconst ignoreChannels = new Set([\"geometry\", \"href\", \"src\", \"ariaLabel\", \"scales\"]);\n\nexport class Tip extends Mark {\n constructor(data, options = {}) {\n if (options.tip) options = {...options, tip: false};\n if (options.title === undefined && isIterable(data) && isTextual(data)) options = {...options, title: identity};\n const {\n x,\n y,\n x1,\n x2,\n y1,\n y2,\n anchor,\n monospace,\n fontFamily = monospace ? \"ui-monospace, monospace\" : undefined,\n fontSize,\n fontStyle,\n fontVariant,\n fontWeight,\n lineHeight = 1,\n lineWidth = 20,\n frameAnchor,\n format,\n textAnchor = \"start\",\n textOverflow,\n textPadding = 8,\n title,\n pointerSize = 12,\n pathFilter = \"drop-shadow(0 3px 4px rgba(0,0,0,0.2))\"\n } = options;\n super(\n data,\n {\n x: {value: x1 != null && x2 != null ? null : x, scale: \"x\", optional: true}, // ignore midpoint\n y: {value: y1 != null && y2 != null ? null : y, scale: \"y\", optional: true}, // ignore midpoint\n x1: {value: x1, scale: \"x\", optional: x2 == null},\n y1: {value: y1, scale: \"y\", optional: y2 == null},\n x2: {value: x2, scale: \"x\", optional: x1 == null},\n y2: {value: y2, scale: \"y\", optional: y1 == null},\n title: {value: title, optional: true} // filter: defined\n },\n options,\n defaults\n );\n this.anchor = maybeAnchor(anchor, \"anchor\");\n this.previousAnchor = this.anchor ?? \"top-left\";\n this.frameAnchor = maybeFrameAnchor(frameAnchor);\n this.textAnchor = impliedString(textAnchor, \"middle\");\n this.textPadding = +textPadding;\n this.pointerSize = +pointerSize;\n this.pathFilter = string(pathFilter);\n this.lineHeight = +lineHeight;\n this.lineWidth = +lineWidth;\n this.textOverflow = maybeTextOverflow(textOverflow);\n this.monospace = !!monospace;\n this.fontFamily = string(fontFamily);\n this.fontSize = number(fontSize);\n this.fontStyle = string(fontStyle);\n this.fontVariant = string(fontVariant);\n this.fontWeight = string(fontWeight);\n for (const key in defaults) if (key in this.channels) this[key] = defaults[key]; // apply default even if channel\n this.splitLines = splitter(this);\n this.clipLine = clipper(this);\n this.format = {...format}; // defensive copy before mutate; also promote nullish to empty\n }\n render(index, scales, values, dimensions, context) {\n const mark = this;\n const {x, y, fx, fy} = scales;\n const {ownerSVGElement: svg, document} = context;\n const {anchor, monospace, lineHeight, lineWidth} = this;\n const {textPadding: r, pointerSize: m, pathFilter} = this;\n const {marginTop, marginLeft} = dimensions;\n\n // The anchor position is the middle of x1 & y1 and x2 & y2, if available,\n // or x & y; the former is considered more specific because it’s how we\n // disable the implicit stack and interval transforms. If any dimension is\n // unspecified, we fallback to the frame anchor. We also need to know the\n // facet offsets to detect when the tip would draw outside the plot, and\n // thus we need to change the orientation.\n const {x1: X1, y1: Y1, x2: X2, y2: Y2, x: X = X1 ?? X2, y: Y = Y1 ?? Y2} = values;\n const ox = fx ? fx(index.fx) - marginLeft : 0;\n const oy = fy ? fy(index.fy) - marginTop : 0;\n\n // The order of precedence for the anchor position is: the middle of x1 & y1\n // and x2 & y2; or x1 & y1 (e.g., area); or lastly x & y. If a dimension is\n // unspecified, the frame anchor is used.\n const [cx, cy] = applyFrameAnchor(this, dimensions);\n const px = anchorX(values, cx);\n const py = anchorY(values, cy);\n\n // Resolve the text metric implementation. We may need an ellipsis for text\n // truncation, so we optimistically compute the ellipsis width.\n const widthof = monospace ? monospaceWidth : defaultWidth;\n const ee = widthof(ellipsis);\n\n // If there’s a title channel, display that as-is; otherwise, show multiple\n // channels as name-value pairs.\n let sources, format;\n if (\"title\" in values) {\n sources = values.channels;\n format = formatTitle;\n } else {\n sources = getSourceChannels.call(this, values, scales);\n format = formatChannels;\n }\n\n // We don’t call applyChannelStyles because we only use the channels to\n // derive the content of the tip, not its aesthetics.\n const g = create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyIndirectTextStyles, this)\n .call(applyTransform, this, {x: X && x, y: Y && y})\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"g\")\n .attr(\"transform\", (i) => `translate(${Math.round(px(i))},${Math.round(py(i))})`) // crisp edges\n .call(applyDirectStyles, this)\n .call((g) => g.append(\"path\").attr(\"filter\", pathFilter))\n .call((g) =>\n g.append(\"text\").each(function (i) {\n const that = select(this);\n // prevent style inheritance (from path)\n this.setAttribute(\"fill\", \"currentColor\");\n this.setAttribute(\"fill-opacity\", 1);\n this.setAttribute(\"stroke\", \"none\");\n // iteratively render each channel value\n const lines = format.call(mark, i, index, sources, scales, values);\n if (typeof lines === \"string\") {\n for (const line of mark.splitLines(lines)) {\n renderLine(that, {value: mark.clipLine(line)});\n }\n } else {\n const labels = new Set();\n for (const line of lines) {\n const {label = \"\"} = line;\n if (label && labels.has(label)) continue;\n else labels.add(label);\n renderLine(that, line);\n }\n }\n })\n )\n );\n\n // Renders a single line (a name-value pair) to the tip, truncating the text\n // as needed, and adding a title if the text is truncated. Note that this is\n // just the initial layout of the text; in postrender we will compute the\n // exact text metrics and translate the text as needed once we know the\n // tip’s orientation (anchor).\n function renderLine(selection, {label, value, color, opacity}) {\n (label ??= \"\"), (value ??= \"\");\n const swatch = color != null || opacity != null;\n let title;\n let w = lineWidth * 100;\n const [j] = cut(label, w, widthof, ee);\n if (j >= 0) {\n // label is truncated\n label = label.slice(0, j).trimEnd() + ellipsis;\n title = value.trim();\n value = \"\";\n } else {\n if (label || (!value && !swatch)) value = \" \" + value;\n const [k] = cut(value, w - widthof(label), widthof, ee);\n if (k >= 0) {\n // value is truncated\n value = value.slice(0, k).trimEnd() + ellipsis;\n title = value.trim();\n }\n }\n const line = selection.append(\"tspan\").attr(\"x\", 0).attr(\"dy\", `${lineHeight}em`).text(\"\\u200b\"); // zwsp for double-click\n if (label) line.append(\"tspan\").attr(\"font-weight\", \"bold\").text(label);\n if (value) line.append(() => document.createTextNode(value));\n if (swatch) line.append(\"tspan\").text(\" ■\").attr(\"fill\", color).attr(\"fill-opacity\", opacity).style(\"user-select\", \"none\"); // prettier-ignore\n if (title) line.append(\"title\").text(title);\n }\n\n // Only after the plot is attached to the page can we compute the exact text\n // metrics needed to determine the tip size and orientation (anchor).\n function postrender() {\n const {width, height} = dimensions.facet ?? dimensions;\n g.selectChildren().each(function (i) {\n let {x: tx, width: w, height: h} = this.getBBox();\n (w = Math.round(w)), (h = Math.round(h)); // crisp edges\n let a = anchor; // use the specified anchor, if any\n if (a === undefined) {\n a = mark.previousAnchor; // favor the previous anchor, if it fits\n const x = px(i) + ox;\n const y = py(i) + oy;\n const fitLeft = x + w + r * 2 < width;\n const fitRight = x - w - r * 2 > 0;\n const fitTop = y + h + m + r * 2 + 7 < height;\n const fitBottom = y - h - m - r * 2 > 0;\n const ax = (/-left$/.test(a) ? fitLeft || !fitRight : fitLeft && !fitRight) ? \"left\" : \"right\";\n const ay = (/^top-/.test(a) ? fitTop || !fitBottom : fitTop && !fitBottom) ? \"top\" : \"bottom\";\n a = mark.previousAnchor = `${ay}-${ax}`;\n }\n const path = this.firstChild; // note: assumes exactly two children!\n const text = this.lastChild; // note: assumes exactly two children!\n path.setAttribute(\"d\", getPath(a, m, r, w, h));\n if (tx) for (const t of text.childNodes) t.setAttribute(\"x\", -tx);\n text.setAttribute(\"y\", `${+getLineOffset(a, text.childNodes.length, lineHeight).toFixed(6)}em`);\n text.setAttribute(\"transform\", `translate(${getTextTranslate(a, m, r, w, h)})`);\n });\n g.attr(\"visibility\", null);\n }\n\n // Wait until the plot is inserted into the page so that we can use getBBox\n // to compute the exact text dimensions. If the SVG is already connected, as\n // when the pointer interaction triggers the re-render, use a faster\n // microtask instead of an animation frame; if this SSR (e.g., JSDOM), skip\n // this step. Perhaps this could be done synchronously; getting the\n // dimensions of the SVG is easy, and although accurate text metrics are\n // hard, we could use approximate heuristics.\n if (index.length) {\n g.attr(\"visibility\", \"hidden\"); // hide until postrender\n if (svg.isConnected) Promise.resolve().then(postrender);\n else if (typeof requestAnimationFrame !== \"undefined\") requestAnimationFrame(postrender);\n }\n\n return g.node();\n }\n}\n\nexport function tip(data, {x, y, ...options} = {}) {\n if (options.frameAnchor === undefined) [x, y] = maybeTuple(x, y);\n return new Tip(data, {...options, x, y});\n}\n\nfunction getLineOffset(anchor, length, lineHeight) {\n return /^top(?:-|$)/.test(anchor)\n ? 0.94 - lineHeight\n : /^bottom(?:-|$)/\n ? -0.29 - length * lineHeight\n : (length / 2) * lineHeight;\n}\n\nfunction getTextTranslate(anchor, m, r, width, height) {\n switch (anchor) {\n case \"middle\":\n return [-width / 2, height / 2];\n case \"top-left\":\n return [r, m + r];\n case \"top\":\n return [-width / 2, m / 2 + r];\n case \"top-right\":\n return [-width - r, m + r];\n case \"right\":\n return [-m / 2 - width - r, height / 2];\n case \"bottom-left\":\n return [r, -m - r];\n case \"bottom\":\n return [-width / 2, -m / 2 - r];\n case \"bottom-right\":\n return [-width - r, -m - r];\n case \"left\":\n return [r + m / 2, height / 2];\n }\n}\n\nfunction getPath(anchor, m, r, width, height) {\n const w = width + r * 2;\n const h = height + r * 2;\n switch (anchor) {\n case \"middle\":\n return `M${-w / 2},${-h / 2}h${w}v${h}h${-w}z`;\n case \"top-left\":\n return `M0,0l${m},${m}h${w - m}v${h}h${-w}z`;\n case \"top\":\n return `M0,0l${m / 2},${m / 2}h${(w - m) / 2}v${h}h${-w}v${-h}h${(w - m) / 2}z`;\n case \"top-right\":\n return `M0,0l${-m},${m}h${m - w}v${h}h${w}z`;\n case \"right\":\n return `M0,0l${-m / 2},${-m / 2}v${m / 2 - h / 2}h${-w}v${h}h${w}v${m / 2 - h / 2}z`;\n case \"bottom-left\":\n return `M0,0l${m},${-m}h${w - m}v${-h}h${-w}z`;\n case \"bottom\":\n return `M0,0l${m / 2},${-m / 2}h${(w - m) / 2}v${-h}h${-w}v${h}h${(w - m) / 2}z`;\n case \"bottom-right\":\n return `M0,0l${-m},${-m}h${m - w}v${-h}h${w}z`;\n case \"left\":\n return `M0,0l${m / 2},${-m / 2}v${m / 2 - h / 2}h${w}v${h}h${-w}v${m / 2 - h / 2}z`;\n }\n}\n\n// Note: mutates this.format!\nfunction getSourceChannels({channels}, scales) {\n const sources = {};\n\n // Promote x and y shorthand for paired channels (in order).\n let format = this.format;\n format = maybeExpandPairedFormat(format, channels, \"x\");\n format = maybeExpandPairedFormat(format, channels, \"y\");\n this.format = format;\n\n // Prioritize channels with explicit formats, in the given order.\n for (const key in format) {\n const value = format[key];\n if (value === null || value === false) {\n continue;\n } else if (key === \"fx\" || key === \"fy\") {\n sources[key] = true;\n } else {\n const source = getSource(channels, key);\n if (source) sources[key] = source;\n }\n }\n\n // Then fallback to all other (non-ignored) channels.\n for (const key in channels) {\n if (key in sources || key in format || ignoreChannels.has(key)) continue;\n const source = getSource(channels, key);\n if (source) sources[key] = source;\n }\n\n // And lastly facet channels, but only if this mark is faceted.\n if (this.facet) {\n if (scales.fx && !(\"fx\" in format)) sources.fx = true;\n if (scales.fy && !(\"fy\" in format)) sources.fy = true;\n }\n\n // Promote shorthand string formats, and materialize default formats.\n for (const key in sources) {\n const format = this.format[key];\n if (typeof format === \"string\") {\n const value = sources[key]?.value ?? scales[key]?.domain() ?? [];\n this.format[key] = (isTemporal(value) ? utcFormat : numberFormat)(format);\n } else if (format === undefined || format === true) {\n // For ordinal scales, the inferred tick format can be more concise, such\n // as only showing the year for yearly data.\n const scale = scales[key];\n this.format[key] = scale?.bandwidth ? inferTickFormat(scale, scale.domain()) : formatDefault;\n }\n }\n\n return sources;\n}\n\n// Promote x and y shorthand for paired channels, while preserving order.\nfunction maybeExpandPairedFormat(format, channels, key) {\n if (!(key in format)) return format;\n const key1 = `${key}1`;\n const key2 = `${key}2`;\n if ((key1 in format || !(key1 in channels)) && (key2 in format || !(key2 in channels))) return format;\n const entries = Object.entries(format);\n const value = format[key];\n entries.splice(entries.findIndex(([name]) => name === key) + 1, 0, [key1, value], [key2, value]);\n return Object.fromEntries(entries);\n}\n\nfunction formatTitle(i, index, {title}) {\n return formatDefault(title.value[i], i);\n}\n\nfunction* formatChannels(i, index, channels, scales, values) {\n for (const key in channels) {\n if (key === \"fx\" || key === \"fy\") {\n yield {\n label: formatLabel(scales, channels, key),\n value: this.format[key](index[key], i)\n };\n continue;\n }\n if (key === \"x1\" && \"x2\" in channels) continue;\n if (key === \"y1\" && \"y2\" in channels) continue;\n const channel = channels[key];\n if (key === \"x2\" && \"x1\" in channels) {\n yield {\n label: formatPairLabel(scales, channels, \"x\"),\n value: formatPair(this.format.x2, channels.x1, channel, i)\n };\n } else if (key === \"y2\" && \"y1\" in channels) {\n yield {\n label: formatPairLabel(scales, channels, \"y\"),\n value: formatPair(this.format.y2, channels.y1, channel, i)\n };\n } else {\n const value = channel.value[i];\n const scale = channel.scale;\n if (!defined(value) && scale == null) continue;\n yield {\n label: formatLabel(scales, channels, key),\n value: this.format[key](value, i),\n color: scale === \"color\" ? values[key][i] : null,\n opacity: scale === \"opacity\" ? values[key][i] : null\n };\n }\n }\n}\n\nfunction formatPair(formatValue, c1, c2, i) {\n return c2.hint?.length // e.g., stackY’s y1 and y2\n ? `${formatValue(c2.value[i] - c1.value[i], i)}`\n : `${formatValue(c1.value[i], i)}–${formatValue(c2.value[i], i)}`;\n}\n\nfunction formatPairLabel(scales, channels, key) {\n const l1 = formatLabel(scales, channels, `${key}1`, key);\n const l2 = formatLabel(scales, channels, `${key}2`, key);\n return l1 === l2 ? l1 : `${l1}–${l2}`;\n}\n\nfunction formatLabel(scales, channels, key, defaultLabel = key) {\n const channel = channels[key];\n const scale = scales[channel?.scale ?? key];\n return String(scale?.label ?? channel?.label ?? defaultLabel);\n}\n","import {creator, select} from \"d3\";\nimport {createChannel, inferChannelScale} from \"./channel.js\";\nimport {createContext} from \"./context.js\";\nimport {createDimensions} from \"./dimensions.js\";\nimport {createFacets, recreateFacets, facetExclude, facetGroups, facetTranslator, facetFilter} from \"./facet.js\";\nimport {pointer, pointerX, pointerY} from \"./interactions/pointer.js\";\nimport {createLegends, exposeLegends} from \"./legends.js\";\nimport {Mark} from \"./mark.js\";\nimport {axisFx, axisFy, axisX, axisY, gridFx, gridFy, gridX, gridY} from \"./marks/axis.js\";\nimport {frame} from \"./marks/frame.js\";\nimport {tip} from \"./marks/tip.js\";\nimport {isColor, isIterable, isNone, isScaleOptions} from \"./options.js\";\nimport {arrayify, map, yes, maybeIntervalTransform, subarray} from \"./options.js\";\nimport {createProjection, getGeometryChannels, hasProjection} from \"./projection.js\";\nimport {createScales, createScaleFunctions, autoScaleRange, exposeScales} from \"./scales.js\";\nimport {innerDimensions, outerDimensions} from \"./scales.js\";\nimport {isPosition, registry as scaleRegistry} from \"./scales/index.js\";\nimport {applyInlineStyles, maybeClassName} from \"./style.js\";\nimport {initializer} from \"./transforms/basic.js\";\nimport {consumeWarnings, warn} from \"./warnings.js\";\n\nexport function plot(options = {}) {\n const {facet, style, title, subtitle, caption, ariaLabel, ariaDescription} = options;\n\n // className for inline styles\n const className = maybeClassName(options.className);\n\n // Flatten any nested marks.\n const marks = options.marks === undefined ? [] : flatMarks(options.marks);\n\n // Add implicit tips.\n marks.push(...inferTips(marks));\n\n // Compute the top-level facet state. This has roughly the same structure as\n // mark-specific facet state, except there isn’t a facetsIndex, and there’s a\n // data and dataLength so we can warn the user if a different data of the same\n // length is used in a mark.\n const topFacetState = maybeTopFacet(facet, options);\n\n // Construct a map from (faceted) Mark instance to facet state, including:\n // channels - an {fx?, fy?} object to add to the fx and fy scale\n // groups - a possibly-nested map from facet values to indexes in the data array\n // facetsIndex - a sparse nested array of indices corresponding to the valid facets\n const facetStateByMark = new Map();\n for (const mark of marks) {\n const facetState = maybeMarkFacet(mark, topFacetState, options);\n if (facetState) facetStateByMark.set(mark, facetState);\n }\n\n // Compute a Map from scale name to an array of associated channels.\n const channelsByScale = new Map();\n if (topFacetState) addScaleChannels(channelsByScale, [topFacetState], options);\n addScaleChannels(channelsByScale, facetStateByMark, options);\n\n // Add implicit axis marks. Because this happens after faceting (because it\n // depends on whether faceting is present), we must initialize the facet state\n // of any implicit axes, too.\n const axes = flatMarks(inferAxes(marks, channelsByScale, options));\n for (const mark of axes) {\n const facetState = maybeMarkFacet(mark, topFacetState, options);\n if (facetState) facetStateByMark.set(mark, facetState);\n }\n marks.unshift(...axes);\n\n // All the possible facets are given by the domains of the fx or fy scales, or\n // the cross-product of these domains if we facet by both x and y. We sort\n // them in order to apply the facet filters afterwards.\n let facets = createFacets(channelsByScale, options);\n\n if (facets !== undefined) {\n const topFacetsIndex = topFacetState ? facetFilter(facets, topFacetState) : undefined;\n\n // Compute a facet index for each mark, parallel to the facets array. For\n // mark-level facets, compute an index for that mark’s data and options.\n // Otherwise, use the top-level facet index.\n for (const mark of marks) {\n if (mark.facet === null || mark.facet === \"super\") continue;\n const facetState = facetStateByMark.get(mark);\n if (facetState === undefined) continue;\n facetState.facetsIndex = mark.fx != null || mark.fy != null ? facetFilter(facets, facetState) : topFacetsIndex;\n }\n\n // The cross product of the domains of fx and fy can include fx-fy\n // combinations for which no mark has an instance associated with that\n // combination, and therefore we don’t want to render this facet (not even\n // the frame). The same can occur if you specify the domain of fx and fy\n // explicitly, but there is no mark instance associated with some values in\n // the domain. Expunge empty facets, and clear the corresponding elements\n // from the nested index in each mark.\n const nonEmpty = new Set();\n for (const {facetsIndex} of facetStateByMark.values()) {\n facetsIndex?.forEach((index, i) => {\n if (index?.length > 0) {\n nonEmpty.add(i);\n }\n });\n }\n\n // If all the facets are empty (as when none of the marks are actually\n // faceted), none of them are empty.\n facets.forEach(\n 0 < nonEmpty.size && nonEmpty.size < facets.length\n ? (f, i) => (f.empty = !nonEmpty.has(i))\n : (f) => (f.empty = false)\n );\n\n // For any mark using the “exclude” facet mode, invert the index.\n for (const mark of marks) {\n if (mark.facet === \"exclude\") {\n const facetState = facetStateByMark.get(mark);\n if (facetState !== undefined) facetState.facetsIndex = facetExclude(facetState.facetsIndex);\n }\n }\n }\n\n // If a scale is explicitly declared in options, initialize its associated\n // channels to the empty array; this will guarantee that a corresponding scale\n // will be created later (even if there are no other channels). Ignore facet\n // scale declarations, which are handled above.\n for (const key of scaleRegistry.keys()) {\n if (isScaleOptions(options[key]) && key !== \"fx\" && key !== \"fy\") {\n channelsByScale.set(key, []);\n }\n }\n\n // A Map from Mark instance to its render state, including:\n // index - the data index e.g. [0, 1, 2, 3, …]\n // channels - an array of materialized channels e.g. [[\"x\", {value}], …]\n // faceted - a boolean indicating whether this mark is faceted\n // values - an object of scaled values e.g. {x: [40, 32, …], …}\n const stateByMark = new Map();\n\n // Initialize the marks’ state.\n for (const mark of marks) {\n if (stateByMark.has(mark)) throw new Error(\"duplicate mark; each mark must be unique\");\n const {facetsIndex, channels: facetChannels} = facetStateByMark.get(mark) ?? {};\n const {data, facets, channels} = mark.initialize(facetsIndex, facetChannels, options);\n applyScaleTransforms(channels, options);\n stateByMark.set(mark, {data, facets, channels});\n }\n\n // Initalize the scales and dimensions.\n const scaleDescriptors = createScales(addScaleChannels(channelsByScale, stateByMark, options), options);\n const dimensions = createDimensions(scaleDescriptors, marks, options);\n\n autoScaleRange(scaleDescriptors, dimensions);\n\n const scales = createScaleFunctions(scaleDescriptors);\n const {fx, fy} = scales;\n const subdimensions = fx || fy ? innerDimensions(scaleDescriptors, dimensions) : dimensions;\n const superdimensions = fx || fy ? actualDimensions(scales, dimensions) : dimensions;\n\n // Initialize the context.\n const context = createContext(options);\n const document = context.document;\n const svg = creator(\"svg\").call(document.documentElement);\n let figure = svg; // replaced with the figure element, if any\n context.ownerSVGElement = svg;\n context.className = className;\n context.projection = createProjection(options, subdimensions);\n\n // Allows e.g. the axis mark to determine faceting lazily.\n context.filterFacets = (data, channels) => {\n return facetFilter(facets, {channels, groups: facetGroups(data, channels)});\n };\n\n // Allows e.g. the tip mark to reference channels and data on other marks.\n context.getMarkState = (mark) => {\n const state = stateByMark.get(mark);\n const facetState = facetStateByMark.get(mark);\n return {...state, channels: {...state.channels, ...facetState?.channels}};\n };\n\n // Allows e.g. the pointer transform to support viewof.\n context.dispatchValue = (value) => {\n if (figure.value === value) return;\n figure.value = value;\n figure.dispatchEvent(new Event(\"input\", {bubbles: true}));\n };\n\n // Reinitialize; for deriving channels dependent on other channels.\n const newByScale = new Set();\n for (const [mark, state] of stateByMark) {\n if (mark.initializer != null) {\n const dimensions = mark.facet === \"super\" ? superdimensions : subdimensions;\n const update = mark.initializer(state.data, state.facets, state.channels, scales, dimensions, context);\n if (update.data !== undefined) {\n state.data = update.data;\n }\n if (update.facets !== undefined) {\n state.facets = update.facets;\n }\n if (update.channels !== undefined) {\n const {fx, fy, ...channels} = update.channels; // separate facet channels\n inferChannelScales(channels);\n Object.assign(state.channels, channels);\n for (const channel of Object.values(channels)) {\n const {scale} = channel;\n // Initializers aren’t allowed to redefine position scales as this\n // would introduce a circular dependency; so simply scale these\n // channels as-is rather than creating new scales, and assume that\n // they already have the scale’s transform applied, if any (e.g., when\n // generating ticks for the axis mark).\n if (scale != null && !isPosition(scaleRegistry.get(scale))) {\n applyScaleTransform(channel, options);\n newByScale.add(scale);\n }\n }\n // If the initializer returns new mark-level facet channels, we must\n // record that the mark is now faceted. Note: we aren’t actually\n // populating the facet state, but subsequently we won’t need it.\n if (fx != null || fy != null) facetStateByMark.set(mark, true);\n }\n }\n }\n\n // Reconstruct scales if new scaled channels were created during\n // reinitialization. Preserve existing scale labels, if any.\n if (newByScale.size) {\n const newChannelsByScale = new Map();\n addScaleChannels(newChannelsByScale, stateByMark, options, (key) => newByScale.has(key));\n addScaleChannels(channelsByScale, stateByMark, options, (key) => newByScale.has(key));\n const newScaleDescriptors = inheritScaleLabels(createScales(newChannelsByScale, options), scaleDescriptors);\n const {scales: newExposedScales, ...newScales} = createScaleFunctions(newScaleDescriptors);\n Object.assign(scaleDescriptors, newScaleDescriptors);\n Object.assign(scales, newScales);\n Object.assign(scales.scales, newExposedScales);\n }\n\n // Sort and filter the facets to match the fx and fy domains; this is needed\n // because the facets were constructed prior to the fx and fy scales.\n let facetDomains, facetTranslate;\n if (facets !== undefined) {\n facetDomains = {x: fx?.domain(), y: fy?.domain()};\n facets = recreateFacets(facets, facetDomains);\n facetTranslate = facetTranslator(fx, fy, dimensions);\n }\n\n // Compute value objects, applying scales and projection as needed.\n for (const [mark, state] of stateByMark) {\n state.values = mark.scale(state.channels, scales, context);\n }\n\n const {width, height} = dimensions;\n\n select(svg)\n .attr(\"class\", className)\n .attr(\"fill\", \"currentColor\")\n .attr(\"font-family\", \"system-ui, sans-serif\")\n .attr(\"font-size\", 10)\n .attr(\"text-anchor\", \"middle\")\n .attr(\"width\", width)\n .attr(\"height\", height)\n .attr(\"viewBox\", `0 0 ${width} ${height}`)\n .attr(\"aria-label\", ariaLabel)\n .attr(\"aria-description\", ariaDescription)\n .call((svg) =>\n // Warning: if you edit this, change defaultClassName.\n svg.append(\"style\").text(\n `.${className} {\n display: block;\n background: white;\n height: auto;\n height: intrinsic;\n max-width: 100%;\n}\n.${className} text,\n.${className} tspan {\n white-space: pre;\n}`\n )\n )\n .call(applyInlineStyles, style);\n\n // Render marks.\n for (const mark of marks) {\n const {channels, values, facets: indexes} = stateByMark.get(mark);\n\n // Render a non-faceted mark.\n if (facets === undefined || mark.facet === \"super\") {\n let index = null;\n if (indexes) {\n index = indexes[0];\n index = mark.filter(index, channels, values);\n if (index.length === 0) continue;\n }\n const node = mark.render(index, scales, values, superdimensions, context);\n if (node == null) continue;\n svg.appendChild(node);\n }\n\n // Render a faceted mark.\n else {\n let g;\n for (const f of facets) {\n if (!(mark.facetAnchor?.(facets, facetDomains, f) ?? !f.empty)) continue;\n let index = null;\n if (indexes) {\n const faceted = facetStateByMark.has(mark);\n index = indexes[faceted ? f.i : 0];\n index = mark.filter(index, channels, values);\n if (index.length === 0) continue;\n if (!faceted && index === indexes[0]) index = subarray(index); // copy before assigning fx, fy, fi\n (index.fx = f.x), (index.fy = f.y), (index.fi = f.i);\n }\n const node = mark.render(index, scales, values, subdimensions, context);\n if (node == null) continue;\n // Lazily construct the shared group (to drop empty marks).\n (g ??= select(svg).append(\"g\")).append(() => node).datum(f);\n // Promote ARIA attributes and mark transform to avoid repetition on\n // each facet; this assumes that these attributes are consistent across\n // facets, but that should be the case!\n for (const name of [\"aria-label\", \"aria-description\", \"aria-hidden\", \"transform\"]) {\n if (node.hasAttribute(name)) {\n g.attr(name, node.getAttribute(name));\n node.removeAttribute(name);\n }\n }\n }\n g?.selectChildren().attr(\"transform\", facetTranslate);\n }\n }\n\n // Wrap the plot in a figure, if needed.\n const legends = createLegends(scaleDescriptors, context, options);\n const {figure: figured = title != null || subtitle != null || caption != null || legends.length > 0} = options;\n if (figured) {\n figure = document.createElement(\"figure\");\n figure.className = `${className}-figure`;\n figure.style.maxWidth = \"initial\"; // avoid Observable default style\n if (title != null) figure.append(createTitleElement(document, title, \"h2\"));\n if (subtitle != null) figure.append(createTitleElement(document, subtitle, \"h3\"));\n figure.append(...legends, svg);\n if (caption != null) figure.append(createFigcaption(document, caption));\n }\n\n figure.scale = exposeScales(scales.scales);\n figure.legend = exposeLegends(scaleDescriptors, context, options);\n\n const w = consumeWarnings();\n if (w > 0) {\n select(svg)\n .append(\"text\")\n .attr(\"x\", width)\n .attr(\"y\", 20)\n .attr(\"dy\", \"-1em\")\n .attr(\"text-anchor\", \"end\")\n .attr(\"font-family\", \"initial\") // fix emoji rendering in Chrome\n .text(\"\\u26a0\\ufe0f\") // emoji variation selector\n .append(\"title\")\n .text(`${w.toLocaleString(\"en-US\")} warning${w === 1 ? \"\" : \"s\"}. Please check the console.`);\n }\n\n return figure;\n}\n\nfunction createTitleElement(document, contents, tag) {\n if (contents.ownerDocument) return contents;\n const e = document.createElement(tag);\n e.append(contents);\n return e;\n}\n\nfunction createFigcaption(document, caption) {\n const e = document.createElement(\"figcaption\");\n e.append(caption);\n return e;\n}\n\nfunction plotThis({marks = [], ...options} = {}) {\n return plot({...options, marks: [...marks, this]});\n}\n\n// Note: This side-effect avoids a circular dependency.\nMark.prototype.plot = plotThis;\n\nfunction flatMarks(marks) {\n return marks\n .flat(Infinity)\n .filter((mark) => mark != null)\n .map(markify);\n}\n\nfunction markify(mark) {\n return typeof mark.render === \"function\" ? mark : new Render(mark);\n}\n\nclass Render extends Mark {\n constructor(render) {\n if (typeof render !== \"function\") throw new TypeError(\"invalid mark; missing render function\");\n super();\n this.render = render;\n }\n render() {}\n}\n\n// Note: mutates channel.value to apply the scale transform, if any.\nfunction applyScaleTransforms(channels, options) {\n for (const name in channels) applyScaleTransform(channels[name], options);\n return channels;\n}\n\n// Note: mutates channel.value to apply the scale transform, if any. Also sets\n// channel.transform to false to prevent duplicate transform application.\nfunction applyScaleTransform(channel, options) {\n const {scale, transform: t = true} = channel;\n if (scale == null || !t) return;\n const {\n type,\n percent,\n interval,\n transform = percent ? (x) => x * 100 : maybeIntervalTransform(interval, type)\n } = options[scale] ?? {};\n if (transform == null) return;\n channel.value = map(channel.value, transform);\n channel.transform = false;\n}\n\n// An initializer may generate channels without knowing how the downstream mark\n// will use them. Marks are typically responsible associated scales with\n// channels, but here we assume common behavior across marks.\nfunction inferChannelScales(channels) {\n for (const name in channels) {\n inferChannelScale(name, channels[name]);\n }\n}\n\nfunction addScaleChannels(channelsByScale, stateByMark, options, filter = yes) {\n for (const {channels} of stateByMark.values()) {\n for (const name in channels) {\n const channel = channels[name];\n const {scale} = channel;\n if (scale != null && filter(scale)) {\n // Geo marks affect the default x and y domains if there is no\n // projection. Skip this (as an optimization) when a projection is\n // specified, or when the domains for x and y are specified.\n if (scale === \"projection\") {\n if (!hasProjection(options)) {\n const gx = options.x?.domain === undefined;\n const gy = options.y?.domain === undefined;\n if (gx || gy) {\n const [x, y] = getGeometryChannels(channel);\n if (gx) addScaleChannel(channelsByScale, \"x\", x);\n if (gy) addScaleChannel(channelsByScale, \"y\", y);\n }\n }\n } else {\n addScaleChannel(channelsByScale, scale, channel);\n }\n }\n }\n }\n return channelsByScale;\n}\n\nfunction addScaleChannel(channelsByScale, scale, channel) {\n const scaleChannels = channelsByScale.get(scale);\n if (scaleChannels !== undefined) scaleChannels.push(channel);\n else channelsByScale.set(scale, [channel]);\n}\n\n// Returns the facet groups, and possibly fx and fy channels, associated with\n// the top-level facet option {data, x, y}.\nfunction maybeTopFacet(facet, options) {\n if (facet == null) return;\n const {x, y} = facet;\n if (x == null && y == null) return;\n const data = arrayify(facet.data);\n if (data == null) throw new Error(\"missing facet data\");\n const channels = {};\n if (x != null) channels.fx = createChannel(data, {value: x, scale: \"fx\"});\n if (y != null) channels.fy = createChannel(data, {value: y, scale: \"fy\"});\n applyScaleTransforms(channels, options);\n const groups = facetGroups(data, channels);\n return {channels, groups, data: facet.data};\n}\n\n// Returns the facet groups, and possibly fx and fy channels, associated with a\n// mark, either through top-level faceting or mark-level facet options {fx, fy}.\nfunction maybeMarkFacet(mark, topFacetState, options) {\n if (mark.facet === null || mark.facet === \"super\") return;\n\n // This mark defines a mark-level facet. TODO There’s some code duplication\n // here with maybeTopFacet that we could reduce.\n const {fx, fy} = mark;\n if (fx != null || fy != null) {\n const data = arrayify(mark.data ?? fx ?? fy);\n if (data === undefined) throw new Error(`missing facet data in ${mark.ariaLabel}`);\n if (data === null) return; // ignore channel definitions if no data is provided TODO this right?\n const channels = {};\n if (fx != null) channels.fx = createChannel(data, {value: fx, scale: \"fx\"});\n if (fy != null) channels.fy = createChannel(data, {value: fy, scale: \"fy\"});\n applyScaleTransforms(channels, options);\n return {channels, groups: facetGroups(data, channels)};\n }\n\n // This mark links to a top-level facet, if present.\n if (topFacetState === undefined) return;\n\n // TODO Can we link the top-level facet channels here?\n const {channels, groups, data} = topFacetState;\n if (mark.facet !== \"auto\" || mark.data === data) return {channels, groups};\n\n // Warn for the common pitfall of wanting to facet mapped data with the\n // top-level facet option.\n if (\n data.length > 0 &&\n (groups.size > 1 || (groups.size === 1 && channels.fx && channels.fy && [...groups][0][1].size > 1)) &&\n arrayify(mark.data)?.length === data.length\n ) {\n warn(\n `Warning: the ${mark.ariaLabel} mark appears to use faceted data, but isn’t faceted. The mark data has the same length as the facet data and the mark facet option is \"auto\", but the mark data and facet data are distinct. If this mark should be faceted, set the mark facet option to true; otherwise, suppress this warning by setting the mark facet option to false.`\n );\n }\n}\n\nfunction derive(mark, options = {}) {\n return initializer({...options, x: null, y: null}, (data, facets, channels, scales, dimensions, context) => {\n return context.getMarkState(mark);\n });\n}\n\nfunction inferTips(marks) {\n const tips = [];\n for (const mark of marks) {\n let tipOptions = mark.tip;\n if (tipOptions) {\n if (tipOptions === true) tipOptions = {};\n else if (typeof tipOptions === \"string\") tipOptions = {pointer: tipOptions};\n let {pointer: p} = tipOptions;\n p = /^x$/i.test(p) ? pointerX : /^y$/i.test(p) ? pointerY : pointer; // TODO validate?\n tipOptions = p(derive(mark, tipOptions));\n tipOptions.title = null; // prevent implicit title for primitive data\n const t = tip(mark.data, tipOptions);\n t.facet = mark.facet; // inherit facet settings\n t.facetAnchor = mark.facetAnchor; // inherit facet settings\n tips.push(t);\n }\n }\n return tips;\n}\n\nfunction inferAxes(marks, channelsByScale, options) {\n let {\n projection,\n x = {},\n y = {},\n fx = {},\n fy = {},\n axis,\n grid,\n facet = {},\n facet: {axis: facetAxis = axis, grid: facetGrid} = facet,\n x: {axis: xAxis = axis, grid: xGrid = xAxis === null ? null : grid} = x,\n y: {axis: yAxis = axis, grid: yGrid = yAxis === null ? null : grid} = y,\n fx: {axis: fxAxis = facetAxis, grid: fxGrid = fxAxis === null ? null : facetGrid} = fx,\n fy: {axis: fyAxis = facetAxis, grid: fyGrid = fyAxis === null ? null : facetGrid} = fy\n } = options;\n\n // Disable axes if the corresponding scale is not present.\n if (projection || (!isScaleOptions(x) && !hasPositionChannel(\"x\", marks))) xAxis = xGrid = null;\n if (projection || (!isScaleOptions(y) && !hasPositionChannel(\"y\", marks))) yAxis = yGrid = null;\n if (!channelsByScale.has(\"fx\")) fxAxis = fxGrid = null;\n if (!channelsByScale.has(\"fy\")) fyAxis = fyGrid = null;\n\n // Resolve the default implicit axes by checking for explicit ones.\n if (xAxis === undefined) xAxis = !hasAxis(marks, \"x\");\n if (yAxis === undefined) yAxis = !hasAxis(marks, \"y\");\n if (fxAxis === undefined) fxAxis = !hasAxis(marks, \"fx\");\n if (fyAxis === undefined) fyAxis = !hasAxis(marks, \"fy\");\n\n // Resolve the default orientation of axes.\n if (xAxis === true) xAxis = \"bottom\";\n if (yAxis === true) yAxis = \"left\";\n if (fxAxis === true) fxAxis = xAxis === \"top\" || xAxis === null ? \"bottom\" : \"top\";\n if (fyAxis === true) fyAxis = yAxis === \"right\" || yAxis === null ? \"left\" : \"right\";\n\n const axes = [];\n maybeGrid(axes, fyGrid, gridFy, fy);\n maybeAxis(axes, fyAxis, axisFy, \"right\", \"left\", facet, fy);\n maybeGrid(axes, fxGrid, gridFx, fx);\n maybeAxis(axes, fxAxis, axisFx, \"top\", \"bottom\", facet, fx);\n maybeGrid(axes, yGrid, gridY, y);\n maybeAxis(axes, yAxis, axisY, \"left\", \"right\", options, y);\n maybeGrid(axes, xGrid, gridX, x);\n maybeAxis(axes, xAxis, axisX, \"bottom\", \"top\", options, x);\n return axes;\n}\n\nfunction maybeAxis(axes, axis, axisType, primary, secondary, defaults, options) {\n if (!axis) return;\n const both = isBoth(axis);\n options = axisOptions(both ? primary : axis, defaults, options);\n const {line} = options;\n if ((axisType === axisY || axisType === axisX) && line && !isNone(line)) axes.push(frame(lineOptions(options)));\n axes.push(axisType(options));\n if (both) axes.push(axisType({...options, anchor: secondary, label: null}));\n}\n\nfunction maybeGrid(axes, grid, gridType, options) {\n if (!grid || isNone(grid)) return;\n axes.push(gridType(gridOptions(grid, options)));\n}\n\nfunction isBoth(value) {\n return /^\\s*both\\s*$/i.test(value);\n}\n\nfunction axisOptions(\n anchor,\n defaults,\n {\n line = defaults.line,\n ticks,\n tickSize,\n tickSpacing,\n tickPadding,\n tickFormat,\n tickRotate,\n fontVariant,\n ariaLabel,\n ariaDescription,\n label = defaults.label,\n labelAnchor,\n labelArrow = defaults.labelArrow,\n labelOffset\n }\n) {\n return {\n anchor,\n line,\n ticks,\n tickSize,\n tickSpacing,\n tickPadding,\n tickFormat,\n tickRotate,\n fontVariant,\n ariaLabel,\n ariaDescription,\n label,\n labelAnchor,\n labelArrow,\n labelOffset\n };\n}\n\nfunction lineOptions(options) {\n const {anchor, line} = options;\n return {anchor, facetAnchor: anchor + \"-empty\", stroke: line === true ? undefined : line};\n}\n\nfunction gridOptions(\n grid,\n {\n stroke = isColor(grid) ? grid : undefined,\n ticks = isGridTicks(grid) ? grid : undefined,\n tickSpacing,\n ariaLabel,\n ariaDescription\n }\n) {\n return {\n stroke,\n ticks,\n tickSpacing,\n ariaLabel,\n ariaDescription\n };\n}\n\nfunction isGridTicks(grid) {\n switch (typeof grid) {\n case \"number\":\n return true;\n case \"string\":\n return !isColor(grid);\n }\n return isIterable(grid) || typeof grid?.range === \"function\";\n}\n\n// Is there an explicit axis already present? TODO We probably want a more\n// explicit test than looking for the ARIA label, but it does afford some\n// flexibility in axis implementation which is nice.\nfunction hasAxis(marks, k) {\n const prefix = `${k}-axis `;\n return marks.some((m) => m.ariaLabel?.startsWith(prefix));\n}\n\nfunction hasPositionChannel(k, marks) {\n for (const mark of marks) {\n for (const key in mark.channels) {\n const {scale} = mark.channels[key];\n if (scale === k || scale === \"projection\") {\n return true;\n }\n }\n }\n return false;\n}\n\nfunction inheritScaleLabels(newScales, scales) {\n for (const key in newScales) {\n const newScale = newScales[key];\n const scale = scales[key];\n if (newScale.label === undefined && scale) {\n newScale.label = scale.label;\n }\n }\n return newScales;\n}\n\n// This differs from the other outerDimensions in that it accounts for rounding\n// and outer padding in the facet scales; we want the frame to align exactly\n// with the actual range, not the desired range.\nfunction actualDimensions({fx, fy}, dimensions) {\n const {marginTop, marginRight, marginBottom, marginLeft, width, height} = outerDimensions(dimensions);\n const fxr = fx && outerRange(fx);\n const fyr = fy && outerRange(fy);\n return {\n marginTop: fy ? fyr[0] : marginTop,\n marginRight: fx ? width - fxr[1] : marginRight,\n marginBottom: fy ? height - fyr[1] : marginBottom,\n marginLeft: fx ? fxr[0] : marginLeft,\n // Some marks, namely the x- and y-axis labels, want to know what the\n // desired (rather than actual) margins are for positioning.\n inset: {\n marginTop: dimensions.marginTop,\n marginRight: dimensions.marginRight,\n marginBottom: dimensions.marginBottom,\n marginLeft: dimensions.marginLeft\n },\n width,\n height\n };\n}\n\nfunction outerRange(scale) {\n const domain = scale.domain();\n let x1 = scale(domain[0]);\n let x2 = scale(domain[domain.length - 1]);\n if (x2 < x1) [x1, x2] = [x2, x1];\n return [x1, x2 + scale.bandwidth()];\n}\n","import {\n curveBasis,\n curveBasisClosed,\n curveBasisOpen,\n curveBundle,\n curveBumpX,\n curveBumpY,\n curveCardinal,\n curveCardinalClosed,\n curveCardinalOpen,\n curveCatmullRom,\n curveCatmullRomClosed,\n curveCatmullRomOpen,\n curveLinear,\n curveLinearClosed,\n curveMonotoneX,\n curveMonotoneY,\n curveNatural,\n curveStep,\n curveStepAfter,\n curveStepBefore\n} from \"d3\";\n\nconst curves = new Map([\n [\"basis\", curveBasis],\n [\"basis-closed\", curveBasisClosed],\n [\"basis-open\", curveBasisOpen],\n [\"bundle\", curveBundle],\n [\"bump-x\", curveBumpX],\n [\"bump-y\", curveBumpY],\n [\"cardinal\", curveCardinal],\n [\"cardinal-closed\", curveCardinalClosed],\n [\"cardinal-open\", curveCardinalOpen],\n [\"catmull-rom\", curveCatmullRom],\n [\"catmull-rom-closed\", curveCatmullRomClosed],\n [\"catmull-rom-open\", curveCatmullRomOpen],\n [\"linear\", curveLinear],\n [\"linear-closed\", curveLinearClosed],\n [\"monotone-x\", curveMonotoneX],\n [\"monotone-y\", curveMonotoneY],\n [\"natural\", curveNatural],\n [\"step\", curveStep],\n [\"step-after\", curveStepAfter],\n [\"step-before\", curveStepBefore]\n]);\n\nexport function maybeCurve(curve = curveLinear, tension) {\n if (typeof curve === \"function\") return curve; // custom curve\n const c = curves.get(`${curve}`.toLowerCase());\n if (!c) throw new Error(`unknown curve: ${curve}`);\n if (tension !== undefined) {\n if (\"beta\" in c) {\n return c.beta(tension);\n } else if (\"tension\" in c) {\n return c.tension(tension);\n } else if (\"alpha\" in c) {\n return c.alpha(tension);\n }\n }\n return c;\n}\n\n// For the “auto” curve, return a symbol instead of a curve implementation;\n// we’ll use d3.geoPath to render if there’s a projection.\nexport function maybeCurveAuto(curve = curveAuto, tension) {\n return typeof curve !== \"function\" && `${curve}`.toLowerCase() === \"auto\" ? curveAuto : maybeCurve(curve, tension);\n}\n\n// This is a special built-in curve that will use d3.geoPath when there is a\n// projection, and the linear curve when there is not. You can explicitly\n// opt-out of d3.geoPath and instead use d3.line with the \"linear\" curve.\nexport function curveAuto(context) {\n return curveLinear(context);\n}\n","import {\n bisect,\n extent,\n thresholdFreedmanDiaconis,\n thresholdScott,\n thresholdSturges,\n tickIncrement,\n ticks,\n utcTickInterval\n} from \"d3\";\nimport {withTip} from \"../mark.js\";\nimport {\n coerceDate,\n coerceNumbers,\n identity,\n isInterval,\n isIterable,\n isTemporal,\n isTimeInterval,\n labelof,\n map,\n maybeApplyInterval,\n maybeColorChannel,\n maybeColumn,\n maybeRangeInterval,\n maybeTuple,\n maybeValue,\n mid,\n valueof\n} from \"../options.js\";\nimport {maybeUtcInterval} from \"../time.js\";\nimport {basic} from \"./basic.js\";\nimport {\n hasOutput,\n maybeEvaluator,\n maybeGroup,\n maybeOutput,\n maybeOutputs,\n maybeReduce,\n maybeSort,\n maybeSubgroup,\n reduceCount,\n reduceFirst,\n reduceIdentity\n} from \"./group.js\";\nimport {maybeInsetX, maybeInsetY} from \"./inset.js\";\n\n// Group on {z, fill, stroke}, then optionally on y, then bin x.\nexport function binX(outputs = {y: \"count\"}, options = {}) {\n [outputs, options] = mergeOptions(outputs, options);\n const {x, y} = options;\n return binn(maybeBinValue(x, options, identity), null, null, y, outputs, maybeInsetX(options));\n}\n\n// Group on {z, fill, stroke}, then optionally on x, then bin y.\nexport function binY(outputs = {x: \"count\"}, options = {}) {\n [outputs, options] = mergeOptions(outputs, options);\n const {x, y} = options;\n return binn(null, maybeBinValue(y, options, identity), x, null, outputs, maybeInsetY(options));\n}\n\n// Group on {z, fill, stroke}, then bin on x and y.\nexport function bin(outputs = {fill: \"count\"}, options = {}) {\n [outputs, options] = mergeOptions(outputs, options);\n const {x, y} = maybeBinValueTuple(options);\n return binn(x, y, null, null, outputs, maybeInsetX(maybeInsetY(options)));\n}\n\nfunction maybeDenseInterval(bin, k, options = {}) {\n if (options?.interval == null) return options;\n const {reduce = reduceFirst} = options;\n const outputs = {filter: null};\n if (options[k] != null) outputs[k] = reduce;\n if (options[`${k}1`] != null) outputs[`${k}1`] = reduce;\n if (options[`${k}2`] != null) outputs[`${k}2`] = reduce;\n return bin(outputs, options);\n}\n\nexport function maybeDenseIntervalX(options = {}) {\n return maybeDenseInterval(binX, \"y\", withTip(options, \"x\"));\n}\n\nexport function maybeDenseIntervalY(options = {}) {\n return maybeDenseInterval(binY, \"x\", withTip(options, \"y\"));\n}\n\nfunction binn(\n bx, // optionally bin on x (exclusive with gx)\n by, // optionally bin on y (exclusive with gy)\n gx, // optionally group on x (exclusive with bx and gy)\n gy, // optionally group on y (exclusive with by and gx)\n {\n data: reduceData = reduceIdentity, // TODO avoid materializing when unused?\n filter = reduceCount, // return only non-empty bins by default\n sort,\n reverse,\n ...outputs // output channel definitions\n } = {},\n inputs = {} // input channels and options\n) {\n bx = maybeBin(bx);\n by = maybeBin(by);\n\n // Compute the outputs.\n outputs = maybeBinOutputs(outputs, inputs);\n reduceData = maybeBinReduce(reduceData, identity);\n sort = sort == null ? undefined : maybeBinOutput(\"sort\", sort, inputs);\n filter = filter == null ? undefined : maybeBinEvaluator(\"filter\", filter, inputs);\n\n // Don’t group on a channel if an output requires it as an input!\n if (gx != null && hasOutput(outputs, \"x\", \"x1\", \"x2\")) gx = null;\n if (gy != null && hasOutput(outputs, \"y\", \"y1\", \"y2\")) gy = null;\n\n // Produce x1, x2, y1, and y2 output channels as appropriate (when binning).\n const [BX1, setBX1] = maybeColumn(bx);\n const [BX2, setBX2] = maybeColumn(bx);\n const [BY1, setBY1] = maybeColumn(by);\n const [BY2, setBY2] = maybeColumn(by);\n\n // Produce x or y output channels as appropriate (when grouping).\n const [k, gk] = gx != null ? [gx, \"x\"] : gy != null ? [gy, \"y\"] : [];\n const [GK, setGK] = maybeColumn(k);\n\n // Greedily materialize the z, fill, and stroke channels (if channels and not\n // constants) so that we can reference them for subdividing groups without\n // computing them more than once. We also want to consume options that should\n // only apply to this transform rather than passing them through to the next.\n const {\n x,\n y,\n z,\n fill,\n stroke,\n x1,\n x2, // consumed if x is an output\n y1,\n y2, // consumed if y is an output\n domain,\n cumulative,\n thresholds,\n interval,\n ...options\n } = inputs;\n const [GZ, setGZ] = maybeColumn(z);\n const [vfill] = maybeColorChannel(fill);\n const [vstroke] = maybeColorChannel(stroke);\n const [GF, setGF] = maybeColumn(vfill);\n const [GS, setGS] = maybeColumn(vstroke);\n\n return {\n ...(\"z\" in inputs && {z: GZ || z}),\n ...(\"fill\" in inputs && {fill: GF || fill}),\n ...(\"stroke\" in inputs && {stroke: GS || stroke}),\n ...basic(options, (data, facets, plotOptions) => {\n const K = maybeApplyInterval(valueof(data, k), plotOptions?.[gk]);\n const Z = valueof(data, z);\n const F = valueof(data, vfill);\n const S = valueof(data, vstroke);\n const G = maybeSubgroup(outputs, {z: Z, fill: F, stroke: S});\n const groupFacets = [];\n const groupData = [];\n const GK = K && setGK([]);\n const GZ = Z && setGZ([]);\n const GF = F && setGF([]);\n const GS = S && setGS([]);\n const BX1 = bx && setBX1([]);\n const BX2 = bx && setBX2([]);\n const BY1 = by && setBY1([]);\n const BY2 = by && setBY2([]);\n const bin = bing(bx?.(data), by?.(data));\n let i = 0;\n for (const o of outputs) o.initialize(data);\n if (sort) sort.initialize(data);\n if (filter) filter.initialize(data);\n for (const facet of facets) {\n const groupFacet = [];\n for (const o of outputs) o.scope(\"facet\", facet);\n if (sort) sort.scope(\"facet\", facet);\n if (filter) filter.scope(\"facet\", facet);\n for (const [f, I] of maybeGroup(facet, G)) {\n for (const [k, g] of maybeGroup(I, K)) {\n for (const [b, extent] of bin(g)) {\n if (filter && !filter.reduce(b, extent)) continue;\n groupFacet.push(i++);\n groupData.push(reduceData.reduceIndex(b, data, extent));\n if (K) GK.push(k);\n if (Z) GZ.push(G === Z ? f : Z[(b.length > 0 ? b : g)[0]]);\n if (F) GF.push(G === F ? f : F[(b.length > 0 ? b : g)[0]]);\n if (S) GS.push(G === S ? f : S[(b.length > 0 ? b : g)[0]]);\n if (BX1) BX1.push(extent.x1), BX2.push(extent.x2);\n if (BY1) BY1.push(extent.y1), BY2.push(extent.y2);\n for (const o of outputs) o.reduce(b, extent);\n if (sort) sort.reduce(b);\n }\n }\n }\n groupFacets.push(groupFacet);\n }\n maybeSort(groupFacets, sort, reverse);\n return {data: groupData, facets: groupFacets};\n }),\n ...(!hasOutput(outputs, \"x\") && (BX1 ? {x1: BX1, x2: BX2, x: mid(BX1, BX2)} : {x, x1, x2})),\n ...(!hasOutput(outputs, \"y\") && (BY1 ? {y1: BY1, y2: BY2, y: mid(BY1, BY2)} : {y, y1, y2})),\n ...(GK && {[gk]: GK}),\n ...Object.fromEntries(outputs.map(({name, output}) => [name, output]))\n };\n}\n\n// Allow bin options to be specified as part of outputs; merge them into options.\nfunction mergeOptions({cumulative, domain, thresholds, interval, ...outputs}, options) {\n return [outputs, {cumulative, domain, thresholds, interval, ...options}];\n}\n\nfunction maybeBinValue(value, {cumulative, domain, thresholds, interval}, defaultValue) {\n value = {...maybeValue(value)};\n if (value.domain === undefined) value.domain = domain;\n if (value.cumulative === undefined) value.cumulative = cumulative;\n if (value.thresholds === undefined) value.thresholds = thresholds;\n if (value.interval === undefined) value.interval = interval;\n if (value.value === undefined) value.value = defaultValue;\n value.thresholds = maybeThresholds(value.thresholds, value.interval);\n return value;\n}\n\nfunction maybeBinValueTuple(options) {\n let {x, y} = options;\n x = maybeBinValue(x, options);\n y = maybeBinValue(y, options);\n [x.value, y.value] = maybeTuple(x.value, y.value);\n return {x, y};\n}\n\nfunction maybeBin(options) {\n if (options == null) return;\n const {value, cumulative, domain = extent, thresholds} = options;\n const bin = (data) => {\n let V = valueof(data, value);\n let T; // bin thresholds\n if (isTemporal(V) || isTimeThresholds(thresholds)) {\n V = map(V, coerceDate, Float64Array); // like coerceDates, but faster\n let [min, max] = typeof domain === \"function\" ? domain(V) : domain;\n let t = typeof thresholds === \"function\" && !isInterval(thresholds) ? thresholds(V, min, max) : thresholds;\n if (typeof t === \"number\") t = utcTickInterval(min, max, t);\n if (isInterval(t)) {\n if (domain === extent) {\n min = t.floor(min);\n max = t.offset(t.floor(max));\n }\n t = t.range(min, t.offset(max));\n }\n T = t;\n } else {\n V = coerceNumbers(V);\n let [min, max] = typeof domain === \"function\" ? domain(V) : domain;\n let t = typeof thresholds === \"function\" && !isInterval(thresholds) ? thresholds(V, min, max) : thresholds;\n if (typeof t === \"number\") {\n // This differs from d3.ticks with regard to exclusive bounds: we want a\n // first threshold less than or equal to the minimum, and a last\n // threshold (strictly) greater than the maximum.\n if (domain === extent) {\n let step = tickIncrement(min, max, t);\n if (isFinite(step)) {\n if (step > 0) {\n let r0 = Math.round(min / step);\n let r1 = Math.round(max / step);\n if (!(r0 * step <= min)) --r0;\n if (!(r1 * step > max)) ++r1;\n let n = r1 - r0 + 1;\n t = new Float64Array(n);\n for (let i = 0; i < n; ++i) t[i] = (r0 + i) * step;\n } else if (step < 0) {\n step = -step;\n let r0 = Math.round(min * step);\n let r1 = Math.round(max * step);\n if (!(r0 / step <= min)) --r0;\n if (!(r1 / step > max)) ++r1;\n let n = r1 - r0 + 1;\n t = new Float64Array(n);\n for (let i = 0; i < n; ++i) t[i] = (r0 + i) / step;\n } else {\n t = [min];\n }\n } else {\n t = [min];\n }\n } else {\n t = ticks(min, max, t);\n }\n } else if (isInterval(t)) {\n if (domain === extent) {\n min = t.floor(min);\n max = t.offset(t.floor(max));\n }\n t = t.range(min, t.offset(max));\n }\n T = t;\n }\n const E = [];\n if (T.length === 1) E.push([T[0], T[0]]); // collapsed domain\n else for (let i = 1; i < T.length; ++i) E.push([T[i - 1], T[i]]);\n E.bin = (cumulative < 0 ? bin1cn : cumulative > 0 ? bin1cp : bin1)(E, T, V);\n return E;\n };\n bin.label = labelof(value);\n return bin;\n}\n\nexport function maybeThresholds(thresholds, interval, defaultThresholds = thresholdAuto) {\n if (thresholds === undefined) {\n return interval === undefined ? defaultThresholds : maybeRangeInterval(interval);\n }\n if (typeof thresholds === \"string\") {\n switch (thresholds.toLowerCase()) {\n case \"freedman-diaconis\":\n return thresholdFreedmanDiaconis;\n case \"scott\":\n return thresholdScott;\n case \"sturges\":\n return thresholdSturges;\n case \"auto\":\n return thresholdAuto;\n }\n return maybeUtcInterval(thresholds);\n }\n return thresholds; // pass array, count, or function to bin.thresholds\n}\n\nfunction maybeBinOutputs(outputs, inputs) {\n return maybeOutputs(outputs, inputs, maybeBinOutput);\n}\n\nfunction maybeBinOutput(name, reduce, inputs) {\n return maybeOutput(name, reduce, inputs, maybeBinEvaluator);\n}\n\nfunction maybeBinEvaluator(name, reduce, inputs) {\n return maybeEvaluator(name, reduce, inputs, maybeBinReduce);\n}\n\nfunction maybeBinReduce(reduce, value) {\n return maybeReduce(reduce, value, maybeBinReduceFallback);\n}\n\nfunction maybeBinReduceFallback(reduce) {\n switch (`${reduce}`.toLowerCase()) {\n case \"x\":\n return reduceX;\n case \"x1\":\n return reduceX1;\n case \"x2\":\n return reduceX2;\n case \"y\":\n return reduceY;\n case \"y1\":\n return reduceY1;\n case \"y2\":\n return reduceY2;\n }\n throw new Error(`invalid bin reduce: ${reduce}`);\n}\n\nfunction thresholdAuto(values, min, max) {\n return Math.min(200, thresholdScott(values, min, max));\n}\n\nfunction isTimeThresholds(t) {\n return isTimeInterval(t) || (isIterable(t) && isTemporal(t));\n}\n\nfunction bing(EX, EY) {\n return EX && EY\n ? function* (I) {\n const X = EX.bin(I); // first bin on x\n for (const [ix, [x1, x2]] of EX.entries()) {\n const Y = EY.bin(X[ix]); // then bin on y\n for (const [iy, [y1, y2]] of EY.entries()) {\n yield [Y[iy], {x1, y1, x2, y2}];\n }\n }\n }\n : EX\n ? function* (I) {\n const X = EX.bin(I);\n for (const [i, [x1, x2]] of EX.entries()) {\n yield [X[i], {x1, x2}];\n }\n }\n : function* (I) {\n const Y = EY.bin(I);\n for (const [i, [y1, y2]] of EY.entries()) {\n yield [Y[i], {y1, y2}];\n }\n };\n}\n\n// non-cumulative distribution\nfunction bin1(E, T, V) {\n T = coerceNumbers(T); // for faster bisection\n return (I) => {\n const B = E.map(() => []);\n for (const i of I) B[bisect(T, V[i]) - 1]?.push(i); // TODO quantization?\n return B;\n };\n}\n\n// cumulative distribution\nfunction bin1cp(E, T, V) {\n const bin = bin1(E, T, V);\n return (I) => {\n const B = bin(I);\n for (let i = 1, n = B.length; i < n; ++i) {\n const C = B[i - 1];\n const b = B[i];\n for (const j of C) b.push(j);\n }\n return B;\n };\n}\n\n// complementary cumulative distribution\nfunction bin1cn(E, T, V) {\n const bin = bin1(E, T, V);\n return (I) => {\n const B = bin(I);\n for (let i = B.length - 2; i >= 0; --i) {\n const C = B[i + 1];\n const b = B[i];\n for (const j of C) b.push(j);\n }\n return B;\n };\n}\n\nfunction mid1(x1, x2) {\n const m = (+x1 + +x2) / 2;\n return x1 instanceof Date ? new Date(m) : m;\n}\n\nconst reduceX = {\n reduceIndex(I, X, {x1, x2}) {\n return mid1(x1, x2);\n }\n};\n\nconst reduceY = {\n reduceIndex(I, X, {y1, y2}) {\n return mid1(y1, y2);\n }\n};\n\nconst reduceX1 = {\n reduceIndex(I, X, {x1}) {\n return x1;\n }\n};\n\nconst reduceX2 = {\n reduceIndex(I, X, {x2}) {\n return x2;\n }\n};\n\nconst reduceY1 = {\n reduceIndex(I, X, {y1}) {\n return y1;\n }\n};\n\nconst reduceY2 = {\n reduceIndex(I, X, {y2}) {\n return y2;\n }\n};\n","import {InternMap, cumsum, greatest, group, groupSort, max, min, rollup, sum} from \"d3\";\nimport {ascendingDefined, descendingDefined} from \"../defined.js\";\nimport {withTip} from \"../mark.js\";\nimport {maybeApplyInterval, maybeColumn, maybeZ, maybeZero} from \"../options.js\";\nimport {column, field, mid, one, range, valueof} from \"../options.js\";\nimport {basic} from \"./basic.js\";\nimport {exclusiveFacets} from \"./exclusiveFacets.js\";\n\nexport function stackX(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {y1, y = y1, x, ...rest} = options; // note: consumes x!\n const [transform, Y, x1, x2] = stack(y, x, \"y\", \"x\", stackOptions, rest);\n return {...transform, y1, y: Y, x1, x2, x: mid(x1, x2)};\n}\n\nexport function stackX1(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {y1, y = y1, x} = options;\n const [transform, Y, X] = stack(y, x, \"y\", \"x\", stackOptions, options);\n return {...transform, y1, y: Y, x: X};\n}\n\nexport function stackX2(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {y1, y = y1, x} = options;\n const [transform, Y, , X] = stack(y, x, \"y\", \"x\", stackOptions, options);\n return {...transform, y1, y: Y, x: X};\n}\n\nexport function stackY(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {x1, x = x1, y, ...rest} = options; // note: consumes y!\n const [transform, X, y1, y2] = stack(x, y, \"x\", \"y\", stackOptions, rest);\n return {...transform, x1, x: X, y1, y2, y: mid(y1, y2)};\n}\n\nexport function stackY1(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {x1, x = x1, y} = options;\n const [transform, X, Y] = stack(x, y, \"x\", \"y\", stackOptions, options);\n return {...transform, x1, x: X, y: Y};\n}\n\nexport function stackY2(stackOptions = {}, options = {}) {\n if (arguments.length === 1) [stackOptions, options] = mergeOptions(stackOptions);\n const {x1, x = x1, y} = options;\n const [transform, X, , Y] = stack(x, y, \"x\", \"y\", stackOptions, options);\n return {...transform, x1, x: X, y: Y};\n}\n\nexport function maybeStackX({x, x1, x2, ...options} = {}) {\n options = withTip(options, \"y\");\n if (x1 === undefined && x2 === undefined) return stackX({x, ...options});\n [x1, x2] = maybeZero(x, x1, x2);\n return {...options, x1, x2};\n}\n\nexport function maybeStackY({y, y1, y2, ...options} = {}) {\n options = withTip(options, \"x\");\n if (y1 === undefined && y2 === undefined) return stackY({y, ...options});\n [y1, y2] = maybeZero(y, y1, y2);\n return {...options, y1, y2};\n}\n\n// The reverse option is ambiguous: it is both a stack option and a basic\n// transform. If only one options object is specified, we interpret it as a\n// stack option, and therefore must remove it from the propagated options.\nfunction mergeOptions(options) {\n const {offset, order, reverse, ...rest} = options;\n return [{offset, order, reverse}, rest];\n}\n\n// This is a hint to the tooltip mark that the y1 and y2 channels (for stackY,\n// or conversely x1 and x2 for stackX) represent a stacked length, and that the\n// tooltip should therefore show y2-y1 instead of an extent.\nconst lengthy = {length: true};\n\nfunction stack(x, y = one, kx, ky, {offset, order, reverse}, options) {\n if (y === null) throw new Error(`stack requires ${ky}`);\n const z = maybeZ(options);\n const [X, setX] = maybeColumn(x);\n const [Y1, setY1] = column(y);\n const [Y2, setY2] = column(y);\n Y1.hint = Y2.hint = lengthy;\n offset = maybeOffset(offset);\n order = maybeOrder(order, offset, ky);\n return [\n basic(options, (data, facets, plotOptions) => {\n ({data, facets} = exclusiveFacets(data, facets));\n const X = x == null ? undefined : setX(maybeApplyInterval(valueof(data, x), plotOptions?.[kx]));\n const Y = valueof(data, y, Float64Array);\n const Z = valueof(data, z);\n const compare = order && order(data, X, Y, Z);\n const n = data.length;\n const Y1 = setY1(new Float64Array(n));\n const Y2 = setY2(new Float64Array(n));\n const facetstacks = [];\n for (const facet of facets) {\n const stacks = X ? Array.from(group(facet, (i) => X[i]).values()) : [facet];\n if (compare) for (const stack of stacks) stack.sort(compare);\n for (const stack of stacks) {\n let yn = 0;\n let yp = 0;\n if (reverse) stack.reverse();\n for (const i of stack) {\n const y = Y[i];\n if (y < 0) yn = Y2[i] = (Y1[i] = yn) + y;\n else if (y > 0) yp = Y2[i] = (Y1[i] = yp) + y;\n else Y2[i] = Y1[i] = yp; // NaN or zero\n }\n }\n facetstacks.push(stacks);\n }\n if (offset) offset(facetstacks, Y1, Y2, Z);\n return {data, facets};\n }),\n X,\n Y1,\n Y2\n ];\n}\n\nfunction maybeOffset(offset) {\n if (offset == null) return;\n if (typeof offset === \"function\") return offset;\n switch (`${offset}`.toLowerCase()) {\n case \"expand\":\n case \"normalize\":\n return offsetExpand;\n case \"center\":\n case \"silhouette\":\n return offsetCenter;\n case \"wiggle\":\n return offsetWiggle;\n }\n throw new Error(`unknown offset: ${offset}`);\n}\n\n// Given a single stack, returns the minimum and maximum values from the given\n// Y2 column. Note that this relies on Y2 always being the outer column for\n// diverging values.\nfunction extent(stack, Y2) {\n let min = 0,\n max = 0;\n for (const i of stack) {\n const y = Y2[i];\n if (y < min) min = y;\n if (y > max) max = y;\n }\n return [min, max];\n}\n\nfunction offsetExpand(facetstacks, Y1, Y2) {\n for (const stacks of facetstacks) {\n for (const stack of stacks) {\n const [yn, yp] = extent(stack, Y2);\n for (const i of stack) {\n const m = 1 / (yp - yn || 1);\n Y1[i] = m * (Y1[i] - yn);\n Y2[i] = m * (Y2[i] - yn);\n }\n }\n }\n}\n\nfunction offsetCenter(facetstacks, Y1, Y2) {\n for (const stacks of facetstacks) {\n for (const stack of stacks) {\n const [yn, yp] = extent(stack, Y2);\n for (const i of stack) {\n const m = (yp + yn) / 2;\n Y1[i] -= m;\n Y2[i] -= m;\n }\n }\n offsetZero(stacks, Y1, Y2);\n }\n offsetCenterFacets(facetstacks, Y1, Y2);\n}\n\nfunction offsetWiggle(facetstacks, Y1, Y2, Z) {\n for (const stacks of facetstacks) {\n const prev = new InternMap();\n let y = 0;\n for (const stack of stacks) {\n let j = -1;\n const Fi = stack.map((i) => Math.abs(Y2[i] - Y1[i]));\n const Df = stack.map((i) => {\n j = Z ? Z[i] : ++j;\n const value = Y2[i] - Y1[i];\n const diff = prev.has(j) ? value - prev.get(j) : 0;\n prev.set(j, value);\n return diff;\n });\n const Cf1 = [0, ...cumsum(Df)];\n for (const i of stack) {\n Y1[i] += y;\n Y2[i] += y;\n }\n const s1 = sum(Fi);\n if (s1) y -= sum(Fi, (d, i) => (Df[i] / 2 + Cf1[i]) * d) / s1;\n }\n offsetZero(stacks, Y1, Y2);\n }\n offsetCenterFacets(facetstacks, Y1, Y2);\n}\n\nfunction offsetZero(stacks, Y1, Y2) {\n const m = min(stacks, (stack) => min(stack, (i) => Y1[i]));\n for (const stack of stacks) {\n for (const i of stack) {\n Y1[i] -= m;\n Y2[i] -= m;\n }\n }\n}\n\nfunction offsetCenterFacets(facetstacks, Y1, Y2) {\n const n = facetstacks.length;\n if (n === 1) return;\n const facets = facetstacks.map((stacks) => stacks.flat());\n const m = facets.map((I) => (min(I, (i) => Y1[i]) + max(I, (i) => Y2[i])) / 2);\n const m0 = min(m);\n for (let j = 0; j < n; j++) {\n const p = m0 - m[j];\n for (const i of facets[j]) {\n Y1[i] += p;\n Y2[i] += p;\n }\n }\n}\n\nfunction maybeOrder(order, offset, ky) {\n if (order === undefined && offset === offsetWiggle) return orderInsideOut(ascendingDefined);\n if (order == null) return;\n if (typeof order === \"string\") {\n const negate = order.startsWith(\"-\");\n const compare = negate ? descendingDefined : ascendingDefined;\n switch ((negate ? order.slice(1) : order).toLowerCase()) {\n case \"value\":\n case ky:\n return orderY(compare);\n case \"z\":\n return orderZ(compare);\n case \"sum\":\n return orderSum(compare);\n case \"appearance\":\n return orderAppearance(compare);\n case \"inside-out\":\n return orderInsideOut(compare);\n }\n return orderAccessor(field(order));\n }\n if (typeof order === \"function\") return (order.length === 1 ? orderAccessor : orderComparator)(order);\n if (Array.isArray(order)) return orderGiven(order);\n throw new Error(`invalid order: ${order}`);\n}\n\n// by value\nfunction orderY(compare) {\n return (data, X, Y) => (i, j) => compare(Y[i], Y[j]);\n}\n\n// by location\nfunction orderZ(compare) {\n return (data, X, Y, Z) => (i, j) => compare(Z[i], Z[j]);\n}\n\n// by sum of value (a.k.a. “ascending”)\nfunction orderSum(compare) {\n return orderZDomain(compare, (data, X, Y, Z) =>\n groupSort(\n range(data),\n (I) => sum(I, (i) => Y[i]),\n (i) => Z[i]\n )\n );\n}\n\n// by x = argmax of value\nfunction orderAppearance(compare) {\n return orderZDomain(compare, (data, X, Y, Z) =>\n groupSort(\n range(data),\n (I) => X[greatest(I, (i) => Y[i])],\n (i) => Z[i]\n )\n );\n}\n\n// by x = argmax of value, but rearranged inside-out by alternating series\n// according to the sign of a running divergence of sums\nfunction orderInsideOut(compare) {\n return orderZDomain(compare, (data, X, Y, Z) => {\n const I = range(data);\n const K = groupSort(\n I,\n (I) => X[greatest(I, (i) => Y[i])],\n (i) => Z[i]\n );\n const sums = rollup(\n I,\n (I) => sum(I, (i) => Y[i]),\n (i) => Z[i]\n );\n const Kp = [],\n Kn = [];\n let s = 0;\n for (const k of K) {\n if (s < 0) {\n s += sums.get(k);\n Kp.push(k);\n } else {\n s -= sums.get(k);\n Kn.push(k);\n }\n }\n return Kn.reverse().concat(Kp);\n });\n}\n\nfunction orderAccessor(f) {\n return (data) => {\n const O = valueof(data, f);\n return (i, j) => ascendingDefined(O[i], O[j]);\n };\n}\n\nfunction orderComparator(f) {\n return (data) => (i, j) => f(data[i], data[j]);\n}\n\nfunction orderGiven(domain) {\n return orderZDomain(ascendingDefined, () => domain);\n}\n\n// Given an ordering (domain) of distinct values in z that can be derived from\n// the data, returns a comparator that can be used to sort stacks. Note that\n// this is a series order: it will be consistent across stacks.\nfunction orderZDomain(compare, domain) {\n return (data, X, Y, Z) => {\n if (!Z) throw new Error(\"missing channel: z\");\n const map = new InternMap(domain(data, X, Y, Z).map((d, i) => [d, i]));\n return (i, j) => compare(map.get(Z[i]), map.get(Z[j]));\n };\n}\n","import {reindex, slice} from \"../options.js\";\n\nexport function exclusiveFacets(data, facets) {\n if (facets.length === 1) return {data, facets}; // only one facet; trivially exclusive\n\n const n = data.length;\n const O = new Uint8Array(n);\n let overlaps = 0;\n\n // Count the number of overlapping indexes across facets.\n for (const facet of facets) {\n for (const i of facet) {\n if (O[i]) ++overlaps;\n O[i] = 1;\n }\n }\n\n // Do nothing if the facets are already exclusive.\n if (overlaps === 0) return {data, facets}; // facets are exclusive\n\n // For each overlapping index (duplicate), assign a new unique index at the\n // end of the existing array, duplicating the datum. For example, [[0, 1, 2],\n // [2, 1, 3]] would become [[0, 1, 2], [4, 5, 3]]. Also attach a reindex to\n // the data to preserve the association of channel values specified as arrays.\n data = slice(data);\n const R = (data[reindex] = new Uint32Array(n + overlaps));\n facets = facets.map((facet) => slice(facet, Uint32Array));\n let j = n;\n O.fill(0);\n for (const facet of facets) {\n for (let k = 0, m = facet.length; k < m; ++k) {\n const i = facet[k];\n if (O[i]) (facet[k] = j), (data[j] = data[i]), (R[j] = i), ++j;\n else R[i] = i;\n O[i] = 1;\n }\n }\n\n return {data, facets};\n}\n","import {geoPath, line as shapeLine} from \"d3\";\nimport {create} from \"../context.js\";\nimport {curveAuto, maybeCurveAuto} from \"../curve.js\";\nimport {Mark} from \"../mark.js\";\nimport {applyGroupedMarkers, markers} from \"../marker.js\";\nimport {coerceNumbers, indexOf, identity, maybeTuple, maybeZ} from \"../options.js\";\nimport {\n applyDirectStyles,\n applyIndirectStyles,\n applyTransform,\n applyGroupedChannelStyles,\n groupIndex\n} from \"../style.js\";\nimport {maybeDenseIntervalX, maybeDenseIntervalY} from \"../transforms/bin.js\";\n\nconst defaults = {\n ariaLabel: \"line\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 1.5,\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n strokeMiterlimit: 1\n};\n\nexport class Line extends Mark {\n constructor(data, options = {}) {\n const {x, y, z, curve, tension} = options;\n super(\n data,\n {\n x: {value: x, scale: \"x\"},\n y: {value: y, scale: \"y\"},\n z: {value: maybeZ(options), optional: true}\n },\n options,\n defaults\n );\n this.z = z;\n this.curve = maybeCurveAuto(curve, tension);\n markers(this, options);\n }\n filter(index) {\n return index;\n }\n project(channels, values, context) {\n // For the auto curve, projection is handled at render.\n if (this.curve !== curveAuto) {\n super.project(channels, values, context);\n }\n }\n render(index, scales, channels, dimensions, context) {\n const {x: X, y: Y} = channels;\n const {curve} = this;\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyTransform, this, scales)\n .call((g) =>\n g\n .selectAll()\n .data(groupIndex(index, [X, Y], this, channels))\n .enter()\n .append(\"path\")\n .call(applyDirectStyles, this)\n .call(applyGroupedChannelStyles, this, channels)\n .call(applyGroupedMarkers, this, channels, context)\n .attr(\n \"d\",\n curve === curveAuto && context.projection\n ? sphereLine(context.projection, X, Y)\n : shapeLine()\n .curve(curve)\n .defined((i) => i >= 0)\n .x((i) => X[i])\n .y((i) => Y[i])\n )\n )\n .node();\n }\n}\n\nfunction sphereLine(projection, X, Y) {\n const path = geoPath(projection);\n X = coerceNumbers(X);\n Y = coerceNumbers(Y);\n return (I) => {\n let line = [];\n const lines = [line];\n for (const i of I) {\n // Check for undefined value; see groupIndex.\n if (i === -1) {\n line = [];\n lines.push(line);\n } else {\n line.push([X[i], Y[i]]);\n }\n }\n return path({type: \"MultiLineString\", coordinates: lines});\n };\n}\n\nexport function line(data, {x, y, ...options} = {}) {\n [x, y] = maybeTuple(x, y);\n return new Line(data, {...options, x, y});\n}\n\nexport function lineX(data, {x = identity, y = indexOf, ...options} = {}) {\n return new Line(data, maybeDenseIntervalY({...options, x, y}));\n}\n\nexport function lineY(data, {x = indexOf, y = identity, ...options} = {}) {\n return new Line(data, maybeDenseIntervalX({...options, x, y}));\n}\n","import {create} from \"../context.js\";\nimport {Mark} from \"../mark.js\";\nimport {hasXY, identity, indexOf, number} from \"../options.js\";\nimport {isCollapsed} from \"../scales.js\";\nimport {applyAttr, applyChannelStyles, applyDirectStyles, applyIndirectStyles, applyTransform} from \"../style.js\";\nimport {impliedString} from \"../style.js\";\nimport {maybeIdentityX, maybeIdentityY} from \"../transforms/identity.js\";\nimport {maybeTrivialIntervalX, maybeTrivialIntervalY} from \"../transforms/interval.js\";\nimport {maybeStackX, maybeStackY} from \"../transforms/stack.js\";\n\nconst defaults = {\n ariaLabel: \"rect\"\n};\n\nexport class Rect extends Mark {\n constructor(data, options = {}) {\n const {\n x1,\n y1,\n x2,\n y2,\n inset = 0,\n insetTop = inset,\n insetRight = inset,\n insetBottom = inset,\n insetLeft = inset,\n rx,\n ry\n } = options;\n super(\n data,\n {\n x1: {value: x1, scale: \"x\", optional: true},\n y1: {value: y1, scale: \"y\", optional: true},\n x2: {value: x2, scale: \"x\", optional: true},\n y2: {value: y2, scale: \"y\", optional: true}\n },\n options,\n defaults\n );\n this.insetTop = number(insetTop);\n this.insetRight = number(insetRight);\n this.insetBottom = number(insetBottom);\n this.insetLeft = number(insetLeft);\n this.rx = impliedString(rx, \"auto\"); // number or percentage\n this.ry = impliedString(ry, \"auto\");\n }\n render(index, scales, channels, dimensions, context) {\n const {x, y} = scales;\n const {x1: X1, y1: Y1, x2: X2, y2: Y2} = channels;\n const {marginTop, marginRight, marginBottom, marginLeft, width, height} = dimensions;\n const {projection} = context;\n const {insetTop, insetRight, insetBottom, insetLeft, rx, ry} = this;\n return create(\"svg:g\", context)\n .call(applyIndirectStyles, this, dimensions, context)\n .call(applyTransform, this, {x: X1 && X2 && x, y: Y1 && Y2 && y}, 0, 0)\n .call((g) =>\n g\n .selectAll()\n .data(index)\n .enter()\n .append(\"rect\")\n .call(applyDirectStyles, this)\n .attr(\n \"x\",\n X1 && X2 && (projection || !isCollapsed(x))\n ? (i) => Math.min(X1[i], X2[i]) + insetLeft\n : marginLeft + insetLeft\n )\n .attr(\n \"y\",\n Y1 && Y2 && (projection || !isCollapsed(y))\n ? (i) => Math.min(Y1[i], Y2[i]) + insetTop\n : marginTop + insetTop\n )\n .attr(\n \"width\",\n X1 && X2 && (projection || !isCollapsed(x))\n ? (i) => Math.max(0, Math.abs(X2[i] - X1[i]) - insetLeft - insetRight)\n : width - marginRight - marginLeft - insetRight - insetLeft\n )\n .attr(\n \"height\",\n Y1 && Y2 && (projection || !isCollapsed(y))\n ? (i) => Math.max(0, Math.abs(Y1[i] - Y2[i]) - insetTop - insetBottom)\n : height - marginTop - marginBottom - insetTop - insetBottom\n )\n .call(applyAttr, \"rx\", rx)\n .call(applyAttr, \"ry\", ry)\n .call(applyChannelStyles, this, channels)\n )\n .node();\n }\n}\n\nexport function rect(data, options) {\n return new Rect(data, maybeTrivialIntervalX(maybeTrivialIntervalY(options)));\n}\n\nexport function rectX(data, options = {}) {\n if (!hasXY(options)) options = {...options, y: indexOf, x2: identity, interval: 1};\n return new Rect(data, maybeStackX(maybeTrivialIntervalY(maybeIdentityX(options))));\n}\n\nexport function rectY(data, options = {}) {\n if (!hasXY(options)) options = {...options, x: indexOf, y2: identity, interval: 1};\n return new Rect(data, maybeStackY(maybeTrivialIntervalX(maybeIdentityY(options))));\n}\n","import {hasX, hasY, identity} from \"../options.js\";\n\nexport function maybeIdentityX(options = {}) {\n return hasX(options) ? options : {...options, x: identity};\n}\n\nexport function maybeIdentityY(options = {}) {\n return hasY(options) ? options : {...options, y: identity};\n}\n","\nimport {html, css} from 'lit';\nimport * as Plot from '@observablehq/plot';\n\n// Special Web Worker import for rollup-plugin-web-worker-loader\nimport HTDFitWorker from 'web-worker:./htd-fit-worker'; /* eslint-disable-line import/no-unresolved */\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n HTDFit element\n <htd-fit>\n\n Attributes:\n interactive: true/false\n\n*/\nexport default class HTDFit extends DiscountableElement {\n static get properties() {\n return {\n };\n }\n\n constructor() {\n super();\n\n this.k = 0.05;\n\n this.choices = [];\n this.samples = null;\n\n this.working = false;\n this.queued = false;\n this.worker = new HTDFitWorker();\n\n this.worker.onmessage = (event) => {\n this.working = false;\n this.samples = event.data.samples;\n this.k = event.data.results.k;\n this.requestUpdate();\n\n this.dispatchEvent(new CustomEvent('htd-fit-update', {\n detail: {\n k: this.k,\n },\n bubbles: true,\n }));\n\n if (this.queued) {\n this.fit();\n }\n };\n\n this.fit();\n }\n\n fit() {\n if (!this.working) {\n this.worker.postMessage(this.choices);\n this.working = true;\n this.queued = false;\n } else {\n this.queued = true;\n }\n }\n\n clear() {\n this.choices = [];\n\n this.fit();\n }\n\n get(name = 'default') {\n const choice = this.choices.find((item) => {\n return (item.name === name);\n });\n\n return (choice === undefined) ? null : choice;\n }\n\n set(as, ds, al, dl, response, name = '', label = '') {\n const choice = this.choices.find((item) => {\n return (item.name === name);\n });\n if (choice === undefined) {\n this.choices.push({\n as: as,\n ds: ds,\n al: al,\n dl: dl,\n response: response,\n name: name,\n label: label,\n });\n } else {\n choice.as = as;\n choice.ds = ds;\n choice.al = al;\n choice.dl = dl;\n choice.response = response;\n choice.label = label;\n }\n\n this.fit();\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n /* :host {\n display: inline-block;\n } */\n\n figure {\n margin: 0.625rem;\n }\n\n figure h2 {\n margin: 0.25rem 0;\n\n font-size: 1.125rem;\n font-weight: 600;\n }\n\n .trace,\n .hist {\n display: inline-block;\n }\n `,\n ];\n }\n\n render() {\n return html`\n <div>\n <div>After ${this.choices.length} trials:</div>\n <div>Current:\n <var class=\"math-var k\">k</var> = ${this.k.toFixed(2)}\n </div>\n <div class=\"param\">\n <div class=\"trace k\"></div>\n <div class=\"hist k\"></div>\n </div>\n <div class=\"param\">\n <div class=\"trace luce\"></div>\n <div class=\"hist luce\"></div>\n </div>\n </div>\n `;\n }\n\n plotParam(param) {\n this.shadowRoot.querySelector(`.hist.${param}`).replaceChildren(\n Plot.plot({\n title: `Posterior of ${param}`,\n x: {label: `${param}`},\n width: 320,\n height: 240,\n style: 'font-size: 0.75rem; font-family: var(---font-family-base);',\n marks: [\n Plot.rectY(\n this.samples[param],\n Plot.binX({y: 'count'}, {x: Plot.identity}),\n ),\n ],\n }),\n );\n\n this.shadowRoot.querySelector(`.trace.${param}`).replaceChildren(\n Plot.plot({\n title: `Traceplot of ${param}`,\n x: {label: 'Samples'},\n y: {label: `${param}`},\n width: 320,\n height: 240,\n style: 'font-size: 0.75rem; font-family: var(---font-family-base);',\n marks: [\n Plot.lineY(\n this.samples[param],\n ),\n ],\n }),\n );\n }\n\n update(changedProperties) {\n super.update(changedProperties);\n\n if (this.samples !== null) {\n this.plotParam('k');\n this.plotParam('luce');\n }\n }\n}\n\ncustomElements.define('htd-fit', HTDFit);\n","\nimport {html, css} from 'lit';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n ITCOption element\n <itc-option>\n\n Attributes:\n State\n Amount, Delay\n*/\nexport default class ITCOption extends DiscountableElement {\n static get properties() {\n return {\n state: {\n attribute: 'state',\n type: String,\n reflect: true,\n },\n\n a: {\n attribute: 'amount',\n type: Number,\n reflect: true,\n },\n d: {\n attribute: 'delay',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n this.states = ['choice', 'fixation', 'blank']; // Possible states\n this.state = 'choice'; // Current state\n\n this.a = 0;\n this.d = 0;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n \n width: 10rem;\n height: 10rem;\n }\n\n .holder {\n display: flex;\n \n flex-flow: column nowrap;\n\n align-items: center;\n justify-content: center;\n\n width: 100%;\n height: 100%;\n overflow: visible;\n \n\n background: var(---color-element-background);\n border: 2px solid var(---color-element-emphasis);\n border-radius: 50%;\n }\n\n .interactive,\n .static {\n font-size: 1.75rem;\n }\n\n .interactive {\n --decidables-spinner-font-size: 1.75rem;\n }\n\n .static {\n padding: 0 0.25rem;\n \n border-radius: var(---border-radius);\n }\n\n .amount {\n --decidables-spinner-prefix: \"$\";\n background-color: var(---color-a-light);\n }\n\n .amount.interactive {\n --decidables-spinner-input-width: 4rem;\n }\n\n .delay {\n background-color: var(---color-d-light);\n }\n \n .delay.interactive {\n --decidables-spinner-input-width: 6.75rem;\n --decidables-spinner-postfix: \"days\";\n --decidables-spinner-postfix-padding: 3.75rem;\n }\n `,\n ];\n }\n\n sendEvent() {\n this.dispatchEvent(new CustomEvent('itc-option-change', {\n detail: {\n a: this.a,\n d: this.d,\n },\n bubbles: true,\n }));\n }\n\n aInput(event) {\n this.a = parseFloat(event.target.value);\n this.sendEvent();\n }\n\n dInput(event) {\n this.d = parseFloat(event.target.value);\n this.sendEvent();\n }\n\n render() { /* eslint-disable-line class-methods-use-this */\n return html`\n <div class=\"holder\">\n ${(this.state === 'choice')\n ? this.interactive\n ? html`<decidables-spinner\n class=\"amount interactive\"\n ?disabled=${!this.interactive}\n step=\"1\"\n .value=\"${this.a}\"\n @input=${this.aInput.bind(this)}\n ></decidables-spinner>`\n : html`<div\n class=\"amount static\"\n >$${this.a}</div>`\n : ''\n }\n ${(this.state === 'choice')\n ? html`<div class=\"in\">in</div>`\n : ''\n }\n ${(this.state === 'choice')\n ? this.interactive\n ? html`<decidables-spinner\n class=\"delay interactive\"\n ?disabled=${!this.interactive}\n min=\"0\" \n step=\"1\"\n .value=\"${this.d}\"\n @input=${this.dInput.bind(this)}\n ></decidables-spinner>`\n : html`<div\n class=\"delay static\"\n >${this.d} days</div>`\n : ''\n }\n </div>\n `;\n }\n}\n\ncustomElements.define('itc-option', ITCOption);\n","\nimport {html, css} from 'lit';\n\nimport DiscountableElement from '../discountable-element';\nimport './itc-option';\n\n/*\n ITCChoice element\n <itc-choice>\n\n Attributes:\n*/\nexport default class ITCChoice extends DiscountableElement {\n static get properties() {\n return {\n state: {\n attribute: 'state',\n type: String,\n reflect: true,\n },\n\n as: {\n attribute: 'amount-ss',\n type: Number,\n reflect: true,\n },\n ds: {\n attribute: 'delay-ss',\n type: Number,\n reflect: true,\n },\n al: {\n attribute: 'amount-ll',\n type: Number,\n reflect: true,\n },\n dl: {\n attribute: 'delay-ll',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n this.states = ['choice', 'fixation', 'blank']; // Possible states\n this.state = 'choice'; // Current state\n\n this.as = 10;\n this.ds = 5;\n this.al = 40;\n this.dl = 30;\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n }\n\n .holder {\n user-select: none;\n }\n\n .holder > * {\n vertical-align: middle;\n }\n\n .query {\n margin: 0 0.5rem;\n\n font-family: var(--font-family-code);\n font-size: 1.75rem;\n }\n\n itc-option {\n width: 10rem;\n height: 10rem;\n }\n `,\n ];\n }\n\n sendEvent() {\n this.dispatchEvent(new CustomEvent('itc-choice-change', {\n detail: {\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n },\n bubbles: true,\n }));\n }\n\n ssChange(event) {\n this.as = parseFloat(event.detail.a);\n this.ds = parseFloat(event.detail.d);\n this.sendEvent();\n }\n\n llChange(event) {\n this.al = parseFloat(event.detail.a);\n this.dl = parseFloat(event.detail.d);\n this.sendEvent();\n }\n\n render() {\n return html`\n <div class=\"holder\">\n <itc-option \n state=${this.state}\n ?interactive=${this.interactive}\n amount=\"${this.as}\"\n delay=\"${this.ds}\"\n @itc-option-change=${this.ssChange.bind(this)}>\n </itc-option><span class=\"query\"\n >${(this.state === 'choice') ? '?' : (this.state === 'fixation') ? '+' : html`∙`}</span\n ><itc-option \n state=${this.state}\n ?interactive=${this.interactive}\n amount=\"${this.al}\"\n delay=\"${this.dl}\"\n @itc-option-change=${this.llChange.bind(this)}>\n </itc-option>\n </div>`;\n }\n}\n\ncustomElements.define('itc-choice', ITCChoice);\n","\nimport {html, css} from 'lit';\nimport * as d3 from 'd3';\n\nimport DiscountableElement from '../discountable-element';\nimport './itc-choice';\n\n/*\n ITCTask element\n <itc-task>\n\n Attributes:\n Dots; Coherence;\n # Direction, Speed, Lifetime\n*/\nexport default class ITCTask extends DiscountableElement {\n static get properties() {\n return {\n duration: {\n attribute: 'duration',\n type: Number,\n reflect: true,\n },\n iti: {\n attribute: 'iti',\n type: Number,\n reflect: true,\n },\n trials: {\n attribute: 'trials',\n type: Number,\n reflect: true,\n },\n running: {\n attribute: 'running',\n type: Boolean,\n reflect: true,\n },\n\n state: {\n attribute: false,\n type: String,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n\n // Attributes\n this.duration = 2000; // Duration of stimulus in milliseconds\n this.iti = 2000; // Duration of inter-trial interval in milliseconds\n this.trials = 5; // Number of trials per block\n this.running = false; // Currently executing block of trials\n\n // Properties\n this.states = ['resetted', 'iti', 'stimulus', 'ended']; // Possible states of task\n this.state = 'resetted'; // Current state of task\n\n // Decision parameters\n this.range = {};\n this.range.as = {start: 10, stop: 20, step: 1}; // Amount SS\n this.range.ds = {start: 10, stop: 40, step: 1}; // Delay SS\n this.range.al = {start: 20, stop: 40, step: 1}; // Amount LL\n this.range.dl = {start: 50, stop: 80, step: 1}; // Delay LL\n\n this.range.as.values = d3.range(\n this.range.as.start,\n this.range.as.stop + 0.01,\n this.range.as.step,\n );\n this.range.ds.values = d3.range(\n this.range.ds.start,\n this.range.ds.stop + 0.01,\n this.range.ds.step,\n );\n this.range.al.values = d3.range(\n this.range.al.start,\n this.range.al.stop + 0.01,\n this.range.al.step,\n );\n this.range.dl.values = d3.range(\n this.range.dl.start,\n this.range.dl.stop + 0.01,\n this.range.dl.step,\n );\n\n // Private\n this.firstUpdate = true;\n\n this.as = 0;\n this.ds = 0;\n this.al = 0;\n this.dl = 0;\n\n this.trial = 0; // Count of current trial\n\n this.baseTime = 0; // Real time, in milliseconds, that the current block started\n this.pauseTime = 0; // Real time, in milliseconds, that block was paused at\n this.startTime = 0; // Virtual time, in milliseconds, that current stage of trial started\n this.lastTime = 0; // Virtual time, in milliseconds, of the most recent frame\n\n this.runner = undefined; // D3 Interval for frame timing\n }\n\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n display: inline-block;\n }\n `,\n ];\n }\n\n render() {\n return html`\n <div class=\"holder\">\n <itc-choice \n state=\"${(this.state === 'stimulus')\n ? 'choice'\n : (this.state === 'iti')\n ? 'fixation'\n : 'blank'}\"\n amount-ss=\"${this.as}\"\n delay-ss=\"${this.ds}\"\n amount-ll=\"${this.al}\"\n delay-ll=\"${this.dl}\">\n </itc-choice>\n </div>`;\n }\n\n update(changedProperties) {\n super.update(changedProperties);\n\n // Start or stop trial block\n if (this.firstUpdate || changedProperties.has('running')) {\n if (this.running) {\n // (Re)Start\n if (this.pauseTime) {\n // Shift timeline forward as if paused time never happened\n this.baseTime += (d3.now() - this.pauseTime);\n this.pauseTime = 0;\n }\n this.runner = d3.interval(this.run.bind(this), 20); // FIXME??\n } else if (this.runner !== undefined) {\n // Pause\n this.runner.stop();\n this.pauseTime = d3.now();\n }\n }\n\n this.firstUpdate = false;\n }\n\n reset() {\n this.runner.stop();\n this.running = false;\n this.trial = 0;\n this.state = 'resetted';\n\n this.as = 0;\n this.ds = 0;\n this.al = 0;\n this.dl = 0;\n\n this.baseTime = 0;\n this.pauseTime = 0;\n this.startTime = 0;\n this.lastTime = 0;\n }\n\n run(/* elapsed */) {\n const realTime = d3.now();\n const currentTime = (this.baseTime) ? (realTime - this.baseTime) : 0;\n const elapsedTime = (this.baseTime) ? (currentTime - this.startTime) : 0;\n this.lastTime = currentTime;\n if (this.state === 'resetted') {\n // Start block with an ITI\n this.state = 'iti';\n this.baseTime = realTime;\n this.startTime = 0;\n this.dispatchEvent(new CustomEvent('itc-block-start', {\n detail: {\n trials: this.trials,\n },\n bubbles: true,\n }));\n } else if ((this.state === 'iti') && (elapsedTime >= this.iti)) {\n // Start new trial with a stimulus\n this.trial += 1;\n this.state = 'stimulus';\n this.startTime = currentTime;\n // Determine trial\n this.as = this.range.as.values[Math.floor(Math.random() * this.range.as.values.length)];\n this.ds = this.range.ds.values[Math.floor(Math.random() * this.range.ds.values.length)];\n this.al = this.range.al.values[Math.floor(Math.random() * this.range.al.values.length)];\n this.dl = this.range.dl.values[Math.floor(Math.random() * this.range.dl.values.length)];\n this.dispatchEvent(new CustomEvent('itc-trial-start', {\n detail: {\n trials: this.trials,\n duration: this.duration,\n iti: this.iti,\n trial: this.trial,\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n },\n bubbles: true,\n }));\n } else if ((this.state === 'stimulus') && (elapsedTime >= this.duration)) {\n // Stimulus is over, end of trial\n this.dispatchEvent(new CustomEvent('itc-trial-end', {\n detail: {\n trials: this.trials,\n duration: this.duration,\n iti: this.iti,\n trial: this.trial,\n as: this.as,\n ds: this.ds,\n al: this.al,\n dl: this.dl,\n },\n bubbles: true,\n }));\n if (this.trial >= this.trials) {\n // End of block\n this.runner.stop();\n this.running = false;\n this.state = 'ended';\n this.baseTime = 0;\n this.pauseTime = 0;\n this.startTime = 0;\n this.lastTime = 0;\n this.dispatchEvent(new CustomEvent('itc-block-end', {\n detail: {\n trials: this.trial,\n },\n bubbles: true,\n }));\n } else {\n // ITI\n this.state = 'iti';\n this.startTime = currentTime;\n }\n }\n }\n}\n\ncustomElements.define('itc-task', ITCTask);\n","import {Timer, now} from \"./timer.js\";\n\nexport default function(callback, delay, time) {\n var t = new Timer, total = delay;\n if (delay == null) return t.restart(callback, delay, time), t;\n t._restart = t.restart;\n t.restart = function(callback, delay, time) {\n delay = +delay, time = time == null ? now() : +time;\n t._restart(function tick(elapsed) {\n elapsed += total;\n t._restart(tick, total += delay, time);\n callback(elapsed);\n }, delay, time);\n }\n t.restart(callback, delay, time);\n return t;\n}\n","\nimport {html} from 'lit';\n\nimport '@decidables/decidables-elements/spinner';\nimport HTDMath from '@decidables/discountable-math';\n\nimport HTDEquation from './htd-equation';\n\n/*\n HTDEquationADK2V element\n <htd-equation-adk2v>\n\n Attributes:\n amount, delay, k, value;\n*/\nexport default class HTDEquationADK2V extends HTDEquation {\n static get properties() {\n return {\n a: {\n attribute: 'amount',\n type: Number,\n reflect: true,\n },\n d: {\n attribute: 'delay',\n type: Number,\n reflect: true,\n },\n k: {\n attribute: 'k',\n type: Number,\n reflect: true,\n },\n\n v: {\n attribute: false,\n type: Number,\n reflect: false,\n },\n };\n }\n\n constructor() {\n super();\n this.a = 100;\n this.d = 30;\n this.k = 0.05;\n this.alignState();\n }\n\n alignState() {\n this.v = HTDMath.adk2v(this.a, this.d, this.k);\n }\n\n sendEvent() {\n this.dispatchEvent(new CustomEvent('htd-equation-adk2v-change', {\n detail: {\n a: this.a,\n d: this.d,\n k: this.k,\n v: this.v,\n },\n bubbles: true,\n }));\n }\n\n aInput(event) {\n this.a = parseFloat(event.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n dInput(event) {\n this.d = parseFloat(event.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n kInput(event) {\n this.k = parseFloat(event.target.value);\n this.alignState();\n this.sendEvent();\n }\n\n render() {\n this.alignState();\n let a;\n let d;\n let k;\n let v;\n if (this.numeric) {\n a = html`<decidables-spinner class=\"a bottom\" ?disabled=${!this.interactive} step=\"1\" .value=\"${this.a}\" @input=${this.aInput.bind(this)}>\n <var class=\"math-var\">A</var>\n </decidables-spinner>`;\n d = html`<decidables-spinner class=\"d bottom\" ?disabled=${!this.interactive} min=\"0\" step=\"1\" .value=\"${this.d}\" @input=${this.dInput.bind(this)}>\n <var class=\"math-var\">D</var>\n </decidables-spinner>`;\n k = html`<decidables-spinner class=\"k bottom\" ?disabled=${!this.interactive} min=\"0\" max=\"100\" step=\".001\" .value=\"${this.k}\" @input=${this.kInput.bind(this)}>\n <var class=\"math-var\">k</var>\n </decidables-spinner>`;\n v = html`<decidables-spinner class=\"v bottom\" disabled step=\".001\" .value=\"${+this.v.toFixed(3)}\">\n <var class=\"math-var\">V</var>\n </decidables-spinner>`;\n } else {\n a = html`<var class=\"math-var a\">A</var>`;\n d = html`<var class=\"math-var d\">D</var>`;\n k = html`<var class=\"math-var k\">k</var>`;\n v = html`<var class=\"math-var v\">V</var>`;\n }\n const equation = html`\n <tr>\n <td rowspan=\"2\">\n ${v}<span class=\"equals\">=</span>\n </td>\n <td class=\"underline\">\n ${a}\n </td>\n </tr>\n <tr>\n <td class=\"\">\n <span class=\"paren tight\">(</span>1<span class=\"plus\">+</span>${k}${d}<span class=\"paren tight\">)</span>\n </td>\n </tr>`;\n return html`\n <div class=\"holder\">\n <table class=\"equation\">\n <tbody>\n ${equation}\n </tbody>\n </table>\n </div>`;\n }\n}\n\ncustomElements.define('htd-equation-adk2v', HTDEquationADK2V);\n","\nimport {html, css} from 'lit';\n\nimport DiscountableElement from '../discountable-element';\n\n/*\n CPTExample Base Class - Not intended for instantiation!\n <sdt-example>\n*/\nexport default class HTDExample extends DiscountableElement {\n static get styles() {\n return [\n super.styles,\n css`\n :host {\n ---border: var(--border, 1px solid var(---color-border));\n display: inline-block;\n\n margin-bottom: 1rem;\n }\n\n .holder {\n display: flex;\n }\n\n .body {\n display: flex;\n\n flex-wrap: wrap;\n\n align-items: center;\n justify-content: left;\n\n padding: 0.625rem;\n\n border: var(---border);\n border-radius: 0.25rem;\n }\n\n .body ::slotted(*) {\n margin: 0.625rem;\n }\n\n /* HACK: Sibling selectors not working with ::slotted */\n /* .body > rdk-task + sdt-response,\n ::slotted(rdk-task) + ::slotted(sdt-response) { */\n /* .body ::slotted(sdt-response) {\n margin-left: 0;\n } */\n\n /* HACK: Sibling selectors not working with ::slotted */\n /* .body > sdt-control + rdk-task,\n ::slotted(sdt-control) + ::slotted(rdk-task) {\n margin-left: 0;\n } */\n /* .body ::slotted(rdk-task) {\n margin-left: 0;\n } */\n `,\n ];\n }\n\n render() { /* eslint-disable-line class-methods-use-this */\n return html`\n <div class=\"holder\">\n <div class=\"body\">\n <slot>Empty!</slot>\n </div>\n </div>`;\n }\n}\n\ncustomElements.define('htd-example', HTDExample);\n","\n// import HTDMath from '@decidables/discountable-math';\n\nimport HTDExample from './htd-example';\n\n/*\n HTDExampleHuman element\n <htd-example-human>\n*/\nexport default class HTDExampleHuman extends HTDExample {\n firstUpdated(/* changedProperties */) {\n this.discountableControl = this.querySelector('discountable-control');\n this.itcTask = this.querySelector('itc-task');\n this.discountableResponse = this.querySelector('discountable-response');\n\n this.htdFit = this.querySelector('htd-fit');\n this.htdCurves = this.querySelector('htd-curves');\n\n if (this.discountableControl) {\n if (this.discountableControl.hasAttribute('trials')) {\n this.discountableControl.addEventListener('discountable-control-trials', (event) => {\n if (this.itcTask) {\n this.itcTask.trials = event.detail.trials;\n }\n\n if (this.discountableResponse) {\n this.discountableResponse.trialTotal = event.detail.trials;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('duration')) {\n this.discountableControl.addEventListener('discountable-control-duration', (event) => {\n if (this.itcTask) {\n this.itcTask.duration = event.detail.duration;\n this.itcTask.iti = event.detail.duration;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('run')) {\n this.discountableControl.addEventListener('discountable-control-run', (/* event */) => {\n if (this.itcTask) {\n this.itcTask.running = true;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('pause')) {\n this.discountableControl.addEventListener('discountable-control-pause', (/* event */) => {\n if (this.itcTask) {\n this.itcTask.running = false;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('reset')) {\n this.discountableControl.addEventListener('discountable-control-reset', (/* event */) => {\n if (this.itcTask) {\n this.itcTask.reset();\n }\n\n if (this.discountableResponse) {\n this.discountableResponse.reset();\n }\n\n if (this.htdFit) {\n this.htdFit.clear();\n }\n\n if (this.htdCurves) {\n this.htdCurves.clearOptions();\n }\n });\n }\n }\n\n if (this.itcTask) {\n if (this.discountableResponse) {\n this.discountableResponse.trialTotal = this.itcTask.trials;\n }\n\n this.itcTask.addEventListener('itc-trial-start', (event) => {\n if (this.discountableResponse) {\n this.discountableResponse.start(\n event.detail.as,\n event.detail.ds,\n event.detail.al,\n event.detail.dl,\n event.detail.trial,\n );\n }\n\n if (this.htdCurves) {\n this.htdCurves.setOption(\n event.detail.as,\n event.detail.ds,\n 'smaller-sooner',\n 's',\n );\n this.htdCurves.setOption(\n event.detail.al,\n event.detail.dl,\n 'larger-later',\n 'l',\n );\n }\n });\n\n this.itcTask.addEventListener('itc-trial-end', (/* event */) => {\n if (this.discountableResponse) {\n this.discountableResponse.stop();\n }\n\n if (this.htdCurves) {\n this.htdCurves.removeOption('smaller-sooner');\n this.htdCurves.removeOption('larger-later');\n }\n });\n\n this.itcTask.addEventListener('itc-block-end', (/* event */) => {\n if (this.discountableControl) {\n this.discountableControl.complete();\n }\n });\n }\n\n if (this.discountableResponse) {\n this.discountableResponse.addEventListener('discountable-response', (event) => {\n if (this.htdFit) {\n this.htdFit.set(\n event.detail.as,\n event.detail.ds,\n event.detail.al,\n event.detail.dl,\n event.detail.response,\n event.detail.trial.toString(),\n event.detail.trial.toString(),\n );\n }\n });\n }\n\n if (this.htdFit) {\n this.htdFit.addEventListener('htd-fit-update', (event) => {\n if (this.htdCurves) {\n this.htdCurves.k = event.detail.k;\n }\n });\n }\n }\n}\n\ncustomElements.define('htd-example-human', HTDExampleHuman);\n","\nimport HTDExample from './htd-example';\n\n/*\n HTDExampleInteractive element\n <htd-example-interactive>\n*/\nexport default class HTDExampleInteractive extends HTDExample {\n static get properties() {\n return {\n as: {\n attribute: 'amount-ss',\n type: Number,\n reflect: true,\n },\n ds: {\n attribute: 'delay-ss',\n type: Number,\n reflect: true,\n },\n al: {\n attribute: 'amount-ll',\n type: Number,\n reflect: true,\n },\n dl: {\n attribute: 'delay-ll',\n type: Number,\n reflect: true,\n },\n\n k: {\n attribute: 'k',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n this.as = 10;\n this.ds = 1;\n this.al = 50;\n this.dl = 40;\n this.k = 0.05;\n\n this.htdCalculation = null;\n this.htdCurves = null;\n this.itcChoice = null;\n }\n\n firstUpdated(/* changedProperties */) {\n this.htdCalculation = this.querySelector('htd-calculation');\n this.htdCurves = this.querySelector('htd-curves');\n this.itcChoice = this.querySelector('itc-choice');\n\n if (this.htdCalculation) {\n this.htdCalculation.addEventListener('htd-calculation-change', (event) => {\n this.as = event.detail.as;\n this.ds = event.detail.ds;\n this.al = event.detail.al;\n this.dl = event.detail.dl;\n\n this.k = event.detail.k;\n });\n }\n\n if (this.htdCurves) {\n this.htdCurves.addEventListener('htd-curves-change', (event) => {\n this.k = event.detail.k;\n if (event.detail.name === 'default') {\n this.as = event.detail.a;\n this.ds = event.detail.d;\n } else if (event.detail.name === 'larger-later') {\n this.al = event.detail.a;\n this.dl = event.detail.d;\n }\n });\n }\n\n if (this.itcChoice) {\n this.itcChoice.addEventListener('itc-choice-change', (event) => {\n this.as = event.detail.as;\n this.ds = event.detail.ds;\n this.al = event.detail.al;\n this.dl = event.detail.dl;\n });\n }\n\n this.requestUpdate();\n }\n\n update(changedProperties) {\n super.update(changedProperties);\n\n if (this.htdCalculation) {\n this.htdCalculation.as = this.as;\n this.htdCalculation.ds = this.ds;\n this.htdCalculation.al = this.al;\n this.htdCalculation.dl = this.dl;\n\n this.htdCalculation.k = this.k;\n }\n\n if (this.htdCurves) {\n this.htdCurves.setOption(this.as, this.ds, 'default', 's');\n this.htdCurves.setOption(this.al, this.dl, 'larger-later', 'l');\n\n this.htdCurves.k = this.k;\n }\n\n if (this.itcChoice) {\n this.itcChoice.as = this.as;\n this.itcChoice.ds = this.ds;\n this.itcChoice.al = this.al;\n this.itcChoice.dl = this.dl;\n }\n }\n}\n\ncustomElements.define('htd-example-interactive', HTDExampleInteractive);\n","\nimport HTDMath from '@decidables/discountable-math';\n\nimport HTDExample from './htd-example';\n\n/*\n HTDExampleModel element\n <htd-example-model>\n*/\nexport default class HTDExampleModel extends HTDExample {\n static get properties() {\n return {\n k: {\n attribute: 'k',\n type: Number,\n reflect: true,\n },\n };\n }\n\n constructor() {\n super();\n\n this.k = 0.2;\n\n this.discountableControl = null;\n this.discountableResponse = null;\n this.htdCalculation = null;\n this.htdCurves = null;\n this.itcTask = null;\n }\n\n firstUpdated(/* changedProperties */) {\n this.discountableControl = this.querySelector('discountable-control');\n this.discountableResponse = this.querySelector('discountable-response');\n this.htdCalculation = this.querySelector('htd-calculation');\n this.htdCurves = this.querySelector('htd-curves');\n this.itcTask = this.querySelector('itc-task');\n\n if (this.discountableControl) {\n if (this.discountableControl.hasAttribute('trials')) {\n this.discountableControl.addEventListener('discountable-control-trials', (event) => {\n if (this.itcTask) {\n this.itcTask.trials = event.detail.trials;\n }\n\n if (this.discountableResponse) {\n this.discountableResponse.trialTotal = event.detail.trials;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('duration')) {\n this.discountableControl.addEventListener('discountable-control-duration', (event) => {\n if (this.itcTask) {\n this.itcTask.duration = event.detail.duration;\n this.itcTask.iti = event.detail.duration;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('run')) {\n this.discountableControl.addEventListener('discountable-control-run', (/* event */) => {\n if (this.htdCurves) {\n this.htdCurves.resumeTrial();\n }\n\n if (this.itcTask) {\n this.itcTask.running = true;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('pause')) {\n this.discountableControl.addEventListener('discountable-control-pause', (/* event */) => {\n if (this.htdCurves) {\n this.htdCurves.pauseTrial();\n }\n\n if (this.itcTask) {\n this.itcTask.running = false;\n }\n });\n }\n\n if (this.discountableControl.hasAttribute('reset')) {\n this.discountableControl.addEventListener('discountable-control-reset', (/* event */) => {\n if (this.discountableResponse) {\n this.discountableResponse.reset();\n }\n\n if (this.htdCurves) {\n this.htdCurves.clearOptions();\n }\n\n if (this.itcTask) {\n this.itcTask.reset();\n }\n });\n }\n }\n\n if (this.htdCurves) {\n this.htdCurves.addEventListener('htd-curves-change', (event) => {\n this.k = event.detail.k;\n });\n\n this.htdCurves.addEventListener('discountable-response', (event) => {\n if (this.discountableResponse) {\n this.discountableResponse.responded(event.detail.response);\n }\n });\n }\n\n if (this.itcTask) {\n if (this.discountableResponse) {\n this.discountableResponse.trialTotal = this.itcTask.trials;\n }\n\n this.itcTask.addEventListener('itc-trial-start', (event) => {\n if (this.discountableResponse) {\n this.discountableResponse.start(\n event.detail.as,\n event.detail.ds,\n event.detail.al,\n event.detail.dl,\n event.detail.trial,\n );\n }\n\n const vs = HTDMath.adk2v(event.detail.as, event.detail.ds, this.k);\n const vl = HTDMath.adk2v(event.detail.al, event.detail.dl, this.k);\n\n const response = (vs > vl)\n ? 'first'\n : 'second';\n\n if (this.htdCurves) {\n this.htdCurves.trial(\n event.detail.as,\n event.detail.ds,\n event.detail.al,\n event.detail.dl,\n event.detail.trial,\n response,\n );\n }\n });\n\n this.itcTask.addEventListener('itc-trial-end', (/* event */) => {\n if (this.discountableResponse) {\n this.discountableResponse.stop();\n }\n });\n\n this.itcTask.addEventListener('itc-block-end', (/* event */) => {\n if (this.discountableControl) {\n this.discountableControl.complete();\n }\n });\n }\n\n this.requestUpdate();\n }\n\n update(changedProperties) {\n super.update(changedProperties);\n\n if (this.htdCalculation) {\n this.htdCalculation.k = this.k;\n }\n\n if (this.htdCurves) {\n this.htdCurves.k = this.k;\n }\n }\n}\n\ncustomElements.define('htd-example-model', HTDExampleModel);\n"],"names":["t","window","e","ShadowRoot","ShadyCSS","nativeShadow","Document","prototype","CSSStyleSheet","s","Symbol","n","WeakMap","o$4","constructor","this","_$cssResult$","Error","cssText","styleSheet","o","length","get","replaceSync","set","toString","r","i","css","reduce","c","cssRules","trustedTypes","h","emptyScript","reactiveElementPolyfillSupport","toAttribute","Boolean","Object","Array","JSON","stringify","fromAttribute","Number","parse","a","notEqual","l","attribute","type","String","converter","reflect","hasChanged","d","HTMLElement","super","_$Ei","Map","isUpdatePending","hasUpdated","_$El","_$Eu","addInitializer","finalize","push","observedAttributes","elementProperties","forEach","_$Ep","_$Ev","createProperty","state","noAccessor","hasOwnProperty","getPropertyDescriptor","defineProperty","requestUpdate","configurable","enumerable","getPropertyOptions","getPrototypeOf","properties","getOwnPropertyNames","getOwnPropertySymbols","elementStyles","finalizeStyles","styles","isArray","Set","flat","reverse","unshift","toLowerCase","_$E_","Promise","enableUpdating","_$AL","_$Eg","addController","_$ES","renderRoot","isConnected","hostConnected","call","removeController","splice","indexOf","createRenderRoot","shadowRoot","attachShadow","shadowRootOptions","adoptStyles","adoptedStyleSheets","map","document","createElement","litNonce","setAttribute","textContent","appendChild","connectedCallback","disconnectedCallback","hostDisconnected","attributeChangedCallback","_$AK","_$EO","removeAttribute","has","_$EC","_$Ej","reject","scheduleUpdate","performUpdate","shouldUpdate","willUpdate","hostUpdate","update","_$Ek","_$AE","hostUpdated","firstUpdated","updated","updateComplete","getUpdateComplete","u","mode","ReactiveElement","reactiveElementVersions","createPolicy","createHTML","Math","random","slice","createMarker","createComment","f","_","m","p","RegExp","g","$","y","w","_$litType$","strings","values","x","b","T","for","A","E","C","createTreeWalker","P","V","getTemplateHtml","v","lastIndex","exec","test","startsWith","N$1","N","parts","el","currentNode","content","firstChild","remove","append","childNodes","nextNode","nodeType","hasAttributes","getAttributeNames","endsWith","getAttribute","split","index","name","ctor","H","L","z","k","tagName","data","innerHTML","S","_$Co","_$Cl","_$litDirective$","_$AO","_$AT","_$AS","M$1","_$AV","_$AN","_$AD","_$AM","parentNode","_$AU","creationScope","importNode","R","nextSibling","Z","_$AI","_$AH","_$AA","_$AB","options","_$Cp","startNode","endNode","_$AR","iterator","insertBefore","createTextNode","_$AC","M","_$AP","setConnected","k$1","element","fill","j","arguments","I","capture","once","passive","removeEventListener","addEventListener","handleEvent","host","B","litHtmlPolyfillSupport","litHtmlVersions","renderOptions","_$Do","renderBefore","render","_$litPart$","finalized","_$litElement$","globalThis","litElementHydrateSupport","LitElement","litElementPolyfillSupport","ascending","NaN","descending","bisector","compare1","compare2","delta","left","lo","hi","mid","zero","center","right","number","litElementVersions","bisectRight","bisect","count","valueof","undefined","value","array","empty","arrayify","from","cumsum","sum","Float64Array","variance","mean","deviation","sqrt","extent","min","max","Adder","_partials","_n","add","abs","valueOf","InternMap","entries","key","keyof","defineProperties","_intern","_key","intern_get","intern_set","delete","intern_delete","InternSet","identity","group","keys","nest","rollup","rollups","regroup","groups","sort","F","TypeError","Uint32Array","ascendingDefined","source","compareDefined","compare","groupSort","ak","av","bk","bv","e10","e5","e2","tickSpec","start","stop","step","power","floor","log10","error","pow","factor","i1","i2","inc","round","ticks","tickIncrement","tickStep","thresholdSturges","ceil","log","LN2","maxIndex","minIndex","quickselect","Infinity","exp","sd","swap","greatest","defined","maxValue","quantile","numbers","isNaN","i0","value0","subarray","quantileSorted","thresholdFreedmanDiaconis","thresholdScott","cbrt","median","merge","arrays","flatten","counts","modeValue","modeCount","pair","range","identity$7","top","bottom","epsilon","translateX","translateY","scale","offset","bandwidth","entering","__axis","axis","orient","tickArguments","tickValues","tickFormat","tickSizeInner","tickSizeOuter","tickPadding","devicePixelRatio","transform","context","apply","domain","format","spacing","range0","range1","position","copy","selection","path","selectAll","tick","order","tickExit","exit","tickEnter","enter","attr","line","select","text","insert","transition","isFinite","filter","each","tickSize","axisBottom","noop","dispatch","Dispatch","callback","concat","on","typename","types","trim","that","args","xhtml","namespaces","svg","xlink","xml","xmlns","namespace","prefix","space","local","creatorInherit","ownerDocument","uri","namespaceURI","documentElement","createElementNS","creatorFixed","fullname","creator","none","selector","querySelector","selectorAll","querySelectorAll","arrayAll","matcher","matches","childMatcher","node","find","childFirst","firstElementChild","children","sparse","EnterNode","parent","datum","_next","_parent","__data__","bindIndex","groupLength","dataLength","bindKey","keyValue","nodeByKeyValue","keyValues","arraylike","attrRemove","attrRemoveNS","removeAttributeNS","attrConstant","attrConstantNS","setAttributeNS","attrFunction","attrFunctionNS","defaultView","styleRemove","style","removeProperty","styleConstant","priority","setProperty","styleFunction","styleValue","getPropertyValue","getComputedStyle","propertyRemove","propertyConstant","propertyFunction","classArray","string","classList","ClassList","_node","_names","classedAdd","names","list","classedRemove","classedTrue","classedFalse","classedFunction","textRemove","textConstant","textFunction","htmlRemove","htmlConstant","htmlFunction","raise","lower","previousSibling","constantNull","removeChild","selection_cloneShallow","clone","cloneNode","selection_cloneDeep","onRemove","__on","listener","onAdd","event","contextListener","dispatchEvent","params","CustomEvent","createEvent","initEvent","bubbles","cancelable","detail","dispatchConstant","dispatchFunction","child","next","join","contains","root","Selection","parents","_groups","_parents","pointof","sourceEvent","currentTarget","ownerSVGElement","createSVGPoint","point","clientX","clientY","matrixTransform","getScreenCTM","inverse","getBoundingClientRect","rect","clientLeft","clientTop","pageX","pageY","subgroups","subnode","subgroup","selectChild","match","childFind","selectChildren","childrenFilter","bind","constant","enterGroup","updateGroup","previous","_enter","_exit","onenter","onupdate","onexit","groups0","groups1","m0","m1","merges","group0","group1","compareDocumentPosition","compareNode","sortgroups","sortgroup","nodes","size","getAttributeNS","property","classed","html","create","before","deep","typenames","parseTypenames","nonpassive","nonpassivecapture","nopropagation","stopImmediatePropagation","noevent","preventDefault","constant$3","DragEvent","subject","target","identifier","active","dx","dy","defaultFilter","ctrlKey","button","defaultContainer","defaultSubject","defaultTouchable","navigator","maxTouchPoints","drag","mousedownx","mousedowny","mousemoving","touchending","container","touchable","gestures","listeners","clickDistance2","mousedowned","touchstarted","touchmoved","touchended","gesture","beforestart","view","mousemoved","mouseupped","__noselect","MozUserSelect","nodrag","mouse","noclick","setTimeout","yesdrag","touches","changedTouches","clearTimeout","touch","pointer","p0","clickDistance","define","factory","extend","definition","Color","darker","brighter","reI","reN","reP","reHex","reRgbInteger","reRgbPercent","reRgbaInteger","reRgbaPercent","reHslPercent","reHslaPercent","named","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","color_formatHex","rgb","formatHex","color_formatRgb","formatRgb","color","parseInt","rgbn","Rgb","rgba","hsla","rgbConvert","opacity","rgb_formatHex","hex","rgb_formatRgb","clampa","clampi","Hsl","hslConvert","hsl","clamph","clampt","hsl2rgb","m2","channels","assign","displayable","formatHex8","formatHsl","clamp","radians","PI","degrees","Xn","Yn","Zn","t0","t1","t2","t3","labConvert","Lab","Hcl","hcl2lab","rgb2lrgb","xyz2lab","lab","lab2xyz","lrgb2rgb","hcl","atan2","hclConvert","cos","sin","D","ED","EB","BC_DA","cubehelix","Cubehelix","bl","cubehelixConvert","cosh","sinh","constant$2","linear","hue","gamma","nogamma","exponential","interpolateRgb","rgbGamma","end","colorRgb","spline","rgbBasis","v1","v2","v0","v3","basis","colors","numberArray","genericArray","nb","na","date$1","Date","setTime","interpolateNumber","object","reA","reB","interpolateString","am","bm","bs","bi","q","one","interpolate$1","date","ArrayBuffer","isView","DataView","isNumberArray","interpolateRound","svgNode","rotate","skewX","scaleX","scaleY","decompose","atan","interpolateTransform","pxComma","pxParen","degParen","pop","xa","ya","xb","yb","translate","interpolateTransformCss","DOMMatrix","WebKitCSSMatrix","isIdentity","interpolateTransformSvg","baseVal","consolidate","matrix","colorHsl","colorHcl","cubehelixGamma","colorCubehelix","cubehelixLong","piecewise","interpolate","quantize","interpolator","samples","taskHead","taskTail","frame","timeout","interval","pokeDelay","clockLast","clockNow","clockSkew","clock","performance","now","setFrame","requestAnimationFrame","clearNow","Timer","_call","_time","timer","delay","time","restart","wake","timerFlush","sleep","nap","poke","clearInterval","setInterval","elapsed","emptyOn","emptyTween","CREATED","SCHEDULED","STARTING","STARTED","RUNNING","ENDING","ENDED","schedule","id","timing","schedules","__transition","self","tween","duration","ease","init","tweenRemove","tween0","tween1","tweenFunction","tweenValue","_id","value1","string00","interpolate0","string1","string0","string10","attrTweenNS","attrInterpolateNS","_value","attrTween","attrInterpolate","delayFunction","delayConstant","durationFunction","durationConstant","Transition","_name","newId","selection_prototype","inherit","id0","id1","on0","on1","sit","every","onFunction","styleTween","styleNull","listener0","styleMaybeRemove","styleInterpolate","textTween","textInterpolate","removeFunction","easeConstant","easeVarying","resolve","cancel","interrupt","cubicOut","defaultTiming","pi","tau","tauEpsilon","Path","digits","_x0","_y0","_x1","_y1","_append","appendRound","moveTo","closePath","lineTo","quadraticCurveTo","x1","y1","bezierCurveTo","x2","y2","arcTo","x0","y0","x21","y21","x01","y01","l01_2","x20","y20","l21_2","l20_2","l21","l01","acos","t01","t21","arc","a0","a1","ccw","cw","da","pathRound","formatDecimalParts","toExponential","coefficient","exponent","prefixExponent","re","formatSpecifier","specifier","FormatSpecifier","align","sign","symbol","width","comma","precision","formatRounded","formatTypes","%","toFixed","toLocaleString","replace","toPrecision","X","toUpperCase","identity$5","locale","formatPrefix","prefixes","formatLocale$1","grouping","thousands","substring","currencyPrefix","currency","currencySuffix","decimal","numerals","formatNumerals","percent","minus","nan","newFormat","suffix","formatType","maybeSuffix","valuePrefix","valueSuffix","valueNegative","out","formatTrim","charCodeAt","padding","formatLocale","epsilon2","halfPi","quarterPi","asin","streamGeometry","geometry","stream","streamGeometryType","streamObjectType","Feature","FeatureCollection","features","Sphere","sphere","Point","coordinates","MultiPoint","LineString","streamLine","MultiLineString","Polygon","streamPolygon","MultiPolygon","GeometryCollection","geometries","closed","coordinate","lineStart","lineEnd","polygonStart","polygonEnd","geoStream","spherical","cartesian","lambda","phi","cosPhi","cartesianDot","cartesianCross","cartesianAddInPlace","cartesianScale","vector","cartesianNormalizeInPlace","compose","invert","rotationIdentity","rotateRadians","deltaLambda","deltaPhi","deltaGamma","rotationLambda","rotationPhiGamma","forwardRotationLambda","rotation","cosDeltaPhi","sinDeltaPhi","cosDeltaGamma","sinDeltaGamma","circleRadius","cosRadius","radius","clipBuffer","lines","rejoin","shift","result","pointEqual","Intersection","points","other","entry","clipRejoin","segments","compareIntersection","startInside","clip","segment","p1","link","current","isSubject","longitude","pointVisible","clipLine","sink","polygon","ring","ringBuffer","ringSink","polygonStarted","pointRing","ringStart","ringEnd","sinPhi","normal","angle","winding","point0","lambda0","phi0","sinPhi0","cosPhi0","lambda1","sinPhi1","cosPhi1","point1","phi1","absDelta","antimeridian","intersection","phiArc","polygonContains","pointLine","clean","ringSegments","validSegment","sign0","sign1","sinLambda0Lambda1","clipAntimeridianIntersect","to","direction","clipCircle","cr","smallRadius","notHemisphere","visible","intersect","two","n1","n2","n2n2","n1n2","determinant","c1","c2","n1xn2","uu","polar","q1","code","c0","v00","point2","sinRadius","circleStream","clipMax","clipMin","clipRectangle","corner","comparePoint","ca","cb","x__","y__","v__","x_","y_","v_","first","activeStream","bufferStream","clipStream","linePoint","b0","b1","polygonInside","cleanInside","ax","ay","x00","y00","areaSum","areaRingSum","areaStream","areaRingStart","areaRingEnd","area","areaPointFirst","areaPoint","pathArea","boundsStream","bounds","boundsStream$1","X0","Y0","Z0","X1","Y1","Z1","X2","Y2","Z2","centroidStream","centroidPoint","centroidLineStart","centroidLineEnd","centroidRingStart","centroidRingEnd","centroid","centroidPointFirstLine","centroidPointLine","centroidPointFirstRing","centroidPointRing","pathCentroid","PathContext","_context","_radius","pointRadius","_line","_point","lengthRing","lengthSum","lengthStream","lengthPointFirst","lengthPoint","pathMeasure","cacheDigits","cacheAppend","cacheRadius","cacheCircle","PathString","RangeError","geoPath","projection","projectionStream","contextStream","measure","pathBounds","geoTransform","methods","transformer","TransformStream","fit","fitBounds","clipExtent","fitExtent","fitSize","fitWidth","fitHeight","height","maxDepth","cosMinDistance","resample","project","delta2","resampleLineTo","depth","d2","phi2","lambda2","dx2","dy2","dz","lambda00","a00","b00","c00","resampleStream","ringPoint","resampleNone","transformRadians","scaleTranslateRotate","sx","sy","alpha","scaleTranslate","cosAlpha","sinAlpha","ai","ci","fi","projectionMutator","projectAt","projectResample","projectTransform","projectRotateTransform","cache","cacheStream","theta","preclip","clipAntimeridian","postclip","recenter","reset","transformRotate","clipAngle","reflectX","reflectY","conicProjection","parallels","conicEqualAreaRaw","sy0","forward","cylindricalEqualAreaRaw","r0","r0y","geoConicEqualArea","geoAlbers","conicEqualArea","geoAlbersUsa","lower48Point","alaskaPoint","hawaiiPoint","lower48","albers","alaska","hawaii","pointStream","albersUsa","streams","multiplex","azimuthalRaw","cx","cy","azimuthalInvert","sc","cc","azimuthalEqualAreaRaw","cxcy","geoAzimuthalEqualArea","azimuthalEquidistantRaw","geoAzimuthalEquidistant","mercatorRaw","geoMercator","mercatorProjection","reclip","tany","conicConformalRaw","cy0","fy","geoConicConformal","equirectangularRaw","geoEquirectangular","conicEquidistantRaw","gy","nx","geoConicEquidistant","A1","A2","A3","A4","equalEarthRaw","l2","l6","geoEqualEarth","gnomonicRaw","geoGnomonic","orthographicRaw","geoOrthographic","stereographicRaw","geoStereographic","transverseMercatorRaw","geoTransverseMercator","initRange","initInterpolator","implicit","ordinal","unknown","band","ordinalRange","r1","paddingInner","paddingOuter","rescale","sequence","rangeRound","pointish","unit","normalize","bimap","d0","d1","polymap","untransform","output","input","interpolateValue","clamper","continuous","precisionPrefix","precisionRound","precisionFixed","linearish","nice","prestep","maxIter","transformLog","transformExp","transformLogn","transformExpn","pow10","loggish","logs","pows","base","log2","logp","powp","transformSymlog","log1p","transformSymexp","expm1","symlogish","symlog","transformPow","transformSqrt","transformSquare","powish","thresholds","threshold","invertExtent","quantiles","timeInterval","floori","offseti","field","millisecond","durationSecond","durationMinute","durationHour","durationDay","durationWeek","durationMonth","durationYear","second","getMilliseconds","getUTCSeconds","timeMinute","getSeconds","getMinutes","utcMinute","setUTCSeconds","getUTCMinutes","timeHour","getHours","utcHour","setUTCMinutes","getUTCHours","timeDay","setHours","setDate","getDate","getTimezoneOffset","utcDay","setUTCHours","setUTCDate","getUTCDate","unixDay","timeWeekday","getDay","timeSunday","timeMonday","timeTuesday","timeWednesday","timeThursday","timeFriday","timeSaturday","utcWeekday","getUTCDay","utcSunday","utcMonday","utcTuesday","utcWednesday","utcThursday","utcFriday","utcSaturday","timeMonth","setMonth","getMonth","getFullYear","utcMonth","setUTCMonth","getUTCMonth","getUTCFullYear","timeYear","setFullYear","utcYear","setUTCFullYear","ticker","year","month","week","day","hour","minute","tickIntervals","tickInterval","utcTicks","utcTickInterval","timeTicks","timeTickInterval","localDate","utcDate","UTC","newDate","timeFormat","utcFormat","pads","numberRe","percentRe","requoteRe","pad","requote","formatRe","formatLookup","parseWeekdayNumberSunday","parseWeekdayNumberMonday","parseWeekNumberSunday","U","parseWeekNumberISO","parseWeekNumberMonday","W","parseFullYear","parseYear","parseZone","parseQuarter","parseMonthNumber","parseDayOfMonth","parseDayOfYear","parseHour24","parseMinutes","parseSeconds","parseMilliseconds","parseMicroseconds","parseLiteralPercent","parseUnixTimestamp","Q","parseUnixTimestampSeconds","formatDayOfMonth","formatHour24","formatHour12","formatDayOfYear","formatMilliseconds","formatMicroseconds","formatMonthNumber","formatMinutes","formatSeconds","formatWeekdayNumberMonday","formatWeekNumberSunday","dISO","formatWeekNumberISO","formatWeekdayNumberSunday","formatWeekNumberMonday","formatYear","formatYearISO","formatFullYear","formatFullYearISO","formatZone","formatUTCDayOfMonth","formatUTCHour24","formatUTCHour12","formatUTCDayOfYear","formatUTCMilliseconds","getUTCMilliseconds","formatUTCMicroseconds","formatUTCMonthNumber","formatUTCMinutes","formatUTCSeconds","formatUTCWeekdayNumberMonday","dow","formatUTCWeekNumberSunday","UTCdISO","formatUTCWeekNumberISO","formatUTCWeekdayNumberSunday","formatUTCWeekNumberMonday","formatUTCYear","formatUTCYearISO","formatUTCFullYear","formatUTCFullYearISO","formatUTCZone","formatLiteralPercent","formatUnixTimestamp","formatUnixTimestampSeconds","calendar","formatMillisecond","formatSecond","formatMinute","formatHour","formatDay","formatWeek","formatMonth","k10","k21","r2","diverging","divergingLog","divergingSymlog","divergingPow","locale_dateTime","dateTime","locale_date","locale_time","locale_periods","periods","locale_weekdays","days","locale_shortWeekdays","shortDays","locale_months","months","locale_shortMonths","shortMonths","periodRe","periodLookup","weekdayRe","weekdayLookup","shortWeekdayRe","shortWeekdayLookup","monthRe","monthLookup","shortMonthRe","shortMonthLookup","formats","G","Y","utcFormats","parses","parseSpecifier","charAt","newParse","utcParse","defaultLocale","ramp$1","scheme","interpolateRgbBasis","ramp","interpolateCividis","interpolateCubehelixLong","warm","cool","interpolateRainbow","ts","pi_1_3","pi_2_3","interpolateSinebow","interpolateTurbo","interpolateViridis","magma","inferno","plasma","constant$1","Linear","curveLinear","shapeLine","curve","shape","withPath","buffer","defined0","pointX","pointY","areaStart","areaEnd","Bump","_x","sqrt3","symbolAsterisk","draw","symbolCircle","symbolCross","tan30","tan30_2","symbolDiamond","symbolDiamond2","symbolPlus","symbolSquare","symbolSquare2","kr","kx","ky","symbolStar","symbolTriangle","symbolTriangle2","symbolWye","symbolTimes","symbolsFill","circle","cross","diamond","square","star","triangle","wye","symbolsStroke","plus","times","triangle2","asterisk","square2","diamond2","Basis","BasisClosed","BasisOpen","Bundle","beta","_basis","_beta","_x2","_x3","_x4","_y2","_y3","_y4","_y","curveBundle","custom","bundle","_k","Cardinal","tension","curveCardinal","cardinal","CardinalClosed","_x5","_y5","curveCardinalClosed","CardinalOpen","curveCardinalOpen","_l01_a","_l01_2a","_l12_a","_l12_2a","_l23_a","_l23_2a","CatmullRom","_alpha","x23","y23","curveCatmullRom","catmullRom","CatmullRomClosed","curveCatmullRomClosed","CatmullRomOpen","curveCatmullRomOpen","LinearClosed","slope3","h0","h1","s0","s1","slope2","MonotoneX","MonotoneY","ReflectContext","Natural","controlPoints","Step","_t","Transform","_t0","px","py","applyX","applyY","location","invertX","invertY","rescaleX","rescaleY","DecidablesElement","getComputedStyleValue","changedProperties","d3","greys","light75","light50","light25","dark25","dark50","dark75","shadows","elevations","baselineColor","baselineColorString","inverseBaselineColor","inverseBaselineColorString","opacityUmbra","opacityPenumbra","opacityAmbient","opacityBoost","mapUmbra","mapPenumbra","mapAmbient","cssBoxShadow","elevation","umbraO","penumbraO","ambientO","umbraC","penumbraC","ambientC","umbraM","penumbraM","ambientM","svgDefs","filters","svgFilters","unsafeCSS","customElements","disabled","changed","inputted","ifDefined","checked","DiscountableElement","interactive","chosen","better","worse","even","correct","nr","lights","acc","cur","darks","DiscountableControl","trials","run","pause","atribute","states","setTrials","setDuration","doRun","doPause","doReset","complete","DiscountableResponse","trial","feedback","trialCount","trialTotal","as","ds","al","dl","responses","response","responded","i$1","_$Ct","_$Ci","notifyChildrenConnectedChanged","_$AQ","reconnected","disconnected","setValue","WeakSet","animationFrame","diffOp","quotientOp","overrideFrom","easing","shouldLog","createFinished","resolveFinished","finished","getController","isDisabled","optionsOrCallback","defaultOptions","keyframeOptions","guard","isAnimating","skipInitial","isHostRendered","prepare","O","calculateKeyframes","inId","in","zIndex","animate","resetStyles","commitStyles","webAnimation","stabilizeOut","onStart","didFinish","onComplete","animatingProperties","frames","then","transformOrigin","onFrames","playState","pending","console","HTDMath","adk2v","adv2k","HTDEquation","numeric","HTDCalculation","alignState","vs","vl","vDiff","sendEvent","asInput","parseFloat","dsInput","alInput","dlInput","kInput","fadeIn","equation","HTDCurves","superClass","rem","getDimensions","resizeObserver","ResizeObserver","observe","unobserve","DecidablesMixinResizeable","label","firstUpdate","discount","option","removeOption","setOption","pauseTrial","lineNew","paused","resumeTrial","clearOptions","getOption","myOption","new","hostWidth","hostHeight","elementWidth","elementHeight","margin","transitionDuration","xScale","yScale","svgUpdate","svgEnter","svgMerge","plotEnter","plotMerge","underlayerEnter","underlayerMerge","titleXEnter","titleYEnter","optionUpdate","optionEnter","getTotalLength","pointEnter","optionMerge","dragD","dragV","includes","keyK","shiftKey","keyD","keyA","elements","interpolateA","interpolateD","descendingDefined","nonempty","finite","positive","negative","fallback","hours","minutes","seconds","milliseconds","padStart","durations","timeIntervals","timeSecond","timeWeek","utcIntervals","utcSecond","utcWeek","intervalDuration","intervalType","formatIntervals","parseInterval","intervals","period","maybeTimeInterval","maybeUtcInterval","generalizeTimeInterval","some","formatTimeInterval","anchor","template","f1","f2","getTimeTemplate","formatConditional","inferTimeFormat","dates","pairof","pairs","maxStep","format1","format2","orderof","TypedArray","Uint8Array","objectToString","reindex","valueType","maybeTypedMap","maybeTypedArrayify","take","maybeTake","coerceNumber","floater","singleton","yes","coerceNumbers","coerceDates","coerceDate","isoParse","maybeColorChannel","defaultValue","isColor","maybeNumberChannel","maybeKeyword","allowed","keyword","hasY","isObject","isScaleOptions","isOptions","isDomainSort","channel","maybeTuple","maybeZ","stroke","column","labelof","maybeColumn","isTemporal","maybeApplyInterval","maybeIntervalTransform","maybeInterval","isInteger","rangei","maybeRangeInterval","isInterval","maybeValue","isIterable","isTextual","isOrdinal","isTemporalString","isNumericString","isEvery","is","namedColors","isOpacity","isNoneish","isNone","maybeAnchor","maybeFrameAnchor","maybeNamed","things","warn","fromEntries","thing","registry","sqrt4_3","symbols","rx","ry","hy","isSymbolObject","isSymbol","maybeSymbol","basic","initializer","filterTransform","composeTransform","sortTransform","reverseTransform","composeInitializer","facets","plotOptions","sortData","sortValue","compareData","negate","compareValue","hasOutput","outputs","maybeOutput","inputs","asEvaluator","maybeEvaluator","evaluator","setOutput","initialize","scope","asReduce","maybeReduce","maybeInput","reducer","reduceCount","reduceIndex","maybeGroup","grouper","invalidReduce","reduceReduce","reduceFunction","reduceAccessor","percentile","reduceFirst","reduceLast","reduceIdentity","reduceDistinct","reduceSum","reduceProportion","reduceMaybeTemporalAccessor","reduceTitle","createChannel","hint","inferChannelScale","findScaleChannel","reindexFacetChannel","originalFacets","original","V1","V2","vi","difference","k1","k2","alias","maybeOrder","ascendingGroup","descendingGroup","getSource","numberFormat","compute","cacheValue","cacheKeys","memoize1","Intl","NumberFormat","formatIsoDate","isoFormat","formatDefault","formatNumber","formatAuto","lastMessage","warnings","message","it","nextClipId","getClipId","mark","title","href","ariaLabel","variaLabel","ariaDescription","ariaHidden","fillOpacity","strokeWidth","strokeOpacity","strokeLinejoin","strokeLinecap","strokeMiterlimit","strokeDasharray","strokeDashoffset","mixBlendMode","imageFilter","paintOrder","pointerEvents","shapeRendering","cariaLabel","defaultFill","defaultFillOpacity","defaultStroke","defaultStrokeOpacity","defaultStrokeWidth","defaultStrokeLinecap","defaultStrokeLinejoin","defaultStrokeMiterlimit","defaultPaintOrder","vfill","cfill","vfillOpacity","cfillOpacity","vstroke","cstroke","vstrokeOpacity","cstrokeOpacity","vopacity","copacity","vstrokeWidth","cstrokeWidth","impliedString","impliedNumber","optional","applyText","applyTextGroup","applyChannelStyles","tip","AL","FO","SO","SW","applyAttr","applyHref","applyTitle","applyGroupedChannelStyles","applyTitleGroup","groupIndex","groupAesthetics","groupZ","Ag","Gg","maybeClip","applyIndirectStyles","dimensions","clipUrl","marginLeft","marginRight","marginTop","marginBottom","applyClip","pointerSticky","applyDirectStyles","applyStyle","applyTransform","tx","ty","impliedValue","validClassName","maybeClassName","applyInlineStyles","applyFrameAnchor","frameAnchor","createContext","defaultAspectRatio","createProjection","inset","globalInset","insetTop","insetRight","insetBottom","insetLeft","namedProjection","geoClipRectangle","maybePostClip","scaleProjection","aspectRatio","hasProjection","getGeometryChannels","categoricalSchemes","schemeAccent","schemeCategory10","schemeDark2","schemePaired","schemePastel1","schemePastel2","schemeSet1","schemeSet2","schemeSet3","schemeTableau10","ordinalSchemes","scheme11","schemeBrBG","interpolateBrBG","schemePRGn","interpolatePRGn","schemePiYG","interpolatePiYG","schemePuOr","interpolatePuOr","schemeRdBu","interpolateRdBu","schemeRdGy","interpolateRdGy","schemeRdYlBu","interpolateRdYlBu","schemeRdYlGn","interpolateRdYlGn","schemeSpectral","interpolateSpectral","scheme11r","scheme9","schemeBlues","interpolateBlues","schemeGreens","interpolateGreens","schemeGreys","interpolateGreys","schemeOranges","interpolateOranges","schemePurples","interpolatePurples","schemeReds","interpolateReds","schemei","interpolateMagma","interpolateInferno","interpolatePlasma","interpolateCubehelixDefault","interpolateWarm","interpolateCool","schemeBuGn","interpolateBuGn","schemeBuPu","interpolateBuPu","schemeGnBu","interpolateGnBu","schemeOrRd","interpolateOrRd","schemePuBu","interpolatePuBu","schemePuBuGn","interpolatePuBuGn","schemePuRd","interpolatePuRd","schemeRdPu","interpolateRdPu","schemeYlGn","interpolateYlGn","schemeYlGnBu","interpolateYlGnBu","schemeYlOrBr","interpolateYlOrBr","schemeYlOrRd","interpolateYlOrRd","schemeicyclical","ordinalScheme","quantitativeSchemes","quantitativeScheme","divergingSchemes","flip","interpolators","interpolateHsl","interpolateHcl","colorLab","maybeInterpolator","createScaleQ","inferAutoDomain","inferRadialRange","inferLengthRange","interpolatePiecewise","reverseof","maybeNiceInterval","maybeNice","createScalePow","scalePow","createScaleLog","inferLogDomain","scaleLog","createScaleSymlog","scaleSymlog","createScaleQuantile","inferQuantileDomain","scaleQuantile","createScaleThreshold","isOrdered","scaleThreshold","inferDomain","inferZeroDomain","h25","h50","createScaleD","pivot","symmetric","mindelta","maxdelta","createScaleDiverging","scaleDiverging","transformIdentity","createScaleDivergingPow","scaleDivergingPow","createScaleDivergingLog","scaleDivergingLog","createScaleDivergingSymlog","scaleDivergingSymlog","createScaleT","createScaleTime","scaleTime","createScaleUtc","scaleUtc","ordinalImplicit","createScaleO","createScaleOrdinal","inferHint","inferSymbolHint","inferSymbolRange","maybeBooleanRange","scaleImplicit","scaleOrdinal","maybeRound","candidate","createScales","channelsByScale","globalLabel","globalInsetTop","globalInsetRight","globalInsetBottom","globalInsetLeft","facet","facetLabel","scales","scaleOptions","createScale","inferScaleLabel","createScaleFunctions","descriptors","scaleFunctions","descriptor","exposeScale","isOrdinalScale","inferred","outerDimensions","facetMarginTop","facetMarginRight","facetMarginBottom","facetMarginLeft","innerDimensions","fx","autoScaleRangeX","piecewiseRange","autoScaleRound","autoScaleRangeY","isBandScale","roundError","isThresholdScale","typeProjection","kind","asOrdinalType","isDivergingScheme","isCategoricalScheme","inferScaleType","formatScaleType","coerceType","coerceSymbols","createScaleDivergingSqrt","scaleLinear","createScaleLinear","createScaleSqrt","createScaleQuantize","scalePoint","createScalePoint","scaleBand","createScaleBand","scaleIdentity","createScaleIdentity","description","isCollapsed","coerceValues","autoHeight","marginTopDefault","marginRightDefault","marginBottomDefault","marginLeftDefault","nfy","ar","projectionAspectRatio","far","lar","ny","ratio","aspectRatioLength","fxb","fyb","createFacets","fxDomain","fyDomain","lengths","product","facetGroups","FX","FY","facetExclude","ex","facetAnchors","facetAnchorTop","facetAnchorRight","facetAnchorBottom","facetAnchorLeft","and","facetIndexOf","facetEmpty","indexCache","facetIndex","facetFind","facetFilter","Mark","defaults","facetAnchor","extraChannels","maybeFacetAnchor","maybeChannels","maybeTip","composeRender","facetChannels","createChannels","defaultOrder","defaultReverse","defaultReduce","limit","defaultLimit","XV","YV","channelDomain","scaleName","valueObject","marks","plot","withTip","pointerK","maxRadius","getMarkState","sticky","roots","renders","renderIndex","faceted","facetState","facetStates","PX","PY","anchorX","anchorY","ii","ri","cancelAnimationFrame","ft","mt","replaceWith","dispatchValue","pointermove","pointerType","buttons","xp","yp","kpx","kpy","rj","pointerX","pointerY","inferFontVariant","markers","marker","markerStart","markerMid","markerEnd","maybeMarker","markerCircleFill","markerArrow","markerDot","markerCircleStroke","nextMarkerId","applyMarkers","applyMarkersColor","applyGroupedMarkers","strokeof","iriByMarkerColor","applyMarker","iriByColor","iri","maybeInsetX","maybeInset","maybeInsetY","inset1","inset2","maybeIntervalValue","maybeIntervalK","maybeInsetK","trivial","kv","D1","maybeIntervalMidK","RuleX","RuleY","ruleX","rest","maybeIntervalY","maybeOptionalZero","ruleY","maybeIntervalX","softHyphen","Text","textAnchor","lineAnchor","lineHeight","lineWidth","textOverflow","monospace","fontFamily","fontSize","fontStyle","fontVariant","fontWeight","vrotate","crotate","vfontSize","cfontSize","fontSizes","maybeFontSizeChannel","maybeTextOverflow","splitLines","splitter","clipper","TL","FS","applyIndirectTextStyles","applyMultilineText","tspan","textX","maybeIntervalMidY","textY","maybeIntervalMidX","isNumeric","lineWrap","maxWidth","widthof","wordStart","wordEnd","required","lineBreaks","defaultWidthMap","J","K","defaultWidth","readCharacter","isPictographic","monospaceWidth","clipStart","clipEnd","ellipsis","ei","cut","trimEnd","trimStart","clipMiddle","reCombiner","rePictographic","isSurrogatePair","isAscii","isCombiner","isZeroWidthJoiner","defaultRadius","wingRatio","shapeArrow","wing","shapeSpike","shapes","Vector","cl","vr","isShapeObject","maybeShape","vectorX","vectorY","maybeData","anchors","anchorFy","anchorFx","axisY","axisKy","axisFy","axisX","axisKx","axisFx","textStroke","textStrokeOpacity","textStrokeWidth","tickRotate","labelAnchor","labelArrow","labelOffset","maybeLabelArrow","axisMark","shapeTickLeft","shapeTickRight","axisTickKy","inferTextChannel","axisTextKy","labelOptions","cla","clo","formatAxisLabel","shapeTickBottom","shapeTickTop","axisTickKx","axisTextKx","gridY","gridKy","gridFy","gridX","gridKx","gridFx","gridDefaults","basicInitializer","_channels","initializeFacets","tickSpacing","hasTemporalDomain","inferTickCount","inclusiveRange","domainSet","initializedChannels","filterFacets","inferTickFormat","inferScaleOrder","maybeScale","legendItems","swatch","columns","swatchSize","swatchWidth","swatchHeight","className","swatches","extraStyle","item","div","legendRegistry","vf","cf","cs","sf","ss","legendColor","legend","interpolateOpacity","legendOptions","legendSwatches","tickAdjust","applyRange","canvas","context2","getContext","fillStyle","fillRect","toDataURL","thresholdFormat","legendRamp","lineDefaults","Frame","ignoreChannels","Tip","textPadding","pointerSize","pathFilter","previousAnchor","ox","oy","ee","sources","formatTitle","getSourceChannels","formatChannels","renderLine","labels","postrender","getBBox","fitLeft","fitRight","fitTop","fitBottom","lastChild","getPath","getLineOffset","getTextTranslate","maybeExpandPairedFormat","key1","key2","findIndex","formatLabel","formatPairLabel","formatPair","formatValue","l1","defaultLabel","subtitle","caption","flatMarks","tips","tipOptions","derive","inferTips","topFacetState","applyScaleTransforms","maybeTopFacet","facetStateByMark","maybeMarkFacet","addScaleChannels","axes","grid","facetAxis","facetGrid","xAxis","xGrid","yAxis","yGrid","fxAxis","fxGrid","fyAxis","fyGrid","hasPositionChannel","hasAxis","maybeGrid","maybeAxis","inferAxes","topFacetsIndex","facetsIndex","nonEmpty","scaleRegistry","stateByMark","scaleDescriptors","facetMargin","createDimensions","superdimensions","subdimensions","autoScaleRange","fxr","outerRange","fyr","actualDimensions","figure","Event","newByScale","inferChannelScales","applyScaleTransform","newChannelsByScale","newScaleDescriptors","newScales","newScale","inheritScaleLabels","newExposedScales","facetDomains","facetTranslate","recreateFacets","facetTranslator","indexes","hasAttribute","legends","createLegends","figured","createTitleElement","createFigcaption","exposeScales","exposeLegends","consumeWarnings","contents","tag","markify","Render","gx","addScaleChannel","scaleChannels","axisType","primary","secondary","both","axisOptions","lineOptions","gridType","isGridTicks","gridOptions","curves","maybeCurveAuto","curveAuto","maybeCurve","binX","cumulative","mergeOptions","bx","by","reduceData","maybeBin","asOutput","nullOutput","maybeOutputs","maybeBinOutput","maybeBinOutputs","maybeBinReduce","maybeBinEvaluator","BX1","setBX1","BX2","setBX2","BY1","setBY1","BY2","setBY2","gk","GK","setGK","GZ","setGZ","GF","setGF","GS","setGS","maybeSubgroup","groupFacets","groupData","bin","EX","EY","ix","iy","groupFacet","maybeSort","binn","defaultThresholds","thresholdAuto","maybeThresholds","maybeBinValue","maybeDenseIntervalX","maybeDenseInterval","isTimeInterval","isTimeThresholds","bin1cn","bin1cp","bin1","maybeBinReduceFallback","reduceX","reduceX1","reduceX2","reduceY","reduceY1","reduceY2","mid1","stackY","stackOptions","setX","setY1","setY2","lengthy","offsetExpand","offsetCenter","offsetWiggle","maybeOffset","orderInsideOut","orderY","orderZ","orderZDomain","orderSum","orderAppearance","orderAccessor","orderComparator","overlaps","exclusiveFacets","facetstacks","stacks","stack","yn","maybeStackY","x3","maybeZero","offsetZero","offsetCenterFacets","prev","Fi","Df","diff","Cf1","sums","Kp","Kn","Line","sphereLine","lineY","Rect","rectY","hasX","hasXY","maybeTrivialIntervalX","maybeIdentityY","HTDFit","choices","working","queued","worker","HTDFitWorker","onmessage","results","postMessage","clear","choice","plotParam","param","replaceChildren","Plot","ITCOption","aInput","dInput","ITCChoice","ssChange","llChange","ITCTask","iti","running","baseTime","pauseTime","startTime","lastTime","runner","total","_restart","realTime","currentTime","elapsedTime","HTDEquationADK2V","HTDExample","HTDExampleHuman","discountableControl","itcTask","discountableResponse","htdFit","htdCurves","HTDExampleInteractive","htdCalculation","itcChoice","HTDExampleModel"],"mappings":"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A,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,yDACA,+DACA,sEACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICZTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,mDACA,0DACArV,IAAI+zB,IAESi3B,GAAAA,GAAKF,ICVTA,GAAS,IAAIzvD,MAAM,GAAGga,OAC/B,qBACA,2BACA,iCACA,uCACA,6CACA,m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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,330,339,340,341,342,343,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,371,372,373,374,375,376,377,378,379,380,381,382,383,384,385,386,387,388,389,390,391,392,393,394,395,396,397,398,399,404]}