{"version":3,"sources":["webpack:///./src/components/WorldMap/WorldMap.vue?c0f3","webpack:///./node_modules/d3-array/src/ascending.js","webpack:///./node_modules/d3-array/src/bisector.js","webpack:///./node_modules/d3-array/src/bisect.js","webpack:///./node_modules/d3-array/src/cross.js","webpack:///./node_modules/d3-array/src/array.js","webpack:///./node_modules/d3-array/src/ticks.js","webpack:///./node_modules/d3-axis/src/array.js","webpack:///./node_modules/d3-dispatch/src/dispatch.js","webpack:///./node_modules/d3-selection/src/selector.js","webpack:///./node_modules/d3-selection/src/selection/select.js","webpack:///./node_modules/d3-selection/src/selectorAll.js","webpack:///./node_modules/d3-selection/src/selection/selectAll.js","webpack:///./node_modules/d3-selection/src/matcher.js","webpack:///./node_modules/d3-selection/src/selection/filter.js","webpack:///./node_modules/d3-selection/src/selection/sparse.js","webpack:///./node_modules/d3-selection/src/selection/enter.js","webpack:///./node_modules/d3-selection/src/constant.js","webpack:///./node_modules/d3-selection/src/selection/data.js","webpack:///./node_modules/d3-selection/src/selection/exit.js","webpack:///./node_modules/d3-selection/src/selection/join.js","webpack:///./node_modules/d3-selection/src/selection/merge.js","webpack:///./node_modules/d3-selection/src/selection/order.js","webpack:///./node_modules/d3-selection/src/selection/sort.js","webpack:///./node_modules/d3-selection/src/selection/call.js","webpack:///./node_modules/d3-selection/src/selection/nodes.js","webpack:///./node_modules/d3-selection/src/selection/node.js","webpack:///./node_modules/d3-selection/src/selection/size.js","webpack:///./node_modules/d3-selection/src/selection/empty.js","webpack:///./node_modules/d3-selection/src/selection/each.js","webpack:///./node_modules/d3-selection/src/namespaces.js","webpack:///./node_modules/d3-selection/src/namespace.js","webpack:///./node_modules/d3-selection/src/selection/attr.js","webpack:///./node_modules/d3-selection/src/window.js","webpack:///./node_modules/d3-selection/src/selection/style.js","webpack:///./node_modules/d3-selection/src/selection/property.js","webpack:///./node_modules/d3-selection/src/selection/classed.js","webpack:///./node_modules/d3-selection/src/selection/text.js","webpack:///./node_modules/d3-selection/src/selection/html.js","webpack:///./node_modules/d3-selection/src/selection/raise.js","webpack:///./node_modules/d3-selection/src/selection/lower.js","webpack:///./node_modules/d3-selection/src/creator.js","webpack:///./node_modules/d3-selection/src/selection/append.js","webpack:///./node_modules/d3-selection/src/selection/insert.js","webpack:///./node_modules/d3-selection/src/selection/remove.js","webpack:///./node_modules/d3-selection/src/selection/clone.js","webpack:///./node_modules/d3-selection/src/selection/datum.js","webpack:///./node_modules/d3-selection/src/selection/on.js","webpack:///./node_modules/d3-selection/src/selection/dispatch.js","webpack:///./node_modules/d3-selection/src/selection/index.js","webpack:///./node_modules/d3-color/src/define.js","webpack:///./node_modules/d3-color/src/color.js","webpack:///./node_modules/d3-interpolate/src/basis.js","webpack:///./node_modules/d3-interpolate/src/basisClosed.js","webpack:///./node_modules/d3-interpolate/src/constant.js","webpack:///./node_modules/d3-interpolate/src/color.js","webpack:///./node_modules/d3-interpolate/src/rgb.js","webpack:///./node_modules/d3-interpolate/src/numberArray.js","webpack:///./node_modules/d3-interpolate/src/array.js","webpack:///./node_modules/d3-interpolate/src/date.js","webpack:///./node_modules/d3-interpolate/src/number.js","webpack:///./node_modules/d3-interpolate/src/object.js","webpack:///./node_modules/d3-interpolate/src/string.js","webpack:///./node_modules/d3-timer/src/timer.js","webpack:///./node_modules/d3-interpolate/src/value.js","webpack:///./node_modules/d3-timer/src/timeout.js","webpack:///./node_modules/d3-transition/src/transition/schedule.js","webpack:///./node_modules/d3-transition/src/interrupt.js","webpack:///./node_modules/d3-interpolate/src/transform/parse.js","webpack:///./node_modules/d3-transition/src/selection/interrupt.js","webpack:///./node_modules/d3-interpolate/src/transform/decompose.js","webpack:///./node_modules/d3-interpolate/src/transform/index.js","webpack:///./node_modules/d3-transition/src/transition/tween.js","webpack:///./node_modules/d3-transition/src/transition/interpolate.js","webpack:///./node_modules/d3-transition/src/transition/attr.js","webpack:///./node_modules/d3-transition/src/transition/attrTween.js","webpack:///./node_modules/d3-transition/src/transition/delay.js","webpack:///./node_modules/d3-transition/src/transition/duration.js","webpack:///./node_modules/d3-transition/src/transition/ease.js","webpack:///./node_modules/d3-transition/src/transition/filter.js","webpack:///./node_modules/d3-transition/src/transition/merge.js","webpack:///./node_modules/d3-transition/src/transition/on.js","webpack:///./node_modules/d3-transition/src/transition/remove.js","webpack:///./node_modules/d3-transition/src/transition/select.js","webpack:///./node_modules/d3-transition/src/transition/selectAll.js","webpack:///./node_modules/d3-transition/src/transition/selection.js","webpack:///./node_modules/d3-transition/src/transition/style.js","webpack:///./node_modules/d3-transition/src/transition/styleTween.js","webpack:///./node_modules/d3-transition/src/transition/text.js","webpack:///./node_modules/d3-transition/src/transition/textTween.js","webpack:///./node_modules/d3-transition/src/transition/transition.js","webpack:///./node_modules/d3-transition/src/transition/end.js","webpack:///./node_modules/d3-transition/src/transition/index.js","webpack:///./node_modules/d3-ease/src/cubic.js","webpack:///./node_modules/d3-transition/src/selection/transition.js","webpack:///./node_modules/d3-transition/src/selection/index.js","webpack:///./node_modules/d3-brush/src/brush.js","webpack:///./node_modules/d3-chord/src/math.js","webpack:///./node_modules/d3-chord/src/array.js","webpack:///./node_modules/d3-chord/src/chord.js","webpack:///./node_modules/d3-path/src/path.js","webpack:///./node_modules/d3-chord/src/ribbon.js","webpack:///./node_modules/d3-collection/src/map.js","webpack:///./node_modules/d3-collection/src/set.js","webpack:///./node_modules/d3-contour/src/array.js","webpack:///./node_modules/d3-contour/src/density.js","webpack:///./node_modules/d3-quadtree/src/add.js","webpack:///./node_modules/d3-quadtree/src/cover.js","webpack:///./node_modules/d3-quadtree/src/data.js","webpack:///./node_modules/d3-quadtree/src/extent.js","webpack:///./node_modules/d3-quadtree/src/quad.js","webpack:///./node_modules/d3-quadtree/src/find.js","webpack:///./node_modules/d3-quadtree/src/remove.js","webpack:///./node_modules/d3-quadtree/src/root.js","webpack:///./node_modules/d3-quadtree/src/size.js","webpack:///./node_modules/d3-quadtree/src/visit.js","webpack:///./node_modules/d3-quadtree/src/visitAfter.js","webpack:///./node_modules/d3-quadtree/src/x.js","webpack:///./node_modules/d3-quadtree/src/y.js","webpack:///./node_modules/d3-quadtree/src/quadtree.js","webpack:///./node_modules/d3-force/src/simulation.js","webpack:///./node_modules/d3-random/src/defaultSource.js","webpack:///./node_modules/d3-random/src/normal.js","webpack:///./node_modules/d3-random/src/uniform.js","webpack:///./node_modules/d3-random/src/irwinHall.js","webpack:///./node_modules/d3-random/src/logNormal.js","webpack:///./node_modules/d3-random/src/bates.js","webpack:///./node_modules/d3-random/src/exponential.js","webpack:///./node_modules/d3-scale/src/init.js","webpack:///./node_modules/d3-scale/src/array.js","webpack:///./node_modules/d3-interpolate/src/round.js","webpack:///./node_modules/d3-scale/src/constant.js","webpack:///./node_modules/d3-scale/src/number.js","webpack:///./node_modules/d3-scale/src/continuous.js","webpack:///./node_modules/d3-format/src/formatSpecifier.js","webpack:///./node_modules/d3-format/src/formatDecimal.js","webpack:///./node_modules/d3-format/src/exponent.js","webpack:///./node_modules/d3-format/src/formatPrefixAuto.js","webpack:///./node_modules/d3-format/src/defaultLocale.js","webpack:///./node_modules/d3-format/src/precisionPrefix.js","webpack:///./node_modules/d3-format/src/formatGroup.js","webpack:///./node_modules/d3-format/src/formatNumerals.js","webpack:///./node_modules/d3-format/src/formatTrim.js","webpack:///./node_modules/d3-format/src/formatRounded.js","webpack:///./node_modules/d3-format/src/formatTypes.js","webpack:///./node_modules/d3-format/src/identity.js","webpack:///./node_modules/d3-format/src/locale.js","webpack:///./node_modules/d3-format/src/precisionRound.js","webpack:///./node_modules/d3-format/src/precisionFixed.js","webpack:///./node_modules/d3-scale/src/tickFormat.js","webpack:///./node_modules/d3-scale/src/linear.js","webpack:///./node_modules/d3-time/src/interval.js","webpack:///./node_modules/d3-time/src/year.js","webpack:///./node_modules/d3-time/src/month.js","webpack:///./node_modules/d3-time/src/duration.js","webpack:///./node_modules/d3-time/src/week.js","webpack:///./node_modules/d3-time/src/day.js","webpack:///./node_modules/d3-time/src/hour.js","webpack:///./node_modules/d3-time/src/minute.js","webpack:///./node_modules/d3-time/src/second.js","webpack:///./node_modules/d3-time/src/millisecond.js","webpack:///./node_modules/d3-time/src/utcWeek.js","webpack:///./node_modules/d3-time/src/utcDay.js","webpack:///./node_modules/d3-time/src/utcYear.js","webpack:///./node_modules/d3-time-format/src/locale.js","webpack:///./node_modules/d3-time-format/src/defaultLocale.js","webpack:///./node_modules/d3-scale/src/time.js","webpack:///./node_modules/d3-time/src/utcMonth.js","webpack:///./node_modules/d3-time/src/utcHour.js","webpack:///./node_modules/d3-time/src/utcMinute.js","webpack:///./node_modules/d3-voronoi/src/RedBlackTree.js","webpack:///./node_modules/d3-voronoi/src/Edge.js","webpack:///./node_modules/d3-voronoi/src/Cell.js","webpack:///./node_modules/d3-voronoi/src/Circle.js","webpack:///./node_modules/d3-voronoi/src/Beach.js","webpack:///./node_modules/d3-voronoi/src/Diagram.js","webpack:///./node_modules/d3-interpolate/src/zoom.js","webpack:///./node_modules/d3-zoom/src/transform.js","webpack:///./src/util/throttle.js","webpack:///src/components/WorldMap/WorldMap.vue","webpack:///./src/components/WorldMap/WorldMap.vue?56e3","webpack:///./src/components/WorldMap/WorldMap.vue","webpack:///./node_modules/core-js/modules/_object-to-array.js","webpack:///./node_modules/core-js/modules/es7.object.values.js","webpack:///./node_modules/topojson/build/topojson.js"],"names":["render","_vm","this","_h","$createElement","_c","_self","staticClass","attrs","id","staticRenderFns","a","b","NaN","compare","length","ascendingComparator","left","x","lo","hi","mid","right","f","d","ascending","ascendingBisect","bisector","bisectRight","bisect","Array","prototype","e10","slice","map","Math","sqrt","e5","e2","reverse","n","ticks","step","i","stop","start","count","tickIncrement","isFinite","ceil","floor","max","power","log","LN10","error","pow","tickStep","step0","abs","step1","noop","value","dispatch","t","arguments","_","test","Error","Dispatch","parseTypenames","typenames","types","trim","split","name","indexOf","hasOwnProperty","type","get","c","set","callback","concat","push","constructor","on","typename","T","copy","call","that","args","apply","none","selector","querySelector","select","groups","_groups","m","subgroups","j","node","subnode","group","subgroup","__data__","Selection","_parents","querySelectorAll","selectorAll","parents","matches","match","matcher","update","_enter","sparse","EnterNode","parent","datum","ownerDocument","namespaceURI","_next","_parent","appendChild","child","insertBefore","next","keyPrefix","bindIndex","enter","exit","data","groupLength","dataLength","bindKey","key","keyValue","nodeByKeyValue","keyValues","size","each","bind","enterGroup","updateGroup","exitGroup","previous","i0","i1","_exit","onenter","append","onupdate","onexit","remove","merge","order","groups0","groups1","selection","m0","m1","min","merges","group0","group1","compareDocumentPosition","parentNode","compareNode","sortgroups","sortgroup","sort","nodes","xhtml","svg","xlink","xml","xmlns","prefix","namespaces","space","local","attrRemove","removeAttribute","attrRemoveNS","fullname","removeAttributeNS","attrConstant","setAttribute","attrConstantNS","setAttributeNS","attrFunction","v","attrFunctionNS","namespace","getAttributeNS","getAttribute","defaultView","document","styleRemove","style","removeProperty","styleConstant","priority","setProperty","styleFunction","styleValue","getPropertyValue","getComputedStyle","propertyRemove","propertyConstant","propertyFunction","classArray","string","classList","ClassList","_node","_names","classedAdd","names","list","add","classedRemove","classedTrue","classedFalse","classedFunction","join","splice","contains","textRemove","textContent","textConstant","textFunction","htmlRemove","innerHTML","htmlConstant","htmlFunction","raise","nextSibling","lower","previousSibling","firstChild","creatorInherit","uri","documentElement","createElement","createElementNS","creatorFixed","create","creator","constantNull","before","removeChild","selection_cloneShallow","clone","cloneNode","selection_cloneDeep","deep","property","filterEvents","mouseenter","mouseleave","filterContextListener","listener","index","contextListener","event","related","relatedTarget","event1","event0","onRemove","__on","o","removeEventListener","capture","onAdd","wrap","addEventListener","dispatchEvent","params","window","CustomEvent","createEvent","initEvent","bubbles","cancelable","detail","dispatchConstant","dispatchFunction","selection_select","selectAll","filter","selection_filter","selection_data","selection_enter","selection_exit","selection_merge","selection_nodes","selection_node","selection_size","empty","selection_empty","attr","classed","text","selection_text","html","selection_raise","selection_lower","insert","selection_remove","selection_on","selection_dispatch","factory","extend","definition","Object","Color","darker","brighter","reI","reN","reP","reHex","reRgbInteger","RegExp","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_formatHsl","hslConvert","formatHsl","color_formatRgb","formatRgb","format","l","toLowerCase","exec","parseInt","rgbn","Rgb","rgba","hsla","r","g","rgbConvert","opacity","rgb_formatHex","hex","rgb_formatRgb","isNaN","round","toString","h","s","Hsl","hsl","hsl2rgb","m2","basis","t1","v0","v1","v2","v3","t2","t3","define","channels","assign","displayable","k","values","linear","exponential","y","gamma","nogamma","color","end","rgbGamma","rgbSpline","spline","colors","basisClosed","isNumberArray","ArrayBuffer","isView","DataView","genericArray","nb","na","Date","setTime","reA","reB","source","one","taskHead","taskTail","am","bm","bs","bi","lastIndex","q","numberArray","isArray","valueOf","object","timeout","pokeDelay","clockLast","clockNow","clockSkew","clock","performance","now","setFrame","requestAnimationFrame","setTimeout","clearNow","Timer","_call","_time","timer","delay","time","restart","timerFlush","e","wake","nap","poke","t0","Infinity","sleep","clearTimeout","clearInterval","setInterval","TypeError","elapsed","emptyOn","emptyTween","CREATED","SCHEDULED","STARTING","STARTED","RUNNING","ENDING","ENDED","schedules","__transition","tween","timing","duration","ease","state","init","schedule","self","tick","cssNode","cssRoot","cssView","svgNode","active","interrupt","degrees","PI","translateX","translateY","rotate","skewX","scaleX","scaleY","atan2","atan","parseCss","transform","decompose","parseSvg","baseVal","consolidate","matrix","interpolateTransform","parse","pxComma","pxParen","degParen","pop","translate","xa","ya","xb","yb","scale","interpolateTransformCss","interpolateTransformSvg","tweenRemove","tween0","tween1","tweenFunction","_id","tweenValue","transition","interpolate","value1","string00","interpolate0","string1","string0","string10","attrTween","attrInterpolate","attrInterpolateNS","attrTweenNS","_value","delayFunction","delayConstant","durationFunction","durationConstant","easeConstant","Transition","_name","every","onFunction","on0","on1","sit","removeFunction","children","inherit","styleNull","styleMaybeRemove","listener0","undefined","styleTween","styleInterpolate","textInterpolate","textTween","id0","id1","newId","Promise","resolve","reject","cancel","selection_prototype","cubicInOut","transition_select","transition_selectAll","transition_filter","transition_merge","transition_selection","transition_transition","transition_on","transition_attr","transition_attrTween","transition_style","transition_styleTween","transition_text","transition_textTween","transition_remove","transition_tween","transition_delay","transition_duration","transition_end","defaultTiming","selection_interrupt","selection_transition","number1","number2","cos","sin","tauEpsilon","Path","_x0","_y0","_x1","_y1","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","dx","dy","cw","da","rect","w","Map","has","clear","keys","entries","Set","proto","_x","_y","cover","tree","xm","ym","xp","yp","bottom","_root","leaf","addAll","xz","yz","z","visit","x3","y3","quads","radius","d2","retainer","removeAll","quadtree","Quadtree","leaf_copy","treeProto","target","extent","find","root","visitAfter","random","randomUniform","sourceRandomUniform","randomNormal","mu","sigma","sourceRandomNormal","randomLogNormal","normal","exp","sourceRandomLogNormal","randomIrwinHall","sum","sourceRandomIrwinHall","randomBates","irwinHall","sourceRandomBates","randomExponential","lambda","sourceRandomExponential","initRange","domain","range","unit","normalize","clamper","bimap","d0","d1","r0","r1","polymap","clamp","unknown","transformer","untransform","piecewise","output","input","rescale","invert","rangeRound","u","continuous","re","formatSpecifier","specifier","FormatSpecifier","fill","align","sign","symbol","zero","width","comma","precision","toLocaleString","replace","formatDecimalParts","p","toExponential","coefficient","prefixExponent","grouping","substring","thousands","numerals","out","exponent","toFixed","formatDecimal","toPrecision","formatRounded","formatPrefixAuto","toUpperCase","prefixes","locale","formatGroup","Number","currencyPrefix","currency","currencySuffix","decimal","formatNumerals","String","percent","minus","nan","newFormat","formatTypes","suffix","formatType","maybeSuffix","valuePrefix","valueSuffix","valueNegative","formatTrim","charCodeAt","padding","formatPrefix","defaultLocale","precisionPrefix","precisionRound","precisionFixed","linearish","tickFormat","nice","newInterval","floori","offseti","field","interval","date","offset","setMonth","setHours","setFullYear","getFullYear","setDate","getMonth","durationSecond","durationMinute","durationHour","durationDay","durationWeek","weekday","getDate","getDay","getTimezoneOffset","sunday","monday","tuesday","wednesday","thursday","friday","saturday","getMilliseconds","getSeconds","getMinutes","getHours","getUTCSeconds","utcWeekday","setUTCDate","getUTCDate","getUTCDay","setUTCHours","utcSunday","utcMonday","utcTuesday","utcWednesday","utcThursday","utcFriday","utcSaturday","utcDay","utcYear","setUTCMonth","setUTCFullYear","getUTCFullYear","localDate","H","M","S","L","utcDate","UTC","newDate","formatLocale","locale_dateTime","dateTime","locale_date","locale_time","locale_periods","periods","locale_weekdays","days","locale_shortWeekdays","shortDays","locale_months","months","locale_shortMonths","shortMonths","periodRe","formatRe","periodLookup","formatLookup","weekdayRe","weekdayLookup","shortWeekdayRe","shortWeekdayLookup","monthRe","monthLookup","shortMonthRe","shortMonthLookup","formats","formatShortWeekday","formatWeekday","formatShortMonth","formatMonth","formatDayOfMonth","formatMicroseconds","formatYearISO","formatFullYearISO","formatHour24","formatHour12","formatDayOfYear","formatMilliseconds","formatMonthNumber","formatMinutes","formatPeriod","formatQuarter","formatUnixTimestamp","formatUnixTimestampSeconds","formatSeconds","formatWeekdayNumberMonday","formatWeekNumberSunday","formatWeekNumberISO","formatWeekdayNumberSunday","formatWeekNumberMonday","formatFullYear","formatZone","formatLiteralPercent","utcFormats","formatUTCShortWeekday","formatUTCWeekday","formatUTCShortMonth","formatUTCMonth","formatUTCDayOfMonth","formatUTCMicroseconds","formatUTCYearISO","formatUTCFullYearISO","formatUTCHour24","formatUTCHour12","formatUTCDayOfYear","formatUTCMilliseconds","formatUTCMonthNumber","formatUTCMinutes","formatUTCPeriod","formatUTCQuarter","formatUTCSeconds","formatUTCWeekdayNumberMonday","formatUTCWeekNumberSunday","formatUTCWeekNumberISO","formatUTCWeekdayNumberSunday","formatUTCWeekNumberMonday","formatUTCYear","formatUTCFullYear","formatUTCZone","parses","parseShortWeekday","parseWeekday","parseShortMonth","parseMonth","parseLocaleDateTime","parseDayOfMonth","parseMicroseconds","parseYear","parseFullYear","parseHour24","parseDayOfYear","parseMilliseconds","parseMonthNumber","parseMinutes","parsePeriod","parseQuarter","parseUnixTimestamp","parseUnixTimestampSeconds","parseSeconds","parseWeekdayNumberMonday","parseWeekNumberSunday","parseWeekNumberISO","parseWeekdayNumberSunday","parseWeekNumberMonday","parseLocaleDate","parseLocaleTime","parseZone","parseLiteralPercent","pad","pads","charAt","newParse","Z","week","day","parseSpecifier","Q","V","getUTCMonth","W","U","getUTCHours","X","utcFormat","utcParse","numberRe","percentRe","requoteRe","requote","dISO","getUTCMilliseconds","getUTCMinutes","dow","UTCdISO","utcMonth","utcHour","setUTCMinutes","utcMinute","setUTCSeconds","RedBlackTree","RedBlackNode","C","R","P","N","RedBlackRotateLeft","RedBlackRotateRight","RedBlackFirst","after","grandpa","uncle","sibling","createEdge","edge","setEdgeEnd","cells","halfedges","createBorderEdge","vertex","clipEdge","ax","ay","bx","by","connectEdge","fm","fb","lx","ly","rx","ry","fx","fy","clipEdges","createCell","site","cellHalfedgeAngle","cell","va","vb","cellHalfedgeStart","cellHalfedgeEnd","sortCellHalfedges","array","clipCells","iCell","iHalfedge","nHalfedges","startX","startY","endX","endY","nCells","dc","v00","v01","v11","v10","firstCircle","circlePool","Circle","cy","attachCircle","lArc","rArc","lSite","cSite","rSite","cx","epsilon2","ha","hc","circle","circles","detachCircle","beachPool","Beach","createBeach","beach","detachBeach","beaches","removeBeach","disappearing","unshift","iArc","nArcs","addBeach","dxl","dxr","directrix","leftBreakPoint","rightBreakPoint","newArc","hb","rfocx","rfocy","pby2","lfocx","lfocy","plby2","hl","aby2","triangleArea","lexicographic","Diagram","sites","edges","polygons","polygon","triangles","forEach","s0","e1","s1","links","_found","vx","vy","SQRT2","Transform","point","applyX","applyY","location","invertX","invertY","rescaleX","rescaleY","__zoom","throttle","handlerFunc","resizeTimeout","props","mapData","default","points","randomString","color1","color2","highlightFillColor","borderColor","highlightBorderColor","bubbleHighlightFillColor","bubbleFillColor","methods","generateColors","generateMapColors","defaultFill","fills","val","fillKey","possible","component","DESCRIPTORS","getKeys","toIObject","isEnum","module","exports","isEntries","it","O","result","$export","$values","global","transformAbsolute","kx","ky","transformRelative","feature","topology","features","geometries","feature$1","properties","geometry","absolute","arcs","line","ring","geometryType","coordinates","Point","MultiPoint","LineString","MultiLineString","Polygon","MultiPolygon","stitchArcs","stitchedArcs","fragmentByStart","fragmentByEnd","fragments","emptyIndex","ends","p1","p0","dp","flush","fg","gf","mesh","meshArcs","geomsByArc","geom","geoms","cartesianTriangleArea","triangle","area","mergeArcs","objects","polygonsByArc","components","register","ring$$","neighbors","ki","indexesByArc","indexes","ij","ik","compareArea","minAreaHeap","heap","up","down","removed","presimplify","relative","maxArea","version","defineProperty"],"mappings":"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","file":"js/chunk-47475f48.5913def5.js","sourcesContent":["var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"world-map\",attrs:{\"id\":_vm.id}})}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","export default function(a, b) {\n return a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","import ascending from \"./ascending\";\n\nexport default function(compare) {\n if (compare.length === 1) compare = ascendingComparator(compare);\n return {\n left: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n }\n return lo;\n },\n right: function(a, x, lo, hi) {\n if (lo == null) lo = 0;\n if (hi == null) hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (compare(a[mid], x) > 0) hi = mid;\n else lo = mid + 1;\n }\n return lo;\n }\n };\n}\n\nfunction ascendingComparator(f) {\n return function(d, x) {\n return ascending(f(d), x);\n };\n}\n","import ascending from \"./ascending\";\nimport bisector from \"./bisector\";\n\nvar ascendingBisect = bisector(ascending);\nexport var bisectRight = ascendingBisect.right;\nexport var bisectLeft = ascendingBisect.left;\nexport default bisectRight;\n","import {pair} from \"./pairs\";\n\nexport default function(values0, values1, reduce) {\n var n0 = values0.length,\n n1 = values1.length,\n values = new Array(n0 * n1),\n i0,\n i1,\n i,\n value0;\n\n if (reduce == null) reduce = pair;\n\n for (i0 = i = 0; i0 < n0; ++i0) {\n for (value0 = values0[i0], i1 = 0; i1 < n1; ++i1, ++i) {\n values[i] = reduce(value0, values1[i1]);\n }\n }\n\n return values;\n}\n","var array = Array.prototype;\n\nexport var slice = array.slice;\nexport var map = array.map;\n","var e10 = Math.sqrt(50),\n e5 = Math.sqrt(10),\n e2 = Math.sqrt(2);\n\nexport default function(start, stop, count) {\n var reverse,\n i = -1,\n n,\n ticks,\n step;\n\n stop = +stop, start = +start, count = +count;\n if (start === stop && count > 0) return [start];\n if (reverse = stop < start) n = start, start = stop, stop = n;\n if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];\n\n if (step > 0) {\n start = Math.ceil(start / step);\n stop = Math.floor(stop / step);\n ticks = new Array(n = Math.ceil(stop - start + 1));\n while (++i < n) ticks[i] = (start + i) * step;\n } else {\n start = Math.floor(start * step);\n stop = Math.ceil(stop * step);\n ticks = new Array(n = Math.ceil(start - stop + 1));\n while (++i < n) ticks[i] = (start - i) / step;\n }\n\n if (reverse) ticks.reverse();\n\n return ticks;\n}\n\nexport function tickIncrement(start, stop, count) {\n var step = (stop - start) / Math.max(0, count),\n power = Math.floor(Math.log(step) / Math.LN10),\n error = step / Math.pow(10, power);\n return power >= 0\n ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)\n : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);\n}\n\nexport function tickStep(start, stop, count) {\n var step0 = Math.abs(stop - start) / Math.max(0, count),\n step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n error = step0 / step1;\n if (error >= e10) step1 *= 10;\n else if (error >= e5) step1 *= 5;\n else if (error >= e2) step1 *= 2;\n return stop < start ? -step1 : step1;\n}\n","export var slice = Array.prototype.slice;\n","var noop = {value: function() {}};\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","function none() {}\n\nexport default function(selector) {\n return selector == null ? none : function() {\n return this.querySelector(selector);\n };\n}\n","import {Selection} from \"./index\";\nimport selector from \"../selector\";\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","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\";\nimport selectorAll from \"../selectorAll\";\n\nexport default function(select) {\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 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","export default function(selector) {\n return function() {\n return this.matches(selector);\n };\n}\n","import {Selection} from \"./index\";\nimport matcher from \"../matcher\";\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(update) {\n return new Array(update.length);\n}\n","import sparse from \"./sparse\";\nimport {Selection} from \"./index\";\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","export default function(x) {\n return function() {\n return x;\n };\n}\n","import {Selection} from \"./index\";\nimport {EnterNode} from \"./enter\";\nimport constant from \"../constant\";\n\nvar keyPrefix = \"$\"; // Protect against keys like “__proto__”.\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 = {},\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 = keyPrefix + key.call(node, node.__data__, i, group);\n if (keyValue in nodeByKeyValue) {\n exit[i] = node;\n } else {\n nodeByKeyValue[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 = keyPrefix + key.call(parent, data[i], i, data);\n if (node = nodeByKeyValue[keyValue]) {\n update[i] = node;\n node.__data__ = data[i];\n nodeByKeyValue[keyValue] = null;\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[keyValues[i]] === node)) {\n exit[i] = node;\n }\n }\n}\n\nexport default function(value, key) {\n if (!value) {\n data = new Array(this.size()), j = -1;\n this.each(function(d) { data[++j] = d; });\n return data;\n }\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 = 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","import sparse from \"./sparse\";\nimport {Selection} from \"./index\";\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 enter = typeof onenter === \"function\" ? onenter(enter) : enter.append(onenter + \"\");\n if (onupdate != null) update = onupdate(update);\n if (onexit == null) exit.remove(); else onexit(exit);\n return enter && update ? enter.merge(update).order() : update;\n}\n","import {Selection} from \"./index\";\n\nexport default function(selection) {\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","import {Selection} from \"./index\";\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","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 var nodes = new Array(this.size()), i = -1;\n this.each(function() { nodes[++i] = this; });\n return nodes;\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 var size = 0;\n this.each(function() { ++size; });\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","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\";\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;\n}\n","import namespace from \"../namespace\";\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\";\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 namespace from \"./namespace\";\nimport {xhtml} from \"./namespaces\";\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","import creator from \"../creator\";\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","import creator from \"../creator\";\nimport selector from \"../selector\";\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","export default function(value) {\n return arguments.length\n ? this.property(\"__data__\", value)\n : this.node().__data__;\n}\n","var filterEvents = {};\n\nexport var event = null;\n\nif (typeof document !== \"undefined\") {\n var element = document.documentElement;\n if (!(\"onmouseenter\" in element)) {\n filterEvents = {mouseenter: \"mouseover\", mouseleave: \"mouseout\"};\n }\n}\n\nfunction filterContextListener(listener, index, group) {\n listener = contextListener(listener, index, group);\n return function(event) {\n var related = event.relatedTarget;\n if (!related || (related !== this && !(related.compareDocumentPosition(this) & 8))) {\n listener.call(this, event);\n }\n };\n}\n\nfunction contextListener(listener, index, group) {\n return function(event1) {\n var event0 = event; // Events can be reentrant (e.g., focus).\n event = event1;\n try {\n listener.call(this, this.__data__, index, group);\n } finally {\n event = event0;\n }\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.capture);\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, capture) {\n var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;\n return function(d, i, group) {\n var on = this.__on, o, listener = wrap(value, i, group);\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.capture);\n this.addEventListener(o.type, o.listener = listener, o.capture = capture);\n o.value = value;\n return;\n }\n }\n this.addEventListener(typename.type, listener, capture);\n o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};\n if (!on) this.__on = [o];\n else on.push(o);\n };\n}\n\nexport default function(typename, value, capture) {\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 if (capture == null) capture = false;\n for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));\n return this;\n}\n\nexport function customEvent(event1, listener, that, args) {\n var event0 = event;\n event1.sourceEvent = event;\n event = event1;\n try {\n return listener.apply(that, args);\n } finally {\n event = event0;\n }\n}\n","import defaultView from \"../window\";\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\";\nimport selection_selectAll from \"./selectAll\";\nimport selection_filter from \"./filter\";\nimport selection_data from \"./data\";\nimport selection_enter from \"./enter\";\nimport selection_exit from \"./exit\";\nimport selection_join from \"./join\";\nimport selection_merge from \"./merge\";\nimport selection_order from \"./order\";\nimport selection_sort from \"./sort\";\nimport selection_call from \"./call\";\nimport selection_nodes from \"./nodes\";\nimport selection_node from \"./node\";\nimport selection_size from \"./size\";\nimport selection_empty from \"./empty\";\nimport selection_each from \"./each\";\nimport selection_attr from \"./attr\";\nimport selection_style from \"./style\";\nimport selection_property from \"./property\";\nimport selection_classed from \"./classed\";\nimport selection_text from \"./text\";\nimport selection_html from \"./html\";\nimport selection_raise from \"./raise\";\nimport selection_lower from \"./lower\";\nimport selection_append from \"./append\";\nimport selection_insert from \"./insert\";\nimport selection_remove from \"./remove\";\nimport selection_clone from \"./clone\";\nimport selection_datum from \"./datum\";\nimport selection_on from \"./on\";\nimport selection_dispatch from \"./dispatch\";\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\nSelection.prototype = selection.prototype = {\n constructor: Selection,\n select: selection_select,\n selectAll: selection_selectAll,\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 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};\n\nexport default selection;\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: function(channels) {\n return Object.assign(new this.constructor, this, channels);\n },\n displayable: function() {\n return this.rgb().displayable();\n },\n hex: color_formatHex, // Deprecated! Use color.formatHex.\n formatHex: color_formatHex,\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_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: function(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: function(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: function() {\n return this;\n },\n displayable: function() {\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 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_formatRgb() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"rgb(\" : \"rgba(\")\n + Math.max(0, Math.min(255, Math.round(this.r) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.g) || 0)) + \", \"\n + Math.max(0, Math.min(255, Math.round(this.b) || 0))\n + (a === 1 ? \")\" : \", \" + a + \")\");\n}\n\nfunction hex(value) {\n value = Math.max(0, Math.min(255, Math.round(value) || 0));\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: function(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: function(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: function() {\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 displayable: function() {\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: function() {\n var a = this.opacity; a = isNaN(a) ? 1 : Math.max(0, Math.min(1, a));\n return (a === 1 ? \"hsl(\" : \"hsla(\")\n + (this.h || 0) + \", \"\n + (this.s || 0) * 100 + \"%, \"\n + (this.l || 0) * 100 + \"%\"\n + (a === 1 ? \")\" : \", \" + a + \")\");\n }\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 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","import {basis} from \"./basis.js\";\n\nexport default function(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","export default function(x) {\n return function() {\n return x;\n };\n}\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 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","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(null, 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 {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","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(function(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 {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","import decompose, {identity} from \"./decompose.js\";\n\nvar cssNode,\n cssRoot,\n cssView,\n svgNode;\n\nexport function parseCss(value) {\n if (value === \"none\") return identity;\n if (!cssNode) cssNode = document.createElement(\"DIV\"), cssRoot = document.documentElement, cssView = document.defaultView;\n cssNode.style.transform = value;\n value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue(\"transform\");\n cssRoot.removeChild(cssNode);\n value = value.slice(7, -1).split(\",\");\n return decompose(+value[0], +value[1], +value[2], +value[3], +value[4], +value[5]);\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 interrupt from \"../interrupt.js\";\n\nexport default function(name) {\n return this.each(function() {\n interrupt(this, name);\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 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 {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 {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 {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 {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 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 {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 {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","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","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 {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}\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_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 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 end: transition_end\n};\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 return defaultTiming.time = now(), defaultTiming;\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 {dispatch} from \"d3-dispatch\";\nimport {dragDisable, dragEnable} from \"d3-drag\";\nimport {interpolate} from \"d3-interpolate\";\nimport {customEvent, event, touch, mouse, select} from \"d3-selection\";\nimport {interrupt} from \"d3-transition\";\nimport constant from \"./constant.js\";\nimport BrushEvent from \"./event.js\";\nimport noevent, {nopropagation} from \"./noevent.js\";\n\nvar MODE_DRAG = {name: \"drag\"},\n MODE_SPACE = {name: \"space\"},\n MODE_HANDLE = {name: \"handle\"},\n MODE_CENTER = {name: \"center\"};\n\nfunction number1(e) {\n return [+e[0], +e[1]];\n}\n\nfunction number2(e) {\n return [number1(e[0]), number1(e[1])];\n}\n\nfunction toucher(identifier) {\n return function(target) {\n return touch(target, event.touches, identifier);\n };\n}\n\nvar X = {\n name: \"x\",\n handles: [\"w\", \"e\"].map(type),\n input: function(x, e) { return x == null ? null : [[+x[0], e[0][1]], [+x[1], e[1][1]]]; },\n output: function(xy) { return xy && [xy[0][0], xy[1][0]]; }\n};\n\nvar Y = {\n name: \"y\",\n handles: [\"n\", \"s\"].map(type),\n input: function(y, e) { return y == null ? null : [[e[0][0], +y[0]], [e[1][0], +y[1]]]; },\n output: function(xy) { return xy && [xy[0][1], xy[1][1]]; }\n};\n\nvar XY = {\n name: \"xy\",\n handles: [\"n\", \"w\", \"e\", \"s\", \"nw\", \"ne\", \"sw\", \"se\"].map(type),\n input: function(xy) { return xy == null ? null : number2(xy); },\n output: function(xy) { return xy; }\n};\n\nvar cursors = {\n overlay: \"crosshair\",\n selection: \"move\",\n n: \"ns-resize\",\n e: \"ew-resize\",\n s: \"ns-resize\",\n w: \"ew-resize\",\n nw: \"nwse-resize\",\n ne: \"nesw-resize\",\n se: \"nwse-resize\",\n sw: \"nesw-resize\"\n};\n\nvar flipX = {\n e: \"w\",\n w: \"e\",\n nw: \"ne\",\n ne: \"nw\",\n se: \"sw\",\n sw: \"se\"\n};\n\nvar flipY = {\n n: \"s\",\n s: \"n\",\n nw: \"sw\",\n ne: \"se\",\n se: \"ne\",\n sw: \"nw\"\n};\n\nvar signsX = {\n overlay: +1,\n selection: +1,\n n: null,\n e: +1,\n s: null,\n w: -1,\n nw: -1,\n ne: +1,\n se: +1,\n sw: -1\n};\n\nvar signsY = {\n overlay: +1,\n selection: +1,\n n: -1,\n e: null,\n s: +1,\n w: null,\n nw: -1,\n ne: -1,\n se: +1,\n sw: +1\n};\n\nfunction type(t) {\n return {type: t};\n}\n\n// Ignore right-click, since that should open the context menu.\nfunction defaultFilter() {\n return !event.ctrlKey && !event.button;\n}\n\nfunction defaultExtent() {\n var svg = this.ownerSVGElement || this;\n if (svg.hasAttribute(\"viewBox\")) {\n svg = svg.viewBox.baseVal;\n return [[svg.x, svg.y], [svg.x + svg.width, svg.y + svg.height]];\n }\n return [[0, 0], [svg.width.baseVal.value, svg.height.baseVal.value]];\n}\n\nfunction defaultTouchable() {\n return navigator.maxTouchPoints || (\"ontouchstart\" in this);\n}\n\n// Like d3.local, but with the name “__brush” rather than auto-generated.\nfunction local(node) {\n while (!node.__brush) if (!(node = node.parentNode)) return;\n return node.__brush;\n}\n\nfunction empty(extent) {\n return extent[0][0] === extent[1][0]\n || extent[0][1] === extent[1][1];\n}\n\nexport function brushSelection(node) {\n var state = node.__brush;\n return state ? state.dim.output(state.selection) : null;\n}\n\nexport function brushX() {\n return brush(X);\n}\n\nexport function brushY() {\n return brush(Y);\n}\n\nexport default function() {\n return brush(XY);\n}\n\nfunction brush(dim) {\n var extent = defaultExtent,\n filter = defaultFilter,\n touchable = defaultTouchable,\n keys = true,\n listeners = dispatch(\"start\", \"brush\", \"end\"),\n handleSize = 6,\n touchending;\n\n function brush(group) {\n var overlay = group\n .property(\"__brush\", initialize)\n .selectAll(\".overlay\")\n .data([type(\"overlay\")]);\n\n overlay.enter().append(\"rect\")\n .attr(\"class\", \"overlay\")\n .attr(\"pointer-events\", \"all\")\n .attr(\"cursor\", cursors.overlay)\n .merge(overlay)\n .each(function() {\n var extent = local(this).extent;\n select(this)\n .attr(\"x\", extent[0][0])\n .attr(\"y\", extent[0][1])\n .attr(\"width\", extent[1][0] - extent[0][0])\n .attr(\"height\", extent[1][1] - extent[0][1]);\n });\n\n group.selectAll(\".selection\")\n .data([type(\"selection\")])\n .enter().append(\"rect\")\n .attr(\"class\", \"selection\")\n .attr(\"cursor\", cursors.selection)\n .attr(\"fill\", \"#777\")\n .attr(\"fill-opacity\", 0.3)\n .attr(\"stroke\", \"#fff\")\n .attr(\"shape-rendering\", \"crispEdges\");\n\n var handle = group.selectAll(\".handle\")\n .data(dim.handles, function(d) { return d.type; });\n\n handle.exit().remove();\n\n handle.enter().append(\"rect\")\n .attr(\"class\", function(d) { return \"handle handle--\" + d.type; })\n .attr(\"cursor\", function(d) { return cursors[d.type]; });\n\n group\n .each(redraw)\n .attr(\"fill\", \"none\")\n .attr(\"pointer-events\", \"all\")\n .on(\"mousedown.brush\", started)\n .filter(touchable)\n .on(\"touchstart.brush\", started)\n .on(\"touchmove.brush\", touchmoved)\n .on(\"touchend.brush touchcancel.brush\", touchended)\n .style(\"touch-action\", \"none\")\n .style(\"-webkit-tap-highlight-color\", \"rgba(0,0,0,0)\");\n }\n\n brush.move = function(group, selection) {\n if (group.selection) {\n group\n .on(\"start.brush\", function() { emitter(this, arguments).beforestart().start(); })\n .on(\"interrupt.brush end.brush\", function() { emitter(this, arguments).end(); })\n .tween(\"brush\", function() {\n var that = this,\n state = that.__brush,\n emit = emitter(that, arguments),\n selection0 = state.selection,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(this, arguments) : selection, state.extent),\n i = interpolate(selection0, selection1);\n\n function tween(t) {\n state.selection = t === 1 && selection1 === null ? null : i(t);\n redraw.call(that);\n emit.brush();\n }\n\n return selection0 !== null && selection1 !== null ? tween : tween(1);\n });\n } else {\n group\n .each(function() {\n var that = this,\n args = arguments,\n state = that.__brush,\n selection1 = dim.input(typeof selection === \"function\" ? selection.apply(that, args) : selection, state.extent),\n emit = emitter(that, args).beforestart();\n\n interrupt(that);\n state.selection = selection1 === null ? null : selection1;\n redraw.call(that);\n emit.start().brush().end();\n });\n }\n };\n\n brush.clear = function(group) {\n brush.move(group, null);\n };\n\n function redraw() {\n var group = select(this),\n selection = local(this).selection;\n\n if (selection) {\n group.selectAll(\".selection\")\n .style(\"display\", null)\n .attr(\"x\", selection[0][0])\n .attr(\"y\", selection[0][1])\n .attr(\"width\", selection[1][0] - selection[0][0])\n .attr(\"height\", selection[1][1] - selection[0][1]);\n\n group.selectAll(\".handle\")\n .style(\"display\", null)\n .attr(\"x\", function(d) { return d.type[d.type.length - 1] === \"e\" ? selection[1][0] - handleSize / 2 : selection[0][0] - handleSize / 2; })\n .attr(\"y\", function(d) { return d.type[0] === \"s\" ? selection[1][1] - handleSize / 2 : selection[0][1] - handleSize / 2; })\n .attr(\"width\", function(d) { return d.type === \"n\" || d.type === \"s\" ? selection[1][0] - selection[0][0] + handleSize : handleSize; })\n .attr(\"height\", function(d) { return d.type === \"e\" || d.type === \"w\" ? selection[1][1] - selection[0][1] + handleSize : handleSize; });\n }\n\n else {\n group.selectAll(\".selection,.handle\")\n .style(\"display\", \"none\")\n .attr(\"x\", null)\n .attr(\"y\", null)\n .attr(\"width\", null)\n .attr(\"height\", null);\n }\n }\n\n function emitter(that, args, clean) {\n var emit = that.__brush.emitter;\n return emit && (!clean || !emit.clean) ? emit : new Emitter(that, args, clean);\n }\n\n function Emitter(that, args, clean) {\n this.that = that;\n this.args = args;\n this.state = that.__brush;\n this.active = 0;\n this.clean = clean;\n }\n\n Emitter.prototype = {\n beforestart: function() {\n if (++this.active === 1) this.state.emitter = this, this.starting = true;\n return this;\n },\n start: function() {\n if (this.starting) this.starting = false, this.emit(\"start\");\n else this.emit(\"brush\");\n return this;\n },\n brush: function() {\n this.emit(\"brush\");\n return this;\n },\n end: function() {\n if (--this.active === 0) delete this.state.emitter, this.emit(\"end\");\n return this;\n },\n emit: function(type) {\n customEvent(new BrushEvent(brush, type, dim.output(this.state.selection)), listeners.apply, listeners, [type, this.that, this.args]);\n }\n };\n\n function started() {\n if (touchending && !event.touches) return;\n if (!filter.apply(this, arguments)) return;\n\n var that = this,\n type = event.target.__data__.type,\n mode = (keys && event.metaKey ? type = \"overlay\" : type) === \"selection\" ? MODE_DRAG : (keys && event.altKey ? MODE_CENTER : MODE_HANDLE),\n signX = dim === Y ? null : signsX[type],\n signY = dim === X ? null : signsY[type],\n state = local(that),\n extent = state.extent,\n selection = state.selection,\n W = extent[0][0], w0, w1,\n N = extent[0][1], n0, n1,\n E = extent[1][0], e0, e1,\n S = extent[1][1], s0, s1,\n dx = 0,\n dy = 0,\n moving,\n shifting = signX && signY && keys && event.shiftKey,\n lockX,\n lockY,\n pointer = event.touches ? toucher(event.changedTouches[0].identifier) : mouse,\n point0 = pointer(that),\n point = point0,\n emit = emitter(that, arguments, true).beforestart();\n\n if (type === \"overlay\") {\n if (selection) moving = true;\n state.selection = selection = [\n [w0 = dim === Y ? W : point0[0], n0 = dim === X ? N : point0[1]],\n [e0 = dim === Y ? E : w0, s0 = dim === X ? S : n0]\n ];\n } else {\n w0 = selection[0][0];\n n0 = selection[0][1];\n e0 = selection[1][0];\n s0 = selection[1][1];\n }\n\n w1 = w0;\n n1 = n0;\n e1 = e0;\n s1 = s0;\n\n var group = select(that)\n .attr(\"pointer-events\", \"none\");\n\n var overlay = group.selectAll(\".overlay\")\n .attr(\"cursor\", cursors[type]);\n\n if (event.touches) {\n emit.moved = moved;\n emit.ended = ended;\n } else {\n var view = select(event.view)\n .on(\"mousemove.brush\", moved, true)\n .on(\"mouseup.brush\", ended, true);\n if (keys) view\n .on(\"keydown.brush\", keydowned, true)\n .on(\"keyup.brush\", keyupped, true)\n\n dragDisable(event.view);\n }\n\n nopropagation();\n interrupt(that);\n redraw.call(that);\n emit.start();\n\n function moved() {\n var point1 = pointer(that);\n if (shifting && !lockX && !lockY) {\n if (Math.abs(point1[0] - point[0]) > Math.abs(point1[1] - point[1])) lockY = true;\n else lockX = true;\n }\n point = point1;\n moving = true;\n noevent();\n move();\n }\n\n function move() {\n var t;\n\n dx = point[0] - point0[0];\n dy = point[1] - point0[1];\n\n switch (mode) {\n case MODE_SPACE:\n case MODE_DRAG: {\n if (signX) dx = Math.max(W - w0, Math.min(E - e0, dx)), w1 = w0 + dx, e1 = e0 + dx;\n if (signY) dy = Math.max(N - n0, Math.min(S - s0, dy)), n1 = n0 + dy, s1 = s0 + dy;\n break;\n }\n case MODE_HANDLE: {\n if (signX < 0) dx = Math.max(W - w0, Math.min(E - w0, dx)), w1 = w0 + dx, e1 = e0;\n else if (signX > 0) dx = Math.max(W - e0, Math.min(E - e0, dx)), w1 = w0, e1 = e0 + dx;\n if (signY < 0) dy = Math.max(N - n0, Math.min(S - n0, dy)), n1 = n0 + dy, s1 = s0;\n else if (signY > 0) dy = Math.max(N - s0, Math.min(S - s0, dy)), n1 = n0, s1 = s0 + dy;\n break;\n }\n case MODE_CENTER: {\n if (signX) w1 = Math.max(W, Math.min(E, w0 - dx * signX)), e1 = Math.max(W, Math.min(E, e0 + dx * signX));\n if (signY) n1 = Math.max(N, Math.min(S, n0 - dy * signY)), s1 = Math.max(N, Math.min(S, s0 + dy * signY));\n break;\n }\n }\n\n if (e1 < w1) {\n signX *= -1;\n t = w0, w0 = e0, e0 = t;\n t = w1, w1 = e1, e1 = t;\n if (type in flipX) overlay.attr(\"cursor\", cursors[type = flipX[type]]);\n }\n\n if (s1 < n1) {\n signY *= -1;\n t = n0, n0 = s0, s0 = t;\n t = n1, n1 = s1, s1 = t;\n if (type in flipY) overlay.attr(\"cursor\", cursors[type = flipY[type]]);\n }\n\n if (state.selection) selection = state.selection; // May be set by brush.move!\n if (lockX) w1 = selection[0][0], e1 = selection[1][0];\n if (lockY) n1 = selection[0][1], s1 = selection[1][1];\n\n if (selection[0][0] !== w1\n || selection[0][1] !== n1\n || selection[1][0] !== e1\n || selection[1][1] !== s1) {\n state.selection = [[w1, n1], [e1, s1]];\n redraw.call(that);\n emit.brush();\n }\n }\n\n function ended() {\n nopropagation();\n if (event.touches) {\n if (event.touches.length) return;\n if (touchending) clearTimeout(touchending);\n touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!\n } else {\n dragEnable(event.view, moving);\n view.on(\"keydown.brush keyup.brush mousemove.brush mouseup.brush\", null);\n }\n group.attr(\"pointer-events\", \"all\");\n overlay.attr(\"cursor\", cursors.overlay);\n if (state.selection) selection = state.selection; // May be set by brush.move (on start)!\n if (empty(selection)) state.selection = null, redraw.call(that);\n emit.end();\n }\n\n function keydowned() {\n switch (event.keyCode) {\n case 16: { // SHIFT\n shifting = signX && signY;\n break;\n }\n case 18: { // ALT\n if (mode === MODE_HANDLE) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n move();\n }\n break;\n }\n case 32: { // SPACE; takes priority over ALT\n if (mode === MODE_HANDLE || mode === MODE_CENTER) {\n if (signX < 0) e0 = e1 - dx; else if (signX > 0) w0 = w1 - dx;\n if (signY < 0) s0 = s1 - dy; else if (signY > 0) n0 = n1 - dy;\n mode = MODE_SPACE;\n overlay.attr(\"cursor\", cursors.selection);\n move();\n }\n break;\n }\n default: return;\n }\n noevent();\n }\n\n function keyupped() {\n switch (event.keyCode) {\n case 16: { // SHIFT\n if (shifting) {\n lockX = lockY = shifting = false;\n move();\n }\n break;\n }\n case 18: { // ALT\n if (mode === MODE_CENTER) {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n move();\n }\n break;\n }\n case 32: { // SPACE\n if (mode === MODE_SPACE) {\n if (event.altKey) {\n if (signX) e0 = e1 - dx * signX, w0 = w1 + dx * signX;\n if (signY) s0 = s1 - dy * signY, n0 = n1 + dy * signY;\n mode = MODE_CENTER;\n } else {\n if (signX < 0) e0 = e1; else if (signX > 0) w0 = w1;\n if (signY < 0) s0 = s1; else if (signY > 0) n0 = n1;\n mode = MODE_HANDLE;\n }\n overlay.attr(\"cursor\", cursors[type]);\n move();\n }\n break;\n }\n default: return;\n }\n noevent();\n }\n }\n\n function touchmoved() {\n emitter(this, arguments).moved();\n }\n\n function touchended() {\n emitter(this, arguments).ended();\n }\n\n function initialize() {\n var state = this.__brush || {selection: null};\n state.extent = number2(extent.apply(this, arguments));\n state.dim = dim;\n return state;\n }\n\n brush.extent = function(_) {\n return arguments.length ? (extent = typeof _ === \"function\" ? _ : constant(number2(_)), brush) : extent;\n };\n\n brush.filter = function(_) {\n return arguments.length ? (filter = typeof _ === \"function\" ? _ : constant(!!_), brush) : filter;\n };\n\n brush.touchable = function(_) {\n return arguments.length ? (touchable = typeof _ === \"function\" ? _ : constant(!!_), brush) : touchable;\n };\n\n brush.handleSize = function(_) {\n return arguments.length ? (handleSize = +_, brush) : handleSize;\n };\n\n brush.keyModifiers = function(_) {\n return arguments.length ? (keys = !!_, brush) : keys;\n };\n\n brush.on = function() {\n var value = listeners.on.apply(listeners, arguments);\n return value === listeners ? brush : value;\n };\n\n return brush;\n}\n","export var cos = Math.cos;\nexport var sin = Math.sin;\nexport var pi = Math.PI;\nexport var halfPi = pi / 2;\nexport var tau = pi * 2;\nexport var max = Math.max;\n","export var slice = Array.prototype.slice;\n","import {range} from \"d3-array\";\nimport {max, tau} from \"./math\";\n\nfunction compareValue(compare) {\n return function(a, b) {\n return compare(\n a.source.value + a.target.value,\n b.source.value + b.target.value\n );\n };\n}\n\nexport default function() {\n var padAngle = 0,\n sortGroups = null,\n sortSubgroups = null,\n sortChords = null;\n\n function chord(matrix) {\n var n = matrix.length,\n groupSums = [],\n groupIndex = range(n),\n subgroupIndex = [],\n chords = [],\n groups = chords.groups = new Array(n),\n subgroups = new Array(n * n),\n k,\n x,\n x0,\n dx,\n i,\n j;\n\n // Compute the sum.\n k = 0, i = -1; while (++i < n) {\n x = 0, j = -1; while (++j < n) {\n x += matrix[i][j];\n }\n groupSums.push(x);\n subgroupIndex.push(range(n));\n k += x;\n }\n\n // Sort groups…\n if (sortGroups) groupIndex.sort(function(a, b) {\n return sortGroups(groupSums[a], groupSums[b]);\n });\n\n // Sort subgroups…\n if (sortSubgroups) subgroupIndex.forEach(function(d, i) {\n d.sort(function(a, b) {\n return sortSubgroups(matrix[i][a], matrix[i][b]);\n });\n });\n\n // Convert the sum to scaling factor for [0, 2pi].\n // TODO Allow start and end angle to be specified?\n // TODO Allow padding to be specified as percentage?\n k = max(0, tau - padAngle * n) / k;\n dx = k ? padAngle : tau / n;\n\n // Compute the start and end angle for each group and subgroup.\n // Note: Opera has a bug reordering object literal properties!\n x = 0, i = -1; while (++i < n) {\n x0 = x, j = -1; while (++j < n) {\n var di = groupIndex[i],\n dj = subgroupIndex[di][j],\n v = matrix[di][dj],\n a0 = x,\n a1 = x += v * k;\n subgroups[dj * n + di] = {\n index: di,\n subindex: dj,\n startAngle: a0,\n endAngle: a1,\n value: v\n };\n }\n groups[di] = {\n index: di,\n startAngle: x0,\n endAngle: x,\n value: groupSums[di]\n };\n x += dx;\n }\n\n // Generate chords for each (non-empty) subgroup-subgroup link.\n i = -1; while (++i < n) {\n j = i - 1; while (++j < n) {\n var source = subgroups[j * n + i],\n target = subgroups[i * n + j];\n if (source.value || target.value) {\n chords.push(source.value < target.value\n ? {source: target, target: source}\n : {source: source, target: target});\n }\n }\n }\n\n return sortChords ? chords.sort(sortChords) : chords;\n }\n\n chord.padAngle = function(_) {\n return arguments.length ? (padAngle = max(0, _), chord) : padAngle;\n };\n\n chord.sortGroups = function(_) {\n return arguments.length ? (sortGroups = _, chord) : sortGroups;\n };\n\n chord.sortSubgroups = function(_) {\n return arguments.length ? (sortSubgroups = _, chord) : sortSubgroups;\n };\n\n chord.sortChords = function(_) {\n return arguments.length ? (_ == null ? sortChords = null : (sortChords = compareValue(_))._ = _, chord) : sortChords && sortChords._;\n };\n\n return chord;\n}\n","var pi = Math.PI,\n tau = 2 * pi,\n epsilon = 1e-6,\n tauEpsilon = tau - epsilon;\n\nfunction Path() {\n this._x0 = this._y0 = // start of current subpath\n this._x1 = this._y1 = null; // end of current subpath\n this._ = \"\";\n}\n\nfunction path() {\n return new Path;\n}\n\nPath.prototype = path.prototype = {\n constructor: Path,\n moveTo: function(x, y) {\n this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y);\n },\n closePath: function() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._ += \"Z\";\n }\n },\n lineTo: function(x, y) {\n this._ += \"L\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n quadraticCurveTo: function(x1, y1, x, y) {\n this._ += \"Q\" + (+x1) + \",\" + (+y1) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) {\n this._ += \"C\" + (+x1) + \",\" + (+y1) + \",\" + (+x2) + \",\" + (+y2) + \",\" + (this._x1 = +x) + \",\" + (this._y1 = +y);\n },\n arcTo: function(x1, y1, x2, y2, r) {\n x1 = +x1, y1 = +y1, x2 = +x2, y2 = +y2, r = +r;\n var 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 the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x1,y1).\n if (this._x1 === null) {\n this._ += \"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._ += \"L\" + (this._x1 = x1) + \",\" + (this._y1 = y1);\n }\n\n // Otherwise, draw an arc!\n else {\n var 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._ += \"L\" + (x1 + t01 * x01) + \",\" + (y1 + t01 * y01);\n }\n\n this._ += \"A\" + r + \",\" + r + \",0,0,\" + (+(y01 * x20 > x01 * y20)) + \",\" + (this._x1 = x1 + t21 * x21) + \",\" + (this._y1 = y1 + t21 * y21);\n }\n },\n arc: function(x, y, r, a0, a1, ccw) {\n x = +x, y = +y, r = +r, ccw = !!ccw;\n var 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 the radius negative? Error.\n if (r < 0) throw new Error(\"negative radius: \" + r);\n\n // Is this path empty? Move to (x0,y0).\n if (this._x1 === null) {\n this._ += \"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._ += \"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._ += \"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._ += \"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: function(x, y, w, h) {\n this._ += \"M\" + (this._x0 = this._x1 = +x) + \",\" + (this._y0 = this._y1 = +y) + \"h\" + (+w) + \"v\" + (+h) + \"h\" + (-w) + \"Z\";\n },\n toString: function() {\n return this._;\n }\n};\n\nexport default path;\n","import {slice} from \"./array\";\nimport constant from \"./constant\";\nimport {cos, halfPi, sin} from \"./math\";\nimport {path} from \"d3-path\";\n\nfunction defaultSource(d) {\n return d.source;\n}\n\nfunction defaultTarget(d) {\n return d.target;\n}\n\nfunction defaultRadius(d) {\n return d.radius;\n}\n\nfunction defaultStartAngle(d) {\n return d.startAngle;\n}\n\nfunction defaultEndAngle(d) {\n return d.endAngle;\n}\n\nexport default function() {\n var source = defaultSource,\n target = defaultTarget,\n radius = defaultRadius,\n startAngle = defaultStartAngle,\n endAngle = defaultEndAngle,\n context = null;\n\n function ribbon() {\n var buffer,\n argv = slice.call(arguments),\n s = source.apply(this, argv),\n t = target.apply(this, argv),\n sr = +radius.apply(this, (argv[0] = s, argv)),\n sa0 = startAngle.apply(this, argv) - halfPi,\n sa1 = endAngle.apply(this, argv) - halfPi,\n sx0 = sr * cos(sa0),\n sy0 = sr * sin(sa0),\n tr = +radius.apply(this, (argv[0] = t, argv)),\n ta0 = startAngle.apply(this, argv) - halfPi,\n ta1 = endAngle.apply(this, argv) - halfPi;\n\n if (!context) context = buffer = path();\n\n context.moveTo(sx0, sy0);\n context.arc(0, 0, sr, sa0, sa1);\n if (sa0 !== ta0 || sa1 !== ta1) { // TODO sr !== tr?\n context.quadraticCurveTo(0, 0, tr * cos(ta0), tr * sin(ta0));\n context.arc(0, 0, tr, ta0, ta1);\n }\n context.quadraticCurveTo(0, 0, sx0, sy0);\n context.closePath();\n\n if (buffer) return context = null, buffer + \"\" || null;\n }\n\n ribbon.radius = function(_) {\n return arguments.length ? (radius = typeof _ === \"function\" ? _ : constant(+_), ribbon) : radius;\n };\n\n ribbon.startAngle = function(_) {\n return arguments.length ? (startAngle = typeof _ === \"function\" ? _ : constant(+_), ribbon) : startAngle;\n };\n\n ribbon.endAngle = function(_) {\n return arguments.length ? (endAngle = typeof _ === \"function\" ? _ : constant(+_), ribbon) : endAngle;\n };\n\n ribbon.source = function(_) {\n return arguments.length ? (source = _, ribbon) : source;\n };\n\n ribbon.target = function(_) {\n return arguments.length ? (target = _, ribbon) : target;\n };\n\n ribbon.context = function(_) {\n return arguments.length ? ((context = _ == null ? null : _), ribbon) : context;\n };\n\n return ribbon;\n}\n","export var prefix = \"$\";\n\nfunction Map() {}\n\nMap.prototype = map.prototype = {\n constructor: Map,\n has: function(key) {\n return (prefix + key) in this;\n },\n get: function(key) {\n return this[prefix + key];\n },\n set: function(key, value) {\n this[prefix + key] = value;\n return this;\n },\n remove: function(key) {\n var property = prefix + key;\n return property in this && delete this[property];\n },\n clear: function() {\n for (var property in this) if (property[0] === prefix) delete this[property];\n },\n keys: function() {\n var keys = [];\n for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));\n return keys;\n },\n values: function() {\n var values = [];\n for (var property in this) if (property[0] === prefix) values.push(this[property]);\n return values;\n },\n entries: function() {\n var entries = [];\n for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});\n return entries;\n },\n size: function() {\n var size = 0;\n for (var property in this) if (property[0] === prefix) ++size;\n return size;\n },\n empty: function() {\n for (var property in this) if (property[0] === prefix) return false;\n return true;\n },\n each: function(f) {\n for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);\n }\n};\n\nfunction map(object, f) {\n var map = new Map;\n\n // Copy constructor.\n if (object instanceof Map) object.each(function(value, key) { map.set(key, value); });\n\n // Index array by numeric index or specified key function.\n else if (Array.isArray(object)) {\n var i = -1,\n n = object.length,\n o;\n\n if (f == null) while (++i < n) map.set(i, object[i]);\n else while (++i < n) map.set(f(o = object[i], i, object), o);\n }\n\n // Convert object to map.\n else if (object) for (var key in object) map.set(key, object[key]);\n\n return map;\n}\n\nexport default map;\n","import {default as map, prefix} from \"./map\";\n\nfunction Set() {}\n\nvar proto = map.prototype;\n\nSet.prototype = set.prototype = {\n constructor: Set,\n has: proto.has,\n add: function(value) {\n value += \"\";\n this[prefix + value] = value;\n return this;\n },\n remove: proto.remove,\n clear: proto.clear,\n values: proto.keys,\n size: proto.size,\n empty: proto.empty,\n each: proto.each\n};\n\nfunction set(object, f) {\n var set = new Set;\n\n // Copy constructor.\n if (object instanceof Set) object.each(function(value) { set.add(value); });\n\n // Otherwise, assume it’s an array.\n else if (object) {\n var i = -1, n = object.length;\n if (f == null) while (++i < n) set.add(object[i]);\n else while (++i < n) set.add(f(object[i], i, object));\n }\n\n return set;\n}\n\nexport default set;\n","var array = Array.prototype;\n\nexport var slice = array.slice;\n","import {max, range, tickStep} from \"d3-array\";\nimport {slice} from \"./array\";\nimport {blurX, blurY} from \"./blur\";\nimport constant from \"./constant\";\nimport contours from \"./contours\";\n\nfunction defaultX(d) {\n return d[0];\n}\n\nfunction defaultY(d) {\n return d[1];\n}\n\nfunction defaultWeight() {\n return 1;\n}\n\nexport default function() {\n var x = defaultX,\n y = defaultY,\n weight = defaultWeight,\n dx = 960,\n dy = 500,\n r = 20, // blur radius\n k = 2, // log2(grid cell size)\n o = r * 3, // grid offset, to pad for blur\n n = (dx + o * 2) >> k, // grid width\n m = (dy + o * 2) >> k, // grid height\n threshold = constant(20);\n\n function density(data) {\n var values0 = new Float32Array(n * m),\n values1 = new Float32Array(n * m);\n\n data.forEach(function(d, i, data) {\n var xi = (+x(d, i, data) + o) >> k,\n yi = (+y(d, i, data) + o) >> k,\n wi = +weight(d, i, data);\n if (xi >= 0 && xi < n && yi >= 0 && yi < m) {\n values0[xi + yi * n] += wi;\n }\n });\n\n // TODO Optimize.\n blurX({width: n, height: m, data: values0}, {width: n, height: m, data: values1}, r >> k);\n blurY({width: n, height: m, data: values1}, {width: n, height: m, data: values0}, r >> k);\n blurX({width: n, height: m, data: values0}, {width: n, height: m, data: values1}, r >> k);\n blurY({width: n, height: m, data: values1}, {width: n, height: m, data: values0}, r >> k);\n blurX({width: n, height: m, data: values0}, {width: n, height: m, data: values1}, r >> k);\n blurY({width: n, height: m, data: values1}, {width: n, height: m, data: values0}, r >> k);\n\n var tz = threshold(values0);\n\n // Convert number of thresholds into uniform thresholds.\n if (!Array.isArray(tz)) {\n var stop = max(values0);\n tz = tickStep(0, stop, tz);\n tz = range(0, Math.floor(stop / tz) * tz, tz);\n tz.shift();\n }\n\n return contours()\n .thresholds(tz)\n .size([n, m])\n (values0)\n .map(transform);\n }\n\n function transform(geometry) {\n geometry.value *= Math.pow(2, -2 * k); // Density in points per square pixel.\n geometry.coordinates.forEach(transformPolygon);\n return geometry;\n }\n\n function transformPolygon(coordinates) {\n coordinates.forEach(transformRing);\n }\n\n function transformRing(coordinates) {\n coordinates.forEach(transformPoint);\n }\n\n // TODO Optimize.\n function transformPoint(coordinates) {\n coordinates[0] = coordinates[0] * Math.pow(2, k) - o;\n coordinates[1] = coordinates[1] * Math.pow(2, k) - o;\n }\n\n function resize() {\n o = r * 3;\n n = (dx + o * 2) >> k;\n m = (dy + o * 2) >> k;\n return density;\n }\n\n density.x = function(_) {\n return arguments.length ? (x = typeof _ === \"function\" ? _ : constant(+_), density) : x;\n };\n\n density.y = function(_) {\n return arguments.length ? (y = typeof _ === \"function\" ? _ : constant(+_), density) : y;\n };\n\n density.weight = function(_) {\n return arguments.length ? (weight = typeof _ === \"function\" ? _ : constant(+_), density) : weight;\n };\n\n density.size = function(_) {\n if (!arguments.length) return [dx, dy];\n var _0 = Math.ceil(_[0]), _1 = Math.ceil(_[1]);\n if (!(_0 >= 0) && !(_0 >= 0)) throw new Error(\"invalid size\");\n return dx = _0, dy = _1, resize();\n };\n\n density.cellSize = function(_) {\n if (!arguments.length) return 1 << k;\n if (!((_ = +_) >= 1)) throw new Error(\"invalid cell size\");\n return k = Math.floor(Math.log(_) / Math.LN2), resize();\n };\n\n density.thresholds = function(_) {\n return arguments.length ? (threshold = typeof _ === \"function\" ? _ : Array.isArray(_) ? constant(slice.call(_)) : constant(_), density) : threshold;\n };\n\n density.bandwidth = function(_) {\n if (!arguments.length) return Math.sqrt(r * (r + 1));\n if (!((_ = +_) >= 0)) throw new Error(\"invalid bandwidth\");\n return r = Math.round((Math.sqrt(4 * _ * _ + 1) - 1) / 2), resize();\n };\n\n return density;\n}\n","export default function(d) {\n var x = +this._x.call(null, d),\n y = +this._y.call(null, d);\n return add(this.cover(x, y), x, y, d);\n}\n\nfunction add(tree, x, y, d) {\n if (isNaN(x) || isNaN(y)) return tree; // ignore invalid points\n\n var parent,\n node = tree._root,\n leaf = {data: d},\n x0 = tree._x0,\n y0 = tree._y0,\n x1 = tree._x1,\n y1 = tree._y1,\n xm,\n ym,\n xp,\n yp,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return tree._root = leaf, tree;\n\n // Find the existing leaf for the new point, or add it.\n while (node.length) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (parent = node, !(node = node[i = bottom << 1 | right])) return parent[i] = leaf, tree;\n }\n\n // Is the new point is exactly coincident with the existing point?\n xp = +tree._x.call(null, node.data);\n yp = +tree._y.call(null, node.data);\n if (x === xp && y === yp) return leaf.next = node, parent ? parent[i] = leaf : tree._root = leaf, tree;\n\n // Otherwise, split the leaf node until the old and new point are separated.\n do {\n parent = parent ? parent[i] = new Array(4) : tree._root = new Array(4);\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n } while ((i = bottom << 1 | right) === (j = (yp >= ym) << 1 | (xp >= xm)));\n return parent[j] = node, parent[i] = leaf, tree;\n}\n\nexport function addAll(data) {\n var d, i, n = data.length,\n x,\n y,\n xz = new Array(n),\n yz = new Array(n),\n x0 = Infinity,\n y0 = Infinity,\n x1 = -Infinity,\n y1 = -Infinity;\n\n // Compute the points and their extent.\n for (i = 0; i < n; ++i) {\n if (isNaN(x = +this._x.call(null, d = data[i])) || isNaN(y = +this._y.call(null, d))) continue;\n xz[i] = x;\n yz[i] = 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\n // If there were no (valid) points, abort.\n if (x0 > x1 || y0 > y1) return this;\n\n // Expand the tree to cover the new points.\n this.cover(x0, y0).cover(x1, y1);\n\n // Add the new points.\n for (i = 0; i < n; ++i) {\n add(this, xz[i], yz[i], data[i]);\n }\n\n return this;\n}\n","export default function(x, y) {\n if (isNaN(x = +x) || isNaN(y = +y)) return this; // ignore invalid points\n\n var x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1;\n\n // If the quadtree has no extent, initialize them.\n // Integer extent are necessary so that if we later double the extent,\n // the existing quadrant boundaries don’t change due to floating point error!\n if (isNaN(x0)) {\n x1 = (x0 = Math.floor(x)) + 1;\n y1 = (y0 = Math.floor(y)) + 1;\n }\n\n // Otherwise, double repeatedly to cover.\n else {\n var z = x1 - x0,\n node = this._root,\n parent,\n i;\n\n while (x0 > x || x >= x1 || y0 > y || y >= y1) {\n i = (y < y0) << 1 | (x < x0);\n parent = new Array(4), parent[i] = node, node = parent, z *= 2;\n switch (i) {\n case 0: x1 = x0 + z, y1 = y0 + z; break;\n case 1: x0 = x1 - z, y1 = y0 + z; break;\n case 2: x1 = x0 + z, y0 = y1 - z; break;\n case 3: x0 = x1 - z, y0 = y1 - z; break;\n }\n }\n\n if (this._root && this._root.length) this._root = node;\n }\n\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n return this;\n}\n","export default function() {\n var data = [];\n this.visit(function(node) {\n if (!node.length) do data.push(node.data); while (node = node.next)\n });\n return data;\n}\n","export default function(_) {\n return arguments.length\n ? this.cover(+_[0][0], +_[0][1]).cover(+_[1][0], +_[1][1])\n : isNaN(this._x0) ? undefined : [[this._x0, this._y0], [this._x1, this._y1]];\n}\n","export default function(node, x0, y0, x1, y1) {\n this.node = node;\n this.x0 = x0;\n this.y0 = y0;\n this.x1 = x1;\n this.y1 = y1;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(x, y, radius) {\n var data,\n x0 = this._x0,\n y0 = this._y0,\n x1,\n y1,\n x2,\n y2,\n x3 = this._x1,\n y3 = this._y1,\n quads = [],\n node = this._root,\n q,\n i;\n\n if (node) quads.push(new Quad(node, x0, y0, x3, y3));\n if (radius == null) radius = Infinity;\n else {\n x0 = x - radius, y0 = y - radius;\n x3 = x + radius, y3 = y + radius;\n radius *= radius;\n }\n\n while (q = quads.pop()) {\n\n // Stop searching if this quadrant can’t contain a closer node.\n if (!(node = q.node)\n || (x1 = q.x0) > x3\n || (y1 = q.y0) > y3\n || (x2 = q.x1) < x0\n || (y2 = q.y1) < y0) continue;\n\n // Bisect the current quadrant.\n if (node.length) {\n var xm = (x1 + x2) / 2,\n ym = (y1 + y2) / 2;\n\n quads.push(\n new Quad(node[3], xm, ym, x2, y2),\n new Quad(node[2], x1, ym, xm, y2),\n new Quad(node[1], xm, y1, x2, ym),\n new Quad(node[0], x1, y1, xm, ym)\n );\n\n // Visit the closest quadrant first.\n if (i = (y >= ym) << 1 | (x >= xm)) {\n q = quads[quads.length - 1];\n quads[quads.length - 1] = quads[quads.length - 1 - i];\n quads[quads.length - 1 - i] = q;\n }\n }\n\n // Visit this point. (Visiting coincident points isn’t necessary!)\n else {\n var dx = x - +this._x.call(null, node.data),\n dy = y - +this._y.call(null, node.data),\n d2 = dx * dx + dy * dy;\n if (d2 < radius) {\n var d = Math.sqrt(radius = d2);\n x0 = x - d, y0 = y - d;\n x3 = x + d, y3 = y + d;\n data = node.data;\n }\n }\n }\n\n return data;\n}\n","export default function(d) {\n if (isNaN(x = +this._x.call(null, d)) || isNaN(y = +this._y.call(null, d))) return this; // ignore invalid points\n\n var parent,\n node = this._root,\n retainer,\n previous,\n next,\n x0 = this._x0,\n y0 = this._y0,\n x1 = this._x1,\n y1 = this._y1,\n x,\n y,\n xm,\n ym,\n right,\n bottom,\n i,\n j;\n\n // If the tree is empty, initialize the root as a leaf.\n if (!node) return this;\n\n // Find the leaf node for the point.\n // While descending, also retain the deepest parent with a non-removed sibling.\n if (node.length) while (true) {\n if (right = x >= (xm = (x0 + x1) / 2)) x0 = xm; else x1 = xm;\n if (bottom = y >= (ym = (y0 + y1) / 2)) y0 = ym; else y1 = ym;\n if (!(parent = node, node = node[i = bottom << 1 | right])) return this;\n if (!node.length) break;\n if (parent[(i + 1) & 3] || parent[(i + 2) & 3] || parent[(i + 3) & 3]) retainer = parent, j = i;\n }\n\n // Find the point to remove.\n while (node.data !== d) if (!(previous = node, node = node.next)) return this;\n if (next = node.next) delete node.next;\n\n // If there are multiple coincident points, remove just the point.\n if (previous) return (next ? previous.next = next : delete previous.next), this;\n\n // If this is the root point, remove it.\n if (!parent) return this._root = next, this;\n\n // Remove this leaf.\n next ? parent[i] = next : delete parent[i];\n\n // If the parent now contains exactly one leaf, collapse superfluous parents.\n if ((node = parent[0] || parent[1] || parent[2] || parent[3])\n && node === (parent[3] || parent[2] || parent[1] || parent[0])\n && !node.length) {\n if (retainer) retainer[j] = node;\n else this._root = node;\n }\n\n return this;\n}\n\nexport function removeAll(data) {\n for (var i = 0, n = data.length; i < n; ++i) this.remove(data[i]);\n return this;\n}\n","export default function() {\n return this._root;\n}\n","export default function() {\n var size = 0;\n this.visit(function(node) {\n if (!node.length) do ++size; while (node = node.next)\n });\n return size;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], q, node = this._root, child, x0, y0, x1, y1;\n if (node) quads.push(new Quad(node, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n if (!callback(node = q.node, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1) && node.length) {\n var xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n }\n }\n return this;\n}\n","import Quad from \"./quad.js\";\n\nexport default function(callback) {\n var quads = [], next = [], q;\n if (this._root) quads.push(new Quad(this._root, this._x0, this._y0, this._x1, this._y1));\n while (q = quads.pop()) {\n var node = q.node;\n if (node.length) {\n var child, x0 = q.x0, y0 = q.y0, x1 = q.x1, y1 = q.y1, xm = (x0 + x1) / 2, ym = (y0 + y1) / 2;\n if (child = node[0]) quads.push(new Quad(child, x0, y0, xm, ym));\n if (child = node[1]) quads.push(new Quad(child, xm, y0, x1, ym));\n if (child = node[2]) quads.push(new Quad(child, x0, ym, xm, y1));\n if (child = node[3]) quads.push(new Quad(child, xm, ym, x1, y1));\n }\n next.push(q);\n }\n while (q = next.pop()) {\n callback(q.node, q.x0, q.y0, q.x1, q.y1);\n }\n return this;\n}\n","export function defaultX(d) {\n return d[0];\n}\n\nexport default function(_) {\n return arguments.length ? (this._x = _, this) : this._x;\n}\n","export function defaultY(d) {\n return d[1];\n}\n\nexport default function(_) {\n return arguments.length ? (this._y = _, this) : this._y;\n}\n","import tree_add, {addAll as tree_addAll} from \"./add.js\";\nimport tree_cover from \"./cover.js\";\nimport tree_data from \"./data.js\";\nimport tree_extent from \"./extent.js\";\nimport tree_find from \"./find.js\";\nimport tree_remove, {removeAll as tree_removeAll} from \"./remove.js\";\nimport tree_root from \"./root.js\";\nimport tree_size from \"./size.js\";\nimport tree_visit from \"./visit.js\";\nimport tree_visitAfter from \"./visitAfter.js\";\nimport tree_x, {defaultX} from \"./x.js\";\nimport tree_y, {defaultY} from \"./y.js\";\n\nexport default function quadtree(nodes, x, y) {\n var tree = new Quadtree(x == null ? defaultX : x, y == null ? defaultY : y, NaN, NaN, NaN, NaN);\n return nodes == null ? tree : tree.addAll(nodes);\n}\n\nfunction Quadtree(x, y, x0, y0, x1, y1) {\n this._x = x;\n this._y = y;\n this._x0 = x0;\n this._y0 = y0;\n this._x1 = x1;\n this._y1 = y1;\n this._root = undefined;\n}\n\nfunction leaf_copy(leaf) {\n var copy = {data: leaf.data}, next = copy;\n while (leaf = leaf.next) next = next.next = {data: leaf.data};\n return copy;\n}\n\nvar treeProto = quadtree.prototype = Quadtree.prototype;\n\ntreeProto.copy = function() {\n var copy = new Quadtree(this._x, this._y, this._x0, this._y0, this._x1, this._y1),\n node = this._root,\n nodes,\n child;\n\n if (!node) return copy;\n\n if (!node.length) return copy._root = leaf_copy(node), copy;\n\n nodes = [{source: node, target: copy._root = new Array(4)}];\n while (node = nodes.pop()) {\n for (var i = 0; i < 4; ++i) {\n if (child = node.source[i]) {\n if (child.length) nodes.push({source: child, target: node.target[i] = new Array(4)});\n else node.target[i] = leaf_copy(child);\n }\n }\n }\n\n return copy;\n};\n\ntreeProto.add = tree_add;\ntreeProto.addAll = tree_addAll;\ntreeProto.cover = tree_cover;\ntreeProto.data = tree_data;\ntreeProto.extent = tree_extent;\ntreeProto.find = tree_find;\ntreeProto.remove = tree_remove;\ntreeProto.removeAll = tree_removeAll;\ntreeProto.root = tree_root;\ntreeProto.size = tree_size;\ntreeProto.visit = tree_visit;\ntreeProto.visitAfter = tree_visitAfter;\ntreeProto.x = tree_x;\ntreeProto.y = tree_y;\n","import {dispatch} from \"d3-dispatch\";\nimport {map} from \"d3-collection\";\nimport {timer} from \"d3-timer\";\n\nexport function x(d) {\n return d.x;\n}\n\nexport function y(d) {\n return d.y;\n}\n\nvar initialRadius = 10,\n initialAngle = Math.PI * (3 - Math.sqrt(5));\n\nexport default function(nodes) {\n var simulation,\n alpha = 1,\n alphaMin = 0.001,\n alphaDecay = 1 - Math.pow(alphaMin, 1 / 300),\n alphaTarget = 0,\n velocityDecay = 0.6,\n forces = map(),\n stepper = timer(step),\n event = dispatch(\"tick\", \"end\");\n\n if (nodes == null) nodes = [];\n\n function step() {\n tick();\n event.call(\"tick\", simulation);\n if (alpha < alphaMin) {\n stepper.stop();\n event.call(\"end\", simulation);\n }\n }\n\n function tick(iterations) {\n var i, n = nodes.length, node;\n\n if (iterations === undefined) iterations = 1;\n\n for (var k = 0; k < iterations; ++k) {\n alpha += (alphaTarget - alpha) * alphaDecay;\n\n forces.each(function (force) {\n force(alpha);\n });\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n if (node.fx == null) node.x += node.vx *= velocityDecay;\n else node.x = node.fx, node.vx = 0;\n if (node.fy == null) node.y += node.vy *= velocityDecay;\n else node.y = node.fy, node.vy = 0;\n }\n }\n\n return simulation;\n }\n\n function initializeNodes() {\n for (var i = 0, n = nodes.length, node; i < n; ++i) {\n node = nodes[i], node.index = i;\n if (node.fx != null) node.x = node.fx;\n if (node.fy != null) node.y = node.fy;\n if (isNaN(node.x) || isNaN(node.y)) {\n var radius = initialRadius * Math.sqrt(i), angle = i * initialAngle;\n node.x = radius * Math.cos(angle);\n node.y = radius * Math.sin(angle);\n }\n if (isNaN(node.vx) || isNaN(node.vy)) {\n node.vx = node.vy = 0;\n }\n }\n }\n\n function initializeForce(force) {\n if (force.initialize) force.initialize(nodes);\n return force;\n }\n\n initializeNodes();\n\n return simulation = {\n tick: tick,\n\n restart: function() {\n return stepper.restart(step), simulation;\n },\n\n stop: function() {\n return stepper.stop(), simulation;\n },\n\n nodes: function(_) {\n return arguments.length ? (nodes = _, initializeNodes(), forces.each(initializeForce), simulation) : nodes;\n },\n\n alpha: function(_) {\n return arguments.length ? (alpha = +_, simulation) : alpha;\n },\n\n alphaMin: function(_) {\n return arguments.length ? (alphaMin = +_, simulation) : alphaMin;\n },\n\n alphaDecay: function(_) {\n return arguments.length ? (alphaDecay = +_, simulation) : +alphaDecay;\n },\n\n alphaTarget: function(_) {\n return arguments.length ? (alphaTarget = +_, simulation) : alphaTarget;\n },\n\n velocityDecay: function(_) {\n return arguments.length ? (velocityDecay = 1 - _, simulation) : 1 - velocityDecay;\n },\n\n force: function(name, _) {\n return arguments.length > 1 ? ((_ == null ? forces.remove(name) : forces.set(name, initializeForce(_))), simulation) : forces.get(name);\n },\n\n find: function(x, y, radius) {\n var i = 0,\n n = nodes.length,\n dx,\n dy,\n d2,\n node,\n closest;\n\n if (radius == null) radius = Infinity;\n else radius *= radius;\n\n for (i = 0; i < n; ++i) {\n node = nodes[i];\n dx = x - node.x;\n dy = y - node.y;\n d2 = dx * dx + dy * dy;\n if (d2 < radius) closest = node, radius = d2;\n }\n\n return closest;\n },\n\n on: function(name, _) {\n return arguments.length > 1 ? (event.on(name, _), simulation) : event.on(name);\n }\n };\n}\n","export default function() {\n return Math.random();\n}\n","import defaultSource from \"./defaultSource\";\n\nexport default (function sourceRandomNormal(source) {\n function randomNormal(mu, sigma) {\n var x, r;\n mu = mu == null ? 0 : +mu;\n sigma = sigma == null ? 1 : +sigma;\n return function() {\n var y;\n\n // If available, use the second previously-generated uniform random.\n if (x != null) y = x, x = null;\n\n // Otherwise, generate a new x and y.\n else do {\n x = source() * 2 - 1;\n y = source() * 2 - 1;\n r = x * x + y * y;\n } while (!r || r > 1);\n\n return mu + sigma * y * Math.sqrt(-2 * Math.log(r) / r);\n };\n }\n\n randomNormal.source = sourceRandomNormal;\n\n return randomNormal;\n})(defaultSource);\n","import defaultSource from \"./defaultSource\";\n\nexport default (function sourceRandomUniform(source) {\n function randomUniform(min, max) {\n min = min == null ? 0 : +min;\n max = max == null ? 1 : +max;\n if (arguments.length === 1) max = min, min = 0;\n else max -= min;\n return function() {\n return source() * max + min;\n };\n }\n\n randomUniform.source = sourceRandomUniform;\n\n return randomUniform;\n})(defaultSource);\n","import defaultSource from \"./defaultSource\";\n\nexport default (function sourceRandomIrwinHall(source) {\n function randomIrwinHall(n) {\n return function() {\n for (var sum = 0, i = 0; i < n; ++i) sum += source();\n return sum;\n };\n }\n\n randomIrwinHall.source = sourceRandomIrwinHall;\n\n return randomIrwinHall;\n})(defaultSource);\n","import defaultSource from \"./defaultSource\";\nimport normal from \"./normal\";\n\nexport default (function sourceRandomLogNormal(source) {\n function randomLogNormal() {\n var randomNormal = normal.source(source).apply(this, arguments);\n return function() {\n return Math.exp(randomNormal());\n };\n }\n\n randomLogNormal.source = sourceRandomLogNormal;\n\n return randomLogNormal;\n})(defaultSource);\n","import defaultSource from \"./defaultSource\";\nimport irwinHall from \"./irwinHall\";\n\nexport default (function sourceRandomBates(source) {\n function randomBates(n) {\n var randomIrwinHall = irwinHall.source(source)(n);\n return function() {\n return randomIrwinHall() / n;\n };\n }\n\n randomBates.source = sourceRandomBates;\n\n return randomBates;\n})(defaultSource);\n","import defaultSource from \"./defaultSource\";\n\nexport default (function sourceRandomExponential(source) {\n function randomExponential(lambda) {\n return function() {\n return -Math.log(1 - source()) / lambda;\n };\n }\n\n randomExponential.source = sourceRandomExponential;\n\n return randomExponential;\n})(defaultSource);\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: this.interpolator(domain); break;\n default: this.interpolator(interpolator).domain(domain); break;\n }\n return this;\n}\n","var array = Array.prototype;\n\nexport var map = array.map;\nexport var slice = array.slice;\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","export default function(x) {\n return function() {\n return x;\n };\n}\n","export default function(x) {\n return +x;\n}\n","import {bisect} from \"d3-array\";\nimport {interpolate as interpolateValue, interpolateNumber, interpolateRound} from \"d3-interpolate\";\nimport {map, slice} from \"./array\";\nimport constant from \"./constant\";\nimport number from \"./number\";\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(domain) {\n var a = domain[0], b = domain[domain.length - 1], 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 piecewise = Math.min(domain.length, range.length) > 2 ? polymap : bimap;\n output = input = null;\n return scale;\n }\n\n function scale(x) {\n return 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 = map.call(_, number), clamp === identity || (clamp = clamper(domain)), rescale()) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = slice.call(_), rescale()) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return range = slice.call(_), interpolate = interpolateRound, rescale();\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = _ ? clamper(domain) : identity, scale) : 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(transform, untransform) {\n return transformer()(transform, untransform);\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","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","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 formatLocale from \"./locale.js\";\n\nvar locale;\nexport var format;\nexport var formatPrefix;\n\ndefaultLocale({\n decimal: \".\",\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"],\n minus: \"-\"\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n format = locale.format;\n formatPrefix = locale.formatPrefix;\n return locale;\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","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","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 \"%\": function(x, p) { return (x * 100).toFixed(p); },\n \"b\": function(x) { return Math.round(x).toString(2); },\n \"c\": function(x) { return x + \"\"; },\n \"d\": formatDecimal,\n \"e\": function(x, p) { return x.toExponential(p); },\n \"f\": function(x, p) { return x.toFixed(p); },\n \"g\": function(x, p) { return x.toPrecision(p); },\n \"o\": function(x) { return Math.round(x).toString(8); },\n \"p\": function(x, p) { return formatRounded(x * 100, p); },\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": function(x) { return Math.round(x).toString(16).toUpperCase(); },\n \"x\": function(x) { return 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 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 {tickStep} from \"d3-array\";\nimport {format, formatPrefix, formatSpecifier, precisionFixed, precisionPrefix, precisionRound} from \"d3-format\";\n\nexport default function(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 {ticks, tickIncrement} from \"d3-array\";\nimport continuous, {copy, identity} from \"./continuous\";\nimport {initRange} from \"./init\";\nimport tickFormat from \"./tickFormat\";\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 i0 = 0,\n i1 = d.length - 1,\n start = d[i0],\n stop = d[i1],\n step;\n\n if (stop < start) {\n step = start, start = stop, stop = step;\n step = i0, i0 = i1, i1 = step;\n }\n\n step = tickIncrement(start, stop, count);\n\n if (step > 0) {\n start = Math.floor(start / step) * step;\n stop = Math.ceil(stop / step) * step;\n step = tickIncrement(start, stop, count);\n } else if (step < 0) {\n start = Math.ceil(start * step) / step;\n stop = Math.floor(stop * step) / step;\n step = tickIncrement(start, stop, count);\n }\n\n if (step > 0) {\n d[i0] = Math.floor(start / step) * step;\n d[i1] = Math.ceil(stop / step) * step;\n domain(d);\n } else if (step < 0) {\n d[i0] = Math.ceil(start * step) / step;\n d[i1] = Math.floor(stop * step) / step;\n domain(d);\n }\n\n return scale;\n };\n\n return scale;\n}\n\nexport default function linear() {\n var scale = continuous(identity, identity);\n\n scale.copy = function() {\n return copy(scale, linear());\n };\n\n initRange.apply(scale, arguments);\n\n return linearish(scale);\n}\n","var t0 = new Date,\n t1 = new Date;\n\nexport default function newInterval(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 = function(date) {\n return floori(date = new Date(+date)), date;\n };\n\n interval.ceil = function(date) {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = function(date) {\n var d0 = interval(date),\n d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = function(date, step) {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = function(start, stop, step) {\n var range = [], previous;\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 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 = function(test) {\n return newInterval(function(date) {\n if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);\n }, function(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 = function(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 = function(step) {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? function(d) { return field(d) % step === 0; }\n : function(d) { return interval.count(0, d) % step === 0; });\n };\n }\n\n return interval;\n}\n","import interval from \"./interval.js\";\n\nvar year = interval(function(date) {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setFullYear(date.getFullYear() + step);\n}, function(start, end) {\n return end.getFullYear() - start.getFullYear();\n}, function(date) {\n return date.getFullYear();\n});\n\n// An optimized implementation for this simple case.\nyear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step * k);\n });\n};\n\nexport default year;\nexport var years = year.range;\n","import interval from \"./interval.js\";\n\nvar month = interval(function(date) {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setMonth(date.getMonth() + step);\n}, function(start, end) {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n}, function(date) {\n return date.getMonth();\n});\n\nexport default month;\nexport var months = month.range;\n","export var durationSecond = 1e3;\nexport var durationMinute = 6e4;\nexport var durationHour = 36e5;\nexport var durationDay = 864e5;\nexport var durationWeek = 6048e5;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationWeek} from \"./duration.js\";\n\nfunction weekday(i) {\n return interval(function(date) {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step * 7);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n}\n\nexport var sunday = weekday(0);\nexport var monday = weekday(1);\nexport var tuesday = weekday(2);\nexport var wednesday = weekday(3);\nexport var thursday = weekday(4);\nexport var friday = weekday(5);\nexport var saturday = weekday(6);\n\nexport var sundays = sunday.range;\nexport var mondays = monday.range;\nexport var tuesdays = tuesday.range;\nexport var wednesdays = wednesday.range;\nexport var thursdays = thursday.range;\nexport var fridays = friday.range;\nexport var saturdays = saturday.range;\n","import interval from \"./interval.js\";\nimport {durationDay, durationMinute} from \"./duration.js\";\n\nvar day = interval(function(date) {\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setDate(date.getDate() + step);\n}, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay;\n}, function(date) {\n return date.getDate() - 1;\n});\n\nexport default day;\nexport var days = day.range;\n","import interval from \"./interval.js\";\nimport {durationHour, durationMinute, durationSecond} from \"./duration.js\";\n\nvar hour = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond - date.getMinutes() * durationMinute);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getHours();\n});\n\nexport default hour;\nexport var hours = hour.range;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationSecond} from \"./duration.js\";\n\nvar minute = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getMinutes();\n});\n\nexport default minute;\nexport var minutes = minute.range;\n","import interval from \"./interval.js\";\nimport {durationSecond} from \"./duration.js\";\n\nvar second = interval(function(date) {\n date.setTime(date - date.getMilliseconds());\n}, function(date, step) {\n date.setTime(+date + step * durationSecond);\n}, function(start, end) {\n return (end - start) / durationSecond;\n}, function(date) {\n return date.getUTCSeconds();\n});\n\nexport default second;\nexport var seconds = second.range;\n","import interval from \"./interval.js\";\n\nvar millisecond = interval(function() {\n // noop\n}, function(date, step) {\n date.setTime(+date + step);\n}, function(start, end) {\n return end - start;\n});\n\n// An optimized implementation for this simple case.\nmillisecond.every = function(k) {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return interval(function(date) {\n date.setTime(Math.floor(date / k) * k);\n }, function(date, step) {\n date.setTime(+date + step * k);\n }, function(start, end) {\n return (end - start) / k;\n });\n};\n\nexport default millisecond;\nexport var milliseconds = millisecond.range;\n","import interval from \"./interval.js\";\nimport {durationWeek} from \"./duration.js\";\n\nfunction utcWeekday(i) {\n return interval(function(date) {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, function(start, end) {\n return (end - start) / durationWeek;\n });\n}\n\nexport var utcSunday = utcWeekday(0);\nexport var utcMonday = utcWeekday(1);\nexport var utcTuesday = utcWeekday(2);\nexport var utcWednesday = utcWeekday(3);\nexport var utcThursday = utcWeekday(4);\nexport var utcFriday = utcWeekday(5);\nexport var utcSaturday = utcWeekday(6);\n\nexport var utcSundays = utcSunday.range;\nexport var utcMondays = utcMonday.range;\nexport var utcTuesdays = utcTuesday.range;\nexport var utcWednesdays = utcWednesday.range;\nexport var utcThursdays = utcThursday.range;\nexport var utcFridays = utcFriday.range;\nexport var utcSaturdays = utcSaturday.range;\n","import interval from \"./interval.js\";\nimport {durationDay} from \"./duration.js\";\n\nvar utcDay = interval(function(date) {\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step);\n}, function(start, end) {\n return (end - start) / durationDay;\n}, function(date) {\n return date.getUTCDate() - 1;\n});\n\nexport default utcDay;\nexport var utcDays = utcDay.range;\n","import interval from \"./interval.js\";\n\nvar utcYear = interval(function(date) {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n}, function(start, end) {\n return end.getUTCFullYear() - start.getUTCFullYear();\n}, function(date) {\n return date.getUTCFullYear();\n});\n\n// An optimized implementation for this simple case.\nutcYear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n};\n\nexport default utcYear;\nexport var utcYears = utcYear.range;\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[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[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[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[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[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 var map = {}, i = -1, n = names.length;\n while (++i < n) map[names[i].toLowerCase()] = i;\n return map;\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 {bisector, tickStep} from \"d3-array\";\nimport {timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeMillisecond} from \"d3-time\";\nimport {timeFormat} from \"d3-time-format\";\nimport {map} from \"./array\";\nimport continuous, {copy, identity} from \"./continuous\";\nimport {initRange} from \"./init\";\nimport nice from \"./nice\";\n\nvar durationSecond = 1000,\n durationMinute = durationSecond * 60,\n durationHour = durationMinute * 60,\n durationDay = durationHour * 24,\n durationWeek = durationDay * 7,\n durationMonth = durationDay * 30,\n durationYear = durationDay * 365;\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(year, month, week, day, hour, minute, second, millisecond, format) {\n var scale = continuous(identity, identity),\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 var 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 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 function tickInterval(interval, start, stop, step) {\n if (interval == null) interval = 10;\n\n // If a desired tick count is specified, pick a reasonable tick interval\n // based on the extent of the domain and a rough estimate of tick size.\n // Otherwise, assume interval is already a time interval and use it.\n if (typeof interval === \"number\") {\n var target = Math.abs(stop - start) / interval,\n i = bisector(function(i) { return i[2]; }).right(tickIntervals, target);\n if (i === tickIntervals.length) {\n step = tickStep(start / durationYear, stop / durationYear, interval);\n interval = year;\n } else if (i) {\n i = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n step = i[1];\n interval = i[0];\n } else {\n step = Math.max(tickStep(start, stop, interval), 1);\n interval = millisecond;\n }\n }\n\n return step == null ? interval : interval.every(step);\n }\n\n scale.invert = function(y) {\n return new Date(invert(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? domain(map.call(_, number)) : domain().map(date);\n };\n\n scale.ticks = function(interval, step) {\n var d = domain(),\n t0 = d[0],\n t1 = d[d.length - 1],\n r = t1 < t0,\n t;\n if (r) t = t0, t0 = t1, t1 = t;\n t = tickInterval(interval, t0, t1, step);\n t = t ? t.range(t0, t1 + 1) : []; // inclusive stop\n return r ? t.reverse() : t;\n };\n\n scale.tickFormat = function(count, specifier) {\n return specifier == null ? tickFormat : format(specifier);\n };\n\n scale.nice = function(interval, step) {\n var d = domain();\n return (interval = tickInterval(interval, d[0], d[d.length - 1], step))\n ? domain(nice(d, interval))\n : scale;\n };\n\n scale.copy = function() {\n return copy(scale, calendar(year, month, week, day, hour, minute, second, millisecond, format));\n };\n\n return scale;\n}\n\nexport default function() {\n return initRange.apply(calendar(timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeMillisecond, timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]), arguments);\n}\n","import interval from \"./interval.js\";\n\nvar utcMonth = interval(function(date) {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCMonth(date.getUTCMonth() + step);\n}, function(start, end) {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n}, function(date) {\n return date.getUTCMonth();\n});\n\nexport default utcMonth;\nexport var utcMonths = utcMonth.range;\n","import interval from \"./interval.js\";\nimport {durationHour} from \"./duration.js\";\n\nvar utcHour = interval(function(date) {\n date.setUTCMinutes(0, 0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getUTCHours();\n});\n\nexport default utcHour;\nexport var utcHours = utcHour.range;\n","import interval from \"./interval.js\";\nimport {durationMinute} from \"./duration.js\";\n\nvar utcMinute = interval(function(date) {\n date.setUTCSeconds(0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getUTCMinutes();\n});\n\nexport default utcMinute;\nexport var utcMinutes = utcMinute.range;\n","function RedBlackTree() {\n this._ = null; // root node\n}\n\nexport function RedBlackNode(node) {\n node.U = // parent node\n node.C = // color - true for red, false for black\n node.L = // left node\n node.R = // right node\n node.P = // previous node\n node.N = null; // next node\n}\n\nRedBlackTree.prototype = {\n constructor: RedBlackTree,\n\n insert: function(after, node) {\n var parent, grandpa, uncle;\n\n if (after) {\n node.P = after;\n node.N = after.N;\n if (after.N) after.N.P = node;\n after.N = node;\n if (after.R) {\n after = after.R;\n while (after.L) after = after.L;\n after.L = node;\n } else {\n after.R = node;\n }\n parent = after;\n } else if (this._) {\n after = RedBlackFirst(this._);\n node.P = null;\n node.N = after;\n after.P = after.L = node;\n parent = after;\n } else {\n node.P = node.N = null;\n this._ = node;\n parent = null;\n }\n node.L = node.R = null;\n node.U = parent;\n node.C = true;\n\n after = node;\n while (parent && parent.C) {\n grandpa = parent.U;\n if (parent === grandpa.L) {\n uncle = grandpa.R;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.R) {\n RedBlackRotateLeft(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateRight(this, grandpa);\n }\n } else {\n uncle = grandpa.L;\n if (uncle && uncle.C) {\n parent.C = uncle.C = false;\n grandpa.C = true;\n after = grandpa;\n } else {\n if (after === parent.L) {\n RedBlackRotateRight(this, parent);\n after = parent;\n parent = after.U;\n }\n parent.C = false;\n grandpa.C = true;\n RedBlackRotateLeft(this, grandpa);\n }\n }\n parent = after.U;\n }\n this._.C = false;\n },\n\n remove: function(node) {\n if (node.N) node.N.P = node.P;\n if (node.P) node.P.N = node.N;\n node.N = node.P = null;\n\n var parent = node.U,\n sibling,\n left = node.L,\n right = node.R,\n next,\n red;\n\n if (!left) next = right;\n else if (!right) next = left;\n else next = RedBlackFirst(right);\n\n if (parent) {\n if (parent.L === node) parent.L = next;\n else parent.R = next;\n } else {\n this._ = next;\n }\n\n if (left && right) {\n red = next.C;\n next.C = node.C;\n next.L = left;\n left.U = next;\n if (next !== right) {\n parent = next.U;\n next.U = node.U;\n node = next.R;\n parent.L = node;\n next.R = right;\n right.U = next;\n } else {\n next.U = parent;\n parent = next;\n node = next.R;\n }\n } else {\n red = node.C;\n node = next;\n }\n\n if (node) node.U = parent;\n if (red) return;\n if (node && node.C) { node.C = false; return; }\n\n do {\n if (node === this._) break;\n if (node === parent.L) {\n sibling = parent.R;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateLeft(this, parent);\n sibling = parent.R;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.R || !sibling.R.C) {\n sibling.L.C = false;\n sibling.C = true;\n RedBlackRotateRight(this, sibling);\n sibling = parent.R;\n }\n sibling.C = parent.C;\n parent.C = sibling.R.C = false;\n RedBlackRotateLeft(this, parent);\n node = this._;\n break;\n }\n } else {\n sibling = parent.L;\n if (sibling.C) {\n sibling.C = false;\n parent.C = true;\n RedBlackRotateRight(this, parent);\n sibling = parent.L;\n }\n if ((sibling.L && sibling.L.C)\n || (sibling.R && sibling.R.C)) {\n if (!sibling.L || !sibling.L.C) {\n sibling.R.C = false;\n sibling.C = true;\n RedBlackRotateLeft(this, sibling);\n sibling = parent.L;\n }\n sibling.C = parent.C;\n parent.C = sibling.L.C = false;\n RedBlackRotateRight(this, parent);\n node = this._;\n break;\n }\n }\n sibling.C = true;\n node = parent;\n parent = parent.U;\n } while (!node.C);\n\n if (node) node.C = false;\n }\n};\n\nfunction RedBlackRotateLeft(tree, node) {\n var p = node,\n q = node.R,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.R = q.L;\n if (p.R) p.R.U = p;\n q.L = p;\n}\n\nfunction RedBlackRotateRight(tree, node) {\n var p = node,\n q = node.L,\n parent = p.U;\n\n if (parent) {\n if (parent.L === p) parent.L = q;\n else parent.R = q;\n } else {\n tree._ = q;\n }\n\n q.U = parent;\n p.U = q;\n p.L = q.R;\n if (p.L) p.L.U = p;\n q.R = p;\n}\n\nfunction RedBlackFirst(node) {\n while (node.L) node = node.L;\n return node;\n}\n\nexport default RedBlackTree;\n","import {cells, edges, epsilon} from \"./Diagram\";\n\nexport function createEdge(left, right, v0, v1) {\n var edge = [null, null],\n index = edges.push(edge) - 1;\n edge.left = left;\n edge.right = right;\n if (v0) setEdgeEnd(edge, left, right, v0);\n if (v1) setEdgeEnd(edge, right, left, v1);\n cells[left.index].halfedges.push(index);\n cells[right.index].halfedges.push(index);\n return edge;\n}\n\nexport function createBorderEdge(left, v0, v1) {\n var edge = [v0, v1];\n edge.left = left;\n return edge;\n}\n\nexport function setEdgeEnd(edge, left, right, vertex) {\n if (!edge[0] && !edge[1]) {\n edge[0] = vertex;\n edge.left = left;\n edge.right = right;\n } else if (edge.left === right) {\n edge[1] = vertex;\n } else {\n edge[0] = vertex;\n }\n}\n\n// Liang–Barsky line clipping.\nfunction clipEdge(edge, x0, y0, x1, y1) {\n var a = edge[0],\n b = edge[1],\n 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) && !(t1 < 1)) return true; // TODO Better check?\n\n if (t0 > 0) edge[0] = [ax + t0 * dx, ay + t0 * dy];\n if (t1 < 1) edge[1] = [ax + t1 * dx, ay + t1 * dy];\n return true;\n}\n\nfunction connectEdge(edge, x0, y0, x1, y1) {\n var v1 = edge[1];\n if (v1) return true;\n\n var v0 = edge[0],\n left = edge.left,\n right = edge.right,\n lx = left[0],\n ly = left[1],\n rx = right[0],\n ry = right[1],\n fx = (lx + rx) / 2,\n fy = (ly + ry) / 2,\n fm,\n fb;\n\n if (ry === ly) {\n if (fx < x0 || fx >= x1) return;\n if (lx > rx) {\n if (!v0) v0 = [fx, y0];\n else if (v0[1] >= y1) return;\n v1 = [fx, y1];\n } else {\n if (!v0) v0 = [fx, y1];\n else if (v0[1] < y0) return;\n v1 = [fx, y0];\n }\n } else {\n fm = (lx - rx) / (ry - ly);\n fb = fy - fm * fx;\n if (fm < -1 || fm > 1) {\n if (lx > rx) {\n if (!v0) v0 = [(y0 - fb) / fm, y0];\n else if (v0[1] >= y1) return;\n v1 = [(y1 - fb) / fm, y1];\n } else {\n if (!v0) v0 = [(y1 - fb) / fm, y1];\n else if (v0[1] < y0) return;\n v1 = [(y0 - fb) / fm, y0];\n }\n } else {\n if (ly < ry) {\n if (!v0) v0 = [x0, fm * x0 + fb];\n else if (v0[0] >= x1) return;\n v1 = [x1, fm * x1 + fb];\n } else {\n if (!v0) v0 = [x1, fm * x1 + fb];\n else if (v0[0] < x0) return;\n v1 = [x0, fm * x0 + fb];\n }\n }\n }\n\n edge[0] = v0;\n edge[1] = v1;\n return true;\n}\n\nexport function clipEdges(x0, y0, x1, y1) {\n var i = edges.length,\n edge;\n\n while (i--) {\n if (!connectEdge(edge = edges[i], x0, y0, x1, y1)\n || !clipEdge(edge, x0, y0, x1, y1)\n || !(Math.abs(edge[0][0] - edge[1][0]) > epsilon\n || Math.abs(edge[0][1] - edge[1][1]) > epsilon)) {\n delete edges[i];\n }\n }\n}\n","import {createBorderEdge} from \"./Edge\";\nimport {cells, edges, epsilon} from \"./Diagram\";\n\nexport function createCell(site) {\n return cells[site.index] = {\n site: site,\n halfedges: []\n };\n}\n\nfunction cellHalfedgeAngle(cell, edge) {\n var site = cell.site,\n va = edge.left,\n vb = edge.right;\n if (site === vb) vb = va, va = site;\n if (vb) return Math.atan2(vb[1] - va[1], vb[0] - va[0]);\n if (site === va) va = edge[1], vb = edge[0];\n else va = edge[0], vb = edge[1];\n return Math.atan2(va[0] - vb[0], vb[1] - va[1]);\n}\n\nexport function cellHalfedgeStart(cell, edge) {\n return edge[+(edge.left !== cell.site)];\n}\n\nexport function cellHalfedgeEnd(cell, edge) {\n return edge[+(edge.left === cell.site)];\n}\n\nexport function sortCellHalfedges() {\n for (var i = 0, n = cells.length, cell, halfedges, j, m; i < n; ++i) {\n if ((cell = cells[i]) && (m = (halfedges = cell.halfedges).length)) {\n var index = new Array(m),\n array = new Array(m);\n for (j = 0; j < m; ++j) index[j] = j, array[j] = cellHalfedgeAngle(cell, edges[halfedges[j]]);\n index.sort(function(i, j) { return array[j] - array[i]; });\n for (j = 0; j < m; ++j) array[j] = halfedges[index[j]];\n for (j = 0; j < m; ++j) halfedges[j] = array[j];\n }\n }\n}\n\nexport function clipCells(x0, y0, x1, y1) {\n var nCells = cells.length,\n iCell,\n cell,\n site,\n iHalfedge,\n halfedges,\n nHalfedges,\n start,\n startX,\n startY,\n end,\n endX,\n endY,\n cover = true;\n\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n halfedges = cell.halfedges;\n iHalfedge = halfedges.length;\n\n // Remove any dangling clipped edges.\n while (iHalfedge--) {\n if (!edges[halfedges[iHalfedge]]) {\n halfedges.splice(iHalfedge, 1);\n }\n }\n\n // Insert any border edges as necessary.\n iHalfedge = 0, nHalfedges = halfedges.length;\n while (iHalfedge < nHalfedges) {\n end = cellHalfedgeEnd(cell, edges[halfedges[iHalfedge]]), endX = end[0], endY = end[1];\n start = cellHalfedgeStart(cell, edges[halfedges[++iHalfedge % nHalfedges]]), startX = start[0], startY = start[1];\n if (Math.abs(endX - startX) > epsilon || Math.abs(endY - startY) > epsilon) {\n halfedges.splice(iHalfedge, 0, edges.push(createBorderEdge(site, end,\n Math.abs(endX - x0) < epsilon && y1 - endY > epsilon ? [x0, Math.abs(startX - x0) < epsilon ? startY : y1]\n : Math.abs(endY - y1) < epsilon && x1 - endX > epsilon ? [Math.abs(startY - y1) < epsilon ? startX : x1, y1]\n : Math.abs(endX - x1) < epsilon && endY - y0 > epsilon ? [x1, Math.abs(startX - x1) < epsilon ? startY : y0]\n : Math.abs(endY - y0) < epsilon && endX - x0 > epsilon ? [Math.abs(startY - y0) < epsilon ? startX : x0, y0]\n : null)) - 1);\n ++nHalfedges;\n }\n }\n\n if (nHalfedges) cover = false;\n }\n }\n\n // If there weren’t any edges, have the closest site cover the extent.\n // It doesn’t matter which corner of the extent we measure!\n if (cover) {\n var dx, dy, d2, dc = Infinity;\n\n for (iCell = 0, cover = null; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n site = cell.site;\n dx = site[0] - x0;\n dy = site[1] - y0;\n d2 = dx * dx + dy * dy;\n if (d2 < dc) dc = d2, cover = cell;\n }\n }\n\n if (cover) {\n var v00 = [x0, y0], v01 = [x0, y1], v11 = [x1, y1], v10 = [x1, y0];\n cover.halfedges.push(\n edges.push(createBorderEdge(site = cover.site, v00, v01)) - 1,\n edges.push(createBorderEdge(site, v01, v11)) - 1,\n edges.push(createBorderEdge(site, v11, v10)) - 1,\n edges.push(createBorderEdge(site, v10, v00)) - 1\n );\n }\n }\n\n // Lastly delete any cells with no edges; these were entirely clipped.\n for (iCell = 0; iCell < nCells; ++iCell) {\n if (cell = cells[iCell]) {\n if (!cell.halfedges.length) {\n delete cells[iCell];\n }\n }\n }\n}\n","import {RedBlackNode} from \"./RedBlackTree\";\nimport {circles, epsilon2} from \"./Diagram\";\n\nvar circlePool = [];\n\nexport var firstCircle;\n\nfunction Circle() {\n RedBlackNode(this);\n this.x =\n this.y =\n this.arc =\n this.site =\n this.cy = null;\n}\n\nexport function attachCircle(arc) {\n var lArc = arc.P,\n rArc = arc.N;\n\n if (!lArc || !rArc) return;\n\n var lSite = lArc.site,\n cSite = arc.site,\n rSite = rArc.site;\n\n if (lSite === rSite) return;\n\n var bx = cSite[0],\n by = cSite[1],\n ax = lSite[0] - bx,\n ay = lSite[1] - by,\n cx = rSite[0] - bx,\n cy = rSite[1] - by;\n\n var d = 2 * (ax * cy - ay * cx);\n if (d >= -epsilon2) return;\n\n var ha = ax * ax + ay * ay,\n hc = cx * cx + cy * cy,\n x = (cy * ha - ay * hc) / d,\n y = (ax * hc - cx * ha) / d;\n\n var circle = circlePool.pop() || new Circle;\n circle.arc = arc;\n circle.site = cSite;\n circle.x = x + bx;\n circle.y = (circle.cy = y + by) + Math.sqrt(x * x + y * y); // y bottom\n\n arc.circle = circle;\n\n var before = null,\n node = circles._;\n\n while (node) {\n if (circle.y < node.y || (circle.y === node.y && circle.x <= node.x)) {\n if (node.L) node = node.L;\n else { before = node.P; break; }\n } else {\n if (node.R) node = node.R;\n else { before = node; break; }\n }\n }\n\n circles.insert(before, circle);\n if (!before) firstCircle = circle;\n}\n\nexport function detachCircle(arc) {\n var circle = arc.circle;\n if (circle) {\n if (!circle.P) firstCircle = circle.N;\n circles.remove(circle);\n circlePool.push(circle);\n RedBlackNode(circle);\n arc.circle = null;\n }\n}\n","import {RedBlackNode} from \"./RedBlackTree\";\nimport {createCell} from \"./Cell\";\nimport {attachCircle, detachCircle} from \"./Circle\";\nimport {createEdge, setEdgeEnd} from \"./Edge\";\nimport {beaches, epsilon} from \"./Diagram\";\n\nvar beachPool = [];\n\nfunction Beach() {\n RedBlackNode(this);\n this.edge =\n this.site =\n this.circle = null;\n}\n\nfunction createBeach(site) {\n var beach = beachPool.pop() || new Beach;\n beach.site = site;\n return beach;\n}\n\nfunction detachBeach(beach) {\n detachCircle(beach);\n beaches.remove(beach);\n beachPool.push(beach);\n RedBlackNode(beach);\n}\n\nexport function removeBeach(beach) {\n var circle = beach.circle,\n x = circle.x,\n y = circle.cy,\n vertex = [x, y],\n previous = beach.P,\n next = beach.N,\n disappearing = [beach];\n\n detachBeach(beach);\n\n var lArc = previous;\n while (lArc.circle\n && Math.abs(x - lArc.circle.x) < epsilon\n && Math.abs(y - lArc.circle.cy) < epsilon) {\n previous = lArc.P;\n disappearing.unshift(lArc);\n detachBeach(lArc);\n lArc = previous;\n }\n\n disappearing.unshift(lArc);\n detachCircle(lArc);\n\n var rArc = next;\n while (rArc.circle\n && Math.abs(x - rArc.circle.x) < epsilon\n && Math.abs(y - rArc.circle.cy) < epsilon) {\n next = rArc.N;\n disappearing.push(rArc);\n detachBeach(rArc);\n rArc = next;\n }\n\n disappearing.push(rArc);\n detachCircle(rArc);\n\n var nArcs = disappearing.length,\n iArc;\n for (iArc = 1; iArc < nArcs; ++iArc) {\n rArc = disappearing[iArc];\n lArc = disappearing[iArc - 1];\n setEdgeEnd(rArc.edge, lArc.site, rArc.site, vertex);\n }\n\n lArc = disappearing[0];\n rArc = disappearing[nArcs - 1];\n rArc.edge = createEdge(lArc.site, rArc.site, null, vertex);\n\n attachCircle(lArc);\n attachCircle(rArc);\n}\n\nexport function addBeach(site) {\n var x = site[0],\n directrix = site[1],\n lArc,\n rArc,\n dxl,\n dxr,\n node = beaches._;\n\n while (node) {\n dxl = leftBreakPoint(node, directrix) - x;\n if (dxl > epsilon) node = node.L; else {\n dxr = x - rightBreakPoint(node, directrix);\n if (dxr > epsilon) {\n if (!node.R) {\n lArc = node;\n break;\n }\n node = node.R;\n } else {\n if (dxl > -epsilon) {\n lArc = node.P;\n rArc = node;\n } else if (dxr > -epsilon) {\n lArc = node;\n rArc = node.N;\n } else {\n lArc = rArc = node;\n }\n break;\n }\n }\n }\n\n createCell(site);\n var newArc = createBeach(site);\n beaches.insert(lArc, newArc);\n\n if (!lArc && !rArc) return;\n\n if (lArc === rArc) {\n detachCircle(lArc);\n rArc = createBeach(lArc.site);\n beaches.insert(newArc, rArc);\n newArc.edge = rArc.edge = createEdge(lArc.site, newArc.site);\n attachCircle(lArc);\n attachCircle(rArc);\n return;\n }\n\n if (!rArc) { // && lArc\n newArc.edge = createEdge(lArc.site, newArc.site);\n return;\n }\n\n // else lArc !== rArc\n detachCircle(lArc);\n detachCircle(rArc);\n\n var lSite = lArc.site,\n ax = lSite[0],\n ay = lSite[1],\n bx = site[0] - ax,\n by = site[1] - ay,\n rSite = rArc.site,\n cx = rSite[0] - ax,\n cy = rSite[1] - ay,\n d = 2 * (bx * cy - by * cx),\n hb = bx * bx + by * by,\n hc = cx * cx + cy * cy,\n vertex = [(cy * hb - by * hc) / d + ax, (bx * hc - cx * hb) / d + ay];\n\n setEdgeEnd(rArc.edge, lSite, rSite, vertex);\n newArc.edge = createEdge(lSite, site, null, vertex);\n rArc.edge = createEdge(site, rSite, null, vertex);\n attachCircle(lArc);\n attachCircle(rArc);\n}\n\nfunction leftBreakPoint(arc, directrix) {\n var site = arc.site,\n rfocx = site[0],\n rfocy = site[1],\n pby2 = rfocy - directrix;\n\n if (!pby2) return rfocx;\n\n var lArc = arc.P;\n if (!lArc) return -Infinity;\n\n site = lArc.site;\n var lfocx = site[0],\n lfocy = site[1],\n plby2 = lfocy - directrix;\n\n if (!plby2) return lfocx;\n\n var hl = lfocx - rfocx,\n aby2 = 1 / pby2 - 1 / plby2,\n b = hl / plby2;\n\n if (aby2) return (-b + Math.sqrt(b * b - 2 * aby2 * (hl * hl / (-2 * plby2) - lfocy + plby2 / 2 + rfocy - pby2 / 2))) / aby2 + rfocx;\n\n return (rfocx + lfocx) / 2;\n}\n\nfunction rightBreakPoint(arc, directrix) {\n var rArc = arc.N;\n if (rArc) return leftBreakPoint(rArc, directrix);\n var site = arc.site;\n return site[1] === directrix ? site[0] : Infinity;\n}\n","import {addBeach, removeBeach} from \"./Beach\";\nimport {sortCellHalfedges, cellHalfedgeStart, clipCells} from \"./Cell\";\nimport {firstCircle} from \"./Circle\";\nimport {clipEdges} from \"./Edge\";\nimport RedBlackTree from \"./RedBlackTree\";\n\nexport var epsilon = 1e-6;\nexport var epsilon2 = 1e-12;\nexport var beaches;\nexport var cells;\nexport var circles;\nexport var edges;\n\nfunction triangleArea(a, b, c) {\n return (a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]);\n}\n\nfunction lexicographic(a, b) {\n return b[1] - a[1]\n || b[0] - a[0];\n}\n\nexport default function Diagram(sites, extent) {\n var site = sites.sort(lexicographic).pop(),\n x,\n y,\n circle;\n\n edges = [];\n cells = new Array(sites.length);\n beaches = new RedBlackTree;\n circles = new RedBlackTree;\n\n while (true) {\n circle = firstCircle;\n if (site && (!circle || site[1] < circle.y || (site[1] === circle.y && site[0] < circle.x))) {\n if (site[0] !== x || site[1] !== y) {\n addBeach(site);\n x = site[0], y = site[1];\n }\n site = sites.pop();\n } else if (circle) {\n removeBeach(circle.arc);\n } else {\n break;\n }\n }\n\n sortCellHalfedges();\n\n if (extent) {\n var x0 = +extent[0][0],\n y0 = +extent[0][1],\n x1 = +extent[1][0],\n y1 = +extent[1][1];\n clipEdges(x0, y0, x1, y1);\n clipCells(x0, y0, x1, y1);\n }\n\n this.edges = edges;\n this.cells = cells;\n\n beaches =\n circles =\n edges =\n cells = null;\n}\n\nDiagram.prototype = {\n constructor: Diagram,\n\n polygons: function() {\n var edges = this.edges;\n\n return this.cells.map(function(cell) {\n var polygon = cell.halfedges.map(function(i) { return cellHalfedgeStart(cell, edges[i]); });\n polygon.data = cell.site.data;\n return polygon;\n });\n },\n\n triangles: function() {\n var triangles = [],\n edges = this.edges;\n\n this.cells.forEach(function(cell, i) {\n if (!(m = (halfedges = cell.halfedges).length)) return;\n var site = cell.site,\n halfedges,\n j = -1,\n m,\n s0,\n e1 = edges[halfedges[m - 1]],\n s1 = e1.left === site ? e1.right : e1.left;\n\n while (++j < m) {\n s0 = s1;\n e1 = edges[halfedges[j]];\n s1 = e1.left === site ? e1.right : e1.left;\n if (s0 && s1 && i < s0.index && i < s1.index && triangleArea(site, s0, s1) < 0) {\n triangles.push([site.data, s0.data, s1.data]);\n }\n }\n });\n\n return triangles;\n },\n\n links: function() {\n return this.edges.filter(function(edge) {\n return edge.right;\n }).map(function(edge) {\n return {\n source: edge.left.data,\n target: edge.right.data\n };\n });\n },\n\n find: function(x, y, radius) {\n var that = this, i0, i1 = that._found || 0, n = that.cells.length, cell;\n\n // Use the previously-found cell, or start with an arbitrary one.\n while (!(cell = that.cells[i1])) if (++i1 >= n) return null;\n var dx = x - cell.site[0], dy = y - cell.site[1], d2 = dx * dx + dy * dy;\n\n // Traverse the half-edges to find a closer cell, if any.\n do {\n cell = that.cells[i0 = i1], i1 = null;\n cell.halfedges.forEach(function(e) {\n var edge = that.edges[e], v = edge.left;\n if ((v === cell.site || !v) && !(v = edge.right)) return;\n var vx = x - v[0], vy = y - v[1], v2 = vx * vx + vy * vy;\n if (v2 < d2) d2 = v2, i1 = v.index;\n });\n } while (i1 !== null);\n\n that._found = i0;\n\n return radius == null || d2 <= radius * radius ? cell.site : null;\n }\n}\n","var rho = Math.SQRT2,\n rho2 = 2,\n rho4 = 4,\n epsilon2 = 1e-12;\n\nfunction cosh(x) {\n return ((x = Math.exp(x)) + 1 / x) / 2;\n}\n\nfunction sinh(x) {\n return ((x = Math.exp(x)) - 1 / x) / 2;\n}\n\nfunction tanh(x) {\n return ((x = Math.exp(2 * x)) - 1) / (x + 1);\n}\n\n// p0 = [ux0, uy0, w0]\n// p1 = [ux1, uy1, w1]\nexport default function(p0, p1) {\n var ux0 = p0[0], uy0 = p0[1], w0 = p0[2],\n ux1 = p1[0], uy1 = p1[1], w1 = p1[2],\n dx = ux1 - ux0,\n dy = uy1 - uy0,\n d2 = dx * dx + dy * dy,\n i,\n S;\n\n // Special case for u0 ≅ u1.\n if (d2 < epsilon2) {\n S = Math.log(w1 / w0) / rho;\n i = function(t) {\n return [\n ux0 + t * dx,\n uy0 + t * dy,\n w0 * Math.exp(rho * t * S)\n ];\n }\n }\n\n // General case.\n else {\n var d1 = Math.sqrt(d2),\n b0 = (w1 * w1 - w0 * w0 + rho4 * d2) / (2 * w0 * rho2 * d1),\n b1 = (w1 * w1 - w0 * w0 - rho4 * d2) / (2 * w1 * rho2 * d1),\n r0 = Math.log(Math.sqrt(b0 * b0 + 1) - b0),\n r1 = Math.log(Math.sqrt(b1 * b1 + 1) - b1);\n S = (r1 - r0) / rho;\n i = function(t) {\n var s = t * S,\n coshr0 = cosh(r0),\n u = w0 / (rho2 * d1) * (coshr0 * tanh(rho * s + r0) - sinh(r0));\n return [\n ux0 + u * dx,\n uy0 + u * dy,\n w0 * coshr0 / cosh(rho * s + r0)\n ];\n }\n }\n\n i.duration = S * 1000;\n\n return i;\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","/**\r\n * Simple throttle function that executes a passed function only once in the specified timeout\r\n * @param handlerFunc\r\n * @param [timeout] the throttle interval\r\n */\r\nexport function throttle(handlerFunc, timeout = 66) {\r\n let resizeTimeout;\r\n if (!resizeTimeout) {\r\n resizeTimeout = setTimeout(() => {\r\n resizeTimeout = null;\r\n handlerFunc();\r\n // The actualResizeHandler will execute at a rate of 15fps\r\n }, timeout);\r\n }\r\n}\r\n","\r\n\r\n\r\n","import mod from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./WorldMap.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--12-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./WorldMap.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./WorldMap.vue?vue&type=template&id=d2879e58&\"\nimport script from \"./WorldMap.vue?vue&type=script&lang=js&\"\nexport * from \"./WorldMap.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports","var DESCRIPTORS = require('./_descriptors');\nvar getKeys = require('./_object-keys');\nvar toIObject = require('./_to-iobject');\nvar isEnum = require('./_object-pie').f;\nmodule.exports = function (isEntries) {\n return function (it) {\n var O = toIObject(it);\n var keys = getKeys(O);\n var length = keys.length;\n var i = 0;\n var result = [];\n var key;\n while (length > i) {\n key = keys[i++];\n if (!DESCRIPTORS || isEnum.call(O, key)) {\n result.push(isEntries ? [key, O[key]] : O[key]);\n }\n }\n return result;\n };\n};\n","// https://github.com/tc39/proposal-object-values-entries\nvar $export = require('./_export');\nvar $values = require('./_object-to-array')(false);\n\n$export($export.S, 'Object', {\n values: function values(it) {\n return $values(it);\n }\n});\n","(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (factory((global.topojson = global.topojson || {})));\n}(this, (function (exports) { 'use strict';\n\nfunction noop() {}\n\nfunction transformAbsolute(transform) {\n if (!transform) return noop;\n var x0,\n y0,\n kx = transform.scale[0],\n ky = transform.scale[1],\n dx = transform.translate[0],\n dy = transform.translate[1];\n return function(point, i) {\n if (!i) x0 = y0 = 0;\n point[0] = (x0 += point[0]) * kx + dx;\n point[1] = (y0 += point[1]) * ky + dy;\n };\n}\n\nfunction transformRelative(transform) {\n if (!transform) return noop;\n var x0,\n y0,\n kx = transform.scale[0],\n ky = transform.scale[1],\n dx = transform.translate[0],\n dy = transform.translate[1];\n return function(point, i) {\n if (!i) x0 = y0 = 0;\n var x1 = Math.round((point[0] - dx) / kx),\n y1 = Math.round((point[1] - dy) / ky);\n point[0] = x1 - x0;\n point[1] = y1 - y0;\n x0 = x1;\n y0 = y1;\n };\n}\n\nfunction reverse(array, n) {\n var t, j = array.length, i = j - n;\n while (i < --j) t = array[i], array[i++] = array[j], array[j] = t;\n}\n\nfunction bisect(a, x) {\n var lo = 0, hi = a.length;\n while (lo < hi) {\n var mid = lo + hi >>> 1;\n if (a[mid] < x) lo = mid + 1;\n else hi = mid;\n }\n return lo;\n}\n\nfunction feature(topology, o) {\n return o.type === \"GeometryCollection\" ? {\n type: \"FeatureCollection\",\n features: o.geometries.map(function(o) { return feature$1(topology, o); })\n } : feature$1(topology, o);\n}\n\nfunction feature$1(topology, o) {\n var f = {\n type: \"Feature\",\n id: o.id,\n properties: o.properties || {},\n geometry: object(topology, o)\n };\n if (o.id == null) delete f.id;\n return f;\n}\n\nfunction object(topology, o) {\n var absolute = transformAbsolute(topology.transform),\n arcs = topology.arcs;\n\n function arc(i, points) {\n if (points.length) points.pop();\n for (var a = arcs[i < 0 ? ~i : i], k = 0, n = a.length, p; k < n; ++k) {\n points.push(p = a[k].slice());\n absolute(p, k);\n }\n if (i < 0) reverse(points, n);\n }\n\n function point(p) {\n p = p.slice();\n absolute(p, 0);\n return p;\n }\n\n function line(arcs) {\n var points = [];\n for (var i = 0, n = arcs.length; i < n; ++i) arc(arcs[i], points);\n if (points.length < 2) points.push(points[0].slice());\n return points;\n }\n\n function ring(arcs) {\n var points = line(arcs);\n while (points.length < 4) points.push(points[0].slice());\n return points;\n }\n\n function polygon(arcs) {\n return arcs.map(ring);\n }\n\n function geometry(o) {\n var t = o.type;\n return t === \"GeometryCollection\" ? {type: t, geometries: o.geometries.map(geometry)}\n : t in geometryType ? {type: t, coordinates: geometryType[t](o)}\n : null;\n }\n\n var geometryType = {\n Point: function(o) { return point(o.coordinates); },\n MultiPoint: function(o) { return o.coordinates.map(point); },\n LineString: function(o) { return line(o.arcs); },\n MultiLineString: function(o) { return o.arcs.map(line); },\n Polygon: function(o) { return polygon(o.arcs); },\n MultiPolygon: function(o) { return o.arcs.map(polygon); }\n };\n\n return geometry(o);\n}\n\nfunction stitchArcs(topology, arcs) {\n var stitchedArcs = {},\n fragmentByStart = {},\n fragmentByEnd = {},\n fragments = [],\n emptyIndex = -1;\n\n // Stitch empty arcs first, since they may be subsumed by other arcs.\n arcs.forEach(function(i, j) {\n var arc = topology.arcs[i < 0 ? ~i : i], t;\n if (arc.length < 3 && !arc[1][0] && !arc[1][1]) {\n t = arcs[++emptyIndex], arcs[emptyIndex] = i, arcs[j] = t;\n }\n });\n\n arcs.forEach(function(i) {\n var e = ends(i),\n start = e[0],\n end = e[1],\n f, g;\n\n if (f = fragmentByEnd[start]) {\n delete fragmentByEnd[f.end];\n f.push(i);\n f.end = end;\n if (g = fragmentByStart[end]) {\n delete fragmentByStart[g.start];\n var fg = g === f ? f : f.concat(g);\n fragmentByStart[fg.start = f.start] = fragmentByEnd[fg.end = g.end] = fg;\n } else {\n fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n }\n } else if (f = fragmentByStart[end]) {\n delete fragmentByStart[f.start];\n f.unshift(i);\n f.start = start;\n if (g = fragmentByEnd[start]) {\n delete fragmentByEnd[g.end];\n var gf = g === f ? f : g.concat(f);\n fragmentByStart[gf.start = g.start] = fragmentByEnd[gf.end = f.end] = gf;\n } else {\n fragmentByStart[f.start] = fragmentByEnd[f.end] = f;\n }\n } else {\n f = [i];\n fragmentByStart[f.start = start] = fragmentByEnd[f.end = end] = f;\n }\n });\n\n function ends(i) {\n var arc = topology.arcs[i < 0 ? ~i : i], p0 = arc[0], p1;\n if (topology.transform) p1 = [0, 0], arc.forEach(function(dp) { p1[0] += dp[0], p1[1] += dp[1]; });\n else p1 = arc[arc.length - 1];\n return i < 0 ? [p1, p0] : [p0, p1];\n }\n\n function flush(fragmentByEnd, fragmentByStart) {\n for (var k in fragmentByEnd) {\n var f = fragmentByEnd[k];\n delete fragmentByStart[f.start];\n delete f.start;\n delete f.end;\n f.forEach(function(i) { stitchedArcs[i < 0 ? ~i : i] = 1; });\n fragments.push(f);\n }\n }\n\n flush(fragmentByEnd, fragmentByStart);\n flush(fragmentByStart, fragmentByEnd);\n arcs.forEach(function(i) { if (!stitchedArcs[i < 0 ? ~i : i]) fragments.push([i]); });\n\n return fragments;\n}\n\nfunction mesh(topology) {\n return object(topology, meshArcs.apply(this, arguments));\n}\n\nfunction meshArcs(topology, o, filter) {\n var arcs = [];\n\n function arc(i) {\n var j = i < 0 ? ~i : i;\n (geomsByArc[j] || (geomsByArc[j] = [])).push({i: i, g: geom});\n }\n\n function line(arcs) {\n arcs.forEach(arc);\n }\n\n function polygon(arcs) {\n arcs.forEach(line);\n }\n\n function geometry(o) {\n if (o.type === \"GeometryCollection\") o.geometries.forEach(geometry);\n else if (o.type in geometryType) geom = o, geometryType[o.type](o.arcs);\n }\n\n if (arguments.length > 1) {\n var geomsByArc = [],\n geom;\n\n var geometryType = {\n LineString: line,\n MultiLineString: polygon,\n Polygon: polygon,\n MultiPolygon: function(arcs) { arcs.forEach(polygon); }\n };\n\n geometry(o);\n\n geomsByArc.forEach(arguments.length < 3\n ? function(geoms) { arcs.push(geoms[0].i); }\n : function(geoms) { if (filter(geoms[0].g, geoms[geoms.length - 1].g)) arcs.push(geoms[0].i); });\n } else {\n for (var i = 0, n = topology.arcs.length; i < n; ++i) arcs.push(i);\n }\n\n return {type: \"MultiLineString\", arcs: stitchArcs(topology, arcs)};\n}\n\nfunction cartesianTriangleArea(triangle) {\n var a = triangle[0], b = triangle[1], c = triangle[2];\n return Math.abs((a[0] - c[0]) * (b[1] - a[1]) - (a[0] - b[0]) * (c[1] - a[1]));\n}\n\nfunction ring(ring) {\n var i = -1,\n n = ring.length,\n a,\n b = ring[n - 1],\n area = 0;\n\n while (++i < n) {\n a = b;\n b = ring[i];\n area += a[0] * b[1] - a[1] * b[0];\n }\n\n return area / 2;\n}\n\nfunction merge(topology) {\n return object(topology, mergeArcs.apply(this, arguments));\n}\n\nfunction mergeArcs(topology, objects) {\n var polygonsByArc = {},\n polygons = [],\n components = [];\n\n objects.forEach(function(o) {\n if (o.type === \"Polygon\") register(o.arcs);\n else if (o.type === \"MultiPolygon\") o.arcs.forEach(register);\n });\n\n function register(polygon) {\n polygon.forEach(function(ring$$) {\n ring$$.forEach(function(arc) {\n (polygonsByArc[arc = arc < 0 ? ~arc : arc] || (polygonsByArc[arc] = [])).push(polygon);\n });\n });\n polygons.push(polygon);\n }\n\n function area(ring$$) {\n return Math.abs(ring(object(topology, {type: \"Polygon\", arcs: [ring$$]}).coordinates[0]));\n }\n\n polygons.forEach(function(polygon) {\n if (!polygon._) {\n var component = [],\n neighbors = [polygon];\n polygon._ = 1;\n components.push(component);\n while (polygon = neighbors.pop()) {\n component.push(polygon);\n polygon.forEach(function(ring$$) {\n ring$$.forEach(function(arc) {\n polygonsByArc[arc < 0 ? ~arc : arc].forEach(function(polygon) {\n if (!polygon._) {\n polygon._ = 1;\n neighbors.push(polygon);\n }\n });\n });\n });\n }\n }\n });\n\n polygons.forEach(function(polygon) {\n delete polygon._;\n });\n\n return {\n type: \"MultiPolygon\",\n arcs: components.map(function(polygons) {\n var arcs = [], n;\n\n // Extract the exterior (unique) arcs.\n polygons.forEach(function(polygon) {\n polygon.forEach(function(ring$$) {\n ring$$.forEach(function(arc) {\n if (polygonsByArc[arc < 0 ? ~arc : arc].length < 2) {\n arcs.push(arc);\n }\n });\n });\n });\n\n // Stitch the arcs into one or more rings.\n arcs = stitchArcs(topology, arcs);\n\n // If more than one ring is returned,\n // at most one of these rings can be the exterior;\n // choose the one with the greatest absolute area.\n if ((n = arcs.length) > 1) {\n for (var i = 1, k = area(arcs[0]), ki, t; i < n; ++i) {\n if ((ki = area(arcs[i])) > k) {\n t = arcs[0], arcs[0] = arcs[i], arcs[i] = t, k = ki;\n }\n }\n }\n\n return arcs;\n })\n };\n}\n\nfunction neighbors(objects) {\n var indexesByArc = {}, // arc index -> array of object indexes\n neighbors = objects.map(function() { return []; });\n\n function line(arcs, i) {\n arcs.forEach(function(a) {\n if (a < 0) a = ~a;\n var o = indexesByArc[a];\n if (o) o.push(i);\n else indexesByArc[a] = [i];\n });\n }\n\n function polygon(arcs, i) {\n arcs.forEach(function(arc) { line(arc, i); });\n }\n\n function geometry(o, i) {\n if (o.type === \"GeometryCollection\") o.geometries.forEach(function(o) { geometry(o, i); });\n else if (o.type in geometryType) geometryType[o.type](o.arcs, i);\n }\n\n var geometryType = {\n LineString: line,\n MultiLineString: polygon,\n Polygon: polygon,\n MultiPolygon: function(arcs, i) { arcs.forEach(function(arc) { polygon(arc, i); }); }\n };\n\n objects.forEach(geometry);\n\n for (var i in indexesByArc) {\n for (var indexes = indexesByArc[i], m = indexes.length, j = 0; j < m; ++j) {\n for (var k = j + 1; k < m; ++k) {\n var ij = indexes[j], ik = indexes[k], n;\n if ((n = neighbors[ij])[i = bisect(n, ik)] !== ik) n.splice(i, 0, ik);\n if ((n = neighbors[ik])[i = bisect(n, ij)] !== ij) n.splice(i, 0, ij);\n }\n }\n }\n\n return neighbors;\n}\n\nfunction compareArea(a, b) {\n return a[1][2] - b[1][2];\n}\n\nfunction minAreaHeap() {\n var heap = {},\n array = [],\n size = 0;\n\n heap.push = function(object) {\n up(array[object._ = size] = object, size++);\n return size;\n };\n\n heap.pop = function() {\n if (size <= 0) return;\n var removed = array[0], object;\n if (--size > 0) object = array[size], down(array[object._ = 0] = object, 0);\n return removed;\n };\n\n heap.remove = function(removed) {\n var i = removed._, object;\n if (array[i] !== removed) return; // invalid request\n if (i !== --size) object = array[size], (compareArea(object, removed) < 0 ? up : down)(array[object._ = i] = object, i);\n return i;\n };\n\n function up(object, i) {\n while (i > 0) {\n var j = ((i + 1) >> 1) - 1,\n parent = array[j];\n if (compareArea(object, parent) >= 0) break;\n array[parent._ = i] = parent;\n array[object._ = i = j] = object;\n }\n }\n\n function down(object, i) {\n while (true) {\n var r = (i + 1) << 1,\n l = r - 1,\n j = i,\n child = array[j];\n if (l < size && compareArea(array[l], child) < 0) child = array[j = l];\n if (r < size && compareArea(array[r], child) < 0) child = array[j = r];\n if (j === i) break;\n array[child._ = i] = child;\n array[object._ = i = j] = object;\n }\n }\n\n return heap;\n}\n\nfunction presimplify(topology, triangleArea) {\n var absolute = transformAbsolute(topology.transform),\n relative = transformRelative(topology.transform),\n heap = minAreaHeap();\n\n if (!triangleArea) triangleArea = cartesianTriangleArea;\n\n topology.arcs.forEach(function(arc) {\n var triangles = [],\n maxArea = 0,\n triangle,\n i,\n n,\n p;\n\n // To store each point’s effective area, we create a new array rather than\n // extending the passed-in point to workaround a Chrome/V8 bug (getting\n // stuck in smi mode). For midpoints, the initial effective area of\n // Infinity will be computed in the next step.\n for (i = 0, n = arc.length; i < n; ++i) {\n p = arc[i];\n absolute(arc[i] = [p[0], p[1], Infinity], i);\n }\n\n for (i = 1, n = arc.length - 1; i < n; ++i) {\n triangle = arc.slice(i - 1, i + 2);\n triangle[1][2] = triangleArea(triangle);\n triangles.push(triangle);\n heap.push(triangle);\n }\n\n for (i = 0, n = triangles.length; i < n; ++i) {\n triangle = triangles[i];\n triangle.previous = triangles[i - 1];\n triangle.next = triangles[i + 1];\n }\n\n while (triangle = heap.pop()) {\n var previous = triangle.previous,\n next = triangle.next;\n\n // If the area of the current point is less than that of the previous point\n // to be eliminated, use the latter's area instead. This ensures that the\n // current point cannot be eliminated without eliminating previously-\n // eliminated points.\n if (triangle[1][2] < maxArea) triangle[1][2] = maxArea;\n else maxArea = triangle[1][2];\n\n if (previous) {\n previous.next = next;\n previous[2] = triangle[2];\n update(previous);\n }\n\n if (next) {\n next.previous = previous;\n next[0] = triangle[0];\n update(next);\n }\n }\n\n arc.forEach(relative);\n });\n\n function update(triangle) {\n heap.remove(triangle);\n triangle[1][2] = triangleArea(triangle);\n heap.push(triangle);\n }\n\n return topology;\n}\n\nvar version = \"1.6.27\";\n\nexports.version = version;\nexports.mesh = mesh;\nexports.meshArcs = meshArcs;\nexports.merge = merge;\nexports.mergeArcs = mergeArcs;\nexports.feature = feature;\nexports.neighbors = neighbors;\nexports.presimplify = presimplify;\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\n})));"],"sourceRoot":""}